QCamera类介绍
QCamera类主要功能为提供方法对相机设备进行操作,比如可以获取相机的名称等具体信息,并操作相机设备的开启与关闭,以及获取当前设备连接的所有相机设备的列表。
使用问题
使用一下代码对相机设备进行操作(以下代码适用于当前设备之连接一台相机设备)
#include <QCamera>
QCamera *pCamera = new QCamera(this);
qDebug()<<pCamera->status()<<"step1";
pCamera->start();
qDebug()<<pCamera->status()<<"step2";
pCamera->stop();
qDebug()<<pCamera->status()<<"step3";
执行后打印结果为
QCamera::UnloadedStatus step1
QCamera::ActiveStatus step2
QCamera::LoadedStatus step3
从结果我们可以看出初次初始化的pCamera其状态为"未加载",当我们调用start()方法后,会将状态变为“有效”,也就是开启相机设备。并且可以获取视频数据,当调用stop()方法后,其状态变为"已加载",表示此时相机加载成功可以进行使用。
上述操作看似一切正常,但在实际使用中,相机设备可能会从外界关闭,此时相机的状态会变为QCamera::UnloadedStatus 但当我们继续调用stop方法后,其状态仍旧会被置为QCamera::LoadedStatus。
分析
查阅Qt的官方文档可以发现,stop方法在被调用时,没有去校验当前camera的状态,只是将当前状态强制置为QCamera::LoadedStatus,以下是文档的说明:
Stops the camera. The camera state is changed from QCamera::ActiveState to QCamera::LoadedState.
解决方法
既然stop()没有判断camera的状态,那我们手动判断一下当前camera的状态,是否满足stop调用的条件,如果此时状态异常则调用unload()方法,然后重新初始化camera。
if(pCamera->status() == QCamera::ActiveStatus)
pCamera->stop();
else
pCamera->unload();
if(pCamera != nullptr){
pCamera->stop();
delete pCamera;
pCamera = nullptr;
}
pCamera = new QCamera(this);
以上为实现代码。