当前位置: 代码迷 >> Android >> Android开发-惯用的传感器总结
  详细解决方案

Android开发-惯用的传感器总结

热度:88   发布时间:2016-04-28 02:28:42.0
Android开发--常用的传感器总结

       随着手机的发展,现在各大手机支持的传感器类型也越来越多,在开发中利用传感器进行某些操作令人们有一种耳目一新的感觉,例如微信中的摇一摇,以及手机音乐播放器中的摇一摇切歌。今天来简单介绍下Android中传感器的使用以及一些常用的传感器。

       一、传感器的使用

        1.首先我们需要获得传感器管理对象:通过  mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);

        2.为SensorManager对象添加监听事件,通过SensorManage的registerListener方法可以为我们的传感器添加监听事件,该方法有多种重载形式,一般我们必须要提供一个listener对象并实现SensorEventListener接口,然后是传感器的类型(int类型值),或一个传感器Sensor对象(通过getDefaultSensor可以得到一个sensor对象)。

        在SensorEventListener接口中有两个重要的方法,

         1)public void onAccuracyChanged(Sensor sensor, int degree),当传感器的精准度发生改变时被调用,degree为新的传感器精度。

         2)public void onSensorChanged(SensorEvent event),传感器信息改变时执行该方法,其中event对象中的values成员中包含了我们所需要的传感器的重要信息,这是一个float数组值,一般根据传感器类型不同,该值也会不同,下面我会来介绍一下一些常用的传感器类型的values值得含义。一般我们在该方法中根据所获得的传感器信息来处理自己的事情。

        3.当我们不需要监听传感器时,通过一个unregisterListener方法来销毁注册。

       二、常用传感器类型介绍

      在前面我们已经知道SensorEvent中的values是一个获取传感器信息的重要变量,接下来就来介绍一些常用传感器的values含义。

        沿手机屏幕横向为x轴,向右为正;沿手机屏幕竖向为y轴,向上为正;垂直手机屏幕方向为z轴,向外为正。

        1.Sensor.TYPE_ACCELEROMETER:加速度感应传感器

        values[0]x轴方向的重力加速度。

        values[1]y轴方向的重力加速度。

        values[2]z轴方向的重力加速度。

 

       2.Sensor.TYPE_GYROSCOPE: 陀螺仪传感器

        values[0]:沿x轴旋转的角速度。

        values[1]:沿y轴旋转的角速度。

        values[2]:沿z轴旋转的角速度。
 

      3.Sensor.TYPE_ORIENTATION:方向传感器

       旋转向量代表设备的结合的方向角和轴的设备通过一个角θ绕轴旋转< x,y,z >

       values[0]:手机绕着z轴旋转的角度。0表示北(North);90表示东(East);180表示南(South);270表示西(West)。如果手机是水平放置,表示手机的正前方与正北方向的夹角就是该值。

       values[1]:手机绕着x轴旋转的角度。取值范围是-180+180度之间。

       values[2]:手机绕着y轴旋转的角度。取值范围是-90+90度之间。

 

      4.Sensor.TYPE_LIGHT:光线传感器

       values[0]:环境光水平勒克斯单位值。

 

      5.Sensor.TYPE_PRESSURE:压力传感器

       values[0]:大气压力值,单位帕。

 

      6.Sensor.TYPE_PROXIMITY: 近程感应器

       values[0]:以厘米为单位的距离值。

 

      7.Sensor.TYPE_RELATIVE_HUMIDITY:湿度传感器

       values[0]: 周围空气相对湿度百分比。

 

      8.Sensor.TYPE_TEMPERATURE: 温度传感器

       values[0]: 周围环境温度的摄氏度值。

       Android API中共定义了十几种传感器的类型,每一部手机不可能支持所有的传感器类型,当通过getDefaultSensor方法返回值为null时表示该手机不支持这种类型的传感器,当我们为不支持的传感器注册了监听事件,并不会引发异常,只是不能得到任何有效的数据。

      三、实践加速度传感器实现摇一摇功能

       接下来,我们通过代码来模拟一个摇一摇的功能,主要是通过加速度感应器来实现,当触发事件时,我们调用手机振动器,并一个Toast显示。调用手机震动提示时需要为我们的app添加权限。

