Removing the video_out things.

Original commit message from CVS:
Removing the video_out things.
This commit is contained in:
Julien Moutte 2003-11-19 22:41:45 +00:00
parent e8bd838897
commit f119708012
3 changed files with 12 additions and 275 deletions

View file

@ -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)
{ {

View file

@ -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
} }

View file

@ -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
} }