显示gsensor即时数据的apk 用gsensor来判断手机的静和动

article/2025/10/6 3:03:50

即时显示gsensor的数据,可以在调试重力感应器驱动和测试手机性能时起到很好的作用。类似的,SensorEventListener还可以用在其他感应器的场合,比如光感应、地磁感应。这里用两种方式来完成读取并显示gsensor数据的功能,一种是activity和SensorEventListener监听分离,在不同类中完成;另一种是在同一个activity中完成(*)。

(1)activity和SensorEventListener监听分离

        Acvitivity启动时初始化SensorEventListener,在退出activity时注销Listener。

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. import android.os.Bundle;  
  2. import android.app.Activity;  
  3.   
  4. import android.util.Log;  
  5. import android.view.Menu;  
  6. import android.widget.TextView;  
  7.   
  8. public class Activity01 extends Activity {  
  9.     private final String TAG = "zhangcheng";  
  10.     SensorListenerTest sensorListenerTest;        //sensor监听类,同一个包里的类被调用时不需要import  
  11.     @Override  
  12.     public void onCreate(Bundle savedInstanceState) {  
  13.         super.onCreate(savedInstanceState);  
  14.         setContentView(R.layout.activity_activity01);  
  15.         sensorListenerTest = new SensorListenerTest(this);     //监听类的构造函数,activity通过this句柄跟监听类绑定  
  16.     }  
  17.   
  18.     protected void onResume(){  
  19.         super.onResume();  
  20.         sensorListenerTest.enableSensor();          //activity启动后使能sensor监听  
  21.     }  
  22.       
  23.     protected void onStop(){  
  24.         super.onStop();  
  25.         sensorListenerTest.disableSensor();                    //出于系统控制原因,在退出activity时注销监听  
  26.     }  
  27. }  

      SensorListenerTest类,监听gsensor数据。注意import android.hardware.sensor的四个类。

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. import android.content.Context;  
  2. import android.hardware.Sensor;  
  3. import android.hardware.SensorEvent;  
  4. import android.hardware.SensorEventListener;  
  5. import android.hardware.SensorManager;  
  6. import android.util.Log;  
  7.   
  8. public class SensorListenerTest implements SensorEventListener   {   //使用listsen的接口,所以必须实现接口的两个成员函数  
  9.     private final String TAG = "zhangcheng";  
  10.     private SensorManager mSensorManager;  
  11.     private Sensor sensor;  
  12.     private float mLastX,mLastY,mLastZ;    // X Y Z三轴数据  
  13.     private Context mContext;  
  14.       
  15.     public SensorListenerTest(Context context){  
  16.         mContext = context;  
  17.     }  
  18.       
  19.     public void enableSensor(){  
  20.         mSensorManager = (SensorManager)mContext.getSystemService(Context.SENSOR_SERVICE);   //获得系统的sensor服务  
  21.         sensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);     //具体要操作的sensor类型  
  22.           
  23.         if(mSensorManager == null){  
  24.             Log.i(TAG,"sensor not supported");  
  25.         }  
  26.         mSensorManager.registerListener(this, sensor, SensorManager.SENSOR_DELAY_NORMAL);  //以普通采样率注册监听器  
  27.     }  
  28.       
  29.     public void disableSensor(){  
  30.         if(mSensorManager != null){  
  31.             mSensorManager.unregisterListener(this);       //注销监听器  
  32.             mSensorManager = null;  
  33.         }  
  34.     }  
  35.       
  36.     public void onAccuracyChanged(Sensor arg0, int arg1){         
  37.     }  
  38.       
  39.     public void onSensorChanged(SensorEvent event){     //必须完成SensorEventListener的响应函数  
  40.         if(event.sensor == null){  
  41.             return;  
  42.         }  
  43.           
  44.         if(event.sensor.getType() == Sensor.TYPE_ACCELEROMETER){  
  45.             mLastX = event.values[0];  
  46.             mLastY = event.values[1];  
  47.             mLastZ = event.values[2];        //得到XYZ三轴数据  
  48.               
  49.             String sX = String.valueOf(mLastX);  
  50.             String sY = String.valueOf(mLastY);  
  51.             String sZ = String.valueOf(mLastZ);    //利用String的成员函数valueOf快速将float型转成String型  
  52.               
  53.             Log.i(TAG,"mLastX == "+sX);  
  54.             Log.i(TAG,"mLastY == "+sY);  
  55.             Log.i(TAG,"mLastZ == "+sZ);       //在Logcat中即时提示读出的gsensor数据  
  56.         }  
  57.     }  
  58. }  

       运行结果诸如在Logcat中显示:

