问题表现
项目中用开发的本地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