• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Sensor Development
2
3
4## When to Use
5
6With the sensor module, a device can obtain sensor data. For example, the device can subscribe to data of the orientation sensor to detect its own orientation, and data of the pedometer sensor to learn the number of steps the user walks every day.
7
8For details about the APIs, see [Sensor](../reference/apis/js-apis-sensor.md).
9
10
11## Available APIs
12
13| Module| API| Description|
14| -------- | -------- | -------- |
15| ohos.sensor | sensor.on(sensorId, callback:AsyncCallback<Response>): void | Subscribes to data changes of a type of sensor.|
16| ohos.sensor | sensor.once(sensorId, callback:AsyncCallback<Response>): void | Subscribes to only one data change of a type of sensor.|
17| ohos.sensor | sensor.off(sensorId, callback?:AsyncCallback<void>): void | Unsubscribes from sensor data changes.|
18
19
20## How to Develop
21
221. Before obtaining data from a type of sensor, check whether the required permission has been configured.<br>
23     The system provides the following sensor-related permissions:
24   - ohos.permission.ACCELEROMETER
25
26   - ohos.permission.GYROSCOPE
27
28   - ohos.permission.ACTIVITY_MOTION
29
30   - ohos.permission.READ_HEALTH_DATA
31
32   For details about how to configure a permission, see [Declaring Permissions](../security/accesstoken-guidelines.md).
33
342. Subscribe to data changes of a type of sensor. The following uses the acceleration sensor as an example.
35
36   ```js
37   import sensor from "@ohos.sensor";
38   sensor.on(sensor.SensorId.ACCELEROMETER, function(data){
39      console.info("Data obtained successfully. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained.
40   });
41   ```
42
43   ![171e6f30-a8d9-414c-bafa-b430340305fb](figures/171e6f30-a8d9-414c-bafa-b430340305fb.png)
44
453. Unsubscribe from sensor data changes.
46
47   ```js
48   import sensor from "@ohos.sensor";
49   sensor.off(sensor.SensorId.ACCELEROMETER);
50   ```
51
52   ![65d69983-29f6-4381-80a3-f9ef2ec19e53](figures/65d69983-29f6-4381-80a3-f9ef2ec19e53.png)
53
544. Subscribe to only one data change of a type of sensor.
55
56   ```js
57   import sensor from "@ohos.sensor";
58   sensor.once(sensor.SensorId.ACCELEROMETER, function(data) {
59      console.info("Data obtained successfully. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained.
60   });
61   ```
62
63   ![db5d017d-6c1c-4a71-a2dd-f74b7f23239e](figures/db5d017d-6c1c-4a71-a2dd-f74b7f23239e.png)
64
65   If the API fails to be called, you are advised to use the **try/catch** statement to capture error information that may occur in the code. Example:
66
67    ```js
68   import sensor from "@ohos.sensor";
69    try {
70      sensor.once(sensor.SensorId.ACCELEROMETER, function(data) {
71          console.info("Data obtained successfully. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained.
72      });
73    } catch (error) {
74      console.error("Get sensor data error. data:" + error.data, " msg:", error.message);
75    }
76    ```
77