android 感測器

鴨脖發表於2012-07-19
1. ACCELEROMETER 加速,描述加速度的。 
  2.GRAVITY 重力,這個在大家都知道。 
  3.GYROSCOPE 陀螺儀,對於物體跌落檢測更強大些,開發遊戲少了它會有點遺憾的,API Level 9新增的型別。 

  4. LIGHT 光線感應器,很多Android手機的螢幕亮度是根據這個感應器的陣列自動調節的。 
  5. LINEAR_ACCELERATION 線性加速器,API Level 9新增的。 
  6. MAGNETIC_FIELD 磁極感應器。 
  7. ORIENTATION 方向感應器。 

  8. PRESSURE 壓力感應器。  
  9. PROXIMITY 距離感應器,對於通話後關閉螢幕背光很有用。 
  10. ROTATION_VECTOR 旋轉向量,Android 2.3新增的,如果我們過去處理影像會發現這個還是很有用的,不過這裡還是對遊戲開發起到輔助。 
  11. TEMPERATURE 溫度感應器,可以獲取手機的內部溫度,不過和周邊的有些差距,畢竟手機內部一般溫度比較高。 

   對於以上感應器Android123提醒開發者,除了特別描述API Level為9或2.3之外的,SDK在1.5即Level 3時就已經支援了,不過最終使用還要看手機硬體的支援,很多山寨機或小品牌的裝置可能會在這些上面偷工減料,同時Android開發網提醒大家,感應器的資料重新整理比較快一般,考慮到電池功耗一般長時間使用CPU的佔用率可能會提升,影響系統效能。 

  列舉手機上已經有的感應器,可以通過SensorManager類的List<Sensor>  getSensorList(int type)  獲取,返回一個感應器型別的陣列。這裡在列舉時type引數應該寫TYPE_ALL. 

一下程式碼有兩個作用 一個是現實手機上的所有感測器 

一個是在title上顯示重力感測器的變化 
 
Java程式碼  收藏程式碼
  1. package com.HelloSensor;     
  2.        
  3.   import java.util.List;     
  4.        
  5.   import android.app.Activity;     
  6.   import android.content.Context;     
  7.   import android.hardware.Sensor;     
  8.   import android.hardware.SensorEvent;     
  9.   import android.hardware.SensorEventListener;     
  10.   import android.hardware.SensorManager;     
  11.   import android.os.Bundle;     
  12.   import android.widget.TextView;     
  13.        
  14.   public class HelloSensor extends Activity {     
  15.       Sensor sensor ;     
  16.       private float x, y, z;     
  17.       /** Called when the activity is first created. */     
  18.       @Override     
  19.       public void onCreate(Bundle savedInstanceState) {     
  20.           super.onCreate(savedInstanceState);     
  21.           setContentView(R.layout.main);     
  22.        
  23.           //準備顯示資訊的UI組建     
  24.           final TextView tx1 = (TextView) findViewById(R.id.TextView01);     
  25.        
  26.           //從系統服務中獲得感測器管理器     
  27.           SensorManager sm = (SensorManager) getSystemService(Context.SENSOR_SERVICE);     
  28.        
  29.           //從感測器管理器中獲得全部的感測器列表     
  30.           List<Sensor> allSensors = sm.getSensorList(Sensor.TYPE_ALL);     
  31.        
  32.           //顯示有多少個感測器     
  33.           tx1.setText("經檢測該手機有" + allSensors.size() + "個感測器,他們分別是:\n");     
  34.        
  35.           //顯示每個感測器的具體資訊     
  36.           for (Sensor s : allSensors) {     
  37.        
  38.               String tempString = "\n" + "  裝置名稱:" + s.getName() + "\n" + "  裝置版本:" + s.getVersion() + "\n" + "  供應商:"     
  39.                       + s.getVendor() + "\n";     
  40.        
  41.               switch (s.getType()) {     
  42.               case Sensor.TYPE_ACCELEROMETER:     
  43.                   tx1.setText(tx1.getText().toString() + s.getType() + " 加速度感測器accelerometer" + tempString);     
  44.                   break;     
  45.               case Sensor.TYPE_GRAVITY:     
  46.                   tx1.setText(tx1.getText().toString() + s.getType() + " 重力感測器gravity API 9" + tempString);     
  47.                   break;     
  48.               case Sensor.TYPE_GYROSCOPE:     
  49.                   tx1.setText(tx1.getText().toString() + s.getType() + " 陀螺儀感測器gyroscope" + tempString);     
  50.                   break;     
  51.               case Sensor.TYPE_LIGHT:     
  52.                   tx1.setText(tx1.getText().toString() + s.getType() + " 環境光線感測器light" + tempString);     
  53.                   break;     
  54.               case Sensor.TYPE_LINEAR_ACCELERATION:     
  55.                   tx1.setText(tx1.getText().toString() + s.getType() + " 線性加速器LINEAR_ACCELERATION API 9" + tempString);     
  56.                   break;     
  57.               case Sensor.TYPE_MAGNETIC_FIELD:     
  58.                   tx1.setText(tx1.getText().toString() + s.getType() + " 電磁場感測器magnetic field" + tempString);     
  59.                   break;     
  60.               case Sensor.TYPE_ORIENTATION:     
  61.                   tx1.setText(tx1.getText().toString() + s.getType() + " 方向感測器orientation" + tempString);     
  62.                   break;     
  63.               case Sensor.TYPE_PRESSURE:     
  64.                   tx1.setText(tx1.getText().toString() + s.getType() + " 壓力感測器pressure" + tempString);     
  65.                   break;     
  66.               case Sensor.TYPE_PROXIMITY:     
  67.                   tx1.setText(tx1.getText().toString() + s.getType() + " 距離感測器proximity" + tempString);     
  68.                   break;     
  69.               case Sensor.TYPE_ROTATION_VECTOR:     
  70.                   tx1.setText(tx1.getText().toString() + s.getType() + " 旋轉向量ROTATION" + tempString);     
  71.                   break;     
  72.               case Sensor.TYPE_TEMPERATURE:     
  73.                   tx1.setText(tx1.getText().toString() + s.getType() + " 溫度感測器temperature" + tempString);     
  74.                   break;     
  75.               default:     
  76.                   tx1.setText(tx1.getText().toString() + s.getType() + " 未知感測器" + tempString);     
  77.                   break;     
  78.               }     
  79.           }     
  80.                 
  81.           //在title上顯示重力感測器的變化     
  82.           sensor = sm.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);     
  83.           SensorEventListener lsn = new SensorEventListener() {     
  84.               public void onSensorChanged(SensorEvent e) {     
  85.                   x = e.values[SensorManager.DATA_X];     
  86.                   y = e.values[SensorManager.DATA_Y];     
  87.                   z = e.values[SensorManager.DATA_Z];     
  88.                   setTitle("x=" + (int) x + "," + "y=" + (int) y + "," + "z="+ (int) z);     
  89.               }     
  90.        
  91.               public void onAccuracyChanged(Sensor s, int accuracy) {     
  92.               }     
  93.           };     
  94.           // 註冊listener,第三個引數是檢測的精確度     
  95.           sm.registerListener(lsn, sensor, SensorManager.SENSOR_DELAY_GAME);     
  96.        
  97.       }     
  98.   }   

相關文章