由于写论文需要,需要用手机加速度采集数据,关于android加速度传感器的介绍网上一抓一大把,但大多都是大同小异,跟官网文档差不多。自己写了个取加速度传感器的APK,发现数据有点不对劲,原理屏幕一关后,系统就自动把各种传感器给停掉了,网上找了很久,发现一些可用的资源。

1、查看手机是否支持锁屏后继续运行传感器

  有些手机可以支持后台取传感器数据,有些手机不行,这与硬件厂商具体实现有关,像GPS这些传感器都是很耗电的,厂商也是出于电源管理的考虑,这里是一个不完全列表,总结哪些软件支持屏幕关闭后依然运行传感器。这里更有一款APK(Accelerometer Frequency)专门查看你的手机是否支持。

  如果你的手机不支持,那还是不要折腾了,换了设备试试。

2、实现方法

  我主要参考了

  1)http://blog.kozaxinan.com/2012/08/using-accelerometer-when-screen-off_16.html

  2)http://stackoverflow.com/questions/9982433/android-accelerometer-not-working-when-screen-is-turned-off

  星期天我按他们的方法实现了一下,主要思想就是申请锁屏后CPU不休眠:

PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);  PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "My Tag");
wl.acquire();
..
wl.release();

  我把service写成activity的一个内部类,而我把申请电源管理的命令放在了service的Oncreate()方法里,之前一直纳闷,明明我的手机检测支持的,锁屏后还是没有取数据,而且连接USB时,锁屏后继续取加速度传感器数据,而拔掉USB后就停了,到处找原因,后来才发现service的OnCreate()方法没执行,坑了我。

  丑又丑点,我把电源管理申请放在了Activity的onCreate()方法中,结果可行了,把代码放上来。

 public class AccleratePersist extends Activity {
private static final String TAG = "AccleratePersist";
private static final int DELAY = SensorManager.SENSOR_DELAY_NORMAL;
private static boolean STOP = true;// 开始暂停按钮 private SensorManager mSensorManager;
private WakeLock mWakeLock;
private TextView accView;// 显示加速度值
private StringBuilder builder = new StringBuilder();
private long lastTimestamp = 0; private PersistService mySerivece; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
accView = (TextView) this.findViewById(R.id.accValue);
final Button stopButton = (Button) this.findViewById(R.id.stopButton);// 停止测量按钮
final Button clearButton = (Button) this.findViewById(R.id.clear); // 清除数据 View.OnClickListener onClickListener = new View.OnClickListener() { @Override
public void onClick(View view) {
if (view == stopButton) {
STOP = !STOP;
setMeasure();
} else if (view == clearButton) {
builder = new StringBuilder();
accView.setText("");
}
} @SuppressLint("Wakelock")
private void setMeasure() {
if (STOP) {// 停止键按下后,取消监听,是否电源
stopButton.setText("继续");
mSensorManager.unregisterListener(mySerivece);
mWakeLock.release();
} else {
stopButton.setText("停止");
mWakeLock.acquire();// 屏幕熄后,CPU继续运行
mSensorManager
.registerListener(
mySerivece,
mSensorManager
.getDefaultSensor(Sensor.TYPE_ACCELEROMETER),
DELAY);
}
} };
clearButton.setOnClickListener(onClickListener);
stopButton.setOnClickListener(onClickListener);
mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
mySerivece = new PersistService();
PowerManager manager = (PowerManager) getSystemService(Context.POWER_SERVICE);
mWakeLock = manager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, TAG);// CPU保存运行
IntentFilter filter = new IntentFilter(Intent.ACTION_SCREEN_ON);// 屏幕熄掉后依然运行
filter.addAction(Intent.ACTION_SCREEN_OFF);
registerReceiver(mySerivece.mReceiver, filter);
} class PersistService extends Service implements SensorEventListener { private float[] accValue = new float[3]; public BroadcastReceiver mReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) { if (!STOP
&& !intent.getAction().equals(Intent.ACTION_SCREEN_OFF)) {
return;
}
if (mSensorManager != null) {//取消监听后重写监听,以保持后台运行
mSensorManager.unregisterListener(PersistService.this);
mSensorManager
.registerListener(
PersistService.this,
mSensorManager
.getDefaultSensor(Sensor.TYPE_ACCELEROMETER),
SensorManager.SENSOR_DELAY_NORMAL);
} } }; public void onAccuracyChanged(Sensor sensor, int accuracy) {
Log.i(TAG, "PersistService.onAccuracyChanged().");
} public void onSensorChanged(SensorEvent sensorEvent) {
if (sensorEvent.sensor.getType() == Sensor.TYPE_ACCELEROMETER) {
Log.i(TAG, "PersistService.TYPE_ACCELEROMETER.");
accValue = sensorEvent.values;
for (int i = 0; i < 3; i++) {
builder.append((int) accValue[i]);
builder.append(",");
}
builder.append((sensorEvent.timestamp - lastTimestamp) / 1000000);// 采样时间差
builder.append("\n");
accView.setText(builder.toString());
lastTimestamp = sensorEvent.timestamp;
} }
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
} }
}

 记得加一个权限:  <uses-permission android:name="android.permission.WAKE_LOCK" />

  有问题欢迎交流。