01-02 23:28:41.634: I/zhangcheng(2238): mLastX == -0.181
01-02 23:28:41.634: I/zhangcheng(2238): mLastY == 0.143
01-02 23:28:41.634: I/zhangcheng(2238): mLastZ == 9.979
01-02 23:28:41.808: I/zhangcheng(2238): mLastX == -0.143
01-02 23:28:41.808: I/zhangcheng(2238): mLastY == 0.172
01-02 23:28:41.808: I/zhangcheng(2238): mLastZ == 10.008

(2)单一activity完成监听。上述方法完成后在Logcat中显示读数不太直观,可以直接在activity上用textview来显示。

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. import android.hardware.Sensor;  
  2. import android.hardware.SensorEvent;  
  3. import android.hardware.SensorEventListener;  
  4. import android.hardware.SensorManager;  
  5. import android.os.Bundle;  
  6. import android.app.Activity;  
  7. import android.content.Context;  
  8. import android.util.Log;  
  9. import android.view.Menu;  
  10. import android.widget.TextView;  
  11.   
  12. public class Activity01 extends Activity implements SensorEventListener{     //在继承activity类的同时使用listsen接口  
  13.     private final String TAG = "zhangcheng";  
  14.     private SensorManager mSensorManager;  
  15.     private Sensor sensor;  
  16.     private float mLastX,mLastY,mLastZ;  
  17.     private String sX,sY,sZ;  
  18.       
  19.     private TextView mTextViewX = null;  
  20.     private TextView mTextViewY = null;  
  21.     private TextView mTextViewZ = null;  
  22.     @Override  
  23.     public void onCreate(Bundle savedInstanceState) {  
  24.         super.onCreate(savedInstanceState);  
  25.         setContentView(R.layout.activity_activity01);  
  26.           
  27.         mTextViewX = (TextView)findViewById(R.id.TextView1);  
  28.         mTextViewY = (TextView)findViewById(R.id.TextView2);  
  29.         mTextViewZ = (TextView)findViewById(R.id.TextView3);    //绑定显示控件句柄  
  30.           
  31.         mSensorManager = (SensorManager)getSystemService(Context.SENSOR_SERVICE);  
  32.         sensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);  
  33.           
  34.         if(mSensorManager == null){  
  35.             Log.i(TAG,"sensor not supported");  
  36.     }  
  37.     mSensorManager.registerListener(this, sensor, SensorManager.SENSOR_DELAY_NORMAL);  
  38.      }  
  39.       
  40.     public void onAccuracyChanged(Sensor arg0, int arg1){         
  41.     }  
  42.       
  43.     public void onSensorChanged(SensorEvent event){          //在activity中完成该接口函数  
  44.         if(event.sensor == null){  
  45.             return;  
  46.         }  
  47.           
  48.         if(event.sensor.getType() == Sensor.TYPE_ACCELEROMETER){  
  49.             mLastX = event.values[0];  
  50.             mLastY = event.values[1];  
  51.             mLastZ = event.values[2];  
  52.               
  53.             sX = String.valueOf(mLastX);  
  54.             sY = String.valueOf(mLastY);  
  55.             sZ = String.valueOf(mLastZ);  
  56.               
  57.             mTextViewX.setText(sX);  
  58.             mTextViewY.setText(sY);  
  59.             mTextViewZ.setText(sZ);   //由于该接口函数不断刷新,所以可以把控件显示函数放在这里显示  
  60.         }  
  61.     }  
  62.       
  63.     protected void onStop(){                          //同样在退出activity时要注销监听  
  64.         super.onStop();  
  65.         if(mSensorManager != null){  
  66.             mSensorManager.unregisterListener(this);  
  67.             mSensorManager = null;  
  68.         }  
  69.     }  
  70. }  

       该函数可在一个activity中即时显示gsensor数据,方便查看。 

