mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
First Try to fix RGB image formats
Original commit message from CVS: First Try to fix RGB image formats
This commit is contained in:
parent
c3328094e8
commit
08bc453edb
2 changed files with 99 additions and 16 deletions
|
@ -351,15 +351,23 @@ gst_xvimagesink_get_xv_support (GstXContext *xcontext)
|
||||||
|
|
||||||
/* First let's check that XVideo extension is available */
|
/* First let's check that XVideo extension is available */
|
||||||
if (!XQueryExtension (xcontext->disp, "XVideo", &i, &i, &i))
|
if (!XQueryExtension (xcontext->disp, "XVideo", &i, &i, &i))
|
||||||
return NULL;
|
{
|
||||||
|
GST_DEBUG ("XVideo extension is not available");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Then we get adaptors list */
|
/* Then we get adaptors list */
|
||||||
if (Success != XvQueryAdaptors (xcontext->disp, xcontext->root,
|
if (Success != XvQueryAdaptors (xcontext->disp, xcontext->root,
|
||||||
&nb_adaptors, &adaptors))
|
&nb_adaptors, &adaptors))
|
||||||
return NULL;
|
{
|
||||||
|
GST_DEBUG ("Failed getting XV adaptors list");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
xcontext->xv_port_id = 0;
|
xcontext->xv_port_id = 0;
|
||||||
|
|
||||||
|
GST_DEBUG ("Found %d XV adaptor(s)", nb_adaptors);
|
||||||
|
|
||||||
/* Now search for an adaptor that supports XvImageMask */
|
/* Now search for an adaptor that supports XvImageMask */
|
||||||
for (i = 0; i < nb_adaptors && !xcontext->xv_port_id; i++)
|
for (i = 0; i < nb_adaptors && !xcontext->xv_port_id; i++)
|
||||||
{
|
{
|
||||||
|
@ -401,18 +409,37 @@ gst_xvimagesink_get_xv_support (GstXContext *xcontext)
|
||||||
switch (formats[i].type)
|
switch (formats[i].type)
|
||||||
{
|
{
|
||||||
case XvRGB:
|
case XvRGB:
|
||||||
format_caps = GST_CAPS_NEW ("xvimagesink_caps",
|
{
|
||||||
"video/x-raw-rgb",
|
format_caps = GST_CAPS_NEW ("xvimagesink_caps",
|
||||||
"endianness", GST_PROPS_INT (xcontext->endianness),
|
"video/x-raw-rgb",
|
||||||
"depth", GST_PROPS_INT (xcontext->depth),
|
"endianness", GST_PROPS_INT (xcontext->endianness),
|
||||||
"bpp", GST_PROPS_INT (xcontext->bpp),
|
"depth", GST_PROPS_INT (xcontext->depth),
|
||||||
"blue_mask", GST_PROPS_INT (formats[i].red_mask),
|
"bpp", GST_PROPS_INT (xcontext->bpp),
|
||||||
"green_mask", GST_PROPS_INT (formats[i].green_mask),
|
"blue_mask", GST_PROPS_INT (formats[i].red_mask),
|
||||||
"red_mask", GST_PROPS_INT (formats[i].blue_mask),
|
"green_mask", GST_PROPS_INT (formats[i].green_mask),
|
||||||
"width", GST_PROPS_INT_RANGE (0, G_MAXINT),
|
"red_mask", GST_PROPS_INT (formats[i].blue_mask),
|
||||||
"height", GST_PROPS_INT_RANGE (0, G_MAXINT),
|
"width", GST_PROPS_INT_RANGE (0, G_MAXINT),
|
||||||
"framerate", GST_PROPS_FLOAT_RANGE (0, G_MAXFLOAT));
|
"height", GST_PROPS_INT_RANGE (0, G_MAXINT),
|
||||||
break;
|
"framerate", GST_PROPS_FLOAT_RANGE (0, G_MAXFLOAT));
|
||||||
|
|
||||||
|
/* For RGB caps we store them and the image
|
||||||
|
format so that we can get back the format
|
||||||
|
when sinkconnect will give us a caps without
|
||||||
|
format property */
|
||||||
|
if (format_caps)
|
||||||
|
{
|
||||||
|
GstXvImageFormat *format = NULL;
|
||||||
|
format = g_new0 (GstXvImageFormat, 1);
|
||||||
|
if (format)
|
||||||
|
{
|
||||||
|
format->format = formats[i].id;
|
||||||
|
format->caps = gst_caps_copy (format_caps);
|
||||||
|
xcontext->formats_list = g_list_append (
|
||||||
|
xcontext->formats_list, format);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case XvYUV:
|
case XvYUV:
|
||||||
format_caps = GST_CAPS_NEW ("xvimagesink_caps",
|
format_caps = GST_CAPS_NEW ("xvimagesink_caps",
|
||||||
"video/x-raw-yuv",
|
"video/x-raw-yuv",
|
||||||
|
@ -540,9 +567,24 @@ gst_xvimagesink_xcontext_get (GstXvImageSink *xvimagesink)
|
||||||
static void
|
static void
|
||||||
gst_xvimagesink_xcontext_clear (GstXvImageSink *xvimagesink)
|
gst_xvimagesink_xcontext_clear (GstXvImageSink *xvimagesink)
|
||||||
{
|
{
|
||||||
|
GList *list;
|
||||||
|
|
||||||
g_return_if_fail (xvimagesink != NULL);
|
g_return_if_fail (xvimagesink != NULL);
|
||||||
g_return_if_fail (GST_IS_XVIMAGESINK (xvimagesink));
|
g_return_if_fail (GST_IS_XVIMAGESINK (xvimagesink));
|
||||||
|
|
||||||
|
list = xvimagesink->xcontext->formats_list;
|
||||||
|
|
||||||
|
while (list)
|
||||||
|
{
|
||||||
|
GstXvImageFormat *format = list->data;
|
||||||
|
gst_caps_unref (format->caps);
|
||||||
|
g_free (format);
|
||||||
|
list = g_list_next (list);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (xvimagesink->xcontext->formats_list)
|
||||||
|
g_list_free (xvimagesink->xcontext->formats_list);
|
||||||
|
|
||||||
gst_caps_unref (xvimagesink->xcontext->caps);
|
gst_caps_unref (xvimagesink->xcontext->caps);
|
||||||
|
|
||||||
g_mutex_lock (xvimagesink->x_lock);
|
g_mutex_lock (xvimagesink->x_lock);
|
||||||
|
@ -559,6 +601,35 @@ gst_xvimagesink_xcontext_clear (GstXvImageSink *xvimagesink)
|
||||||
|
|
||||||
/* Element stuff */
|
/* Element stuff */
|
||||||
|
|
||||||
|
static gint
|
||||||
|
gst_xvimagesink_get_fourcc_from_caps (GstXvImageSink *xvimagesink,
|
||||||
|
GstCaps *caps)
|
||||||
|
{
|
||||||
|
gint fourcc = 0;
|
||||||
|
GList *list = NULL;
|
||||||
|
|
||||||
|
g_return_val_if_fail (xvimagesink != NULL, 0);
|
||||||
|
g_return_val_if_fail (GST_IS_XVIMAGESINK (xvimagesink), 0);
|
||||||
|
|
||||||
|
list = xvimagesink->xcontext->formats_list;
|
||||||
|
|
||||||
|
while (list)
|
||||||
|
{
|
||||||
|
GstXvImageFormat *format = list->data;
|
||||||
|
|
||||||
|
if (format)
|
||||||
|
{
|
||||||
|
GstCaps *icaps = NULL;
|
||||||
|
icaps = gst_caps_intersect (caps, format->caps);
|
||||||
|
if (icaps)
|
||||||
|
fourcc = format->format;
|
||||||
|
}
|
||||||
|
list = g_list_next (list);
|
||||||
|
}
|
||||||
|
|
||||||
|
return fourcc;
|
||||||
|
}
|
||||||
|
|
||||||
static GstCaps *
|
static GstCaps *
|
||||||
gst_xvimagesink_getcaps (GstPad *pad, GstCaps *caps)
|
gst_xvimagesink_getcaps (GstPad *pad, GstCaps *caps)
|
||||||
{
|
{
|
||||||
|
@ -614,6 +685,9 @@ gst_xvimagesink_sinkconnect (GstPad *pad, GstCaps *caps)
|
||||||
|
|
||||||
if (gst_caps_has_fixed_property (caps, "format"))
|
if (gst_caps_has_fixed_property (caps, "format"))
|
||||||
gst_caps_get_fourcc_int (caps, "format", &xvimagesink->xcontext->im_format);
|
gst_caps_get_fourcc_int (caps, "format", &xvimagesink->xcontext->im_format);
|
||||||
|
else
|
||||||
|
xvimagesink->xcontext->im_format = gst_xvimagesink_get_fourcc_from_caps (
|
||||||
|
xvimagesink, caps);
|
||||||
|
|
||||||
if (gst_caps_has_fixed_property (caps, "pixel_width"))
|
if (gst_caps_has_fixed_property (caps, "pixel_width"))
|
||||||
gst_caps_get_int (caps, "pixel_width", &xvimagesink->pixel_width);
|
gst_caps_get_int (caps, "pixel_width", &xvimagesink->pixel_width);
|
||||||
|
|
|
@ -56,7 +56,8 @@ G_BEGIN_DECLS
|
||||||
typedef struct _GstXContext GstXContext;
|
typedef struct _GstXContext GstXContext;
|
||||||
typedef struct _GstXWindow GstXWindow;
|
typedef struct _GstXWindow GstXWindow;
|
||||||
typedef struct _GstXvImage GstXvImage;
|
typedef struct _GstXvImage GstXvImage;
|
||||||
|
typedef struct _GstXvImageFormat GstXvImageFormat;
|
||||||
|
|
||||||
typedef struct _GstXvImageSink GstXvImageSink;
|
typedef struct _GstXvImageSink GstXvImageSink;
|
||||||
typedef struct _GstXvImageSinkClass GstXvImageSinkClass;
|
typedef struct _GstXvImageSinkClass GstXvImageSinkClass;
|
||||||
|
|
||||||
|
@ -82,6 +83,8 @@ struct _GstXContext {
|
||||||
XvPortID xv_port_id;
|
XvPortID xv_port_id;
|
||||||
gint im_format;
|
gint im_format;
|
||||||
|
|
||||||
|
GList *formats_list;
|
||||||
|
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -93,7 +96,13 @@ struct _GstXWindow {
|
||||||
GC gc;
|
GC gc;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* XImage stuff */
|
/* XvImage format stuff */
|
||||||
|
struct _GstXvImageFormat {
|
||||||
|
gint format;
|
||||||
|
GstCaps *caps;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* XvImage stuff */
|
||||||
struct _GstXvImage {
|
struct _GstXvImage {
|
||||||
XvImage *xvimage;
|
XvImage *xvimage;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue