Top |
GObject ╰── GInitiallyUnowned ╰── GstObject ╰── GstElement ╰── GstBaseTransform ╰── GstVideoRate
This element takes an incoming stream of timestamped video frames. It will produce a perfect stream that matches the source pad's framerate.
The correction is performed by dropping and duplicating frames, no fancy algorithm is used to interpolate frames (yet).
By default the element will simply negotiate the same framerate on its source and sink pad.
This operation is useful to link to elements that require a perfect stream. Typical examples are formats that do not store timestamps for video frames, but only store a framerate, like Ogg and AVI.
A conversion to a specific framerate can be forced by using filtered caps on the source pad.
The properties “in”, “out”, “duplicate” and “drop” can be read to obtain information about number of input frames, output frames, dropped frames (i.e. the number of unused input frames) and duplicated frames (i.e. the number of times an input frame was duplicated, beside being used normally).
An input stream that needs no adjustments will thus never have dropped or duplicated frames.
When the “silent” property is set to FALSE, a GObject property notification will be emitted whenever one of the “duplicate” or “drop” values changes. This can potentially cause performance degradation. Note that property notification will happen from the streaming thread, so applications should be prepared for this.
1 |
gst-launch-1.0 -v uridecodebin uri=file:///path/to/video.ogg ! videoconvert ! videoscale ! videorate ! video/x-raw,framerate=15/1 ! autovideosink |
1 |
gst-launch-1.0 -v v4l2src ! videorate ! video/x-raw,framerate=25/2 ! theoraenc ! oggmux ! filesink location=recording.ogg |
1 |
gst-launch-1.0 -v uridecodebin uri=file:///path/to/video.ogg ! videoconvert ! videoscale ! videorate ! video/x-raw,framerate=1/5 ! jpegenc ! multifilesink location=snapshot-%05d.jpg |
“average-period”
property“average-period” guint64
Arrange for maximum framerate by dropping frames beyond a certain framerate, where the framerate is calculated using a moving average over the configured.
Flags: Read / Write
Allowed values: <= G_MAXLONG
Default value: 0
“drop-only”
property“drop-only” gboolean
Only drop frames, no duplicates are produced.
Flags: Read / Write
Default value: FALSE
“duplicate”
property“duplicate” guint64
Number of duplicated frames.
Flags: Read
Default value: 0
“max-rate”
property“max-rate” gint
maximum framerate to pass through
Flags: Read / Write / Construct
Allowed values: >= 1
Default value: 2147483647
“new-pref”
property“new-pref” gdouble
Value indicating how much to prefer new frames (unused).
Flags: Read / Write
Allowed values: [0,1]
Default value: 1
“silent”
property“silent” gboolean
Don't emit notify for dropped and duplicated frames.
Flags: Read / Write
Default value: TRUE
“skip-to-first”
property“skip-to-first” gboolean
Don't produce buffers before the first one we receive.
Flags: Read / Write
Default value: FALSE