您的位置:首页 > 移动开发 > Android开发

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

2015-02-03 15:36 344 查看
       随着手机的发展,现在各大手机支持的传感器类型也越来越多,在开发中利用传感器进行某些操作令人们有一种耳目一新的感觉,例如微信中的摇一摇,以及手机音乐播放器中的摇一摇切歌。今天来简单介绍下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;
}

}


    
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  android开发 传感器