第十周--传感器

传感器类型:

  • 加速度:SENSOR_TYPE_ACCELEROMETER
  • 磁力:SENSOR_TYPE_MAGNETIC_FIELD
  • 方向:SENSOR_TYPE_ORIENTATION
  • 陀螺仪:SENSOR_TYPE_GYROSCOPE
  • 光线感应:SENSOR_TYPE_LIGHT
  • 压力:SENSOR_TYPE_PRESSURE
  • 温度 :SENSOR_TYPE_TEMPERATURE
  • 接近:SENSOR_TYPE_PROXIMITY
  • 重力:SENSOR_TYPE_GRAVITY
  • 线性加速度:SENSOR_TYPE_LINEAR_ACCELERATION
  • 旋转矢量:SENSOR_TYPE_ROTATION_VECTOR

如何使用:

  • 获取SensorManager对象
  • 获取Sensor对象
  • 注册Sensor对象
  • 重写onAccuracyChanged, onSensorChanged方法
  • 注销Sensor对象

以下是加速度传感器的例子:

public class AccelerometerActivity extends AppCompatActivity implements SensorEventListener {
    private SensorManager mSensorManager;
    private Sensor mSensor;    
    private EditText mEdtAcc;  
    @Override
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);      
        setContentView(R.layout.activity_accelerometer);  

        mEdtAcc = (EditText) findViewById(R.id.acc_edtAcc);     

        //1. 获取SensorManager
        mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);  
        //2. 获取Sensor
        mSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        if (mSensor == null){  
            Toast.makeText(this, "传感器不存在", Toast.LENGTH_SHORT).show();
        }  
    }    
    @Override 
    protected void onResume() {  
        super.onResume();  
        //3. 注册Sensor 
        mSensorManager.registerListener(this, mSensor, SensorManager.SENSOR_DELAY_UI); 
    } 
    @Override
    // 当传感器的值发生改变时回调该方法
    public void onSensorChanged(SensorEvent sensorEvent) { 
       //4. 重写onSensorChanged和onAccuracyChanged方法  
       float[] values = sensorEvent.values; 
       StringBuilder stringBuilder = new StringBuilder();     
       stringBuilder.append("X轴上的加速度:");     
       stringBuilder.append(values[0]);
       stringBuilder.append("Y轴上的加速度");       
       stringBuilder.append(values[1]);   
       stringBuilder.append("Z轴上的加速度");   
       stringBuilder.append(values[2]);    

       mEdtAcc.setText(stringBuilder.toString()); 
    }    
    @Override 
    // 当传感器精度改变时回调该方法。
    public void onAccuracyChanged(Sensor sensor, int i) {  
    } 
    @Override  
    protected void onPause() {  
         super.onPause();  
         //5. 注销Sensor 
         mSensorManager.unregisterListener(this, mSensor);  
    }
}

注:
SersorManager.registerListener(SensorListener listener, Sensor sensor, int rate)中的第三个方法是int类型的rate,指定获取传感器数据的频率。
rate可以获取传感器数据的频率,支持如下几个频率值:
SENSOR_DELAY_FASTEST:最快,延迟最小。
SENSOR_DELAY_GAME:适合游戏的频率。
SENSOR_DELAY_NORMAL:正常频率。
SENSOR_DELAY_UI:适合普通用户界面的频率。


关于 方向传感器 的写法可以参考下面网址,写得不错:
http://www.bkjia.com/Androidjc/924827.html


检测传感器

检测传感器一般有两种方法:

  • 一种是在实例化Sensor的时候判断当前传感器是否存在,如:


    第十周--传感器_第1张图片
    检测设备是否存在xxx传感器
  • 另一种方法在manifest.xml清单上加上来过滤,如:


    第十周--传感器_第2张图片

如果你向你的清单文件中添加这个元素和描述符,仅仅 设备有加速度传感器的用户能在Google Play中看见你的应用程序。
如果你的应用程序一定要某个传感器的时候,你应该设置这个描述符为android:required="true"。如果你的应用程序的一些功能使用一个传感器,但是没有传感器仍然可以运行,你应该在元素中列出这个传感器,但是设置这个描述符为android:required="false"。这个帮助确保设备能安装你的应用,即使它们没有这个特定的传感器。这也是一个项目管理的最佳实践,帮组你跟踪你的应用程序使用的特性。记住,如果你的应用程序使用一个特定的传感器,但是没有它仍然可以运行,那么你应该在运行时检测这个传感器,并且酌情启动或禁用应用程序的功能。


相关文献:http://blog.csdn.net/p106786860/article/details/16800467

你可能感兴趣的:(第十周--传感器)