Merge pull request #6359 from alalek:videocapture_exceptions
This commit is contained in:
commit
169b5e9fde
@ -117,6 +117,36 @@ CV_IMPL int cvGetCaptureDomain( CvCapture* capture)
|
|||||||
return capture ? capture->getCaptureDomain() : 0;
|
return capture ? capture->getCaptureDomain() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool get_capture_debug_flag()
|
||||||
|
{
|
||||||
|
static bool initialized = false;
|
||||||
|
static bool flag = false;
|
||||||
|
if (!initialized)
|
||||||
|
{
|
||||||
|
#ifndef NO_GETENV
|
||||||
|
flag = getenv("OPENCV_VIDEOCAPTURE_DEBUG") ? true : false; // TODO Use getBoolParameter
|
||||||
|
#endif
|
||||||
|
initialized = true;
|
||||||
|
}
|
||||||
|
return flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define TRY_OPEN(capture, backend_func) \
|
||||||
|
{ \
|
||||||
|
if (!capture) \
|
||||||
|
try { \
|
||||||
|
if (get_capture_debug_flag()) fprintf(stderr, "VIDEOIO(%s): trying ...\n", #backend_func); \
|
||||||
|
capture = backend_func; \
|
||||||
|
if (get_capture_debug_flag()) fprintf(stderr, "VIDEOIO(%s): result=%p ...\n", #backend_func, capture); \
|
||||||
|
} catch (const cv::Exception& e) { \
|
||||||
|
fprintf(stderr, "VIDEOIO(%s): raised OpenCV exception:\n\n%s\n", #backend_func, e.what()); \
|
||||||
|
} catch (const std::exception& e) { \
|
||||||
|
fprintf(stderr, "VIDEOIO(%s): raised C++ exception:\n\n%s\n", #backend_func, e.what()); \
|
||||||
|
} catch (...) { \
|
||||||
|
fprintf(stderr, "VIDEOIO(%s): raised unknown C++ exception!\n\n", #backend_func); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Camera dispatching method: index is the camera number.
|
* Camera dispatching method: index is the camera number.
|
||||||
@ -144,120 +174,101 @@ CV_IMPL CvCapture * cvCreateCameraCapture (int index)
|
|||||||
|
|
||||||
#ifdef HAVE_MSMF
|
#ifdef HAVE_MSMF
|
||||||
case CV_CAP_MSMF:
|
case CV_CAP_MSMF:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_MSMF(index))
|
||||||
capture = cvCreateCameraCapture_MSMF(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_TYZX
|
#ifdef HAVE_TYZX
|
||||||
case CV_CAP_STEREO:
|
case CV_CAP_STEREO:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_TYZX(index))
|
||||||
capture = cvCreateCameraCapture_TYZX(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
case CV_CAP_VFW:
|
case CV_CAP_VFW:
|
||||||
#ifdef HAVE_VFW
|
#ifdef HAVE_VFW
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_VFW(index))
|
||||||
capture = cvCreateCameraCapture_VFW(index);
|
|
||||||
#endif
|
|
||||||
#if defined HAVE_LIBV4L || defined HAVE_CAMV4L || defined HAVE_CAMV4L2 || defined HAVE_VIDEOIO
|
|
||||||
if (!capture)
|
|
||||||
capture = cvCreateCameraCapture_V4L(index);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_GSTREAMER
|
|
||||||
if (!capture)
|
|
||||||
capture = cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_V4L2,
|
|
||||||
reinterpret_cast<char *>(index));
|
|
||||||
|
|
||||||
if (!capture)
|
|
||||||
capture = cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_V4L,
|
|
||||||
reinterpret_cast<char *>(index));
|
|
||||||
#endif
|
#endif
|
||||||
if (pref) break; // CV_CAP_VFW
|
if (pref) break; // CV_CAP_VFW
|
||||||
|
|
||||||
|
#if defined HAVE_LIBV4L || defined HAVE_CAMV4L || defined HAVE_CAMV4L2 || defined HAVE_VIDEOIO
|
||||||
|
TRY_OPEN(capture, cvCreateCameraCapture_V4L(index))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_GSTREAMER
|
||||||
|
TRY_OPEN(capture, cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_V4L2, reinterpret_cast<char *>(index)))
|
||||||
|
|
||||||
|
TRY_OPEN(capture, cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_V4L, reinterpret_cast<char *>(index)))
|
||||||
|
#endif
|
||||||
|
|
||||||
case CV_CAP_FIREWIRE:
|
case CV_CAP_FIREWIRE:
|
||||||
#ifdef HAVE_DC1394_2
|
#ifdef HAVE_DC1394_2
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_DC1394_2(index))
|
||||||
capture = cvCreateCameraCapture_DC1394_2(index);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_DC1394
|
#ifdef HAVE_DC1394
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_DC1394(index))
|
||||||
capture = cvCreateCameraCapture_DC1394(index);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_CMU1394
|
#ifdef HAVE_CMU1394
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_CMU(index))
|
||||||
capture = cvCreateCameraCapture_CMU(index);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_GSTREAMER) && 0
|
#if defined(HAVE_GSTREAMER) && 0
|
||||||
// Re-enable again when gstreamer 1394 support will land in the backend code
|
// Re-enable again when gstreamer 1394 support will land in the backend code
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_1394, 0))
|
||||||
capture = cvCreateCapture_GStreamer(CV_CAP_GSTREAMER_1394, 0);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (pref) break; // CV_CAP_FIREWIRE
|
if (pref) break; // CV_CAP_FIREWIRE
|
||||||
|
|
||||||
#ifdef HAVE_MIL
|
#ifdef HAVE_MIL
|
||||||
case CV_CAP_MIL:
|
case CV_CAP_MIL:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_MIL(index))
|
||||||
capture = cvCreateCameraCapture_MIL(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
||||||
case CV_CAP_QT:
|
case CV_CAP_QT:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_QT(index))
|
||||||
capture = cvCreateCameraCapture_QT(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_UNICAP
|
#ifdef HAVE_UNICAP
|
||||||
case CV_CAP_UNICAP:
|
case CV_CAP_UNICAP:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_Unicap(index))
|
||||||
capture = cvCreateCameraCapture_Unicap(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_PVAPI
|
#ifdef HAVE_PVAPI
|
||||||
case CV_CAP_PVAPI:
|
case CV_CAP_PVAPI:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_PvAPI(index))
|
||||||
capture = cvCreateCameraCapture_PvAPI(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_OPENNI
|
#ifdef HAVE_OPENNI
|
||||||
case CV_CAP_OPENNI:
|
case CV_CAP_OPENNI:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_OpenNI(index))
|
||||||
capture = cvCreateCameraCapture_OpenNI(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_OPENNI2
|
#ifdef HAVE_OPENNI2
|
||||||
case CV_CAP_OPENNI2:
|
case CV_CAP_OPENNI2:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_OpenNI2(index))
|
||||||
capture = cvCreateCameraCapture_OpenNI2(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_XIMEA
|
#ifdef HAVE_XIMEA
|
||||||
case CV_CAP_XIAPI:
|
case CV_CAP_XIAPI:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_XIMEA(index))
|
||||||
capture = cvCreateCameraCapture_XIMEA(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_AVFOUNDATION
|
#ifdef HAVE_AVFOUNDATION
|
||||||
case CV_CAP_AVFOUNDATION:
|
case CV_CAP_AVFOUNDATION:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_AVFoundation(index))
|
||||||
capture = cvCreateCameraCapture_AVFoundation(index);
|
|
||||||
if (pref) break;
|
if (pref) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_GIGE_API
|
#ifdef HAVE_GIGE_API
|
||||||
case CV_CAP_GIGANETIX:
|
case CV_CAP_GIGANETIX:
|
||||||
if (!capture)
|
TRY_OPEN(capture, cvCreateCameraCapture_Giganetix(index))
|
||||||
capture = cvCreateCameraCapture_Giganetix(index);
|
|
||||||
if (pref) break; // CV_CAP_GIGANETIX
|
if (pref) break; // CV_CAP_GIGANETIX
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -281,66 +292,56 @@ CV_IMPL CvCapture * cvCreateFileCaptureWithPreference (const char * filename, in
|
|||||||
|
|
||||||
#ifdef HAVE_FFMPEG
|
#ifdef HAVE_FFMPEG
|
||||||
case CV_CAP_FFMPEG:
|
case CV_CAP_FFMPEG:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_FFMPEG_proxy (filename))
|
||||||
result = cvCreateFileCapture_FFMPEG_proxy (filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_VFW
|
#ifdef HAVE_VFW
|
||||||
case CV_CAP_VFW:
|
case CV_CAP_VFW:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_VFW (filename))
|
||||||
result = cvCreateFileCapture_VFW (filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
#if defined HAVE_LIBV4L || defined HAVE_CAMV4L || defined HAVE_CAMV4L2 || defined HAVE_VIDEOIO
|
#if defined HAVE_LIBV4L || defined HAVE_CAMV4L || defined HAVE_CAMV4L2 || defined HAVE_VIDEOIO
|
||||||
if (!result)
|
TRY_OPEN(result, cvCreateCameraCapture_V4L(filename))
|
||||||
result = cvCreateCameraCapture_V4L(filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
case CV_CAP_MSMF:
|
case CV_CAP_MSMF:
|
||||||
#ifdef HAVE_MSMF
|
#ifdef HAVE_MSMF
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_MSMF (filename))
|
||||||
result = cvCreateFileCapture_MSMF (filename);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_XINE
|
#ifdef HAVE_XINE
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_XINE (filename))
|
||||||
result = cvCreateFileCapture_XINE (filename);
|
|
||||||
#endif
|
#endif
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
|
|
||||||
#ifdef HAVE_GSTREAMER
|
#ifdef HAVE_GSTREAMER
|
||||||
case CV_CAP_GSTREAMER:
|
case CV_CAP_GSTREAMER:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateCapture_GStreamer (CV_CAP_GSTREAMER_FILE, filename))
|
||||||
result = cvCreateCapture_GStreamer (CV_CAP_GSTREAMER_FILE, filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
||||||
case CV_CAP_QT:
|
case CV_CAP_QT:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_QT (filename))
|
||||||
result = cvCreateFileCapture_QT (filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_AVFOUNDATION
|
#ifdef HAVE_AVFOUNDATION
|
||||||
case CV_CAP_AVFOUNDATION:
|
case CV_CAP_AVFOUNDATION:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_AVFoundation (filename))
|
||||||
result = cvCreateFileCapture_AVFoundation (filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_OPENNI
|
#ifdef HAVE_OPENNI
|
||||||
case CV_CAP_OPENNI:
|
case CV_CAP_OPENNI:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_OpenNI (filename))
|
||||||
result = cvCreateFileCapture_OpenNI (filename);
|
|
||||||
if (apiPreference) break;
|
if (apiPreference) break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
case CV_CAP_IMAGES:
|
case CV_CAP_IMAGES:
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateFileCapture_Images (filename))
|
||||||
result = cvCreateFileCapture_Images (filename);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -358,63 +359,47 @@ CV_IMPL CvCapture * cvCreateFileCapture (const char * filename)
|
|||||||
CV_IMPL CvVideoWriter* cvCreateVideoWriter( const char* filename, int fourcc,
|
CV_IMPL CvVideoWriter* cvCreateVideoWriter( const char* filename, int fourcc,
|
||||||
double fps, CvSize frameSize, int is_color )
|
double fps, CvSize frameSize, int is_color )
|
||||||
{
|
{
|
||||||
|
// If none of the writers is used
|
||||||
|
// these statements suppress 'unused parameter' warnings.
|
||||||
|
CV_UNUSED(frameSize);
|
||||||
|
CV_UNUSED(is_color);
|
||||||
|
|
||||||
//CV_FUNCNAME( "cvCreateVideoWriter" );
|
//CV_FUNCNAME( "cvCreateVideoWriter" );
|
||||||
|
|
||||||
CvVideoWriter *result = 0;
|
CvVideoWriter *result = 0;
|
||||||
|
|
||||||
if(!fourcc || !fps)
|
if(!fourcc || !fps)
|
||||||
result = cvCreateVideoWriter_Images(filename);
|
TRY_OPEN(result, cvCreateVideoWriter_Images(filename))
|
||||||
|
|
||||||
#ifdef HAVE_FFMPEG
|
#ifdef HAVE_FFMPEG
|
||||||
if(!result)
|
TRY_OPEN(result, cvCreateVideoWriter_FFMPEG_proxy (filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_FFMPEG_proxy (filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_VFW
|
#ifdef HAVE_VFW
|
||||||
if(!result)
|
TRY_OPEN(result, cvCreateVideoWriter_VFW(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_VFW(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_MSMF
|
#ifdef HAVE_MSMF
|
||||||
if (!result)
|
TRY_OPEN(result, cvCreateVideoWriter_MSMF(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_MSMF(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* #ifdef HAVE_XINE
|
/* #ifdef HAVE_XINE
|
||||||
if(!result)
|
TRY_OPEN(result, cvCreateVideoWriter_XINE(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_XINE(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
#ifdef HAVE_AVFOUNDATION
|
#ifdef HAVE_AVFOUNDATION
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateVideoWriter_AVFoundation(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_AVFoundation(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
#if defined(HAVE_QUICKTIME) || defined(HAVE_QTKIT)
|
||||||
if(!result)
|
TRY_OPEN(result, cvCreateVideoWriter_QT(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_QT(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_GSTREAMER
|
#ifdef HAVE_GSTREAMER
|
||||||
if (! result)
|
TRY_OPEN(result, cvCreateVideoWriter_GStreamer(filename, fourcc, fps, frameSize, is_color))
|
||||||
result = cvCreateVideoWriter_GStreamer(filename, fourcc, fps, frameSize, is_color);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(HAVE_FFMPEG) && \
|
TRY_OPEN(result, cvCreateVideoWriter_Images(filename))
|
||||||
!defined(HAVE_VFW) && \
|
|
||||||
!defined(HAVE_MSMF) && \
|
|
||||||
!defined(HAVE_AVFOUNDATION) && \
|
|
||||||
!defined(HAVE_QUICKTIME) && \
|
|
||||||
!defined(HAVE_QTKIT) && \
|
|
||||||
!defined(HAVE_GSTREAMER)
|
|
||||||
// If none of the writers is used
|
|
||||||
// these statements suppress 'unused parameter' warnings.
|
|
||||||
(void)frameSize;
|
|
||||||
(void)is_color;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if(!result)
|
|
||||||
result = cvCreateVideoWriter_Images(filename);
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user