Android ApiDemos示例解析(90):OS->Sensors
2012-07-29 10:41
369 查看
在前面的例子
Android ApiDemos示例解析(61):Graphics->Compass 和例子Android ApiDemos示例解析(79):Graphics->SensorTest 涉及到了Sensors。
本例再集中介绍Android 中支持的Sensors用法。
SensorManager用于管理Android设备中的各种传感器,取的SensorManager实例对象的方法是使用getSystemService:
SensorListener 和 SensorEventListener 定义了监视设备传感器的回调函数。SensorListener和SensorEventListener 定义的方法大同小异,主要是值得Sensor类型的参数不同,SensorListener 是过时的接口,尽量不要再用,本例还是使用SensorListener。
它定义里两个回调函数:
sensor指定了传感器的类型,类型为int ,而SensorEventListener 中是使用Sensor类型。values数组定义了X,Y,Z方向传感器的值方向为度,横向和纵向时,X,Y,Z定义有所不 同,values[3],values[4],values[5]定义与屏幕方向无关的X,Y,Z值。
Android设备可能带有多种传感器,每种传感器的精度不同,当精度变换时onAccuracyChanged被触发,是sensor 指定了传感器的类型,而accuracy 为新的精度:
SensorManager.SENSOR_STATUS_ACCURACY_HIGH 传感器报告高精度值
SensorManager.SENSOR_STATUS_ACCURACY_LOW 传感器报告低精度值
SensorManager.SENSOR_STATUS_ACCURACY_MEDIUM 传感器报告平均精度值
SensorManager.SENSOR_STATUS_ACCURACY_UNRELIABLE 传感器报告的精度值不可靠。
sensor 指定了传感器的类型,Android系统中可能支持的传感器有如下几种:
SENSOR_ACCELEROMETER: 加速传感器,检测沿X,Y,Z三个方向的加速度(m/s2).
SENSOR_ORIENTATION: 方向传感器,沿X,Y,Z三个方向的角度。
SENSOR_LIGHT: 亮度传感器,检测当前光线强度。
SENSOR_MAGNETIC_FIELD: 磁场传感器,检测沿X,Y,Z三个方向的磁通量。
SENSOR_PROXIMITY: 位置传感器,检测当前位置和目标位置之间的距离。
SENSOR_TEMPERATURE: 温度传感器,检测当前气温。
在Android最新的开发包中提供了一个新类Sensor 用来代替原先使用int表示的Sensor 类型,在新的应用中建议使用这个Sensor类。
如果想指定使用某种Sensor,可以在registerListener时指定,传感器是共享设备,对于一个“好”的应用,在不需要使用传感器时要清除对传感器的监视,这反应的onResume,onStop方法中:
在registerListener 中除了指定需要监听的Sensor类型外,还可以指定传感器更新的频率,支持的频率支持下面几个选项:
SENSOR_DELAY_FASTEST: 选择尽可能快的频率。
SENSOR_DELAY_GAME: 选择适应于游戏应用的更新频率。
SENSOR_DELAY_NORMAL: 选择缺省的更新频率。
SENSOR_DELAY_UI: 选择适合更新UI的频率。
本例的onSensorChanged定义如下,使用SENSOR_ORIENTATION,SENSOR_MAGNETIC_FIELD 和SENSOR_MAGNETIC_FIELD 因此需要手机来测试:
Android ApiDemos示例解析(61):Graphics->Compass 和例子Android ApiDemos示例解析(79):Graphics->SensorTest 涉及到了Sensors。
本例再集中介绍Android 中支持的Sensors用法。
SensorManager用于管理Android设备中的各种传感器,取的SensorManager实例对象的方法是使用getSystemService:
private SensorManager mSensorManager; ... mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
SensorListener 和 SensorEventListener 定义了监视设备传感器的回调函数。SensorListener和SensorEventListener 定义的方法大同小异,主要是值得Sensor类型的参数不同,SensorListener 是过时的接口,尽量不要再用,本例还是使用SensorListener。
它定义里两个回调函数:
public void onSensorChanged(int sensor, float[] values) { mValues = values; if (mView != null) { mView.invalidate(); } } public void onAccuracyChanged(int sensor, int accuracy) { // TODO Auto-generated method stub }
sensor指定了传感器的类型,类型为int ,而SensorEventListener 中是使用Sensor类型。values数组定义了X,Y,Z方向传感器的值方向为度,横向和纵向时,X,Y,Z定义有所不 同,values[3],values[4],values[5]定义与屏幕方向无关的X,Y,Z值。
Android设备可能带有多种传感器,每种传感器的精度不同,当精度变换时onAccuracyChanged被触发,是sensor 指定了传感器的类型,而accuracy 为新的精度:
SensorManager.SENSOR_STATUS_ACCURACY_HIGH 传感器报告高精度值
SensorManager.SENSOR_STATUS_ACCURACY_LOW 传感器报告低精度值
SensorManager.SENSOR_STATUS_ACCURACY_MEDIUM 传感器报告平均精度值
SensorManager.SENSOR_STATUS_ACCURACY_UNRELIABLE 传感器报告的精度值不可靠。
sensor 指定了传感器的类型,Android系统中可能支持的传感器有如下几种:
SENSOR_ACCELEROMETER: 加速传感器,检测沿X,Y,Z三个方向的加速度(m/s2).
SENSOR_ORIENTATION: 方向传感器,沿X,Y,Z三个方向的角度。
SENSOR_LIGHT: 亮度传感器,检测当前光线强度。
SENSOR_MAGNETIC_FIELD: 磁场传感器,检测沿X,Y,Z三个方向的磁通量。
SENSOR_PROXIMITY: 位置传感器,检测当前位置和目标位置之间的距离。
SENSOR_TEMPERATURE: 温度传感器,检测当前气温。
在Android最新的开发包中提供了一个新类Sensor 用来代替原先使用int表示的Sensor 类型,在新的应用中建议使用这个Sensor类。
如果想指定使用某种Sensor,可以在registerListener时指定,传感器是共享设备,对于一个“好”的应用,在不需要使用传感器时要清除对传感器的监视,这反应的onResume,onStop方法中:
@Override protected void onResume() { super.onResume(); mSensorManager.registerListener(mGraphView, SensorManager.SENSOR_ACCELEROMETER | SensorManager.SENSOR_MAGNETIC_FIELD | SensorManager.SENSOR_ORIENTATION, SensorManager.SENSOR_DELAY_FASTEST); } @Override protected void onStop() { mSensorManager.unregisterListener(mGraphView); super.onStop(); }
在registerListener 中除了指定需要监听的Sensor类型外,还可以指定传感器更新的频率,支持的频率支持下面几个选项:
SENSOR_DELAY_FASTEST: 选择尽可能快的频率。
SENSOR_DELAY_GAME: 选择适应于游戏应用的更新频率。
SENSOR_DELAY_NORMAL: 选择缺省的更新频率。
SENSOR_DELAY_UI: 选择适合更新UI的频率。
本例的onSensorChanged定义如下,使用SENSOR_ORIENTATION,SENSOR_MAGNETIC_FIELD 和SENSOR_MAGNETIC_FIELD 因此需要手机来测试:
public void onSensorChanged(int sensor, float[] values) { synchronized (this) { if (mBitmap != null) { final Canvas canvas = mCanvas; final Paint paint = mPaint; if (sensor == SensorManager.SENSOR_ORIENTATION) { for (int i=0 ; i<3 ; i++) { mOrientationValues[i] = values[i]; } } else { float deltaX = mSpeed; float newX = mLastX + deltaX; int j = (sensor == SensorManager.SENSOR_MAGNETIC_FIELD) ? 1 : 0; for (int i=0 ; i<3 ; i++) { int k = i+j*3; final float v = mYOffset + values[i] * mScale[j]; paint.setColor(mColors[k]); canvas.drawLine(mLastX, mLastValues[k], newX, v, paint); mLastValues[k] = v; } if (sensor == SensorManager.SENSOR_MAGNETIC_FIELD) mLastX += mSpeed; } invalidate(); } } }
相关文章推荐
- Android ApiDemos示例解析(91):OS->SMS Messaging
- Android ApiDemos示例解析(89):OS->Morse Code
- Android ApiDemos示例解析(35):App->Preferences->Advanced preferences
- Android ApiDemos示例解析(46):App->Voice Recognition
- Android ApiDemos示例解析(48):Content->Resources->Resources
- Android ApiDemos示例解析(191):Views->Seek Bar
- Android ApiDemos示例解析(197):Views->Visibility
- Android ApiDemos示例解析(158):Views->Layouts->TableLayout->03.Long Content
- Android ApiDemos示例解析(69):Graphics->PathEffects
- Android ApiDemos示例解析(198):Views->WebView
- Android ApiDemos示例解析(200):Graphics->OpenGL ES->Textured Triangle
- Android ApiDemos示例解析(54):Graphics->BitmapDecode
- Android ApiDemos示例解析(81):Graphics->Text Align
- Android ApiDemos示例解析(14):App->Activity->Save & Restore State
- Android ApiDemos示例解析(29):App->Notification->Status Bar
- Android ApiDemos示例解析(178):Views->Lists->11. Multiple choice list
- Android ApiDemos示例解析(17):App->Activity->Translucent Blur
- Android ApiDemos示例解析(129):Views->Layout Animation->4. Randomize
- Android ApiDemos示例解析(109):Views->Custom
- Android ApiDemos示例解析(159):Views->Layouts->TableLayout->04.Stretchable