Do rate control, skip frames when too old.
Original commit message from CVS: Do rate control, skip frames when too old.
This commit is contained in:
parent
5e9794a11a
commit
244658dc96
@ -90,6 +90,7 @@ GST_PAD_TEMPLATE_FACTORY (videotestsrc_src_template_factory,
|
||||
static void gst_videotestsrc_class_init (GstVideotestsrcClass * klass);
|
||||
static void gst_videotestsrc_init (GstVideotestsrc * videotestsrc);
|
||||
static GstElementStateReturn gst_videotestsrc_change_state (GstElement * element);
|
||||
static void gst_videotestsrc_set_clock (GstElement *element, GstClock *clock);
|
||||
|
||||
static void gst_videotestsrc_set_property (GObject * object, guint prop_id,
|
||||
const GValue * value, GParamSpec * pspec);
|
||||
@ -160,6 +161,17 @@ gst_videotestsrc_class_init (GstVideotestsrcClass * klass)
|
||||
gobject_class->get_property = gst_videotestsrc_get_property;
|
||||
|
||||
gstelement_class->change_state = gst_videotestsrc_change_state;
|
||||
gstelement_class->set_clock = gst_videotestsrc_set_clock;
|
||||
}
|
||||
|
||||
static void
|
||||
gst_videotestsrc_set_clock (GstElement *element, GstClock *clock)
|
||||
{
|
||||
GstVideotestsrc *v;
|
||||
|
||||
v = GST_VIDEOTESTSRC (element);
|
||||
|
||||
gst_object_replace ((GstObject **)&v->clock, (GstObject *)clock);
|
||||
}
|
||||
|
||||
static GstPadLinkReturn
|
||||
@ -302,6 +314,7 @@ gst_videotestsrc_get (GstPad * pad)
|
||||
GstVideotestsrc *videotestsrc;
|
||||
gulong newsize;
|
||||
GstBuffer *buf;
|
||||
GstClockTimeDiff jitter = 0;
|
||||
|
||||
GST_DEBUG (0, "gst_videotestsrc_get");
|
||||
|
||||
@ -325,11 +338,22 @@ gst_videotestsrc_get (GstPad * pad)
|
||||
}
|
||||
g_return_val_if_fail (GST_BUFFER_DATA (buf) != NULL, NULL);
|
||||
|
||||
videotestsrc->make_image (videotestsrc, (void *) GST_BUFFER_DATA (buf),
|
||||
videotestsrc->width, videotestsrc->height);
|
||||
|
||||
do {
|
||||
GstClockID id;
|
||||
|
||||
videotestsrc->timestamp += videotestsrc->interval;
|
||||
GST_BUFFER_TIMESTAMP (buf) = videotestsrc->timestamp;
|
||||
|
||||
videotestsrc->make_image (videotestsrc, (void *) GST_BUFFER_DATA (buf),
|
||||
videotestsrc->width, videotestsrc->height);
|
||||
if (videotestsrc->clock) {
|
||||
id = gst_clock_new_single_shot_id (videotestsrc->clock, GST_BUFFER_TIMESTAMP (buf));
|
||||
gst_element_clock_wait (GST_ELEMENT (videotestsrc), id, &jitter);
|
||||
gst_clock_id_free (id);
|
||||
}
|
||||
}
|
||||
while (jitter > 100 * GST_MSECOND);
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
@ -65,6 +65,7 @@ struct _GstVideotestsrc {
|
||||
gint64 interval;
|
||||
gint bpp;
|
||||
int rate;
|
||||
GstClock *clock;
|
||||
|
||||
GstBufferPool *pool;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user