【相机开发问题总结】锁屏下相机资源释放问题
问题描述
系统锁屏时间设置了15秒,有一个页面是人脸识别页面,会开启相机展示相机预览内容,并分析人脸结果,自动跳转到下一个页面。
问题出现在跳转页面之前,可能触发了锁屏,会导致息屏,息屏呢,同时会释放相机资源,释放人脸识别sdk,以便于两瓶再次恢复页面的时候,重新申请相机资源,而此时会出现app crash
问题分析
在自定义相机页面按HOME键时的执行流程:
程序运行->按HOME键;
Activity调用的顺序是onPause->onStop;
SurfaceView调用了surfaceDestroyed方法;。
然后再切回程序:
Activity调用的顺序是onRestart->onStart->onResume;
SurfaceView调用了surfaceCreated->surfaceChanged方法。
而对于锁屏,其执行流程则是:
Activity只调用onPause方法 ;
解锁后Activity调用onResume方法;
由此可见,问题所在是SurfaceView中surfaceholder.callback的所有方法都没有执行。
由于锁屏时,callback的回调方法没有执行,导致相机和预览的连接还没有断开,相机资源就被释放了,所以导致在重新申请相机资源时,系统报crash。根据上面的文档,推测是锁屏下系统并没有改变surfaceview的可见性,于是我尝试在onPause和onResume时通过手动设置surfaceview的visibile属性,结果发现可以正常触发回调函数了。由于在切后台或者锁屏时,用户本来就应该看不到surfaceview,因此这种手动更改surfaceview的可见性的方法,并不会对用户的体验造成影响。
问题解决
设置可见性,强制进入SurfaceView中surfaceholder.callback回调。
@Overrideprotected void onResume() {super.onResume();if(previewView != null){previewView.setVisibility(View.VISIBLE);}}@Overrideprotected void onPause() {super.onPause();if(previewView != null){previewView.setVisibility(View.INVISIBLE);}}