转载请注明出处:http://www.cnblogs.com/fengfenggirl

Android--保持加速度传感器在屏幕关闭后运行(收集)的更多相关文章

  1. Android--保持加速度传感器在屏幕关闭后运行

    由于写论文需要,需要用手机加速度采集数据,关于android加速度传感器的介绍网上一抓一大把,但大多都是大同小异,跟官网文档差不多.自己写了个取加速度传感器的APK,发现数据有点不对劲,原理屏幕一关后 ...

  2. Android 使用加速度传感器实现摇一摇功能及优化

    如有转载,请声明出处: 时之沙: http://blog.csdn.net/t12x3456 目前很多应用已经实现了摇一摇功能,这里通过讲解该功能的原理及实现回顾一下加速度传感器的使用: 1.首先获得 ...

  3. 玩转Android之加速度传感器的使用,模仿微信摇一摇

    Android系统带的传感器有很多种,最常见的莫过于微信的摇一摇了,那么今天我们就来看看Anroid中传感器的使用,做一个类似于微信摇一摇的效果. OK ,废话不多说,我们就先来看看效果图吧: 当我摇 ...

  4. Android的加速度传感器模拟摇一摇的效果-android学习之旅(66)

    主要介绍一下android的加速传感器的简单用法,模拟摇一摇 ,如果x,y,z三个方向的加速度超过了15,就会弹出Toast,当然你可以设置更复杂的策略,比如判断间隔 代码如下 public clas ...

  5. Android加速度传感器

    Android加速度传感器 效果图 手机平放桌面的两张截屏,数据一直在刷新 源码 下载地址(Android Studio工程):http://download.csdn.net/detail/q487 ...

  6. Android的重力传感器(3轴加速度传感器)简单实例

    重力感应主要是依靠手机的加速度传感器(accelerometer)来实现 在Android的开发中一共有八种传感器但是不一定每一款真机都支持这些传感器.因为很多功能用户根本不care的所以可能开发商会 ...

  7. Android根据加速度和地磁场传感器实现自动对焦

    在相机预览开始后新建AutoFocusManage对象即可,传入context和camera. 注意,在停止预览或者关闭相机时需调用方法中unregisterListener方法. 目前实现是当前方向 ...

  8. Android加速度传感器实现“摇一摇”,带手机振动

    由于代码有点多,所以就分开写了,注释还算详细,方便学习 Activity package com.lmw.android.test;   import android.app.Activity; im ...

  9. android:windowSoftInputMode属性;界面关闭后软键盘不隐藏的解决方法;

    stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置 stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activit ...

随机推荐

  1. python全栈开发day48-jqurey自定义动画,jQuery属性操作,jQuery的文档操作,jQuery中的ajax

    一.昨日内容回顾 1.jQuery初识 1).使用jQuery而非JS的六大理由 2).jQuery对象和js对象转换 3).jQuery的两大特点 4).jQuery的入口函数三大写法 5).jQu ...

  2. P2502 [HAOI2006]旅行 并查集

    题目描述 Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N个景点(编号为1,2,3,…,N),这些景点被M条道路连接着,所有道路都是双向的,两个景点之间可能有多条道路.也 ...

  3. Unity 之 中文乱码

    更改 C#脚本的编码格式: 文件 -> 高级保存选项 -> Unicode

  4. HTTP协议学习笔记(二)

    HTTP协议学习笔记(二) 1.HTTP报文 HTTP报文:用于HTTP协议交互的信息.请求报文:请求端(客户端)的HTTP报文叫做请求报文.响应报文:响应端(服务端)的HTTP报文叫做响应报文. H ...

  5. 004.Kickstart部署之FTP架构

    一 准备 1.1 完整架构:Kickstart+DHCP+VSFTP+TFTP+PXE 1.2 组件应用 Kickstart服务端IP:172.24.8.12 DHCP:提供客户端IP,网关,镜像路径 ...

  6. VB.NET只允许打开一个实例

    If UBound(Diagnostics.Process.GetProcessesByName(Diagnostics.Process.GetCurrentProcess.ProcessName)) ...

  7. Bzoj4598: [Sdoi2016]模式字符串 点分治 哈希

    国际惯例的题面:这种关于树上路径的题,我也没什么好办法,只好点分治.考虑当前分治重心为root,如何统计经过分治重心的路径的答案.我们令prf[i]表示某个点到root的路径(不含root)已经循环匹 ...

  8. [HihoCoder1369]网络流一·Ford-Fulkerson算法

    思路: 最大流模板. #include<queue> #include<cstdio> #include<cctype> #include<vector> ...

  9. rabbitmq使用(四)

    In the previous tutorial we built a simple logging system. We were able to broadcast log messages to ...

  10. angular2项目关于Echarts图表的处理

    在NiceFish项目中关于Echarts组件和指令是直接注册在appModule根模块中的,这样路由只需这样写就可以让浏览器加载图标组件: 在chart组件视图中: <div class=&q ...