亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android重力傳感器實現(xiàn)滾動的彈球

 更新時間:2015年12月11日 09:27:31   作者:杰瑞教育  
所謂傳感器能夠探測如光、熱、溫度、重力、方向 等等的功能,本文給大家介紹Android傳感器應(yīng)用之重力傳感器實現(xiàn)滾動的彈球,對android重力傳感器相關(guān)知識感興趣的朋友一起看看吧

熟知:

什么是傳感器:

     所謂傳感器能夠探測如光、熱、溫度、重力、方向 等等的功能!

Android中提供傳感器有哪些:

     1.  加速度傳感器(重力傳感器)
     2.  陀螺儀傳感器
     3.  光傳感器
     5.  恒定磁場傳感器
     6.  方向傳感器
     7.  恒定的壓力傳感器
     8.  接近傳感器
     9.  溫度傳感器

一、 問題描述

Android中有多達(dá)11種傳感器,不同的手機(jī)設(shè)備支持的傳感器類型也不盡相同

1、 重力傳感器 GV-sensor
2、 加速度傳感器 G-sensor
3、  磁力傳感器  M-sensor
4、 方向傳感器  O-sensor
5、 線性加速度傳感器 LA-sensor
6、 光線感應(yīng)傳感器 SENSOR_TYPE_LIGHT
7、 溫度傳感器
8、 壓力傳感器
9、 接近傳感器
10、 旋轉(zhuǎn)矢量傳感器 RV-sensor
11、 陀螺儀傳感器Gyro-sensor

  對于傳感器的使用并不復(fù)雜,掌握不同傳感器的作用和數(shù)據(jù)參數(shù)即可,下面我們就通過實踐逐步掌握一些主要傳感器的使用

  首先我們使用重力傳感器來完成實現(xiàn)滾動的彈球,如圖所示

二、 案例技術(shù)準(zhǔn)備

1、 傳感器框架 

 傳感器應(yīng)用開發(fā)涉及到的組件如下:

Sensor 

一個指定傳感器的實例。這個類提供了各種方法讓你確定傳感器的功能。

SensorManager 

使用這個類來創(chuàng)建一個傳感器服務(wù)的實例。這個類提供了各種方法類訪問和列舉傳感器,注冊和注銷傳感器事件監(jiān)聽,并獲取相應(yīng)的信息。設(shè)置數(shù)據(jù)獲取速率,和校準(zhǔn)傳感器 

SensorEventListener 

傳感器監(jiān)聽器,檢測傳感器的數(shù)據(jù)變化,并接受傳感器事件

SensorEvent 

傳感器事件,信息載體,檢測的傳感器的數(shù)據(jù)  

2、了解重力傳感器 GV-sensor

  測量應(yīng)用于設(shè)備X、Y、Z軸上的重力,重力數(shù)值為9.8

  坐標(biāo)數(shù)據(jù):

  將手機(jī)平放在桌面上,x軸默認(rèn)為0,y軸默認(rèn)0,z軸默認(rèn)9.81。將手機(jī)朝下放在桌面上,z軸為-9.81。

  將手機(jī)向左傾斜,x軸為正值。將手機(jī)向右傾斜,x軸為負(fù)值。將手機(jī)向上傾斜,y軸為負(fù)值。將手機(jī)向下傾斜,y軸為正值。

三、 代碼實現(xiàn)

1、基于SurfaceView編寫游戲界面 (MySurfaceView)

