編輯:關於Android編程
一般情況下,在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=(float) Math.toDegrees(value); buff.append(value+" "); } show_change.setText(buff.toString()); } @Override public void onAccuracyChanged(Sensor sensor, int accuracy) { } }
本文與《利用adt-bundle輕松搭建Android開發環境與Hello world(Windows) 》是姊妹篇,只是這次操作換成了Linux 。拿Ubuntu做例子
本文實例講述了Android開發之ListView列表刷新和加載更多實現方法。分享給大家供大家參考。具體如下:上下拉實現刷新和加載更多的ListView,如下:packa
並不是所有的BAT的API都是非常好用的,微信支付就有不少的缺陷,總結一下微信支付實現中出現的問題 坑點一: PayReq的參數 sign的生成&
今天有一個Android新手使用strings.xml進行格式化的時候報了占位符錯誤, Multiple substitutions specified in non-