========================================================================================================================

        现实中的很多手机应用会到gsensor这个感应器,比如手机的倾斜角度,手机的运动方向和加速度。如果我们要在一个服务中通过监控gsensor的数据来判断手机的静止或者运动,进而作相应处理。流程是:原始数据 -> 低通滤波 -> 重力在3个方向的分量 -> 判断即可。以下步骤:

(1)服务定义时要implements SensorEventListener接口,以下是一些变量。

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. private SensorManager mSensorManager;          //sensor管理器  
  2. private Sensor sensor;                
  3. private float[] curGravity = new float[3];  //xyz重力数据  
  4. private lowPassFilter filter1;  
  5. private lowPassFilter filter2;  
  6. private firLowPassFilter firFilter1;  
  7. private firLowPassFilter firFilter2;  
  8. private firLowPassFilter firFilter3;        //低通滤波的一些类的内容  
  9. private int mAccSkipCnt = 0;        //抖动计数  
  10. private static final int __ACC_SKIP_SAMPLES = 30;   // 跳过刚开始的若干个加速度采样  
  11. private int _NTAPS = 6;  
  12. private double[] h = {  
  13.         0.125514644795420960,  
  14.         0.414388923238107440,  
  15.         -0.013420976983735622,  
  16.         -0.013420976983735622,  
  17.         0.414388923238107440,  
  18.         0.125514644795420960  
  19.         };  
  20. private boolean DeviceFlating = false;  //手机是否平躺了  

(2)在服务onCreate函数中定义sensor相关变量,并设置低通滤波的一些系数

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. mSensorManager = (SensorManager)getSystemService(SENSOR_SERVICE);    
  2. sensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);    
  3. mSensorManager.registerListener(this, sensor, SensorManager.SENSOR_DELAY_NORMAL);   
  4. filter1 = new lowPassFilter(120);  
  5. filter2 = new lowPassFilter(00.9f);             
  6. firFilter1 = new firLowPassFilter(_NTAPS, h);  
  7. firFilter2 = new firLowPassFilter(_NTAPS, h);  
  8. firFilter3 = new firLowPassFilter(_NTAPS, h);  

(3)SensorEventListener接口中要完成的成员函数

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. public void onSensorChanged(SensorEvent event){      
  2.         if(event.sensor == null){    
  3.             return;    
  4.         }    
  5.         mIsSmartStayOn= Settings.System.getInt(cr,"isSmartStayEnabled",0) == 1 ? true : false;//人眼识别打开时才启动重力监听  
  6.         if(mIsSmartStayOn == true){  
  7.             Log.i(TAG,"gsensor respond");  
  8.               
  9.             curGravity[0] = (float)firFilter1.filter1((double)event.values[0]);  
  10.             curGravity[1] = (float)firFilter2.filter1((double)event.values[1]);  
  11.             curGravity[2] = (float)firFilter3.filter1((double)event.values[2]);  
  12.             curGravity = filter1.SMAFilter(curGravity);     //取得三轴重力数据并滤波处理  
  13.               
  14.             if(mAccSkipCnt < __ACC_SKIP_SAMPLES) {  
  15.                 mAccSkipCnt++;  
  16.                 return ;                    //待gsensor读数稳定才继续后面的处理  
  17.             }  
  18.   
  19.             float[] linearAcc = new float[]{  
  20.                     event.values[0]-curGravity[0],  
  21.                     event.values[1]-curGravity[1],  
  22.                     event.values[2]-curGravity[2]  
  23.             };  
  24.             double linearLen = KonkaGeneHelper.vecLength(linearAcc);    //三轴数据平方和相加开根号的结果  
  25.             Log.w(TAG,"linearLen is "+linearLen);  
  26.             if(linearLen < 0.6f && DeviceFlating == false){  //如果手机一开始没有静止并且linearLen小于0.6  
  27.                 DeviceFlating = true;           //手机趋近于静止状态(不论方向)  
  28.             }  
  29.             if(linearLen > 1.0f && DeviceFlating == true && pm.isScreenOn() == true){  
  30.                 DisplayEyeIcon(1);          //如果手机静止的,并且gsensor检测到linearLen大于1且手机亮屏                 freshDetect();  
  31.                 DeviceFlating = false;      //马上启动人眼识别  
  32.             }             
  33.         }         
  34.     }  

