Android开发获取重力加速度和磁场强度的方法
作者:GISuuser 时间:2022-05-27 23:07:09
本文实例讲述了Android开发获取重力加速度和磁场强度的方法。分享给大家供大家参考,具体如下:
Android获取重力加速度和磁场强度主要依靠:
Sensor.getRotationMatrix (float[] R, float[] I, float[] gravity, float[] geomagnetic)
输入数据:
gravity为重力传感器测得的重力加速度float[3];
geomagnetic为罗盘传感器测得的地磁数据float[3];
输出数据:
R为通过这个方法计算得到的从手机的设备到坐标系到真实世界坐标系的转换矩阵
I为从将地磁数据转换到重力数据所在坐标的旋转矩阵
[0 0 g] = R * gravity (g = 重力加速度)
[0 m 0] = I * R * geomagnetic (m = 磁场强度)
下面是我做的结果图
核心部分代码如下:
public class MainActivity extends AppCompatActivity implements SensorEventListener {
private static final String TAG = "CompassActivity";
private SensorManager sensorManager;
//记录rotationMatrix矩阵值
private float[] r = new float[9];
private float[] gravity = null;
private float[] geomagnetic = null;
private float[] I=new float[9];
private Handler handler=new Handler(){
@Override
public void handleMessage(Message msg) {
if(gravity!=null&&geomagnetic!=null)
{
if(SensorManager.getRotationMatrix(r, I, gravity, geomagnetic)) {
float gri = gravity[0] * r[6] + gravity[1] * r[7] + gravity[2] * r[8];
float h= (I[3]*r[0]+I[4]*r[3]+I[5]*r[6])*geomagnetic[0]+
(I[3]*r[1]+I[4]*r[4]+I[5]*r[7])*geomagnetic[1]+
(I[3]*r[2]+I[4]*r[5]+I[5]*r[8])*geomagnetic[2];
TextView textView = (TextView) findViewById(R.id.textView);
textView.setText("重力加速度" + gri + "\n"+"磁场强度" + h + "\n");
}
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
public void onSensorChanged(SensorEvent sensorEvent) {
switch (sensorEvent.sensor.getType()){
case Sensor.TYPE_ACCELEROMETER:
gravity=sensorEvent.values;
handler.sendEmptyMessage(0);
break;
case Sensor.TYPE_MAGNETIC_FIELD:
geomagnetic=sensorEvent.values;
handler.sendEmptyMessage(0);
break;
default:break;
}
}
@Override
public void onAccuracyChanged(Sensor sensor, int i) {
}
private void showMessage(String message){
View view=findViewById(R.id.fab);
final Snackbar snackbar=Snackbar.make(view, message, Snackbar.LENGTH_INDEFINITE);
snackbar.setAction("关闭", new View.OnClickListener() {
@Override
public void onClick(View view) {
snackbar.dismiss();
}
});
snackbar.show();
}
@Override
protected void onPause() {
super.onPause();
sensorManager.unregisterListener(this);
}
@Override
protected void onResume() {
super.onResume();
Sensor sensor1=sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
sensorManager.registerListener(this,sensor1,SensorManager.SENSOR_DELAY_UI);
Sensor sensor2=sensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);
sensorManager.registerListener(this,sensor2,SensorManager.SENSOR_DELAY_UI);
}
}
希望本文所述对大家Android程序设计有所帮助。
来源:http://blog.csdn.net/gisuuser/article/details/77854526
标签:Android,重力,磁场
0
投稿
猜你喜欢
C#利用原图和水印图的重叠简单实现水印的方法
2023-04-21 01:41:24
Java数据结构之链表的增删查改详解
2023-08-13 07:48:40
使用Springboot自定义注解,支持SPEL表达式
2023-11-20 01:18:58
Hadoop1.2中配置伪分布式的实例
2023-01-26 12:20:56
Spring boot整合log4j2过程解析
2023-11-29 10:47:53
Springboot-admin整合Quartz实现动态管理定时任务的过程详解
2023-08-26 03:01:07
C#执行EXE文件与输出消息的提取操作
2023-02-28 00:08:06
JAVA中使用FTPClient实现文件上传下载实例代码
2021-08-17 20:45:05
java构造函数示例(构造方法)
2022-05-08 19:06:03
C#抓取网络图片保存到本地的实现方法
2023-06-28 11:35:13
Java面向接口编程之简单工厂模式示例
2021-07-14 21:40:27
Java毕业设计实战之在线蛋糕销售商城的实现
2022-06-06 14:25:39
详解Java利用同步块synchronized()保证并发安全
2021-09-12 12:15:07
Android EditText限制输入字符的方法总结
2023-04-22 03:16:24
C#设置输入法实例分析
2022-07-07 14:30:05
Java实现图片验证码具体代码
2021-06-30 13:16:35
SpringBoot中Dozer的使用小结
2023-11-25 01:24:38
Java中OAuth2.0第三方授权原理与实战
2021-09-27 01:48:57
SpringBoot Java后端实现okhttp3超时设置的方法实例
2022-11-06 04:56:03
c# 使用模式匹配以及 is 和 as 运算符安全地进行强制转换
2022-11-23 09:47:51