当前位置: 首页 > java >正文

Android framework 问题记录

一、休眠唤醒,很快熄屏

1.1 问题描述

机器休眠唤醒后,没有按照约定的熄屏timeout 进行熄屏,很快就熄屏(约2s~3s左右)

1.2 原因分析:

抓取相关log,打印休眠背光 相关调用栈

//具体打印调用栈直接从网上找即可,这里checkout了,就随便贴一个
//在frameworks/base/services/core/java/com/android/server/power/PowerManagerService.java的isBeingKeptAwakeLocked 函数里 加入如下
Log.e("TAG", Log.getStackTraceString(new Exception("Stack trace")));

根据打印调用栈 对比正常情况,可以得知多出如下打印

java.lang.Throwableat com.android.server.power.PowerManagerService.isBeingKeptAwakeLocked(PowerManagerService.java:2909)at com.android.server.power.PowerManagerService.isItBedTimeYetLocked(PowerManagerService.java:2887)at com.android.server.power.PowerManagerService.updateWakefulnessLocked(PowerManagerService.java:2843)at com.android.server.power.PowerManagerService.updatePowerStateLocked(PowerManagerService.java:2152)at com.android.server.power.PowerManagerService.userActivityInternal(PowerManagerService.java:1698)at com.android.server.power.PowerManagerService.onFlip(PowerManagerService.java:1086)at com.android.server.power.PowerManagerService.$r8$lambda$q7dp6tNnllSjuO6t2c5KypV49H8(Unknown Source:0)at com.android.server.power.PowerManagerService$$ExternalSyntheticLambda1.accept(Unknown Source:8)at com.android.server.power.FaceDownDetector.faceDownDetected(FaceDownDetector.java:297)at com.android.server.power.FaceDownDetector.onSensorChanged(FaceDownDetector.java:284)at android.hardware.SystemSensorManager$SensorEventQueue.dispatchSensorEvent(SystemSensorManager.java:886)at android.os.MessageQueue.nativePollOnce(Native Method)at android.os.MessageQueue.next(MessageQueue.java:335)at android.os.Looper.loopOnce(Looper.java:161)at android.os.Looper.loop(Looper.java:288)at com.android.server.SystemServer.run(SystemServer.java:922)at com.android.server.SystemServer.main(SystemServer.java:618)at java.lang.reflect.Method.invoke(Native Method)at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:568)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1023)

排查onSensorChanged中的faceDownDetected

    @Overridepublic void onSensorChanged(SensorEvent event) {if (event.sensor.getType() != Sensor.TYPE_ACCELEROMETER) return;if (!mActive || !mIsEnabled) return;final float x = event.values[0];final float y = event.values[1];mCurrentXYAcceleration.updateMovingAverage(x * x + y * y);mCurrentZAcceleration.updateMovingAverage(event.values[2]);// Detect movement// If the x, y acceleration is within the acc threshold for at least a length of time longer// than the time threshold, we set moving to true.final long curTime = event.timestamp;if (Math.abs(mCurrentXYAcceleration.mMovingAverage - mPrevAcceleration)> mAccelerationThreshold) {mPrevAcceleration = mCurrentXYAcceleration.mMovingAverage;mPrevAccelerationTime = curTime;}final boolean moving = curTime - mPrevAccelerationTime <= mTimeThreshold.toNanos();// If the z acceleration is beyond the gravity/z-acceleration threshold for at least a// length of time longer than the time threshold, we set isFaceDownForPeriod to true.final float zAccelerationThreshold =mFaceDown ? mZAccelerationThresholdLenient : mZAccelerationThreshold;final boolean isCurrentlyFaceDown =mCurrentZAcceleration.mMovingAverage < zAccelerationThreshold;final boolean isFaceDownForPeriod = isCurrentlyFaceDown&& mZAccelerationIsFaceDown&& curTime - mZAccelerationFaceDownTime > mTimeThreshold.toNanos();if (isCurrentlyFaceDown && !mZAccelerationIsFaceDown) {mZAccelerationFaceDownTime = curTime;mZAccelerationIsFaceDown = true;} else if (!isCurrentlyFaceDown) {mZAccelerationIsFaceDown = false;}if (!moving && isFaceDownForPeriod && !mFaceDown) {//已知是这个导致的,把这个func注释后,现象就消失了.//关注原因,是因为G-sensor导致的,关注到调试时,板子并非按整机方式进行放置,x、y会出现问题,//最终导致执行了faceDownDetected,因而导致了亮屏后快速熄屏。faceDownDetected();} else if (!isFaceDownForPeriod && mFaceDown) {unFlipDetected();}}

1.3 解决方案:

如1.2中所述,如果G-sensor 方向不正确,有可能会导致该问题,建议调整/校准g-sensor,而不是修改framework中的代码。

http://www.xdnf.cn/news/7218.html

相关文章:

  • Ubuntu开机自启服务
  • 【数据仓库面试题合集③】实时数仓建模思路与实践详解
  • InternLM 论文分类微调实践(XTuner 版)
  • Java设计模式之外观模式:从入门到精通(保姆级教程)
  • 基于Elasticsearch的搜索引擎简介
  • 【Android】一键创建Keystore + Keystore 参数说明 + 查询SHA256(JDK Keytool Keystore)
  • 【神经网络与深度学习】GAN 生成对抗训练模型在实际训练中很容易判别器收敛,生成器发散
  • 【物联网】 ubantu20.04 搭建L2TP服务器
  • 电脑安装程序报错写入注册表失败
  • 基于51单片机教室红外计数灯光控制—可蓝牙控制
  • 为什么wifi有信号却连接不上?
  • Oracle 数据库的默认隔离级别
  • 探索C++面向对象:从抽象到实体的元规则(上篇)
  • docker介绍与常用命令汇总
  • C语法备注01
  • 项目记录:「五秒反应挑战」小游戏的开发全过程
  • 「NameCraft · 幻想命名器」开发记:我和 CodeBuddy 的一次奇幻共创之旅
  • MySQL之函数
  • 洛谷U536262 井底之“鸡”
  • 初识 Redis
  • 云计算简介:从“水电”到“数字引擎”的技术革命
  • LeetCode 219.存在重复元素 II
  • OpenCV CUDA 模块中的矩阵算术运算-----在频域(复数频谱)中执行逐元素乘法并缩放的函数mulAndScaleSpectrums()
  • OSPF路由撤销及优化
  • 集成电路生产测试中CP针卡(Probe Card)简介
  • 深度强化学习 | 基于SAC算法的移动机器人路径跟踪(附Pytorch实现)
  • Redis学习打卡-Day4-Redis实现消息队列
  • 企业开发工具git的使用:从入门到高效团队协作
  • RabbitMQ通信模式(Simplest)Python示例
  • Codeforces 1017 Div4(ABCDEFG)