成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android傳感器編程帶實例

移動開發 Android
我很喜歡電腦,可是筆記本還是太大,筆記本電腦再小還是要弄個小包背起來的,智能手機則不同,它完全就是一個手機,可以隨意裝在一個口袋里隨身攜帶。因此我在2002年左右時最喜歡玩裝備是Dell的PDA,2007年的時候最喜歡玩的是N73,而在2010年最喜歡玩的則是Milestone。眼見著手機的功能越來越強,時至今日智能手機甚至在某些方面已經強過了臺式機和筆記本。本節課講的就是智能手機強過臺式機和筆記本的地方:傳感器。

一、前言

我很喜歡電腦,可是筆記本還是太大,筆記本電腦再小還是要弄個小包背起來的,智能手機則不同,它完全就是一個手機,可以隨意裝在一個口袋里隨身攜帶。因此我在2002年左右時最喜歡玩裝備是Dell的PDA,2007年的時候最喜歡玩的是N73,而在2010年最喜歡玩的則是Milestone。眼見著手機的功能越來越強,時至今日智能手機甚至在某些方面已經強過了臺式機和筆記本。本節課講的就是智能手機強過臺式機和筆記本的地方:傳感器。

2008年的時候我很喜歡我的小白筆記本Macbook,喜歡玩它的一個小軟件,一拍桌子,筆記本感受到了震動,它就轉換了一個桌面出來,這讓我像個小孩子一樣沒事就拍拍桌子。這一功能這得益于蘋果筆記本內置有傳感器。

我不知道iPhone手機是不是***個把各種各樣的傳感器運用在手機上的,不過我知道iPhone是把傳感器運用在手機上最成功的***個。隨后的Android系統也內置了大量的傳感器,這讓Android系統手機和普通的諾基亞智能機和Windows CE智能機相比牛氣了許多,在擁有了Milestone之后,我的N73就被仍在抽屜的角落里了。

從Android1.5開始,系統內置了對多達八種傳感器的支持,他們分別是:加速度傳感器(accelerometer)、陀螺儀(gyroscope)、環境光照傳感器(light)、磁力傳感器(magnetic field)、方向傳感器(orientation)、壓力傳感器(pressure)、距離傳感器(proximity)和溫度傳感器(temperature)。

  利用這些傳感器我們可以制作出各種有趣的應用程序和游戲。譬如在口袋里晃一晃手機,手機就開始神不知鬼不覺的錄音,不要著急這個很容易做,我們在本文的結尾就一起制作這個小應用。

本講的學習方式還是在實戰中學習,需要提醒的是模擬器中無法模擬傳感器,因此你需要準備一款Android真機才能運行本講的例子。

二、實例:手機傳感器清單

我們還是先看程序后解釋。

1、創建一個項目 Lesson37_HelloSensor ,主Activity名字叫 mainActivity.java。

