提交 74e997f1 编写于 作者: A Alexander Alekhin

Merge pull request #7062 from kurenai:return_if_camera_disconnected

......@@ -204,6 +204,7 @@ DEFINE_GUID(IID_ICreateDevEnum,0x29840822,0x5b84,0x11d0,0xbd,0x3b,0x00,0xa0,0xc9
DEFINE_GUID(IID_IGraphBuilder,0x56a868a9,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70);
DEFINE_GUID(IID_IMPEG2PIDMap,0xafb6c2a1,0x2c41,0x11d3,0x8a,0x60,0x00,0x00,0xf8,0x1e,0x0e,0x4a);
DEFINE_GUID(IID_IMediaControl,0x56a868b1,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70);
DEFINE_GUID(IID_IMediaEventEx, 0x56a868c0,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70);
DEFINE_GUID(IID_IMediaFilter,0x56a86899,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70);
DEFINE_GUID(IID_ISampleGrabber,0x6b652fff,0x11fe,0x4fce,0x92,0xad,0x02,0x66,0xb5,0xd7,0xc7,0x8f);
DEFINE_GUID(LOOK_UPSTREAM_ONLY,0xac798be0,0x98e3,0x11d1,0xb3,0xf1,0x00,0xaa,0x00,0x37,0x61,0xc5);
......@@ -573,6 +574,8 @@ class videoInput{
int getVideoPropertyFromCV(int cv_property);
int getCameraPropertyFromCV(int cv_property);
bool isDeviceDisconnected(int deviceID);
private:
void setPhyCon(int deviceID, int conn);
void setAttemptCaptureSize(int deviceID, int w, int h,GUID mediaType=MEDIASUBTYPE_RGB24);
......@@ -2309,6 +2312,27 @@ int videoInput::getCameraPropertyFromCV(int cv_property){
return -1;
}
bool videoInput::isDeviceDisconnected(int deviceNumber)
{
if (!isDeviceSetup(deviceNumber)) return true;
long evCode;
LONG_PTR param1, param2;
bool disconnected = false;
while (S_OK == VDList[deviceNumber]->pMediaEvent->GetEvent(&evCode, &param1, &param2, 0))
{
DebugPrintOut("Event: Code: %#04x Params: %d, %d\n", evCode, param1, param2);
VDList[deviceNumber]->pMediaEvent->FreeEventParams(evCode, param1, param2);
if (evCode == EC_DEVICE_LOST)
{
DebugPrintOut("ERROR: Device disconnected\n");
disconnected = true;
}
}
return disconnected;
}
void videoInput::getCameraPropertyAsString(int prop, char * propertyAsString){
char tmpStr[16];
......@@ -2511,6 +2535,16 @@ int videoInput::start(int deviceID, videoDevice *VD){
return hr;
}
//MEDIA EVENT//
//Used to obtain event when capture device is disconnected
hr = VD->pGraph->QueryInterface(IID_IMediaEventEx, (void**)&VD->pMediaEvent);
if (FAILED(hr))
{
DebugPrintOut("ERROR - Could not create media event object\n");
stopDevice(deviceID);
return hr;
}
//SET THE FILTERGRAPH//
hr = VD->pCaptureGraph->SetFiltergraph(VD->pGraph);
if (FAILED(hr))
......@@ -3309,7 +3343,7 @@ bool VideoCapture_DShow::setProperty(int propIdx, double propVal)
bool VideoCapture_DShow::grabFrame()
{
return true;
return !g_VI.isDeviceDisconnected(m_index);
}
bool VideoCapture_DShow::retrieveFrame(int, OutputArray frame)
{
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册