mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-17 04:45:47 +00:00
Removing the video_out things.
Original commit message from CVS: Removing the video_out things.
This commit is contained in:
parent
e8bd838897
commit
f119708012
3 changed files with 12 additions and 275 deletions
|
@ -27,84 +27,15 @@
|
||||||
/* VideoSink signals and args */
|
/* VideoSink signals and args */
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
HAVE_VIDEO_OUT,
|
HAVE_VIDEO_SIZE,
|
||||||
HAVE_SIZE,
|
|
||||||
FRAME_DISPLAYED,
|
|
||||||
LAST_SIGNAL
|
LAST_SIGNAL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
enum {
|
|
||||||
ARG_0,
|
|
||||||
ARG_WIDTH,
|
|
||||||
ARG_HEIGHT,
|
|
||||||
ARG_FRAMES_DISPLAYED,
|
|
||||||
ARG_FRAME_TIME,
|
|
||||||
};
|
|
||||||
|
|
||||||
static GstElementClass *parent_class = NULL;
|
static GstElementClass *parent_class = NULL;
|
||||||
static guint gst_videosink_signals[LAST_SIGNAL] = { 0 };
|
static guint gst_videosink_signals[LAST_SIGNAL] = { 0 };
|
||||||
|
|
||||||
/* Private methods */
|
/* Private methods */
|
||||||
|
|
||||||
static void
|
|
||||||
gst_videosink_set_property (GObject *object, guint prop_id,
|
|
||||||
const GValue *value, GParamSpec *pspec)
|
|
||||||
{
|
|
||||||
GstVideoSink *videosink;
|
|
||||||
|
|
||||||
g_return_if_fail (object != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (object));
|
|
||||||
|
|
||||||
videosink = GST_VIDEOSINK (object);
|
|
||||||
|
|
||||||
switch (prop_id)
|
|
||||||
{
|
|
||||||
case ARG_WIDTH:
|
|
||||||
gst_video_sink_set_geometry (videosink, g_value_get_int (value),
|
|
||||||
videosink->height);
|
|
||||||
break;
|
|
||||||
case ARG_HEIGHT:
|
|
||||||
gst_video_sink_set_geometry (videosink, videosink->width,
|
|
||||||
g_value_get_int (value));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
gst_videosink_get_property (GObject *object, guint prop_id,
|
|
||||||
GValue *value, GParamSpec *pspec)
|
|
||||||
{
|
|
||||||
GstVideoSink *videosink;
|
|
||||||
|
|
||||||
g_return_if_fail (object != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (object));
|
|
||||||
|
|
||||||
videosink = GST_VIDEOSINK (object);
|
|
||||||
|
|
||||||
switch (prop_id)
|
|
||||||
{
|
|
||||||
case ARG_WIDTH:
|
|
||||||
g_value_set_int (value, videosink->width);
|
|
||||||
break;
|
|
||||||
case ARG_HEIGHT:
|
|
||||||
g_value_set_int (value, videosink->height);
|
|
||||||
break;
|
|
||||||
case ARG_FRAMES_DISPLAYED:
|
|
||||||
g_value_set_int (value, videosink->frames_displayed);
|
|
||||||
break;
|
|
||||||
case ARG_FRAME_TIME:
|
|
||||||
g_value_set_int64 (value, videosink->frame_time);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_videosink_set_clock (GstElement *element, GstClock *clock)
|
gst_videosink_set_clock (GstElement *element, GstClock *clock)
|
||||||
{
|
{
|
||||||
|
@ -120,14 +51,9 @@ gst_videosink_set_clock (GstElement *element, GstClock *clock)
|
||||||
static void
|
static void
|
||||||
gst_videosink_init (GstVideoSink *videosink)
|
gst_videosink_init (GstVideoSink *videosink)
|
||||||
{
|
{
|
||||||
videosink->video_out = NULL;
|
videosink->width = 0;
|
||||||
videosink->width = -1;
|
videosink->height = 0;
|
||||||
videosink->height = -1;
|
|
||||||
videosink->frames_displayed = 0;
|
|
||||||
videosink->frame_time = 0;
|
|
||||||
|
|
||||||
videosink->clock = NULL;
|
videosink->clock = NULL;
|
||||||
videosink->formats = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -140,125 +66,20 @@ gst_videosink_class_init (GstVideoSinkClass *klass)
|
||||||
gstelement_class = (GstElementClass*)klass;
|
gstelement_class = (GstElementClass*)klass;
|
||||||
|
|
||||||
parent_class = g_type_class_ref (GST_TYPE_ELEMENT);
|
parent_class = g_type_class_ref (GST_TYPE_ELEMENT);
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_WIDTH,
|
gst_videosink_signals[HAVE_VIDEO_SIZE] =
|
||||||
g_param_spec_int ("width", "Width", "Width of the video output",
|
g_signal_new ("have_video_size",
|
||||||
G_MININT, G_MAXINT, 0, G_PARAM_READWRITE));
|
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_HEIGHT,
|
|
||||||
g_param_spec_int ("height", "Height", "Height of the video output",
|
|
||||||
G_MININT, G_MAXINT, 0, G_PARAM_READWRITE));
|
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FRAMES_DISPLAYED,
|
|
||||||
g_param_spec_int ("frames_displayed", "Frames displayed",
|
|
||||||
"The number of frames displayed so far",
|
|
||||||
G_MININT,G_MAXINT, 0, G_PARAM_READABLE));
|
|
||||||
|
|
||||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FRAME_TIME,
|
|
||||||
g_param_spec_int64 ("frame_time", "Frame time", "The interval between frames",
|
|
||||||
G_MININT64, G_MAXINT64, 0, G_PARAM_READABLE));
|
|
||||||
|
|
||||||
gobject_class->set_property = gst_videosink_set_property;
|
|
||||||
gobject_class->get_property = gst_videosink_get_property;
|
|
||||||
|
|
||||||
gst_videosink_signals[FRAME_DISPLAYED] =
|
|
||||||
g_signal_new ("frame_displayed",
|
|
||||||
G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
||||||
G_STRUCT_OFFSET (GstVideoSinkClass, frame_displayed),
|
G_STRUCT_OFFSET (GstVideoSinkClass, have_video_size),
|
||||||
NULL, NULL,
|
|
||||||
g_cclosure_marshal_VOID__VOID, G_TYPE_NONE, 0);
|
|
||||||
|
|
||||||
gst_videosink_signals[HAVE_SIZE] =
|
|
||||||
g_signal_new ("have_size",
|
|
||||||
G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
|
||||||
G_STRUCT_OFFSET (GstVideoSinkClass, have_size),
|
|
||||||
NULL, NULL,
|
NULL, NULL,
|
||||||
gst_marshal_VOID__INT_INT, G_TYPE_NONE, 2,
|
gst_marshal_VOID__INT_INT, G_TYPE_NONE, 2,
|
||||||
G_TYPE_UINT, G_TYPE_UINT);
|
G_TYPE_UINT, G_TYPE_UINT);
|
||||||
|
|
||||||
gst_videosink_signals[HAVE_VIDEO_OUT] =
|
|
||||||
g_signal_new ("have_video_out",
|
|
||||||
G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
|
||||||
G_STRUCT_OFFSET (GstVideoSinkClass, have_video_out),
|
|
||||||
NULL, NULL,
|
|
||||||
gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
|
|
||||||
G_TYPE_POINTER);
|
|
||||||
|
|
||||||
gstelement_class->set_clock = gst_videosink_set_clock;
|
gstelement_class->set_clock = gst_videosink_set_clock;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Public virtual methods */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_video_sink_set_video_out:
|
|
||||||
* @videosink: a #GstVideoSink to set the video out on.
|
|
||||||
* @video_out: the #gpointer linking to video out.
|
|
||||||
*
|
|
||||||
* This will call the video sink's set_video_out method. You should use this
|
|
||||||
* method to tell to a video sink to display video output to a specific
|
|
||||||
* video out ressource.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
gst_video_sink_set_video_out (GstVideoSink *videosink, gpointer video_out)
|
|
||||||
{
|
|
||||||
GstVideoSinkClass *class;
|
|
||||||
|
|
||||||
g_return_if_fail (videosink != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
|
||||||
|
|
||||||
class = GST_VIDEOSINK_GET_CLASS (videosink);
|
|
||||||
|
|
||||||
if (class->set_video_out)
|
|
||||||
class->set_video_out (videosink, video_out);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_video_sink_set_geometry:
|
|
||||||
* @videosink: a #GstVideoSink which geometry will be set.
|
|
||||||
* @width: a width as a #gint.
|
|
||||||
* @height: a height as a #gint.
|
|
||||||
*
|
|
||||||
* Set video sink's geometry to @width x @height. If that succeed you should
|
|
||||||
* get the have_size signal being fired.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
gst_video_sink_set_geometry (GstVideoSink *videosink, gint width, gint height)
|
|
||||||
{
|
|
||||||
GstVideoSinkClass *class;
|
|
||||||
|
|
||||||
g_return_if_fail (videosink != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
|
||||||
|
|
||||||
class = GST_VIDEOSINK_GET_CLASS (videosink);
|
|
||||||
|
|
||||||
if (class->set_geometry)
|
|
||||||
class->set_geometry (videosink, width, height);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Public methods */
|
/* Public methods */
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_video_sink_got_video_out:
|
|
||||||
* @videosink: a #GstVideoSink which got a video out ressource.
|
|
||||||
* @video_out: a #gpointer linking to the video out ressource.
|
|
||||||
*
|
|
||||||
* This will fire an have_video_out signal and update the internal object's
|
|
||||||
* #gpointer.
|
|
||||||
*
|
|
||||||
* This function should be used by video sink developpers.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
gst_video_sink_got_video_out (GstVideoSink *videosink, gpointer video_out)
|
|
||||||
{
|
|
||||||
g_return_if_fail (videosink != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
|
||||||
|
|
||||||
videosink->video_out = video_out;
|
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (videosink), gst_videosink_signals[HAVE_VIDEO_OUT],
|
|
||||||
0, video_out);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_video_sink_got_video_size:
|
* gst_video_sink_got_video_size:
|
||||||
* @videosink: a #GstVideoSink which received video geometry.
|
* @videosink: a #GstVideoSink which received video geometry.
|
||||||
|
@ -276,48 +97,10 @@ gst_video_sink_got_video_size (GstVideoSink *videosink, gint width, gint height)
|
||||||
g_return_if_fail (videosink != NULL);
|
g_return_if_fail (videosink != NULL);
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (videosink), gst_videosink_signals[HAVE_SIZE],
|
g_signal_emit (G_OBJECT (videosink), gst_videosink_signals[HAVE_VIDEO_SIZE],
|
||||||
0, width, height);
|
0, width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_video_sink_frame_displayed:
|
|
||||||
* @videosink: a #GstVideoSink which displayed a frame.
|
|
||||||
*
|
|
||||||
* This will fire an frame_displayed signal and update the internal object's
|
|
||||||
* counter.
|
|
||||||
*
|
|
||||||
* This function should be used by video sink developpers.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
gst_video_sink_frame_displayed (GstVideoSink *videosink)
|
|
||||||
{
|
|
||||||
g_return_if_fail (videosink != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
|
||||||
|
|
||||||
videosink->frames_displayed++;
|
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (videosink),
|
|
||||||
gst_videosink_signals[FRAME_DISPLAYED], 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_video_sink_get_geometry:
|
|
||||||
* @videosink: a #GstVideoSink which displayed a frame.
|
|
||||||
* @width: a #gint pointer where the width will be set.
|
|
||||||
* @height: a #gint pointer where the height will be set.
|
|
||||||
*
|
|
||||||
* This will fill set @width and @height with the video sink's current geometry.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
gst_video_sink_get_geometry (GstVideoSink *videosink, gint *width, gint *height)
|
|
||||||
{
|
|
||||||
g_return_if_fail (videosink != NULL);
|
|
||||||
g_return_if_fail (GST_IS_VIDEOSINK (videosink));
|
|
||||||
*width = videosink->width;
|
|
||||||
*height = videosink->height;
|
|
||||||
}
|
|
||||||
|
|
||||||
GType
|
GType
|
||||||
gst_videosink_get_type (void)
|
gst_videosink_get_type (void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -52,50 +52,27 @@ struct _GstVideoSink {
|
||||||
|
|
||||||
GstPad *sinkpad;
|
GstPad *sinkpad;
|
||||||
|
|
||||||
gpointer video_out;
|
|
||||||
|
|
||||||
gint width, height;
|
gint width, height;
|
||||||
gint frames_displayed;
|
|
||||||
gint64 frame_time;
|
|
||||||
|
|
||||||
GstClock *clock;
|
GstClock *clock;
|
||||||
|
|
||||||
GstCaps *formats;
|
|
||||||
|
|
||||||
GST_OBJECT_PADDING
|
GST_OBJECT_PADDING
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstVideoSinkClass {
|
struct _GstVideoSinkClass {
|
||||||
GstElementClass parent_class;
|
GstElementClass parent_class;
|
||||||
|
|
||||||
/* public virtual methods */
|
|
||||||
void (*set_video_out) (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void (*set_geometry) (GstVideoSink *videosink, gint width, gint height);
|
|
||||||
|
|
||||||
/* signals */
|
/* signals */
|
||||||
void (*have_video_out) (GstVideoSink *element, gpointer video_out);
|
|
||||||
void (*have_size) (GstVideoSink *element, gint width, gint height);
|
void (*have_size) (GstVideoSink *element, gint width, gint height);
|
||||||
void (*frame_displayed) (GstVideoSink *element);
|
|
||||||
|
|
||||||
GST_CLASS_PADDING
|
GST_CLASS_PADDING
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gst_videosink_get_type (void);
|
GType gst_videosink_get_type (void);
|
||||||
|
|
||||||
/* public virtual methods */
|
|
||||||
void gst_video_sink_set_video_out (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void gst_video_sink_set_geometry (GstVideoSink *videosink, gint width,
|
|
||||||
gint height);
|
|
||||||
|
|
||||||
/* public methods to fire signals */
|
/* public methods to fire signals */
|
||||||
void gst_video_sink_got_video_out (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void gst_video_sink_got_video_size (GstVideoSink *videosink,
|
void gst_video_sink_got_video_size (GstVideoSink *videosink,
|
||||||
gint width, gint height);
|
gint width, gint height);
|
||||||
void gst_video_sink_frame_displayed (GstVideoSink *videosink);
|
|
||||||
|
|
||||||
/* public methods */
|
|
||||||
void gst_video_sink_get_geometry (GstVideoSink *videosink,
|
|
||||||
gint *width, gint *height);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,50 +52,27 @@ struct _GstVideoSink {
|
||||||
|
|
||||||
GstPad *sinkpad;
|
GstPad *sinkpad;
|
||||||
|
|
||||||
gpointer video_out;
|
|
||||||
|
|
||||||
gint width, height;
|
gint width, height;
|
||||||
gint frames_displayed;
|
|
||||||
gint64 frame_time;
|
|
||||||
|
|
||||||
GstClock *clock;
|
GstClock *clock;
|
||||||
|
|
||||||
GstCaps *formats;
|
|
||||||
|
|
||||||
GST_OBJECT_PADDING
|
GST_OBJECT_PADDING
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstVideoSinkClass {
|
struct _GstVideoSinkClass {
|
||||||
GstElementClass parent_class;
|
GstElementClass parent_class;
|
||||||
|
|
||||||
/* public virtual methods */
|
|
||||||
void (*set_video_out) (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void (*set_geometry) (GstVideoSink *videosink, gint width, gint height);
|
|
||||||
|
|
||||||
/* signals */
|
/* signals */
|
||||||
void (*have_video_out) (GstVideoSink *element, gpointer video_out);
|
|
||||||
void (*have_size) (GstVideoSink *element, gint width, gint height);
|
void (*have_size) (GstVideoSink *element, gint width, gint height);
|
||||||
void (*frame_displayed) (GstVideoSink *element);
|
|
||||||
|
|
||||||
GST_CLASS_PADDING
|
GST_CLASS_PADDING
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gst_videosink_get_type (void);
|
GType gst_videosink_get_type (void);
|
||||||
|
|
||||||
/* public virtual methods */
|
|
||||||
void gst_video_sink_set_video_out (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void gst_video_sink_set_geometry (GstVideoSink *videosink, gint width,
|
|
||||||
gint height);
|
|
||||||
|
|
||||||
/* public methods to fire signals */
|
/* public methods to fire signals */
|
||||||
void gst_video_sink_got_video_out (GstVideoSink *videosink, gpointer video_out);
|
|
||||||
void gst_video_sink_got_video_size (GstVideoSink *videosink,
|
void gst_video_sink_got_video_size (GstVideoSink *videosink,
|
||||||
gint width, gint height);
|
gint width, gint height);
|
||||||
void gst_video_sink_frame_displayed (GstVideoSink *videosink);
|
|
||||||
|
|
||||||
/* public methods */
|
|
||||||
void gst_video_sink_get_geometry (GstVideoSink *videosink,
|
|
||||||
gint *width, gint *height);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue