Fixed compatibility with GStreamer 1.x
This commit is contained in:
parent
cc6e6aa028
commit
15251056ba
@ -788,26 +788,32 @@ bool CvCapture_GStreamer::open( int type, const char* filename )
|
|||||||
duration = -1;
|
duration = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
GstPad* pad = gst_element_get_pad(color, "src");
|
GstPad* pad = gst_element_get_static_pad(color, "src");
|
||||||
|
#if GST_VERSION_MAJOR == 0
|
||||||
GstCaps* buffer_caps = gst_pad_get_caps(pad);
|
GstCaps* buffer_caps = gst_pad_get_caps(pad);
|
||||||
|
#else
|
||||||
|
GstCaps* buffer_caps = gst_pad_get_current_caps(pad);
|
||||||
|
#endif
|
||||||
const GstStructure *structure = gst_caps_get_structure (buffer_caps, 0);
|
const GstStructure *structure = gst_caps_get_structure (buffer_caps, 0);
|
||||||
|
|
||||||
if (!gst_structure_get_int (structure, "width", &width))
|
if (!gst_structure_get_int (structure, "width", &width))
|
||||||
|
{
|
||||||
CV_WARN("Cannot query video width\n");
|
CV_WARN("Cannot query video width\n");
|
||||||
|
}
|
||||||
|
|
||||||
if (!gst_structure_get_int (structure, "height", &height))
|
if (!gst_structure_get_int (structure, "height", &height))
|
||||||
|
{
|
||||||
CV_WARN("Cannot query video heigth\n");
|
CV_WARN("Cannot query video heigth\n");
|
||||||
|
}
|
||||||
if (!gst_structure_get_int (structure, "height", &height))
|
|
||||||
CV_WARN("Cannot query video heigth\n");
|
|
||||||
|
|
||||||
gint num = 0, denom=1;
|
gint num = 0, denom=1;
|
||||||
if(!gst_structure_get_fraction(structure, "framerate", &num, &denom))
|
if(!gst_structure_get_fraction(structure, "framerate", &num, &denom))
|
||||||
|
{
|
||||||
CV_WARN("Cannot query video fps\n");
|
CV_WARN("Cannot query video fps\n");
|
||||||
|
}
|
||||||
|
|
||||||
fps = (double)num/(double)denom;
|
fps = (double)num/(double)denom;
|
||||||
|
|
||||||
|
|
||||||
// GST_DEBUG_BIN_TO_DOT_FILE(GST_BIN(pipeline), GST_DEBUG_GRAPH_SHOW_ALL, "pipeline");
|
// GST_DEBUG_BIN_TO_DOT_FILE(GST_BIN(pipeline), GST_DEBUG_GRAPH_SHOW_ALL, "pipeline");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1217,8 +1223,11 @@ bool CvVideoWriter_GStreamer::open( const char * filename, int fourcc,
|
|||||||
gboolean done = FALSE;
|
gboolean done = FALSE;
|
||||||
GstElement *element = NULL;
|
GstElement *element = NULL;
|
||||||
gchar* name = NULL;
|
gchar* name = NULL;
|
||||||
|
|
||||||
|
#if GST_VERSION_MAJOR == 0
|
||||||
GstElement* splitter = NULL;
|
GstElement* splitter = NULL;
|
||||||
GstElement* combiner = NULL;
|
GstElement* combiner = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
// we first try to construct a pipeline from the given string.
|
// we first try to construct a pipeline from the given string.
|
||||||
// if that fails, we assume it is an ordinary filename
|
// if that fails, we assume it is an ordinary filename
|
||||||
|
@ -51,7 +51,11 @@ using namespace cv;
|
|||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace cvtest;
|
using namespace cvtest;
|
||||||
|
|
||||||
const string ext[] = {"avi"}; //, "mov", "mp4"};
|
#ifdef HAVE_GSTREAMER
|
||||||
|
const string ext[] = {"avi"};
|
||||||
|
#else
|
||||||
|
const string ext[] = {"avi", "mov", "mp4"};
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST(Videoio_Video, prop_resolution)
|
TEST(Videoio_Video, prop_resolution)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user