<uses-permission android:name="android.permission.VIBRATE" />
接下来是我们的代码部分
package com.example.shaketest;import android.app.Activity;import android.content.Context;import android.hardware.Sensor;import android.hardware.SensorEvent;import android.hardware.SensorEventListener;import android.hardware.SensorManager;import android.os.Bundle;import android.os.Vibrator;import android.util.Log;import android.view.Menu;import android.widget.Toast;public class MainActivity extends Activity {	private SensorManager mSensorManager;// 传感器管理类	private Vibrator mVibrator;// 振动器	private static final String TAG = "MainActivity";	@Override	protected void onCreate(Bundle savedInstanceState) {		super.onCreate(savedInstanceState);		setContentView(R.layout.activity_main);		mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);		mVibrator = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);// 获得手机振动器	}	@Override	protected void onPause() {		// TODO Auto-generated method stub		super.onPause();		if (mSensorManager != null) {			mSensorManager.unregisterListener(mySensorListener);		}	}	@Override	protected void onResume() {		// TODO Auto-generated method stub		super.onResume();		if (mSensorManager != null) {			// 第一个参数是Listener,第二个参数是所得传感器类型,第三个参数值获取传感器信息的频率			mSensorManager.registerListener(mySensorListener,					mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER),					SensorManager.SENSOR_DELAY_NORMAL);			// SensorManager.SENSOR_DELAY_NORMAL:默认的获得传感器数据的速度。			// SensorManager.SENSOR_DELAY_GAME:如果利用传感器开发游戏,建议使用该值。			// SensorManager.SENSOR_DELAY_UI:如果使用传感器更新UI中的数据,建议使用该值。					}	}	private SensorEventListener mySensorListener = new SensorEventListener() {		@Override		public void onAccuracyChanged(Sensor sensor, int degree) {			// TODO Auto-generated method stub			// 当传感器的精准度发生改变时被调用,int为新的传感器精度		}		@Override		public void onSensorChanged(SensorEvent event) {			// TODO Auto-generated method stub			// 传感器信息改变时执行该方法			float[] values = event.values;			// 该变量最多只有3个元素,而且根据传感器的不同,values变量中元素所代表的含义也不同。			float x = values[0]; // x轴方向的重力加速度			float y = values[1]; // y轴方向的重力加速度			float z = values[2]; // z轴方向的重力加速度			// 设定重力加速度值,当摇晃到达该值时触发震动,并相应自己的事件			int medumValue = 19;			if (Math.abs(x) > medumValue) {				mVibrator.vibrate(500);				Log.w(TAG, "x_shake");				Log.w(TAG, "x轴::" + x + ";y轴::" + y + ";z轴::" + z);				Toast.makeText(MainActivity.this, "Shaking!!!!",						Toast.LENGTH_SHORT).show();			}			if (Math.abs(y) > medumValue) {				mVibrator.vibrate(500);				Log.w(TAG, "y_shake");				Log.w(TAG, "x轴::" + x + ";y轴::" + y + ";z轴::" + z);				Toast.makeText(MainActivity.this, "Shaking!!!!",						Toast.LENGTH_SHORT).show();			}			if (Math.abs(z) > medumValue) {				mVibrator.vibrate(500);				Log.w(TAG, "z_shake");				Log.w(TAG, "x轴::" + x + ";y轴::" + y + ";z轴::" + z);				Toast.makeText(MainActivity.this, "Shaking!!!!",						Toast.LENGTH_SHORT).show();			}		}	};	@Override	public boolean onCreateOptionsMenu(Menu menu) {		// Inflate the menu; this adds items to the action bar if it is present.		getMenuInflater().inflate(R.menu.main, menu);		return true;	}}


    

  相关解决方案