android传感器使用的demo,包括光线传感器,加速度传感器,距离传感器和方向传感器。

demo:下载地址

源码:

package com.bobo.study.study_5_1;
 
import android.app.Activity;
import android.content.Context;
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.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
 
import java.util.List;
//1,获得SensorManager对象
//2,获得想要的Sensor对象
//3,绑定监听器
public class MainActivity extends Activity implements View.OnClickListener{
 Button findBut,accelerationBut,lightBut,orientationBut,proximityBut;
 SensorManager sensorManager;
 TextView text,accText,luxText;
 float gravity[]=new float[3];
 float linear_acceleration[]=new float[3];
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
 
  findBut=(Button)findViewById(R.id.findBut);
  findBut.setOnClickListener(this);
  lightBut=(Button)findViewById(R.id.lightBut);
  lightBut.setOnClickListener(this);
  accelerationBut=(Button)findViewById(R.id.accelerationBut);
  accelerationBut.setOnClickListener(this);
  orientationBut=(Button)findViewById(R.id.orientationBut);
  orientationBut.setOnClickListener(this);
  proximityBut=(Button)findViewById(R.id.proximityBut);
  proximityBut.setOnClickListener(this);
 
  text=(TextView)findViewById(R.id.text);
  accText=(TextView)findViewById(R.id.accText);
  luxText=(TextView)findViewById(R.id.luxText);
 
  //获得传感器管理器对象
  sensorManager=(SensorManager)getSystemService(Context.SENSOR_SERVICE);
 }
 
 @Override
 public void onClick(View v) {
  if(v==findBut){
   //获取手机上所有传感器的列表
   List<Sensor> sensors=sensorManager.getSensorList(Sensor.TYPE_ALL);
   for(Sensor sensor:sensors){
    System.out.println(sensor.getName());
   }
  }else if(v==lightBut){
   //得到默认的加速度传感器
   Sensor lightSensor=sensorManager.getDefaultSensor(Sensor.TYPE_LIGHT);
   //绑定监听器(上下文接口,要监听的传感器,传感器采样率<时间间隔>),返回结果
   Boolean res=sensorManager.registerListener(new LightSensorListener(),lightSensor,SensorManager.SENSOR_DELAY_NORMAL);
   Toast.makeText(this,"绑定光线传感器:" res,Toast.LENGTH_LONG).show();
  }
  else if(v==accelerationBut){
   Sensor accelerometerSensor=sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
   Boolean res=sensorManager.registerListener(new AccerationSensorListener(),accelerometerSensor,SensorManager.SENSOR_DELAY_NORMAL);
   Toast.makeText(this,"绑定加速度传感器:" res,Toast.LENGTH_LONG).show();
  }else if(v==orientationBut){
   Sensor orientationSensor=sensorManager.getDefaultSensor(Sensor.TYPE_ORIENTATION);
   Boolean res=sensorManager.registerListener(new OrientaationListener(),orientationSensor,SensorManager.SENSOR_DELAY_NORMAL);
   Toast.makeText(this,"绑定方向传感器:" res,Toast.LENGTH_LONG).show();
  }
  else if(v==proximityBut){
   Sensor proximitySensor=sensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY);
   Boolean res=sensorManager.registerListener(new ProximityListener(),proximitySensor,SensorManager.SENSOR_DELAY_NORMAL);
   Toast.makeText(this,"绑定距离传感器:" res,Toast.LENGTH_LONG).show();
  }
 }
 
 public class LightSensorListener implements SensorEventListener{
  @Override
  //传感器的数据被打包成event,主要的检测数据放在enent.values[]数组中
  public void onSensorChanged(SensorEvent event) {
   System.out.println(event.timestamp);//时间戳
   System.out.println(event.sensor.getResolution());//分辨率(能识别出最小数值)
   System.out.println(event.accuracy);//精度(等级)
   System.out.println(event.values[0]);//光线强度
  }
  @Override
  //传感器精度变化时调用这个函数
  public void onAccuracyChanged(Sensor sensor, int accuracy) {}
 }
 
 public class AccerationSensorListener implements SensorEventListener{
  @Override
  public void onSensorChanged(SensorEvent event) {
   final float alpha=0.8f;
 
   //event.values[0]X轴加速度,负方向为正
   //event.values[1]Y轴加速度,负方向为正
   //event.values[2]Z轴加速度,负方向为正
   gravity[0]=alpha*gravity[0] (1-alpha)*event.values[0];
   gravity[1]=alpha*gravity[1] (1-alpha)*event.values[1];
   gravity[2]=alpha*gravity[2] (1-alpha)*event.values[2];
 
   linear_acceleration[0]=event.values[0]-gravity[0];
   linear_acceleration[1]=event.values[1]-gravity[1];
   linear_acceleration[2]=event.values[2]-gravity[2];
 
   //通过以上公式可以抛去三个方向上的重力加速度,只剩下纯加速度
   text.setText(linear_acceleration[0]   "");
   accText.setText(linear_acceleration[1]   "");
   luxText.setText(linear_acceleration[2]   "");
  }
  @Override
  public void onAccuracyChanged(Sensor sensor, int accuracy) {}
 }
 
 public class OrientaationListener implements SensorEventListener{
  @Override
  public void onSensorChanged(SensorEvent event) {
   //(需要手机屏幕向上,向下的话南北会反掉)设备绕Z轴旋转,Y轴正方向与地磁北极方向的夹角,顺时针方向为正,范围【0,180】
   float azimuth=event.values[0];
   //设备绕X轴旋转的角度,当Z轴向Y轴正方向旋转时为正,反之为负,范围【-180,180】
   float pitch=event.values[1];
   //设备绕Y轴旋转的角度,当Z轴向X轴正方向旋转时为负,反之为正,范围【-90,90】
   float roll=event.values[2];
 
   text.setText(azimuth "");
   accText.setText(pitch  "");
   luxText.setText(roll "");
  }
  @Override
  public void onAccuracyChanged(Sensor sensor, int accuracy) {}
 }
 
 public class ProximityListener implements SensorEventListener{
  @Override
  public void onSensorChanged(SensorEvent event) {
   //距离传感器测试手机屏幕距离别的物体的记录,只有两个值:0和5
   //距离很近时为0,否则为5
   System.out.println(event.values[0] "");
  }
  @Override
  public void onAccuracyChanged(Sensor sensor, int accuracy) {}
 }
 
 
 
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  // Inflate the menu; this adds items to the action bar if it is present.
  getMenuInflater().inflate(R.menu.menu_main, menu);
  return true;
 }
 @Override
 public boolean onOptionsItemSelected(MenuItem item) {
  // Handle action bar item clicks here. The action bar will
  // automatically handle clicks on the Home/Up button, so long
  // as you specify a parent activity in AndroidManifest.xml.
  int id = item.getItemId();
  //noinspection SimplifiableIfStatement
  if (id == R.id.action_settings) {
   return true;
  }
  return super.onOptionsItemSelected(item);
 }
}

