Sensor(ORIENTATION)

复制代码
package com.example.sensor01;

import java.util.List;

import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.TextView;

public class MainActivity extends Activity implements SensorEventListener{
    
    private SensorManager mSensorManager;
    private TextView textview;
    private float[] mags;
    private float[] accs;
    private float[] oris;
    private float[] rotate;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        textview = (TextView) findViewById(R.id.content);
                
        mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
        //Sensor.TYPE_ORIENTATION 在新版本中已经放弃
        Sensor magsensor  = mSensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);
        Sensor accsensor  = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        
        mSensorManager.registerListener(this, magsensor, SensorManager.SENSOR_DELAY_FASTEST);
        mSensorManager.registerListener(this, accsensor, SensorManager.SENSOR_DELAY_FASTEST);
        
        mags = new float[3];
        accs = new float[3];
        oris = new float[3];
        rotate = new float[9];
    }

    @Override
    public void onAccuracyChanged(Sensor arg0, int arg1) {
        // TODO Auto-generated method stub    
    }

    @Override
    public void onSensorChanged(SensorEvent event) {
        
        
        if (event.sensor.getType() == Sensor.TYPE_MAGNETIC_FIELD){
            mags = event.values;//x轴地磁强度
        }
        
        if (event.sensor.getType() == Sensor.TYPE_ACCELEROMETER){
            accs = event.values;//x轴地磁强度
        }
        
        mSensorManager.getRotationMatrix(rotate, null, accs, mags);
        mSensorManager.getOrientation(rotate, oris);
        /*oris[0]      :azimuth 方向角,但用(磁场+加速度)得到的数据范围是(-180~180),也就是说,0表示正北,90表示正东,180/-180表示正南,-90表示正西。
        oris[1]      :pitch 倾斜角  即由静止状态开始,围绕X轴前后翻转
        oris[2]      :roll 旋转角 即由静止状态开始,围绕Y轴左右翻转*/
        double azimuth = Math.toDegrees(oris[0]);
        if (azimuth<0) {
            azimuth=azimuth + 360;
        }
        double pitch = Math.toDegrees(oris[1]);
        double roll = Math.toDegrees(oris[2]);
        

        textview.setText(String.valueOf(azimuth) + "   " 
        + String.valueOf(pitch) + "  " + String.valueOf(roll));                
    }
}
复制代码

 

posted @   Fredric_2013  阅读(1116)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示