2、UI布局文件main.xml的內容如下:
XML/HTML代碼

 

  1. <?xml version="1.0" encoding="utf-8"?>   
  2. <linearlayout android:layout_height="fill_parent" android:layout_width="fill_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android">   
  3. <textview android:layout_height="wrap_content" android:layout_width="fill_parent" android:text="" android:id="@+id/TextView01">   
  4. </textview></linearlayout>   
  5.  
  6.    3、mainActivity.java的內容如下: 
  7. 代碼 
  8.  
  9. package basic.android.lesson37;    
  10.    
  11. import java.util.List;    
  12.    
  13. import android.app.Activity;    
  14. import android.content.Context;    
  15. import android.hardware.Sensor;    
  16. import android.hardware.SensorManager;    
  17. import android.os.Bundle;    
  18. import android.widget.TextView;    
  19.    
  20. public class MainActivity extends Activity {    
  21.    
  22.         /** Called when the activity is first created. */   
  23.         @Override   
  24.         public void onCreate(Bundle savedInstanceState) {    
  25.                 super.onCreate(savedInstanceState);    
  26.                 setContentView(R.layout.main);    
  27.    
  28.                 //準備顯示信息的UI組建    
  29.                 final TextView tx1 = (TextView) findViewById(R.id.TextView01);    
  30.    
  31.                 //從系統服務中獲得傳感器管理器    
  32.                 SensorManager sm = (SensorManager) getSystemService(Context.SENSOR_SERVICE);    
  33.    
  34.                 //從傳感器管理器中獲得全部的傳感器列表    
  35.                 List<sensor> allSensors = sm.getSensorList(Sensor.TYPE_ALL);    
  36.    
  37.                 //顯示有多少個傳感器    
  38.                 tx1.setText("經檢測該手機有" + allSensors.size() + "個傳感器,他們分別是:\n");    
  39.    
  40.                 //顯示每個傳感器的具體信息    
  41.                 for (Sensor s : allSensors) {    
  42.    
  43.                         String tempString = "\n" + "  設備名稱:" + s.getName() + "\n" + "  設備版本:" + s.getVersion() + "\n" + "  供應商:"   
  44.                                         + s.getVendor() + "\n";    
  45.    
  46.                         switch (s.getType()) {    
  47.                         case Sensor.TYPE_ACCELEROMETER:    
  48.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 加速度傳感器accelerometer" + tempString);    
  49.                                 break;    
  50.                         case Sensor.TYPE_GYROSCOPE:    
  51.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 陀螺儀傳感器gyroscope" + tempString);    
  52.                                 break;    
  53.                         case Sensor.TYPE_LIGHT:    
  54.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 環境光線傳感器light" + tempString);    
  55.                                 break;    
  56.                         case Sensor.TYPE_MAGNETIC_FIELD:    
  57.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 電磁場傳感器magnetic field" + tempString);    
  58.                                 break;    
  59.                         case Sensor.TYPE_ORIENTATION:    
  60.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 方向傳感器orientation" + tempString);    
  61.                                 break;    
  62.                         case Sensor.TYPE_PRESSURE:    
  63.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 壓力傳感器pressure" + tempString);    
  64.                                 break;    
  65.                         case Sensor.TYPE_PROXIMITY:    
  66.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 距離傳感器proximity" + tempString);    
  67.                                 break;    
  68.                         case Sensor.TYPE_TEMPERATURE:    
  69.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 溫度傳感器temperature" + tempString);    
  70.                                 break;    
  71.                         default:    
  72.                                 tx1.setText(tx1.getText().toString() + s.getType() + " 未知傳感器" + tempString);    
  73.                                 break;    
  74.                         }    
  75.                 }    
  76.    
  77.         }    
  78. }</sensor>   

   4、連接真機Milestone,編譯并運行程序,顯示結果如下:

5、結合上面的程序我們做一些解釋。

1)Android所有的傳感器都歸傳感器管理器 SensorManager 管理,獲取傳感器管理器的方法很簡單:

String service_name = Context.SENSOR_SERVICE;

SensorManager sensorManager = (SensorManager)getSystemService(service_name);

2)現階段Android支持的傳感器有8種,它們分別是:

 

3)從傳感器管理器中獲取其中某個或者某些傳感器的方法有如下三種:

***種:獲取某種傳感器的默認傳感器

Sensor defaultGyroscope = sensorManager.getDefaultSensor(Sensor.TYPE_GYROSCOPE);

第二種:獲取某種傳感器的列表

List<Sensor> pressureSensors = sensorManager.getSensorList(Sensor.TYPE_PRESSURE);

第三種:獲取所有傳感器的列表,我們這個例子就用的第三種

List<Sensor> allSensors = sensorManager.getSensorList(Sensor.TYPE_ALL);

4)對于某一個傳感器,它的一些具體信息的獲取方法可以見下表:

三、實例:窈窈錄音器

通過上面的例子我們學會了如何獲得某種類型的傳感器,下面我通過一個實例來學會如何使用某一個類型的傳感器。我們這里使用加速度傳感器來實現這樣一個功能:開啟我們的錄音程序放在你的口袋或者提包里,需要錄音的時候把衣服整理一下,或者把提包挪動個位置,那么此時手機就會感受到變化從而開始錄音。由此達到神不知鬼不覺的錄音效果。說起來似乎有點神,其實做起來很簡單,讓我們開始吧。

簡單的錄音程序已經在第28講的時候做過了,我們在28講程序的基礎上寫本講的代碼。

1、新建一個項目 Lesson37_YYRecorder ,主文件叫 MainActivity.java 。

2、這里只貼出于28講不同的 MainActivity.java 的代碼,請注意看注釋:
Java代碼

 

  1. package basic.android.lesson37;    
  2.    
  3. import java.io.File;    
  4. import java.io.IOException;    
  5. import java.util.Calendar;    
  6. import java.util.Locale;    
  7.    
  8. import android.app.Activity;    
  9. import android.content.Context;    
  10. import android.hardware.Sensor;    
  11. import android.hardware.SensorEvent;    
  12. import android.hardware.SensorEventListener;    
  13. import android.hardware.SensorManager;    
  14. import android.media.MediaRecorder;    
  15. import android.os.Bundle;    
  16. import android.text.format.DateFormat;    
  17. import android.view.View;    
  18. import android.widget.Button;    
  19. import android.widget.TextView;    
  20. import android.widget.Toast;    
  21.    
  22. public class MainActivity extends Activity {    
  23.    
  24.         //錄音和停止按鈕    
  25.         private Button recordButton;    
  26.         private Button stopButton;    
  27.    
  28.         //檢測搖動相關變量    
  29.         private long initTime = 0;    
  30.         private long lastTime = 0;    
  31.         private long curTime = 0;    
  32.         private long duration = 0;    
  33.    
  34.         private float last_x = 0.0f;    
  35.         private float last_y = 0.0f;    
  36.         private float last_z = 0.0f;    
  37.    
  38.         private float shake = 0.0f;    
  39.         private float totalShake = 0.0f;    
  40.    
  41.         //媒體錄音器對象    
  42.         private MediaRecorder mr;    
  43.    
  44.         //是否正在錄音    
  45.         private boolean isRecoding = false;    
  46.    
  47.         @Override   
  48.         public void onCreate(Bundle savedInstanceState) {    
  49.                 super.onCreate(savedInstanceState);    
  50.                 setContentView(R.layout.main);    
  51.    
  52.                 // UI組件    
  53.                 recordButton = (Button) this.findViewById(R.id.Button01);    
  54.                 stopButton = (Button) this.findViewById(R.id.Button02);    
  55.                 final TextView tx1 = (TextView) this.findViewById(R.id.TextView01);    
  56.    
  57.                 // 錄音按鈕點擊事件    
  58.                 recordButton.setOnClickListener(new View.OnClickListener() {    
  59.    
  60.                         @Override   
  61.                         public void onClick(View v) {    
  62.                                 //如果沒有在錄音,那么點擊按鈕可以開始錄音    
  63.                                 if(!isRecoding){    
  64.                                         startRecord();    
  65.                                 }    
  66.                         }    
  67.                 });    
  68.    
  69.                 // 停止按鈕點擊事件    
  70.                 stopButton.setOnClickListener(new View.OnClickListener() {    
  71.    
  72.                         @Override   
  73.                         public void onClick(View v) {    
  74.                                 initShake();    
  75.                                 //如果正在錄音,那么可以停止錄音    
  76.                                 if (mr != null) {    
  77.                                         mr.stop();    
  78.                                         mr.release();    
  79.                                         mr = null;    
  80.                                         recordButton.setText("錄音");    
  81.                                         Toast.makeText(getApplicationContext(), "錄音完畢", Toast.LENGTH_LONG).show();    
  82.                                         isRecoding = false;    
  83.    
  84.                                 }    
  85.                         }    
  86.                 });    
  87.    
  88.                 // 獲取傳感器管理器    
  89.                 SensorManager sm = (SensorManager) getSystemService(Context.SENSOR_SERVICE);    
  90.                 // 獲取加速度傳感器    
  91.                 Sensor acceleromererSensor = sm.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);    
  92.    
  93.                 // 定義傳感器事件監聽器    
  94.                 SensorEventListener acceleromererListener = new SensorEventListener() {    
  95.    
  96.                         @Override   
  97.                         public void onAccuracyChanged(Sensor sensor, int accuracy) {    
  98.                                 //什么也不干    
  99.                         }    
  100.    
  101.                         //傳感器數據變動事件    
  102.                         @Override   
  103.                         public void onSensorChanged(SensorEvent event) {            
  104.    
  105.                                 //如果沒有開始錄音的話可以監聽是否有搖動事件,如果有搖動事件可以開始錄音    
  106.                                 if(!isRecoding){    
  107.                                         //獲取加速度傳感器的三個參數    
  108.                                         float x = event.values[SensorManager.DATA_X];    
  109.                                         float y = event.values[SensorManager.DATA_Y];    
  110.                                         float z = event.values[SensorManager.DATA_Z];    
  111.    
  112.                                         //獲取當前時刻的毫秒數    
  113.                                         curTime = System.currentTimeMillis();    
  114.    
  115.                                         //100毫秒檢測一次    
  116.                                         if ((curTime - lastTime) > 100) {    
  117.    
  118.                                                 duration = (curTime - lastTime);    
  119.    
  120.                                                 // 看是不是剛開始晃動    
  121.                                                 if (last_x == 0.0f && last_y == 0.0f && last_z == 0.0f) {    
  122.                                                         //last_x、last_y、last_z同時為0時,表示剛剛開始記錄    
  123.                                                         initTime = System.currentTimeMillis();    
  124.                                                 } else {    
  125.                                                         // 單次晃動幅度    
  126.                                                         shake = (Math.abs(x - last_x) + Math.abs(y - last_y) + Math.abs(z - last_z)) / duration * 100;    
  127.                                                 }    
  128.    
  129.                                                 //把每次的晃動幅度相加,得到總體晃動幅度    
  130.                                                 totalShake += shake;    
  131.    
  132.                                                 // 判斷是否為搖動,這是我自己寫的標準,不準確,只是用來做教學示例,別誤會了^_^    
  133.                                                 if (totalShake > 10 && totalShake / (curTime - initTime) * 1000 > 10) {    
  134.                                                         startRecord();    
  135.                                                         initShake();    
  136.                                                 }    
  137.    
  138.                                                 tx1.setText("總體晃動幅度="+totalShake+ "\n平均晃動幅度="+totalShake / (curTime - initTime) * 1000 );    
  139.                                         }    
  140.    
  141.                                         last_x = x;    
  142.                                         last_y = y;    
  143.                                         last_z = z;    
  144.                                         lastTime = curTime;    
  145.                                 }    
  146.                         }    
  147.    
  148.                 };    
  149.    
  150.                 //在傳感器管理器中注冊監聽器    
  151.                 sm.registerListener(acceleromererListener, acceleromererSensor, SensorManager.SENSOR_DELAY_NORMAL);    
  152.    
  153.         }    
  154.    
  155.         // 開始錄音    
  156.         public void startRecord() {    
  157.                 //把正在錄音的標志設為真    
  158.                 isRecoding = true;    
  159.                 //存放文件    
  160.                 File file = new File("/sdcard/" + "YY"   
  161.                                 + new DateFormat().format("yyyyMMdd_hhmmss", Calendar.getInstance(Locale.CHINA)) + ".amr");    
  162.    
  163.                 Toast.makeText(getApplicationContext(), "正在錄音,錄音文件在" + file.getAbsolutePath(), Toast.LENGTH_LONG).show();    
  164.    
  165.                 // 創建錄音對象    
  166.                 mr = new MediaRecorder();    
  167.    
  168.                 // 從麥克風源進行錄音    
  169.                 mr.setAudioSource(MediaRecorder.AudioSource.DEFAULT);    
  170.    
  171.                 // 設置輸出格式    
  172.                 mr.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT);    
  173.    
  174.                 // 設置編碼格式    
  175.                 mr.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);    
  176.    
  177.                 // 設置輸出文件    
  178.                 mr.setOutputFile(file.getAbsolutePath());    
  179.    
  180.                 try {    
  181.                         // 創建文件    
  182.                         file.createNewFile();    
  183.                         // 準備錄制    
  184.                         mr.prepare();    
  185.                 } catch (IllegalStateException e) {    
  186.                         e.printStackTrace();    
  187.                 } catch (IOException e) {    
  188.                         e.printStackTrace();    
  189.                 }    
  190.                 // 開始錄制    
  191.                 mr.start();    
  192.                 recordButton.setText("錄音中……");    
  193.         }    
  194.    
  195.         //搖動初始化    
  196.         public void initShake() {    
  197.                 lastTime = 0;    
  198.                 duration = 0;    
  199.                 curTime = 0;    
  200.                 initTime = 0;    
  201.                 last_x = 0.0f;    
  202.                 last_y = 0.0f;    
  203.                 last_z = 0.0f;    
  204.                 shake = 0.0f;    
  205.                 totalShake = 0.0f;    
  206.         }    
  207. }  

4、我們小結一下:到Android2.2版本為止,系統并沒有給開發者提供多少可用的包裝好的傳感器信息,只是提供了傳感器發出的原始數據,這些原始數 據存放在  event.values 的數組里,開發人員需要從這些裸數據總自行發掘有用的信息,譬如從加速度傳感器的3維裸數據中獲得搖動的判斷(我的搖動判斷很***,有時間再改吧……)。 好了本講就先到這里,關于傳感器有機會我們展開再談,下次再見吧。

 

責任編輯:chenqingxiang 來源: cnblogs
相關推薦

2010-01-25 13:37:07

Android傳感器

2012-02-28 14:43:43

2010-02-04 16:03:40

Android傳感器

2021-04-14 14:55:08

智能傳感器物聯網新技術

2020-05-12 20:57:41

物聯網傳感器IOT

2023-08-25 15:39:34

物聯網傳感器

2021-09-14 10:12:10

物聯網傳感器IOT

2015-07-13 09:21:50

風速傳感器物聯網

2020-12-01 12:13:37

物聯網智能傳感器IOT

2010-01-04 20:36:54

光纖技術

2022-07-26 12:43:53

機器人

2023-03-12 15:21:57

傳感器Wi-Fi

2021-08-20 13:32:45

傳感器物聯網智能音箱

