From e432ae2dc8d754a2c0043849b87be2e86dc299c4 Mon Sep 17 00:00:00 2001 From: Gloria Date: Thu, 3 Aug 2023 20:06:24 +0800 Subject: [PATCH] Update docs against 21038+21114+21212+21053 Signed-off-by: wusongqing --- en/application-dev/device/figures/001.png | Bin 0 -> 35613 bytes en/application-dev/device/figures/002.png | Bin 0 -> 30727 bytes en/application-dev/device/figures/003.png | Bin 0 -> 3866 bytes .../device/sensor-guidelines.md | 89 ++++++----- .../device/vibrator-guidelines.md | 79 +++++----- .../reference/apis/js-apis-sensor.md | 140 +++++++++--------- 6 files changed, 153 insertions(+), 155 deletions(-) create mode 100644 en/application-dev/device/figures/001.png create mode 100644 en/application-dev/device/figures/002.png create mode 100644 en/application-dev/device/figures/003.png diff --git a/en/application-dev/device/figures/001.png b/en/application-dev/device/figures/001.png new file mode 100644 index 0000000000000000000000000000000000000000..0b173958ed943fb9ecebd686b4f378d93fa2a7b0 GIT binary patch literal 35613 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
  • OiEIm%`Eb}sO{j;W?| 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 literal 0 HcmV?d00001 diff --git a/en/application-dev/device/figures/002.png b/en/application-dev/device/figures/002.png new file mode 100644 index 0000000000000000000000000000000000000000..34af38f77c66cbef900a1a4e536e3873bd0d94aa GIT binary patch literal 30727 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 TtOJktPTOT_wIgr);n4pA1RS>A literal 0 HcmV?d00001 diff --git a/en/application-dev/device/figures/003.png b/en/application-dev/device/figures/003.png new file mode 100644 index 0000000000000000000000000000000000000000..3c95c64ccb305ec25b1927733615ec4553505f97 GIT binary patch literal 3866 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 literal 0 HcmV?d00001 diff --git a/en/application-dev/device/sensor-guidelines.md b/en/application-dev/device/sensor-guidelines.md index 6ff5eb7405..21e1b55296 100644 --- a/en/application-dev/device/sensor-guidelines.md +++ b/en/application-dev/device/sensor-guidelines.md @@ -15,65 +15,64 @@ For details about the APIs, see [Sensor](../reference/apis/js-apis-sensor.md). | ohos.sensor | sensor.on(sensorId, callback:AsyncCallback<Response>): void | Subscribes to data changes of a type of sensor.| | ohos.sensor | sensor.once(sensorId, callback:AsyncCallback<Response>): void | Subscribes to only one data change of a type of sensor.| | ohos.sensor | sensor.off(sensorId, callback?:AsyncCallback<void>): void | Unsubscribes from sensor data changes.| +| ohos.sensor | sensor.getSensorList(callback: AsyncCallback\>): void| Obtains information about all sensors on the device. This API uses an asynchronous callback to return the result.| ## How to Develop -1. Before obtaining data from a type of sensor, check whether the required permission has been configured.
    - The system provides the following sensor-related permissions: - - ohos.permission.ACCELEROMETER +The acceleration sensor is used as an example. - - ohos.permission.GYROSCOPE +1. Import the module. - - ohos.permission.ACTIVITY_MOTION - - - ohos.permission.READ_HEALTH_DATA - - For details about how to configure a permission, see [Declaring Permissions](../security/accesstoken-guidelines.md). - -2. Subscribe to data changes of a type of sensor. The following uses the acceleration sensor as an example. - ```ts import sensor from "@ohos.sensor"; - - sensor.on(sensor.SensorId.ACCELEROMETER, function (data) { - console.info("Succeeded in obtaining data. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained. - }); ``` - - ![171e6f30-a8d9-414c-bafa-b430340305fb](figures/171e6f30-a8d9-414c-bafa-b430340305fb.png) -3. Unsubscribe from sensor data changes. - - ```ts - import sensor from "@ohos.sensor"; - sensor.off(sensor.SensorId.ACCELEROMETER); - ``` - - ![65d69983-29f6-4381-80a3-f9ef2ec19e53](figures/65d69983-29f6-4381-80a3-f9ef2ec19e53.png) +2. Obtain information about all sensors on the device. + + ```ts + sensor.getSensorList(function (error, data) { + if (error) { + console.info('getSensorList failed'); + } else { + console.info('getSensorList success'); + for (let i = 0; i < data.length; i++) { + console.info(JSON.stringify(data[i])); + } + } + }); + ``` -4. Subscribe to only one data change of a type of sensor. - - ```ts - import sensor from "@ohos.sensor"; + ![](figures/001.png) - sensor.once(sensor.SensorId.ACCELEROMETER, function (data) { - console.info("Succeeded in obtaining data. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained. - }); - ``` - - ![db5d017d-6c1c-4a71-a2dd-f74b7f23239e](figures/db5d017d-6c1c-4a71-a2dd-f74b7f23239e.png) + The minimum and the maximum sampling periods supported by the sensor are 5000000 ns and 200000000 ns, respectively. Therefore, the value of **interval** must be within this range. + +3. Check whether the corresponding permission has been configured. For details, see [Applying for Permissions](../security/accesstoken-guidelines.md). - 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: +4. Register a listener. You can call **on()** or **once()** to listen for sensor data changes. + +- The **on()** API is used to continuously listen for data changes of the sensor. The sensor reporting interval is set to 100000000 ns. + + ```ts + sensor.on(sensor.SensorId.ACCELEROMETER, function (data) { + console.info("Succeeded in obtaining data. x: " + data.x + " y: " + data.y + " z: " + data.z); + }, {'interval': 100000000}); + ``` + + ![](figures/002.png) + +- The **once()** API is used to listen for only one data change of the sensor. ```ts - import sensor from "@ohos.sensor"; + sensor.once(sensor.SensorId.ACCELEROMETER, function (data) { + console.info("Succeeded in obtaining data. x: " + data.x + " y: " + data.y + " z: " + data.z); + }); + ``` + + ![](figures/003.png) - try { - sensor.once(sensor.SensorId.ACCELEROMETER, function (data) { - console.info("Succeeded in obtaining data. x: " + data.x + "y: " + data.y + "z: " + data.z); // Data is obtained. - }); - } catch (error) { - console.error(`Failed to get sensor data. Code: ${error.code}, message: ${error.message}`); - } +5. Cancel continuous listening. + + ```ts + sensor.off(sensor.SensorId.ACCELEROMETER); ``` diff --git a/en/application-dev/device/vibrator-guidelines.md b/en/application-dev/device/vibrator-guidelines.md index 7d3434d680..4619a52a2f 100644 --- a/en/application-dev/device/vibrator-guidelines.md +++ b/en/application-dev/device/vibrator-guidelines.md @@ -76,9 +76,9 @@ This JSON file contains two attributes: **MetaData** and **Channels**. - **Create**: time when the file was created. This parameter is optional. - **Description**: additional information such as the vibration effect and creation information. This parameter is optional. - **Channels** provides information about the vibration channel. It is a JSON array that holds information about each channel. It contains two attributes: **Parameters** and **Pattern**. -- **Parameters** provides parameters related to the channel. Under it, **Index** indicates the channel ID. The value is fixed at **1** for a single channel. This parameter is mandatory. + - **Parameters** provides parameters related to the channel. Under it, **Index** indicates the channel ID. The value is fixed at **1** for a single channel. This parameter is mandatory. - **Pattern** indicates the vibration sequence. It is a JSON array. Under it, **Event** indicates a vibration event, which can be either of the following types: -- **transient**: short vibration + - **transient**: short vibration - **continuous**: long vibration The table below describes the parameters under **Event**. @@ -89,7 +89,7 @@ The table below describes the parameters under **Event**. | StartTime | Start time of the vibration. This parameter is mandatory.| [0, 1800 000], in ms, without overlapping| | Duration | Duration of the vibration. This parameter is valid only when **Type** is **continuous**.| (10, 1600), in ms| | Intensity | Intensity of the vibration. This parameter is mandatory.| [0, 100], a relative value that does not represent the actual vibration strength.| -| Frequency | Frequency of the vibration. This parameter is mandatory.| [0, 100], a relative value that does not represent the actual vibration frequency| +| Frequency | Frequency of the vibration. This parameter is mandatory.| [0, 100], a relative value that does not represent the actual vibration frequency.| The following requirements must be met: @@ -221,45 +221,42 @@ The following requirements must be met: ```ts import vibrator from '@ohos.vibrator'; - const FILE_NAME = "xxx.json"; - // Obtain the file descriptor of the vibration configuration file. - let fileDescriptor = undefined; - getContext().resourceManager.getRawFd(FILE_NAME).then(value => { - fileDescriptor = { fd: value.fd, offset: value.offset, length: value.length }; - console.info('Succeed in getting resource file descriptor'); - }).catch(error => { - console.error(`Failed to get resource file descriptor. Code: ${error.code}, message: ${error.message}`); - }); - // To use startVibration and stopVibration, you must configure the ohos.permission.VIBRATE permission. - try { - // Start custom vibration. - vibrator.startVibration({ - type: "file", - hapticFd: { fd: fileDescriptor.fd, offset: fileDescriptor.offset, length: fileDescriptor.length } - }, { - usage: "alarm" - }).then(() => { - console.info('Succeed in starting vibration'); - }, (error) => { - console.error(`Failed to start vibration. Code: ${error.code}, message: ${error.message}`); - }); - // Stop vibration in all modes. - vibrator.stopVibration(function (error) { - if (error) { - console.error(`Failed to stop vibration. Code: ${error.code}, message: ${error.message}`); - return; - } - console.info('Succeed in stopping vibration'); - }) - } catch (error) { - console.error(`An unexpected error occurred. Code: ${error.code}, message: ${error.message}`); + async function getRawfileFd(fileName) { + let rawFd = await globalThis.getContext().resourceManager.getRawFd(fileName); + return rawFd; + } + + // Close the file descriptor of the vibration configuration file. + async function closeRawfileFd(fileName) { + await globalThis.getContext().resourceManager.closeRawFd(fileName) + } + + // Play the custom vibration. To use startVibration and stopVibration, you must configure the ohos.permission.VIBRATE permission. + async function playCustomHaptic(fileName) { + try { + let rawFd = await getRawfileFd(fileName); + vibrator.startVibration({ + type: "file", + hapticFd: { fd: rawFd.fd, offset: rawFd.offset, length: rawFd.length } + }, { + usage: "alarm" + }).then(() => { + console.info('Succeed in starting vibration'); + }, (error) => { + console.error(`Failed to start vibration. Code: ${error.code}, message: ${error.message}`); + }); + vibrator.stopVibration(function (error) { + if (error) { + console.error(`Failed to stop vibration. Code: ${error.code}, message: ${error.message}`); + return; + } + console.info('Succeed in stopping vibration'); + }) + await closeRawfileFd(fileName); + } catch (error) { + console.error(`An unexpected error occurred. Code: ${error.code}, message: ${error.message}`); + } } - // Close the vibration file. - getContext().resourceManager.closeRawFd(FILE_NAME).then(() => { - console.info('Succeed in closing resource file descriptor'); - }).catch(error => { - console.error(`Failed to close resource file descriptor. Code: ${error.code}, message: ${error.message}`); - }); ``` diff --git a/en/application-dev/reference/apis/js-apis-sensor.md b/en/application-dev/reference/apis/js-apis-sensor.md index e2058f68ea..bf7ca4b511 100644 --- a/en/application-dev/reference/apis/js-apis-sensor.md +++ b/en/application-dev/reference/apis/js-apis-sensor.md @@ -24,7 +24,7 @@ Subscribes to data of the color sensor. **System API**: This is a system API. -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -63,7 +63,7 @@ Subscribes to data of the Sodium Adsorption Ratio (SAR) sensor. **System API**: This is a system API. -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -109,7 +109,7 @@ Subscribes to data of the acceleration sensor. | callback | Callback<[AccelerometerResponse](#accelerometerresponse)> | Yes | Callback used to report the sensor data, which is an **AccelerometerResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -149,7 +149,7 @@ Subscribes to data of the uncalibrated acceleration sensor. | callback | Callback<[AccelerometerUncalibratedResponse](#accelerometeruncalibratedresponse)> | Yes | Callback used to report the sensor data, which is an **AccelerometerUncalibratedResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -190,7 +190,7 @@ Subscribes to data of the ambient light sensor. | callback | Callback<[LightResponse](#lightresponse)> | Yes | Callback used to report the sensor data, which is a **LightResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -226,7 +226,7 @@ Subscribes to data of the ambient temperature sensor. | callback | Callback<[AmbientTemperatureResponse](#ambienttemperatureresponse)> | Yes | Callback used to report the sensor data, which is an **AmbientTemperatureResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -262,7 +262,7 @@ Subscribes to data of the barometer sensor. | callback | Callback<[BarometerResponse](#barometerresponse)> | Yes | Callback used to report the sensor data, which is a **BarometerResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -298,7 +298,7 @@ Subscribes to data of the gravity sensor. | callback | Callback<[GravityResponse](#gravityresponse)> | Yes | Callback used to report the sensor data, which is a **GravityResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -338,7 +338,7 @@ Subscribes to data of the gyroscope sensor. | callback | Callback<[GyroscopeResponse](#gyroscoperesponse)> | Yes | Callback used to report the sensor data, which is a **GyroscopeResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -379,7 +379,7 @@ Subscribes to data of the uncalibrated gyroscope sensor. | callback | Callback<[GyroscopeUncalibratedResponse](#gyroscopeuncalibratedresponse)> | Yes | Callback used to report the sensor data, which is a **GyroscopeUncalibratedResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -420,7 +420,7 @@ Subscribes to data of the Hall effect sensor. | callback | Callback<[HallResponse](#hallresponse)> | Yes | Callback used to report the sensor data, which is a **HallResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -458,7 +458,7 @@ Subscribes to data of the heart rate sensor. | callback | Callback<[HeartRateResponse](#heartrateresponse)> | Yes | Callback used to report the sensor data, which is a **HeartRateResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -494,7 +494,7 @@ Subscribes to data of the humidity sensor. | callback | Callback<[HumidityResponse](#humidityresponse)> | Yes | Callback used to report the sensor data, which is a **HumidityResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -533,7 +533,7 @@ Subscribes to data of the linear acceleration sensor. | callback | Callback<[LinearAccelerometerResponse](#linearaccelerometerresponse)> | Yes | Callback used to report the sensor data, which is a **LinearAccelerometerResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -571,7 +571,7 @@ Subscribes to data of the magnetic field sensor. | callback | Callback<[MagneticFieldResponse](#magneticfieldresponse)> | Yes | Callback used to report the sensor data, which is a **MagneticFieldResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -609,7 +609,7 @@ Subscribes to data of the uncalibrated magnetic field sensor. | callback | Callback<[MagneticFieldUncalibratedResponse](#magneticfielduncalibratedresponse)> | Yes | Callback used to report the sensor data, which is a **MagneticFieldUncalibratedResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -642,7 +642,7 @@ Subscribes to data of the orientation sensor. **System capability**: SystemCapability.Sensors.Sensor -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -682,7 +682,7 @@ Subscribes to data of the pedometer sensor. **System capability**: SystemCapability.Sensors.Sensor -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -729,7 +729,7 @@ Subscribes to data of the pedometer detection sensor. | callback | Callback<[PedometerDetectionResponse](#pedometerdetectionresponse)> | Yes | Callback used to report the sensor data, which is a **PedometerDetectionResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -765,7 +765,7 @@ Subscribes to data of the proximity sensor. | callback | Callback<[ProximityResponse](#proximityresponse)> | Yes | Callback used to report the sensor data, which is a **ProximityResponse** object. | | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -802,7 +802,7 @@ Subscribes to data of the rotation vector sensor. | callback | Callback<[RotationVectorResponse](#rotationvectorresponse)> | Yes | Callback used to report the sensor data, which is a **RotationVectorResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -842,7 +842,7 @@ Subscribes to data of the significant motion sensor. | callback | Callback<[SignificantMotionResponse](#significantmotionresponse)> | Yes | Callback used to report the sensor data, which is a **SignificantMotionResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns. | -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -879,7 +879,7 @@ Subscribes to data of the wear detection sensor. | callback | Callback<[WearDetectionResponse](#weardetectionresponse)> | Yes | Callback used to report the sensor data, which is a **WearDetectionResponse** object.| | options | [Options](#options) | No | List of optional parameters. This parameter is used to set the data reporting frequency. The default value is 200,000,000 ns.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -918,7 +918,7 @@ Obtains data of the acceleration sensor once. | type | [SensorId](#sensorid9).ACCELEROMETER | Yes | Sensor type. The value is fixed at **SensorId.ACCELEROMETER**. | | callback | Callback<[AccelerometerResponse](#accelerometerresponse)> | Yes | Callback used to report the sensor data, which is an **AccelerometerResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -957,7 +957,7 @@ Obtains data of the uncalibrated acceleration sensor once. | type | [SensorId](#sensorid9).ACCELEROMETER_UNCALIBRATED | Yes | Sensor type. The value is fixed at **SensorId.ACCELEROMETER_UNCALIBRATED**. | | callback | Callback<[AccelerometerUncalibratedResponse](#accelerometeruncalibratedresponse)> | Yes | Callback used to report the sensor data, which is an **AccelerometerUncalibratedResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -997,7 +997,7 @@ Obtains data of the ambient light sensor once. | type | [SensorId](#sensorid9).AMBIENT_LIGHT | Yes | Sensor type. The value is fixed at **SensorId.AMBIENT_LIGHT**. | | callback | Callback<[LightResponse](#lightresponse)> | Yes | Callback used to report the sensor data, which is a **LightResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1032,7 +1032,7 @@ Obtains data of the temperature sensor once. | type | [SensorId](#sensorid9).AMBIENT_TEMPERATURE | Yes | Sensor type. The value is fixed at **SensorId.AMBIENT_TEMPERATURE**. | | callback | Callback<[AmbientTemperatureResponse](#ambienttemperatureresponse)> | Yes | Callback used to report the sensor data, which is an **AmbientTemperatureResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1067,7 +1067,7 @@ Obtains data of the barometer sensor once. | type | [SensorId](#sensorid9).BAROMETER | Yes | Sensor type. The value is fixed at **SensorId.BAROMETER**. | | callback | Callback<[BarometerResponse](#barometerresponse)> | Yes | Callback used to report the sensor data, which is a **BarometerResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1102,7 +1102,7 @@ Obtains data of the gravity sensor once. | type | [SensorId](#sensorid9).GRAVITY | Yes | Sensor type. The value is fixed at **SensorId.GRAVITY**. | | callback | Callback<[GravityResponse](#gravityresponse)> | Yes | Callback used to report the sensor data, which is a **GravityResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1141,7 +1141,7 @@ Obtains to data of the gyroscope sensor once. | type | [SensorId](#sensorid9).GYROSCOPE | Yes | Sensor type. The value is fixed at **SensorId.GYROSCOPE**. | | callback | Callback<[GyroscopeResponse](#gyroscoperesponse)> | Yes | Callback used to report the sensor data, which is a **GyroscopeResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1182,7 +1182,7 @@ Obtains data of the uncalibrated gyroscope sensor once. | type | [SensorId](#sensorid9).GYROSCOPE_UNCALIBRATED | Yes | Sensor type. The value is fixed at **SensorId.GYROSCOPE_UNCALIBRATED**. | | callback | Callback<[GyroscopeUncalibratedResponse](#gyroscopeuncalibratedresponse)> | Yes | Callback used to report the sensor data, which is a **GyroscopeUncalibratedResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1222,7 +1222,7 @@ Obtains data of the Hall effect sensor once. | type | [SensorId](#sensorid9).HALL | Yes | Sensor type. The value is fixed at **SensorId.HALL**. | | callback | Callback<[HallResponse](#hallresponse)> | Yes | Callback used to report the sensor data, which is a **HallResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1259,7 +1259,7 @@ Obtains data of the heart rate sensor once. | type | [SensorId](#sensorid9).HEART_RATE | Yes | Sensor type. The value is fixed at **SensorId.HEART_RATE**. | | callback | Callback<[HeartRateResponse](#heartrateresponse)> | Yes | Callback used to report the sensor data, which is a **HeartRateResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1294,7 +1294,7 @@ Obtains data of the humidity sensor once. | type | [SensorId](#sensorid9).HUMIDITY | Yes | Sensor type. The value is fixed at **SensorId.HUMIDITY**. | | callback | Callback<[HumidityResponse](#humidityresponse)> | Yes | Callback used to report the sensor data, which is a **HumidityResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1331,7 +1331,7 @@ Obtains data of the linear acceleration sensor once. | type | [SensorId](#sensorid9).LINEAR_ACCELEROMETER | Yes | Sensor type. The value is fixed at **SensorId.LINEAR_ACCELEROMETER**. | | callback | Callback<[LinearAccelerometerResponse](#linearaccelerometerresponse)> | Yes | Callback used to report the sensor data, which is a **LinearAccelerometerResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1368,7 +1368,7 @@ Obtains data of the magnetic field sensor once. | type | [SensorId](#sensorid9).MAGNETIC_FIELD | Yes | Sensor type. The value is fixed at **SensorId.MAGNETIC_FIELD**. | | callback | Callback<[MagneticFieldResponse](#magneticfieldresponse)> | Yes | Callback used to report the sensor data, which is a **MagneticFieldResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1405,7 +1405,7 @@ Obtains data of the uncalibrated magnetic field sensor once. | type | [SensorId](#sensorid9).MAGNETIC_FIELD_UNCALIBRATED | Yes | Sensor type. The value is fixed at **SensorId.MAGNETIC_FIELD_UNCALIBRATED**.| | callback | Callback<[MagneticFieldUncalibratedResponse](#magneticfielduncalibratedresponse)> | Yes | Callback used to report the sensor data, which is a **MagneticFieldUncalibratedResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1445,7 +1445,7 @@ Obtains data of the orientation sensor once. | type | [SensorId](#sensorid9).ORIENTATION | Yes | Sensor type. The value is fixed at **SensorId.ORIENTATION**. | | callback | Callback<[OrientationResponse](#orientationresponse)> | Yes | Callback used to report the sensor data, which is a **OrientationResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1484,7 +1484,7 @@ Obtains data of the pedometer sensor once. | type | [SensorId](#sensorid9).PEDOMETER | Yes | Sensor type. The value is fixed at **SensorId.PEDOMETER**. | | callback | Callback<[PedometerResponse](#pedometerresponse)> | Yes | Callback used to report the sensor data, which is a **PedometerResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1521,7 +1521,7 @@ Obtains data of the pedometer sensor once. | type | [SensorId](#sensorid9).PEDOMETER_DETECTION | Yes | Sensor type. The value is fixed at **SensorId.PEDOMETER_DETECTION**. | | callback | Callback<[PedometerDetectionResponse](#pedometerdetectionresponse)> | Yes | Callback used to report the sensor data, which is a **PedometerDetectionResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1556,7 +1556,7 @@ Obtains data of the proximity sensor once. | type | [SensorId](#sensorid9).PROXIMITY | Yes | Sensor type. The value is fixed at **SensorId.PROXIMITY**. | | callback | Callback<[ProximityResponse](#proximityresponse)> | Yes | Callback used to report the sensor data, which is a **ProximityResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1591,7 +1591,7 @@ Obtains data of the rotation vector sensor once. | type | [SensorId](#sensorid9).ROTATION_VECTOR | Yes | Sensor type. The value is fixed at **SensorId.ROTATION_VECTOR**. | | callback | Callback<[RotationVectorResponse](#rotationvectorresponse)> | Yes | Callback used to report the sensor data, which is a **RotationVectorResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1629,7 +1629,7 @@ Obtains data of the significant motion sensor once. | type | [SensorId](#sensorid9).SIGNIFICANT_MOTION | Yes | Sensor type. The value is fixed at **SensorId.SIGNIFICANT_MOTION**. | | callback | Callback<[SignificantMotionResponse](#significantmotionresponse)> | Yes | Callback used to report the sensor data, which is a **SignificantMotionResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -1664,7 +1664,7 @@ Obtains data of the wear detection sensor once. | type | [SensorId](#sensorid9).WEAR_DETECTION | Yes | Sensor type. The value is fixed at **SensorId.WEAR_DETECTION**. | | callback | Callback<[WearDetectionResponse](#weardetectionresponse)> | Yes | Callback used to report the sensor data, which is a **WearDetectionResponse** object.| -**Error code** +**Error codes** For details about the following error codes, see [Sensor Error Codes](../errorcodes/errorcode-sensor.md). @@ -2596,7 +2596,7 @@ Obtains the geomagnetic field of a geographic location at a certain time. This A | timeMillis | number | Yes | Time when the magnetic declination is obtained. The value is a Unix timestamp, in ms.| | callback | AsyncCallback<[GeomagneticResponse](#geomagneticresponse)> | Yes | Callback used to return the geomagnetic field. | -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getGeomagneticInfo](../errorcodes/errorcode-sensor.md). @@ -2647,7 +2647,7 @@ Obtains the geomagnetic field of a geographic location at a certain time. This A | ---------------------------------------------------------- | -------------- | | Promise<[GeomagneticResponse](#geomagneticresponse)> | Promise used to return the geomagnetic field.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getGeomagneticInfo](../errorcodes/errorcode-sensor.md). @@ -2692,7 +2692,7 @@ Obtains the altitude based on the atmospheric pressure. This API uses an asynchr | currentPressure | number | Yes | Specified atmospheric pressure, in hPa.| | callback | AsyncCallback<number> | Yes | Callback used to return the altitude, in meters. | -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getDeviceAltitude](../errorcodes/errorcode-sensor.md). @@ -2739,7 +2739,7 @@ Obtains the altitude based on the atmospheric pressure. This API uses a promise | --------------------- | ------------------------------------ | | Promise<number> | Promise used to return the altitude, in meters.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getDeviceAltitude](../errorcodes/errorcode-sensor.md). @@ -2779,7 +2779,7 @@ Obtains the magnetic dip based on the inclination matrix. This API uses an async | inclinationMatrix | Array<number> | Yes | Inclination matrix. | | callback | AsyncCallback<number> | Yes | Callback used to return the magnetic dip, in radians.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getInclination](../errorcodes/errorcode-sensor.md). @@ -2829,7 +2829,7 @@ Obtains the magnetic dip based on the inclination matrix. This API uses a promis | --------------------- | ---------------------------- | | Promise<number> | Promise used to return the magnetic dip, in radians.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getInclination](../errorcodes/errorcode-sensor.md). @@ -2875,7 +2875,7 @@ Obtains the angle change between two rotation matrices. This API uses an asynchr | preRotationMatrix | Array<number> | Yes | The other rotation matrix. | | callback | AsyncCallback<Array<number>> | Yes | Callback used to return the angle change around the z, x, and y axes.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getAngleVariation](../errorcodes/errorcode-sensor.md). @@ -2936,7 +2936,7 @@ Obtains the angle change between two rotation matrices. This API uses a promise | ---------------------------------- | --------------------------------- | | Promise<Array<number>> | Promise used to return the angle change around the z, x, and y axes.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getAngleVariation](../errorcodes/errorcode-sensor.md). @@ -2990,7 +2990,7 @@ Obtains the rotation matrix from a rotation vector. This API uses an asynchronou | rotationVector | Array<number> | Yes | Rotation vector.| | callback | AsyncCallback<Array<number>> | Yes | Callback used to return the rotation matrix.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getRotationMatrix](../errorcodes/errorcode-sensor.md). @@ -3037,7 +3037,7 @@ Obtains the rotation matrix from a rotation vector. This API uses a promise to r | ---------------------------------- | -------------- | | Promise<Array<number>> | Promise used to return the rotation matrix.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getRotationMatrix](../errorcodes/errorcode-sensor.md). @@ -3132,7 +3132,7 @@ Transforms a rotation vector based on the coordinate system. This API uses a pro | ---------------------------------- | ---------------------- | | Promise<Array<number>> | Promise used to return the rotation vector after being transformed.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.transformRotationMatrix](../errorcodes/errorcode-sensor.md). @@ -3177,7 +3177,7 @@ Obtains the quaternion from a rotation vector. This API uses an asynchronous cal | rotationVector | Array<number> | Yes | Rotation vector.| | callback | AsyncCallback<Array<number>> | Yes | Callback used to return the quaternion. | -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getQuaternion](../errorcodes/errorcode-sensor.md). @@ -3224,7 +3224,7 @@ Obtains the quaternion from a rotation vector. This API uses a promise to return | ---------------------------------- | ------------ | | Promise<Array<number>> | Promise used to return the quaternion.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getQuaternion](../errorcodes/errorcode-sensor.md). @@ -3265,7 +3265,7 @@ Obtains the device direction based on the rotation matrix. This API uses an asyn | rotationMatrix | Array<number> | Yes | Rotation matrix. | | callback | AsyncCallback<Array<number>> | Yes | Callback used to return the rotation angle around the z, x, and y axes.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getOrientation](../errorcodes/errorcode-sensor.md). @@ -3319,7 +3319,7 @@ Obtains the device direction based on the rotation matrix. This API uses a promi | ---------------------------------- | --------------------------------- | | Promise<Array<number>> | Promise used to return the rotation angle around the z, x, and y axes.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getOrientation](../errorcodes/errorcode-sensor.md). @@ -3365,7 +3365,7 @@ Obtains the rotation matrix based on a gravity vector and geomagnetic vector. Th | geomagnetic | Array<number> | Yes | Geomagnetic vector.| | callback | AsyncCallback<[RotationMatrixResponse](#rotationmatrixresponse)> | Yes | Callback used to return the rotation matrix.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getRotationMatrix](../errorcodes/errorcode-sensor.md). @@ -3387,7 +3387,7 @@ try { console.info('Succeeded in getting rotationMatrix' + JSON.stringify(data)); }) } catch (error) { -console.error(`Failed to get rotationMatrix. Code: ${error.code}, message: ${error.message}`); + console.error(`Failed to get rotationMatrix. Code: ${error.code}, message: ${error.message}`); } ``` @@ -3412,7 +3412,7 @@ Obtains the rotation matrix based on a gravity vector and geomagnetic vector. Th | ------------------------------------------------------------ | -------------- | | Promise<[RotationMatrixResponse](#rotationmatrixresponse)> | Promise used to return the rotation matrix.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getRotationMatrix](../errorcodes/errorcode-sensor.md). @@ -3451,7 +3451,7 @@ Obtains information about all sensors on the device. This API uses an asynchrono | -------- | ---------------------------------------------- | ---- | ---------------- | | callback | AsyncCallback<Array<[Sensor](#sensor9)>> | Yes | Callback used to return the sensor list.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getSensorList](../errorcodes/errorcode-sensor.md). @@ -3491,7 +3491,7 @@ Obtains information about all sensors on the device. This API uses a promise to | ------- | ---------------------------------------- | ---- | ---------------- | | promise | Promise<Array<[Sensor](#sensor9)>> | Yes | Promise used to return the sensor list.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getSensorList](../errorcodes/errorcode-sensor.md). @@ -3530,7 +3530,7 @@ Obtains information about the sensor of a specific type. This API uses an asynch | type | [SensorId](#sensorid9) | Yes | Sensor type. | | callback | AsyncCallback<[Sensor](#sensor9)> | Yes | Callback used to return the sensor information.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getSingleSensor](../errorcodes/errorcode-sensor.md). @@ -3574,7 +3574,7 @@ Obtains information about the sensor of a specific type. This API uses a promise | ------- | --------------------------------- | ---- | ---------------- | | promise | Promise<[Sensor](#sensor9)> | Yes | Promise used to return the sensor information.| -**Error code** +**Error codes** For details about the following error codes, see [Error Codes of sensor.getSingleSensor](../errorcodes/errorcode-sensor.md). @@ -3612,6 +3612,8 @@ Enumerates the sensor types. | HALL | 10 | Hall effect sensor. | | PROXIMITY | 12 | Proximity sensor. | | HUMIDITY | 13 | Humidity sensor. | +| COLOR10+ | 14 | Color sensor.
    System API: This is a system API. | +| SAR10+ | 15 | Sodium Adsorption Ratio (SAR) sensor.
    System API: This is a system API.| | ORIENTATION | 256 | Orientation sensor. | | GRAVITY | 257 | Gravity sensor. | | LINEAR_ACCELEROMETER | 258 | Linear acceleration sensor. | @@ -4912,7 +4914,7 @@ This API is deprecated since API version 9. You are advised to use [sensor.once. | callback | Callback<[PedometerResponse](#pedometerresponse)> | Yes | One-shot callback used to return the pedometer sensor data. The reported data type in the callback is **PedometerResponse**.| **Example** - + ```ts sensor.once(sensor.SensorType.SENSOR_TYPE_ID_PEDOMETER, function (data) { console.info('Succeeded in invoking once. Steps: ' + data.steps); @@ -6211,7 +6213,7 @@ promise.then((data) => { }).catch((reason) => { console.info("Succeeded in getting promise::catch", reason); }) -``` + ``` ## sensor.createQuaternion(deprecated) @@ -6410,4 +6412,4 @@ promise.then((data) => { }).catch((err) => { console.info(`Failed to get promise.`); }) - ``` +``` -- GitLab