public class MySurfaceView extends SurfaceView implements Callback, Runnable {
 private SurfaceHolder sfh;
 private Paint paint;
 private Thread th;
 private boolean flag;
 private Canvas canvas;
 private int screenW, screenH;
 //聲明一個傳感器管理器
 private SensorManager sm;
 //聲明一個傳感器
 private Sensor sensor;
 //聲明一個傳感器監(jiān)聽器
 private SensorEventListener mySensorListener;
 //圓形的X,Y坐標(biāo)
 private int arc_x, arc_y;
 //傳感器的xyz值
 private float x = 0, y = 0, z = 0;
 /**
 * SurfaceView初始化函數(shù)
 */
 public MySurfaceView(Context context) {
 super(context);
 sfh = this.getHolder();
 sfh.addCallback(this);
 paint = new Paint();
 paint.setColor(Color.WHITE);
 paint.setAntiAlias(true);
 setFocusable(true);
 //獲取傳感器管理類實例
 sm = (SensorManager) MainActivity.instance.getSystemService(Service.SENSOR_SERVICE);
 //實例一個重力傳感器實例 
 sensor = sm.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
 //實例傳感器監(jiān)聽器
 mySensorListener = new SensorEventListener() {
  @Override
  //傳感器獲取值發(fā)生改變時在響應(yīng)此函數(shù) 
  public void onSensorChanged(SensorEvent event) {
  x = event.values[0]; 
  //x>0 說明當(dāng)前手機(jī)左翻 x<0右翻 
  y = event.values[1];
  //y>0 說明當(dāng)前手機(jī)下翻 y<0上翻 
  z = event.values[2]; 
  //z>0 手機(jī)屏幕朝上 z<0 手機(jī)屏幕朝下 
  arc_x -= x;
  arc_y += y;
  }
  @Override
  //傳感器的精度發(fā)生改變時響應(yīng)此函數(shù) 
  public void onAccuracyChanged(Sensor sensor, int accuracy) {
  }
 };
 //為傳感器注冊監(jiān)聽器
 sm.registerListener(mySensorListener, sensor, SensorManager.SENSOR_DELAY_GAME);
 }
 /**
 * SurfaceView視圖創(chuàng)建,響應(yīng)此函數(shù)
 */
 @Override
 public void surfaceCreated(SurfaceHolder holder) {
 screenW = this.getWidth();
 screenH = this.getHeight();
 flag = true;
 //實例線程
 th = new Thread(this);
 //啟動線程
 th.start();
 }
 /**
 * 游戲繪圖
 */
 public void myDraw() {
 try {
  canvas = sfh.lockCanvas();
  if (canvas != null) {
  canvas.drawColor(Color.BLACK);
  paint.setColor(Color.RED);
  canvas.drawArc(new RectF(arc_x, arc_y, arc_x + 50, arc_y + 50), 0, 360, true, paint);
  paint.setColor(Color.YELLOW);
  canvas.drawText("當(dāng)前重力傳感器的值:", arc_x - 50, arc_y - 30, paint);
  canvas.drawText("x=" + x + ",y=" + y + ",z=" + z, arc_x - 50, arc_y, paint);
  String temp_str = "tony提示: ";
  String temp_str2 = "";
  String temp_str3 = "";
  if (x < 1 && x > -1 && y < 1 && y > -1) {
   temp_str += "當(dāng)前手機(jī)處于水平放置的狀態(tài)";
   if (z > 0) {
   temp_str2 += "并且屏幕朝上";
   } else {
   temp_str2 += "并且屏幕朝下,提示別躺著玩手機(jī),對眼睛不好喲~";
   }
  } else {
   if (x > 1) {
   temp_str2 += "當(dāng)前手機(jī)處于向左翻的狀態(tài)";
   } else if (x < -1) {
   temp_str2 += "當(dāng)前手機(jī)處于向右翻的狀態(tài)";
   }
   if (y > 1) {
   temp_str2 += "當(dāng)前手機(jī)處于向下翻的狀態(tài)";
   } else if (y < -1) {
   temp_str2 += "當(dāng)前手機(jī)處于向上翻的狀態(tài)";
   }
   if (z > 0) {
   temp_str3 += "并且屏幕朝上";
   } else {
   temp_str3 += "并且屏幕朝下,提示別躺著玩手機(jī),對眼睛不好喲~";
   }
  }
  paint.setTextSize(10);
  canvas.drawText(temp_str, 0, 50, paint);
  canvas.drawText(temp_str2, 0, 80, paint);
  canvas.drawText(temp_str3, 0, 110, paint);
  }
 } catch (Exception e) {
  // TODO: handle exception
 } finally {
  if (canvas != null)
  sfh.unlockCanvasAndPost(canvas);
 }
 }
 /**
 * 觸屏事件監(jiān)聽
 */
 @Override
 public boolean onTouchEvent(MotionEvent event) {
 return true;
 }
 /**
 * 按鍵事件監(jiān)聽
 */
 @Override
 public boolean onKeyDown(int keyCode, KeyEvent event) {
 return super.onKeyDown(keyCode, event);
 }
 /**
 * 游戲邏輯
 */
 private void logic() {
 }
 @Override
 public void run() {
 while (flag) {
  long start = System.currentTimeMillis();
  myDraw();
  logic();
  long end = System.currentTimeMillis();
  try {
  if (end - start < 50) {
   Thread.sleep(50 - (end - start));
  }
  } catch (InterruptedException e) {
  e.printStackTrace();
  }
 }
 }
 /**
 * SurfaceView視圖狀態(tài)發(fā)生改變,響應(yīng)此函數(shù)
 */
 @Override
 public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
 }
 /**
 * SurfaceView視圖消亡時,響應(yīng)此函數(shù)
 */
 @Override
 public void surfaceDestroyed(SurfaceHolder holder) {
 flag = false;
 }
} 