通过以上过程,可以参考其中的重力计算和判断流程用在其他场合。

 

参考原文:http://www.cnblogs.com/snowdrop/articles/1802092.html


http://chatgpt.dhexx.cn/article/1PZ9W7Qm.shtml

相关文章

老化测试Gsensor失败分析

在log中搜Gsensor可以看到如下&#xff1a; 在Y:\1\18045c1老化\bug127302c1_slog\last_log\2015-01-01-06-19-23\android\0-events-06-19-24.log中搜到如下&#xff1a; 行号 500 - 01-01 06:36:08.996 664 2050 I am_create_activity: [0,509924699,15,com.wingtech.runin…

MTK 9.0平台调试gsensor

MTK 9.0平台调试gsensor ----型号为&#xff1a;stk8baxx 1 查看原理图可以知道stk8baxx重力传感器 使用i2c1通道进行通讯&#xff0c;由于该重力传感器是不使用中断模式的进行触发的&#xff0c;所以不需要配置中断引脚。由此可以配置stk8baxx重力传感器的dts dts文件配置如…

APK无法识别gsensor问题剖析

APK无法识别gsensor问题的原因有很多&#xff0c;这里只是提供一条思路&#xff0c;解决现有项目遇到的问题。 1、确保驱动层可以工作。 2、打印LOGCAT数据&#xff0c;分析sensorservice流程 1、移植流程&#xff1a; 步骤&#xff1a;移植gsensor驱动&#xff0c;mc3413&am…

mtk平台gsensor,msensor方向确定方法

在gsensor和msensor驱动调试中&#xff0c;一个很重要的参数就是direction。 direction与芯片、layout和结构三者结合&#xff0c;才能最终确定该参数值。 mtk平台中该参数的示意图 在mtk10.0的kernel中提供了一个简单的调试接口&#xff0c;用于确认该参数值。 内核节点 /…

Gsensor驱动概述

本文以Bma250驱动为例子&#xff0c;详细介绍Gsensor设计的一个模板。 gsensor驱动在系统中的层次如下图所示&#xff1a; 图中包含三个部分&#xff1a;hardware,driver, input&#xff1a; n Hardware&#xff1a;其实我们可以认为Gsensor也是一个I2C设备。整个Gsens…

MTK平台Android Gsensor数据校准与数据获取

http://blog.csdn.net/morixinguan/article/details/76850600 上节,写WIFI MAC地址的时候我们已经知道,MTKAndroid系统的Gsensor校准的数据其实也是存储在NVRAM中的,Gsensor隶属于传感器系统架构。 接下来我们来看下Gsensor校准的基准图像: 那么如何来校准Gsensor的X,Y,Z三…

android g sensor,android gsensor 休眠震动唤醒功能怎么实现

一、唤醒源 设备休眠后&#xff0c;通过触发唤醒源使设备恢复正常工作模式。设备唤醒源有多种&#xff0c;对于Android设备常见的就有PowerKey、来电唤醒、Alarm唤醒等。 唤醒源的实现处于内核空间&#xff0c;本文重点讨论下PowerKey作为唤醒源的具体实现。 二、PowerKey唤醒源…

G-sensor 介绍

转自&#xff1a;http://blog.chinaunix.net/uid-29595319-id-4200772.html G-sensor G-sensor是加速度传感器&#xff0c;可以通过其来获得分别来自三个不同轴向上的加速度用以通知上层应用做出相应处理。 由于地球的引力作用&#xff0c;gsensor平放时&#xff0c;Z轴方向能…

G-sensor概述及常用概念整理【转】

本文转载自:http://www.jianshu.com/p/d471958189a0?nomobile=yesG 本文对G-sensor进行整理,先介绍G-sensor的一些基本概念,再具体讲解BOSCH、ST、ADI三家的G-sensor,其中BOSCH的G-sensor重点讲BMA222E,ST的G-sensor重点讲LIS2DH12,ADI的G-sensor具体讲ADXL362。 一、G-…