界面截图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

android实现手机传感器调用的更多相关文章

  1. html5视频自动横过来自适应页面且点击播放功能的实现

    这篇文章主要介绍了h5视频自动横过来自适应页面且点击播放,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. html5 canvas合成海报所遇问题及解决方案总结

    这篇文章主要介绍了html5 canvas合成海报所遇问题及解决方案总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. Html5 video标签视频的最佳实践

    这篇文章主要介绍了Html5 video标签视频的最佳实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  4. HTML5调用手机发短信和打电话功能

    这篇文章主要介绍了HTML5调用手机发短信和打电话功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. HTML5在微信内置浏览器下右上角菜单的调整字体导致页面显示错乱的问题

    HTML5在微信内置浏览器下,在右上角菜单的调整字体导致页面显示错乱的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  6. ios – containerURLForSecurityApplicationGroupIdentifier:在iPhone和Watch模拟器上给出不同的结果

    我使用默认的XCode模板创建了一个WatchKit应用程序.我向iOSTarget,WatchkitAppTarget和WatchkitAppExtensionTarget添加了应用程序组权利.(这是应用程序组名称:group.com.lombax.fiveminutes)然后,我尝试使用iOSApp和WatchKitExtension访问共享文件夹URL:延期:iOS应用:但是,测试NSURL

  7. Xcode:iPhone截图不再有效

    解决方法我没有针对您的问题的解决方案,但这是一个解决方法:使用设备制作屏幕截图.生成的屏幕截图将保存在设备上.要将屏幕截图传输到桌面,请不要使用慢速iPhoto或iTunes进行同步.而是使用Preview.app导入图像.文件菜单中有一个命令可以在iPhone连接时从iPhone导入图像.

  8. Ionic – Splash Screen适用于iOS,但不适用于Android

    我有一个离子应用程序,其中使用CLI命令离子资源生成的启动画面和图标iOS版本与正在渲染的启动画面完美配合,但在Android版本中,只有在加载应用程序时才会显示白屏.我检查了config.xml文件,所有路径看起来都是正确的,生成的图像出现在相应的文件夹中.(我使用了splash.psd模板来生成它们.我错过了什么?这是config.xml文件供参考,我觉得我在这里做错了–解决方法在config.xml中添加以下键:它对我有用!

  9. ios – 页面上有一个或多个错误.在itunesconnect上

    我正在尝试在iTunesconnect上传一个新的iOS应用程序版本,我不断收到错误页面上有一个或多个错误它突出了唯一的语言.请帮忙.并参考附图解决方法简而言之,必须将所有图像添加到“AppPreview和Screenshots”.我刚刚遇到这个问题,这个https://stackoverflow.com/a/38887524/795114的答案帮助我解决了这个问题.不知道为什么,但是当删除其他图

  10. xcode – 了解iPhone分辨率

    我正在使用phonegap将一个非常简单的html5页面导出到iphone应用程序并遇到这个愚蠢的问题.iPhone分辨率为960×640.当我将画布设置为那些尺寸时,它似乎太大了.这是为什么?我怎样才能利用iphone4的全高清功能.如果我将画布设置为较旧的iPhone,似乎画布适合全屏.将视口设置为这样的东西似乎有效,但是这会是性能损失吗?

随机推荐

  1. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. Android单选按钮RadioButton的使用详解

    今天小编就为大家分享一篇关于Android单选按钮RadioButton的使用详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

  3. 解决android studio 打包发现generate signed apk 消失不见问题

    这篇文章主要介绍了解决android studio 打包发现generate signed apk 消失不见问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  4. Android 实现自定义圆形listview功能的实例代码

    这篇文章主要介绍了Android 实现自定义圆形listview功能的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. 详解Android studio 动态fragment的用法

    这篇文章主要介绍了Android studio 动态fragment的用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. Android用RecyclerView实现图标拖拽排序以及增删管理

    这篇文章主要介绍了Android用RecyclerView实现图标拖拽排序以及增删管理的方法,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下

  7. Android notifyDataSetChanged() 动态更新ListView案例详解

    这篇文章主要介绍了Android notifyDataSetChanged() 动态更新ListView案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

  8. Android自定义View实现弹幕效果

    这篇文章主要为大家详细介绍了Android自定义View实现弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. Android自定义View实现跟随手指移动

    这篇文章主要为大家详细介绍了Android自定义View实现跟随手指移动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. Android实现多点触摸操作

    这篇文章主要介绍了Android实现多点触摸操作,实现图片的放大、缩小和旋转等处理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部