Android传感器之方向传感器
发表时间:2020-10-19
发布人:葵宇科技
浏览次数:55
一般情况下,在android体系中获取手机的方位信息在api中有TYPE_ORIENTATION常量,可以像获得加快度传感器那样获得偏向传感器sm.getDefaultSensor(Sensor.TYPE_ORIENTATION);然而我们如许做的话在最新版的SDK中就会看到这么一句话:“TYPE_ORIENTATION This constant is deprecated. use SensorManager.getOrientation() instead. ”即这种方法也过时,不建议应用!Google建议我们在应用法度榜样中应用SensorManager.getOrientation()来获得原始数据。
public static float[] getOrientation (float[] R, float[] values)
第一个参数是R[] 是一个扭转矩阵,用来保存磁场和加快度的数据,可以懂得为这个函数的传入值,经由过程它这个函数给你求出方位角。
第二个参数就是这个函数的输出了,他有函数主动为我们填充,这就是我们想要的。
values[0] :偏向角,但用(磁场+加快度缉获得的数据范围是(-180~180),也就是说,0表示正北,90表示正东,180/-180表示正南,-90表示正西。而直接经由过程偏向感应器数据范围是(0~359)360/0表示正北,90表示正东,180表示正南,270表示正西。
values[1] pitch 倾斜角 即竽暌股静止状况开端,前后翻转棘手机顶部往上抬起(0~-90)棘手机尾部往上抬起(0~90)
values[2] roll 扭转角 即竽暌股静止状况开端,阁下翻转棘手机左侧抬起(0~90),手机右侧抬起(0~-90)
如今问题是这个R[]怎么获取,其实他是经由过程函数getRotationMatrix获得的。
看看getRotationMatrix的定义:
public static boolean getRotationMatrix (float[] R, float[] I, float[] gravity, float[] geomagnetic)
解释以下参数,第一个就是我们须要填充的R数组,大年夜小是9
第二个是是一个转换矩阵,将磁场数据转换进实际的重力坐标中 一般默认情况下可以设置为null
第三个是一个大年夜小为3的数组,表示大年夜加快度感应器获取来的数据 在onSensorChanged中
第四个是一个大年夜小为3的数组,表示大年夜磁场感应器获取来的数据 在onSensorChanged中
示例代码:
package com.example.testoritation;
import android.app.Activity;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.view.Menu;
import android.widget.TextView;
//实现传感器事宜监听:SensorEventListener
public class MainActivity extends Activity implements SensorEventListener{
private SensorManager sensorManager;
private Sensor acc_sensor;
private Sensor mag_sensor;
//加快度传感器数据
float accValues[]=new float[3];
//地磁传感器数据
float magValues[]=new float[3];
//扭转矩阵,用来保存磁场和加快度的数据
float r[]=new float[9];
//模仿偏向传感器的数据(原始数据为弧度)
float values[]=new float[3];
TextView show_change=null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
show_change=(TextView) findViewById(R.id.show_change);
sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
acc_sensor = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
mag_sensor = sensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);
//给传感器注册监听:
sensorManager.registerListener(this, acc_sensor, SensorManager.SENSOR_DELAY_GAME);
sensorManager.registerListener(this, mag_sensor,SensorManager.SENSOR_DELAY_GAME);
}
@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;
}
//传感器状况改变时的回调办法
@Override
public void onSensorChanged(SensorEvent event) {
if(event.sensor.getType()==Sensor.TYPE_ACCELEROMETER){
accValues=event.values;
}
else if(event.sensor.getType()==Sensor.TYPE_MAGNETIC_FIELD){
magValues=event.values;
}
/**public static boolean getRotationMatrix (float[] R, float[] I, float[] gravity, float[] geomagnetic)
* 填充扭转数组r
* r:要填充的扭转数组
* I:将磁场数据转换进实际的重力坐标中 一般默认情况下可以设置为null
* gravity:加快度传感器数据
* geomagnetic:地磁传感器数据
*/
SensorManager.getRotationMatrix(r, null, accValues, magValues);
/**
* public static float[] getOrientation (float[] R, float[] values)
* R:扭转数组
* values :模仿偏向传感器的数据
*/
SensorManager.getOrientation(r, values);
//将弧度转化为角度后输出
StringBuffer buff=new StringBuffer();
for(float value:values){
value=http://www.sjsjw.com/100/000177MYM030657/(float) Math.toDegrees(value);
buff.append(value+" ");
}
show_change.setText(buff.toString());
}
@Override
public void onAccuracyChanged(Sensor sensor, int accuracy) {
}
}