初次使用Fleck+redis订阅发布实现学习小demo

https://www.cnblogs.com/SupPilot/p/10396333.html 首先安装Fleck的程序包添加引用下面是客户端代码&#xff1a; 客户端代码&#xff1a; 运行效果&#xff1a; 遇到的问题&#xff1a; Q:通常每个套接字地址(协议/网络地址/端口)只允许使用一次 A:是因为本萌新把WebSocke…

core+Fleck+redis

1.新建core版控制台程序引用 2.初始化websocket class Program { //客户端url以及其对应的Socket对象字典 static IDictionary<string, IWebSocketConnection> dic_Sockets new Dictionary<string, IWebSocketConnection>(); static …

[c#]使用Fleck实现简单的WebSocket含兼容低版本IE

WebSocket是html5的一种协议,那么就表示要使用websocket客户端的浏览器就要支持html5。 对于不支持的使用flash去解决。 Fleck源码地址 服务端采用的是Fleck,Fleck的好处就是简单方便,作者已经进行了完整的封装,可以根据自己情况进行修改 兼容低版本IE 使用flash实现兼容低…

C#实现WebSocket(基于Fleck-服务端和WebSocketSharp-客户端)

C#实现WebSocket(基于Fleck-服务端和WebSocketSharp-客户端) 官网&#xff1a;https://github.com/sta/websocket-sharp 客户端 private void btn_Connect_Click_1(object sender, EventArgs e){Console.WriteLine("Websocket Demo");WebSocket web new WebSocket(…

C#通过fleck实现wss协议的WebSocket多人Web实时聊天(附源码)

前言 最近想做一个Web版的即时聊天为后面开发的各项功能做辅助&#xff0c;就需要浏览器与服务器能够实时通讯。而WebSocket这种双向通信协议&#xff0c;就很合适用来实现这种需求。 本篇文章主要解决C#如何实现WebSocket服务端和Javascript客户端基于wss协议的安全通信问题。…

Asp.Net Mvc基于Fleck开发的多人网页版即时聊天室

一、项目的核心说明 1、Fleck这个是实现websocket一个比较简单第三方组件&#xff0c;它不需要安装额外的容器。本身也就几个接口可供调用。 2、项目是基于.net framework 4.7.2 &#xff0c;在vs2019上开发的&#xff0c;没试过在低版本上运行。但是代码上没怎么用到新特性&…

winfrom+Fleck 上传文件

最近这个项目要做一个Winfrom上传Execl到服务器。 就想到之前用Fleck做的一个小功能&#xff0c;但是客户端Web端的。百度吧&#xff0c;看有没有办法&#xff0c;开始找到fw4 &#xff0c;但是要引用它的dll&#xff0c;是可以&#xff0c;继续找了会结果找到ClientWebSocket…

C#工作总结(一):Fleck的WebSocket使用

一.引子&#xff08;Foreword&#xff09; 最近公司里面要做窗体和网页交互的功能。网上找了一下资料&#xff0c;这里做一个简单的扩充和整理&#xff0c;部分内容可能是摘自其他博客&#xff0c;这里会注明出处和原文地址供大家和自己日后查阅。 二.基础知识&#xff08;Foun…

Fleck说明文档翻译

CSDN ZslLoveMiwa的博客 Fleck Fleck是一个在C#中的WebSocket服务器端的一个实现.。分支自Nugget项目, Fleck不需要任何的继承、容器亦或是需要增加的引用就可以使用。 实例 下面是一个把客户端网页发来的消息回发到客户端的服务器程序。 var server new WebSocketServer(&q…

fleck 客户端_C#中使用Fleck实现WebSocket通信简例

Fleck是一个开源的使用C#封装的WebSocket服务端工具库。 一、服务端搭建 这里选择在.net core 2.1框架下新建了一个控制台程序 在项目里使用NuGet引入Fleck包 NuGet引入Fleck包 其它方式也可以,最终引入项目里都是Fleck.dll Fleck.dll 二、服务端实例 Github上的简单例子: 简…