由于写论文需要,需要用手机加速度采集数据,关于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. php 发送超大数据处理

    set_time_limit(0);//设置永不超时 ignore_user_abort(); //设置客户端断开,继续处理 //总数 $allusercount= $this->gamedb_ ...

  2. BZOJ1179 [Apio2009]Atm Tarjan 强连通缩点 动态规划

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1179 题意概括 有一个有向图,每一个节点有一个权值,其中有一些结束点. 现在,你要从S出发,到达任 ...

  3. [OpenCV-Python] OpenCV 中图像特征提取与描述 部分 V (一)

    部分 V图像特征提取与描述 OpenCV-Python 中文教程(搬运)目录 29 理解图像特征 目标本节我会试着帮你理解什么是图像特征,为什么图像特征很重要,为什么角点很重要等.29.1 解释 我相 ...

  4. (转)细说JDK动态代理的实现原理

    原文:http://blog.csdn.net/mhmyqn/article/details/48474815 关于JDK的动态代理,最为人熟知的可能要数Spring AOP的实现,默认情况下,Spr ...

  5. python tkinter-消息框、对话框、文件对话框

    python tkinter-消息框.对话框.文件对话框   消息框 导入 import tkinter import tkinter.messagebox #这个是消息框,对话框的关键 提示消息框 ...

  6. hdu 1166 敌兵布阵【线段树】(求给定区间和)

    题目链接:https://vjudge.net/contest/182746#problem/B       敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)   ...

  7. HDU 2602 Bone Collector 骨头收集者【01背包】

    题目链接:https://vjudge.net/contest/103424#problem/A 题目大意: 第一行输入几组数据,第二行第一个数字代表物体个数,第二个数代表总体积.需要注意的是,第三排 ...

  8. Qt学习之信号与槽(一)

    Qt学习之信号与槽(一) 目录 QT的信号与槽机制 在窗口的UI设计中操作添加信号和槽     QT的信号与槽机制   QT的两种机制 在Qt和PyQt中有两种通信机制: 低级事件处理机制(low-l ...

  9. RabbitMQ 初学及其深入学习推荐的一些文章

    记录一下学习RabbitMQ过程中,收获比较大的一些文章: 什么都别说,先把这6个Demo 玩一遍 https://www.rabbitmq.com/getstarted.html 大佬1号 http ...

  10. SQL server学习(五)T-SQL编程之存储过程

    周五了,祝大家周末愉快. 之前一直在写SQL server的分享,今天再来个T-SQL编程中的存储过程. 存储过程 存储过程(procedure)类似于C语言中的函数,用来执行管理任务或应用复杂的业务 ...