Sensor Overview
大部分的Android裝置有感應器讓你監測裝置在移動和位置的變化,許多裝置也有監測周遭環境的感應器,比如溫度、濕度、壓力及亮度,你可以藉由Android感應器框架存取這些裝置與取得感應器的數據。
Android感應器框架提供許多類別與介面幫助你執行廣泛與感應器有關的任務,例如你可以使用感應器框架完成以下任務:
- 決定在裝置的哪一個感應器是可用的。
- 決定一個個別的感應器的能力,比如它的最大範圍、廠商、電源要求等。
- 取得感應器數據。
- 註冊與註銷事件監聽器。
此主題提供在Android裝置上可用的感應器的概觀,及感應器框架的介紹。
Introduction to Sensors
Android感應器框架讓你存取許多類型的感應器,一些感應器是基於硬體的,一些感應器是基於軟體的。基於硬體的感應器是建在手持裝置或平板裝置的物理元件,這些硬體感應器截油直接測量特定環境屬性提供數據,比如加速、地磁強度或是角度改變。基於軟體的感應器不是物理裝置,雖然他們模擬基於硬體的感應器。基於軟體的感應器從一個或是多個基於硬體的感應器產生數據,且基於軟體的感應器有時也叫做虛擬感應器或是合成感應器。線性加速感應器與重力感應器是基於軟體的感應器的例子。下表總結了Android平台支援的感應器。
少數的Android裝置有美意種類型的感應器。例如,大部分的手持裝置或平板電腦有一個加速度計和磁力儀,但少數的裝置有晴雨表或溫度計。還有一個裝置可以擁有多個同一類型的感應器。例如,一個裝置可以有兩個重力感應器,兩個有不同的範圍。
Sensor Framework
你可以使用Android感應器框架存取這些感應器與取得原始數據,感應器框架為android.hardware套件的一部分,包括以下類別與介面:
SensorManager
你可以使用此類別創造一個感應器服務實例,此類別提供許多方法來存取與列表感應器、註冊與註銷感應器事件監聽器、取得方向資訊。此類別也提供許多用來回報感應器準確度、數據回報率、及校準感應器的感應器常數。
Sensor
你可以使用此類別創造一個指定感應器實例,此類別提供多種方法讓你決定一個感應器的能力。
SensorEvent
系統利用此類別產生一個感應器事件物件,用物件來提供有關感應器事件的資訊。一個感應器事件物件包括以下資訊:原始感應器數據、產生事件的感應器的型態、數據的準確度、事件的時間戳。
SensorEventListener
你可以利用此介面產生兩個回呼方法,當感應器數值改變時或是當感應器準確度改變時接收通知的方法。
在使用這些與感應器有關的API的典型應用程式中施行兩個基本任務:
Sensor Avaibability
當感應器的可用性從一個裝置到另一個裝置之間有所變化時,同樣在Android版本間也有所變化。下表總結了各版本可用的感應器。
少數的Android裝置有美意種類型的感應器。例如,大部分的手持裝置或平板電腦有一個加速度計和磁力儀,但少數的裝置有晴雨表或溫度計。還有一個裝置可以擁有多個同一類型的感應器。例如,一個裝置可以有兩個重力感應器,兩個有不同的範圍。
Sensor | Type | Description | Common Uses |
---|---|---|---|
TYPE_ACCELEROMETER | Hardware | Measures the acceleration force in m/s2 that is applied to a device on all three physical axes (x, y, and z), including the force of gravity. | Motion detection (shake, tilt, etc.). |
TYPE_AMBIENT_TEMPERATURE | Hardware | Measures the ambient room temperature in degrees Celsius (°C). See note below. | Monitoring air temperatures. |
TYPE_GRAVITY | Software or Hardware | Measures the force of gravity in m/s2 that is applied to a device on all three physical axes (x, y, z). | Motion detection (shake, tilt, etc.). |
TYPE_GYROSCOPE | Hardware | Measures a device's rate of rotation in rad/s around each of the three physical axes (x, y, and z). | Rotation detection (spin, turn, etc.). |
TYPE_LIGHT | Hardware | Measures the ambient light level (illumination) in lx. | Controlling screen brightness. |
TYPE_LINEAR_ACCELERATION | Software or Hardware | Measures the acceleration force in m/s2 that is applied to a device on all three physical axes (x, y, and z), excluding the force of gravity. | Monitoring acceleration along a single axis. |
TYPE_MAGNETIC_FIELD | Hardware | Measures the ambient geomagnetic field for all three physical axes (x, y, z) in μT. | Creating a compass. |
TYPE_ORIENTATION | Software | Measures degrees of rotation that a device makes around all three physical axes (x, y, z). As of API level 3 you can obtain the inclination matrix and rotation matrix for a device by using the gravity sensor and the geomagnetic field sensor in conjunction with the getRotationMatrix() method. | Determining device position. |
TYPE_PRESSURE | Hardware | Measures the ambient air pressure in hPa or mbar. | Monitoring air pressure changes. |
TYPE_PROXIMITY | Hardware | Measures the proximity of an object in cm relative to the view screen of a device. This sensor is typically used to determine whether a handset is being held up to a person's ear. | Phone position during a call. |
TYPE_RELATIVE_HUMIDITY | Hardware | Measures the relative ambient humidity in percent (%). | Monitoring dewpoint, absolute, and relative humidity. |
TYPE_ROTATION_VECTOR | Software or Hardware | Measures the orientation of a device by providing the three elements of the device's rotation vector. | Motion detection and rotation detection. |
TYPE_TEMPERATURE | Hardware | Measures the temperature of the device in degrees Celsius (°C). This sensor implementation varies across devices and this sensor was replaced with the TYPE_AMBIENT_TEMPERATURE sensor in API Level 14 | Monitoring temperatures. |
你可以使用Android感應器框架存取這些感應器與取得原始數據,感應器框架為android.hardware套件的一部分,包括以下類別與介面:
SensorManager
你可以使用此類別創造一個感應器服務實例,此類別提供許多方法來存取與列表感應器、註冊與註銷感應器事件監聽器、取得方向資訊。此類別也提供許多用來回報感應器準確度、數據回報率、及校準感應器的感應器常數。
Sensor
你可以使用此類別創造一個指定感應器實例,此類別提供多種方法讓你決定一個感應器的能力。
SensorEvent
系統利用此類別產生一個感應器事件物件,用物件來提供有關感應器事件的資訊。一個感應器事件物件包括以下資訊:原始感應器數據、產生事件的感應器的型態、數據的準確度、事件的時間戳。
SensorEventListener
你可以利用此介面產生兩個回呼方法,當感應器數值改變時或是當感應器準確度改變時接收通知的方法。
在使用這些與感應器有關的API的典型應用程式中施行兩個基本任務:
- 查明感應器與感應器能力
- 如果你的應用程式有依賴特定感應器類型與能力的功能,在運行時能查明感應器與感應器的能力是很有用的。例如,你可能想要查明你的裝置中所有的感應器且停用這些依賴了裝置中所沒有的感應器的功能。同樣地,你可能想查明所有指定類型的感應器,選擇能在你的應用程式上有最佳執行效果的感應器執行。
- 監聽感應器事件
- 監聽感應器事件來取得原始數據的,一個感應器偵測到參數的改變時會發生一個感應器事件,感應器事件提供了四個資訊:觸發事件的感應器名稱、事件的時間戳、事件的準確度、觸發事件的原始數據。
Sensor Avaibability
當感應器的可用性從一個裝置到另一個裝置之間有所變化時,同樣在Android版本間也有所變化。下表總結了各版本可用的感應器。
Sensor | Android 4.0 (API Level 14) | Android 2.3 (API Level 9) | Android 2.2 (API Level 8) | Android 1.5 (API Level 3) |
---|---|---|---|---|
TYPE_ACCELEROMETER | Yes | Yes | Yes | Yes |
TYPE_AMBIENT_TEMPERATURE | Yes | n/a | n/a | n/a |
TYPE_GRAVITY | Yes | Yes | n/a | n/a |
TYPE_GYROSCOPE | Yes | Yes | n/a1 | n/a1 |
TYPE_LIGHT | Yes | Yes | Yes | Yes |
TYPE_LINEAR_ACCELERATION | Yes | Yes | n/a | n/a |
TYPE_MAGNETIC_FIELD | Yes | Yes | Yes | Yes |
TYPE_ORIENTATION | Yes2 | Yes2 | Yes2 | Yes |
TYPE_PRESSURE | Yes | Yes | n/a1 | n/a1 |
TYPE_PROXIMITY | Yes | Yes | Yes | Yes |
TYPE_RELATIVE_HUMIDITY | Yes | n/a | n/a | n/a |
TYPE_ROTATION_VECTOR | Yes | Yes | n/a | n/a |
TYPE_TEMPERATURE | Yes2 | Yes | Yes | Yes |
1 This sensor type was added in Android 1.5 (API Level 3), but it was not available for use until Android 2.3 (API Level 9).
2 This sensor is available, but it has been deprecated.