2022-12-15 10:16:23

2010-09-09 21:44:26

無線傳感器

2010-06-11 16:54:50

無線路由協議

2010-03-15 10:44:14

無線傳感器網絡

2020-11-13 06:04:25

ToF傳感器物聯網

2011-07-27 12:57:49

無線傳感器資源受限故障管理

2021-11-01 10:26:08

傳感器農業自動化物聯網
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 97在线观看| 国产精品久久久久久久午夜 | 国产精品视频在线免费观看 | 久久久久久久香蕉 | 国产在线一区观看 | 日韩精品一区二区三区在线 | av日韩精品 | 国产精品视频久久久 | 日韩精品1区2区 | 无码国模国产在线观看 | www.youjizz.com日韩 | 日本精品国产 | 男人的天堂在线视频 | 中文字幕不卡在线88 | 欧美一区二区在线观看 | 欧美一区精品 | 成人一区二区三区在线观看 | 99精品网 | 国产日韩精品一区二区三区 | 欧美一区二| 久久精品小短片 | 国产精品永久免费视频 | 久久不卡区 | 久久久男人的天堂 | 色在线看 | 欧美激情综合 | 久久综合久久综合久久 | 日韩一级不卡 | 粉嫩在线 | 中文字幕一区在线观看视频 | 日韩精品极品视频在线观看免费 | 天堂色区 | 97起碰 | 日本亚洲精品成人欧美一区 | v片网站 | 国产精品入口久久 | 成人在线视频网站 | 中文字幕免费视频 | 色片在线观看 | 九九热在线免费视频 | 国产精品久久7777777 |