熄屏(待机)状态下打开相机失败的解决

文章描述了一个项目中遇到的问题,即通过后台服务在熄屏状态下无法正常录像。经过分析,确定是相机下电导致的。为解决这个问题,文中提出了一个终极解决方案,即修改源码,使得熄屏时相机不下电,从而在熄屏状态下能正常工作并保持低功耗。

问题表现

项目中用开发的本地apk去打开相机并录像是正常的。但通过后台服务进行录像就失败了。

分析原因

我们排除了服务被杀死以及权限等可能。因为设备开机后自动进入熄屏状态(或者说待机状态),而用demo预览会先解锁和点亮屏幕。因此是熄屏(待机)导致的打开相机失败。

初期解决方案

首先我们是想办法不让设备熄屏。具体做法是删除系统的systemUi模块,这样开机后就不会自动进入熄屏状态。并且修改系统默认的屏幕超时时间改为最大值。

新的问题

虽然一直亮屏可以正常拉流,但是我们停止录像后需要先熄屏,才能进入低功耗状态,这样可以最大限度的保证降低功耗。所以最好的解决方案是能在熄屏状态下打开相机正常拉流。

终极解决方案。

熄屏状态下相机无法使用的原因是相机会下电,这个是电源管理决定的。要实现熄屏后相机不下电需对源码进行如下修改。

  • 在源码的 /Vendor/qcom/proprietary/mm-camera/mm-camera2/media-controller/modules/sensors/sensor/libs/ov32a1q/ov32a1q_lib.h文件如下位置添加代码
static sensor_lib_t sensor_lib_ptr =
{
  .sensor_slave_info =
  {
    。。。
     .power_setting_array =
    {
      .power_setting_a =
      {
        {
          。。。
        },
        // 添加这段关键代码,表示休眠时camera不下电。 
        {
          .seq_type = CAMERA_POW_SEQ_VREG,
          .seq_val = CAMERA_VIO,
          .config_val = 0,
          .delay = 5,
        },
        {
        。。。
        }
      }// n+1表示在原来的基础上加1
      .size=n+1
        
在手机处于 **待机状态**(即休眠状态)时,系统会进入低功耗模式,大部分后台服务和应用会被限制运行,以节省电量。Android 系统为此设计了多种机制来控制应用在状态下的行为。 --- ### ✅ 待机状态下的行为限制: 1. **Doze 模式(Android 6.0 及以上)** - 当设备、电池电量不低、且未连接充电器时,系统会进入 Doze 模式。 - 在 Doze 模式下: - 网络访问被限制 - 后台服务暂停 - AlarmManager 闹钟被延迟 - JobScheduler 和 WorkManager 的任务会被合并执行 2. **App Standby 模式** - 针对长时间未使用的应用,系统会限制其后台活动。 3. **唤醒窗口(Maintenance Windows)** - 在 Doze 模式下,系统会定期放短暂的“维护窗口”,允许应用执行被延迟的任务。 - 初始窗口可能每几分钟一次,之后逐渐延长到数小时。 --- ### 🧠 如果你在状态下发现任务被调度(如 16h 的任务): - 这是 **正常行为**,尤其是系统服务(如 `CameraStatsJobService`)。 - 任务会在 Doze 模式允许的维护窗口中执行,不会立即唤醒设备。 - 实际执行时间可能会有延迟,系统会根据设备状态动态调整。 --- ### 📊 如何查看状态下后台任务的执行情况: 1. **使用 adb 命令查看 JobScheduler 状态**: ```bash adb shell dumpsys jobscheduler ``` 2. **查看设备唤醒记录**: ```bash adb shell dumpsys power ``` 3. **使用 Battery Historian 工具分析耗电和唤醒行为** 可以生成详细的图表,分析设备在状态下的唤醒情况。 --- ### 🔍 举例说明: 如果你设置了如下任务: ```java new PeriodicWorkRequest.Builder(MyWorker.class, 16, TimeUnit.HOURS) ``` 在状态下: - 任务不会立刻执行 - 会被系统延迟到下一个维护窗口中执行 - 实际执行间隔可能大于 16 小时,取决于 Doze 模式调度 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值