2、 編寫主程序

public class MainActivity extends Activity {
 public static MainActivity instance;
 @Override
 public void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 instance = this;
 //設(shè)置全屏
 this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
 requestWindowFeature(Window.FEATURE_NO_TITLE);
 //顯示自定義的SurfaceView視圖
 setContentView(new MySurfaceView(this));
 }
}

相關(guān)文章

  • Android實現(xiàn)簡易計算器小程序

    Android實現(xiàn)簡易計算器小程序

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)簡易計算器小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • 通俗易通講解Android藍(lán)牙鍵值適配

    通俗易通講解Android藍(lán)牙鍵值適配

    這篇文章介紹了Android藍(lán)牙鍵值適配的方法,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值。需要的朋友可以收藏下,方便下次瀏覽觀看
    2021-12-12
  • 分享Android中Toast的自定義使用

    分享Android中Toast的自定義使用

    Android中的Toast是一種簡易的消息提示框,toast提示框不能被用戶點擊,toast會根據(jù)用戶設(shè)置的顯示時間后自動消失。本文將介紹Toast的自定義使用,下面一起來看看吧。
    2016-08-08
  • Android實現(xiàn)滑動到頂部懸停的效果

    Android實現(xiàn)滑動到頂部懸停的效果

    這篇文章給大家介紹一種不常見的實現(xiàn)Android滑動到頂部懸停效果的方式,對大家開發(fā)Android具有一定的參考借鑒價值,有需要的朋友們可以來一起看看。
    2016-09-09
  • Android中屏幕密度和圖片大小的關(guān)系詳解

    Android中屏幕密度和圖片大小的關(guān)系詳解

    這篇文章主要介紹了Android中屏幕密度和圖片大小的關(guān)系詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Android進(jìn)階Hook攔截系統(tǒng)實例化View過程實現(xiàn)App換膚功能

    Android進(jìn)階Hook攔截系統(tǒng)實例化View過程實現(xiàn)App換膚功能

    這篇文章主要為大家介紹了Android進(jìn)階Hook攔截系統(tǒng)實例化View過程實現(xiàn)App換膚功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 詳解Android JNI的基本使用(CMake)

    詳解Android JNI的基本使用(CMake)

    本文介紹了Android JNI的基本使用(CMake),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • Android自定義控件實現(xiàn)折線圖

    Android自定義控件實現(xiàn)折線圖

    這篇文章主要為大家詳細(xì)介紹了Android自定義控件實現(xiàn)折線圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Android實現(xiàn)濾鏡效果ColorMatrix

    Android實現(xiàn)濾鏡效果ColorMatrix

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)濾鏡效果ColorMatrix,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Android人臉識別Demo豎屏YUV方向調(diào)整和圖片保存(分享)

    Android人臉識別Demo豎屏YUV方向調(diào)整和圖片保存(分享)

    下面小編就為大家分享一篇Android人臉識別Demo實現(xiàn)豎屏YUV方向調(diào)整和圖片保存的方法。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12

最新評論