vibrator-guidelines.md 3.5 KB
Newer Older
H
update  
HelloCrease 已提交
1 2 3 4 5 6
# Vibrator开发指导


## 场景介绍

当设备需要设置不同的振动效果时,可以调用Vibrator模块,例如:设备的按键可以设置不同强度和不同时长的振动,闹钟和来电可以设置不同强度和时长的单次或周期振动。
7

8
详细的接口介绍请参考[Vibrator接口](../reference/apis/js-apis-vibrator.md)
H
update  
HelloCrease 已提交
9 10 11 12


## 接口说明

13 14 15 16 17 18 19 20
| 模块            | 接口名                                      | 描述                              |
| ------------- | ---------------------------------------- | ------------------------------- |
| ohos.vibrator | vibrate(duration: number): Promise<void> | 触发马达按照时长振动,使用Promise异步回调。       |
| ohos.vibrator | vibrate(duration: number, callback?: AsyncCallback<void>): void | 触发马达按照时长振动,使用Callback异步回调。      |
| ohos.vibrator | vibrate(effectId: EffectId): Promise<void> | 触发马达按照开发者传递效果振动,使用Promise异步回调。  |
| ohos.vibrator | vibrate(effectId: EffectId, callback?: AsyncCallback<void>): void | 触发马达按照开发者传递效果振动,使用Callback异步回调。 |
| ohos.vibrator | stop(stopMode: VibratorStopMode): Promise<void> | 停止振动。                           |
| ohos.vibrator | stop(stopMode: VibratorStopMode, callback?: AsyncCallback<void>): void | 停止振动。                           |
H
update  
HelloCrease 已提交
21 22 23 24


## 开发步骤

25
1. 控制设备上的振动器,需要在`config.json`里面进行配置请求权限。具体如下:
H
HelloCrease 已提交
26

H
update  
HelloCrease 已提交
27
   ```
28
   "reqPermissions": [
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
       {
           "name": "ohos.permission.ACCELEROMETER",
           "reason": "",
           "usedScene": {
               "ability": [
                   ".MainAbility"
               ],
               "when": "inuse"
           }
       },
       {
           "name": "ohos.permission.VIBRATE",
           "reason": "",
           "usedScene": {
               "ability": [
                   ".MainAbility"
               ],
               "when": "inuse"
           }
       },
       {
           "name": "ohos.permission.ACTIVITY_MOTION",
           "reason": "",
           "usedScene": {
               "ability": [
                   ".MainAbility"
               ],
               "when": "inuse"
           }
       },
H
update  
HelloCrease 已提交
59 60 61 62
   ]
   ```

2. 触发设备振动。
H
HelloCrease 已提交
63

H
update  
HelloCrease 已提交
64 65
   ```
   import vibrator from "@ohos.vibrator"
66 67 68 69
   vibrator.vibrate(1000).then((error) => {
       if (error) { //调用失败,打印error.code和error.message
          Console.log("Promise return failed.error.code " + error.code + "error.message " + error.message);  
       } else { //调用成功,设备开始振动
C
cff-gite 已提交
70
          Console.log("Promise returned to indicate a successful vibration.")  
71
       }
H
update  
HelloCrease 已提交
72 73 74 75
   })
   ```

3. 停止设备振动。
H
HelloCrease 已提交
76

H
update  
HelloCrease 已提交
77 78
   ```
   import vibrator from "@ohos.vibrator"
79 80 81 82
   vibrator.stop(vibrator.VibratorStopMode.VIBRATOR_STOP_MODE_PRESET).then((error) => {
      if (error) { //调用失败,打印error.code和error.message
          Console.log("Promise return failed.error.code " + error.code + "error.message " + error.message);
      } else { //调用成功,设备停止振动
C
cff-gite 已提交
83
          Console.log("Promise returned to indicate successful.");
84
      }
H
update  
HelloCrease 已提交
85 86
   })
   ```
Z
zengyawen 已提交
87 88 89 90 91 92

## 相关实例

针对振动开发,有以下相关实例可供参考:

- [`Vibrator`:振动(eTS)(API8)](https://gitee.com/openharmony/app_samples/tree/master/device/Vibrator)