| Top |  |  |  |  | 
| gboolean | threaded | Read / Write | 
| GstCaps * | sink-caps | Read / Write | 
| GstCaps * | caps | Read / Write | 
| gboolean | expose-all-streams | Read / Write | 
| gint | high-percent | Read / Write | 
| gint | low-percent | Read / Write | 
| guint | max-size-buffers | Read / Write | 
| guint | max-size-bytes | Read / Write | 
| guint64 | max-size-time | Read / Write | 
| gboolean | post-stream-topology | Read / Write | 
| gchar * | subtitle-encoding | Read / Write | 
| gboolean | use-buffering | Read / Write | 
| guint64 | connection-speed | Read / Write | 
| void | new-decoded-pad | Run Last | 
| void | removed-decoded-pad | Run Last | 
| void | unknown-type | Run Last | 
| gboolean | autoplug-continue | Run Last | 
| GValueArray* | autoplug-factories | Run Last | 
| GstAutoplugSelectResult | autoplug-select | Run Last | 
| GValueArray* | autoplug-sort | Run Last | 
| void | drained | Run Last | 
| gboolean | autoplug-query | Run Last | 
GObject ╰── GInitiallyUnowned ╰── GstObject ╰── GstElement ╰── GstBin ╰── GstDecodeBin
GstBin that auto-magically constructs a decoding pipeline using available decoders and demuxers via auto-plugging.
decodebin is considered stable now and replaces the old decodebin element. uridecodebin uses decodebin internally and is often more convenient to use, as it creates a suitable source element as well.
| plugin | playback | 
| author | Edward Hervey <edward.hervey@collabora.co.uk>, Sebastian Dröge <sebastian.droege@collabora.co.uk> | 
| class | Generic/Bin/Decoder | 
“sink-caps” property“sink-caps” GstCaps *
The caps of the input data. (NULL = use typefind element).
Flags: Read / Write
“expose-all-streams” property“expose-all-streams” gboolean
Expose all streams, including those of unknown type or that don't match the 'caps' property.
Flags: Read / Write
Default value: TRUE
“high-percent” property“high-percent” gint
High threshold percent for buffering to finish.
Flags: Read / Write
Allowed values: [0,100]
Default value: 99
Since 0.10.26
“low-percent” property“low-percent” gint
Low threshold percent for buffering to start.
Flags: Read / Write
Allowed values: [0,100]
Default value: 10
Since 0.10.26
“max-size-buffers” property“max-size-buffers” guint
Max amount of buffers in the queue (0=automatic).
Flags: Read / Write
Default value: 0
Since 0.10.26
“max-size-bytes” property“max-size-bytes” guint
Max amount of bytes in the queue (0=automatic).
Flags: Read / Write
Default value: 0
Since 0.10.26
“max-size-time” property  “max-size-time”            guint64
Max amount of time in the queue (in ns, 0=automatic).
Flags: Read / Write
Default value: 0
Since 0.10.26
“post-stream-topology” property“post-stream-topology” gboolean
Post stream-topology messages.
Flags: Read / Write
Default value: FALSE
“subtitle-encoding” property“subtitle-encoding” gchar *
Encoding to assume if input subtitles are not in UTF-8 encoding. If not set, the GST_SUBTITLE_ENCODING environment variable will be checked for an encoding to use. If that is not set either, ISO-8859-15 will be assumed.
Flags: Read / Write
Default value: NULL
“use-buffering” property“use-buffering” gboolean
Emit GST_MESSAGE_BUFFERING based on low-/high-percent thresholds.
Flags: Read / Write
Default value: FALSE
“new-decoded-pad” signalvoid user_function (GstDecodeBin *gstdecodebin, GstPad *arg1, gboolean arg2, gpointer user_data)
| gstdecodebin | the object which received the signal. | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
“removed-decoded-pad” signalvoid user_function (GstDecodeBin *gstdecodebin, GstPad *arg1, gpointer user_data)
| gstdecodebin | the object which received the signal. | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
“unknown-type” signalvoid user_function (GstDecodeBin *bin, GstPad *pad, GstCaps *caps, gpointer user_data)
This signal is emitted when a pad for which there is no further possible decoding is added to the decodebin.
| bin | The decodebin. | |
| pad | The new pad containing caps that cannot be resolved to a 'final' stream type. | |
| caps | The GstCaps of the pad that cannot be resolved. | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
“autoplug-continue” signalgboolean user_function (GstDecodeBin *bin, GstPad *pad, GstCaps *caps, gpointer user_data)
This signal is emitted whenever decodebin finds a new stream. It is emitted before looking for any elements that can handle that stream.
 TRUE if you wish decodebin to look for elements that can
handle the given caps
. If FALSE, those caps will be considered as
final and the pad will be exposed as such (see 'pad-added' signal of
GstElement).
Flags: Run Last
“autoplug-factories” signalGValueArray* user_function (GstDecodeBin *bin, GstPad *pad, GstCaps *caps, gpointer user_data)
This function is emited when an array of possible factories for caps
 on
pad
 is needed. Decodebin will by default return an array with all
compatible factories, sorted by rank.
If this function returns NULL, pad
 will be exposed as a final caps.
If this function returns an empty array, the pad will be considered as having an unhandled type media type.
a GValueArray* with a list of factories to try. The factories are by default tried in the returned order or based on the index returned by "autoplug-select".
Flags: Run Last
“autoplug-select” signalGstAutoplugSelectResult user_function (GstDecodeBin *bin, GstPad *pad, GstCaps *caps, GstElementFactory *factory, gpointer user_data)
This signal is emitted once decodebin has found all the possible
GstElementFactory that can be used to handle the given caps
. For each of
those factories, this signal is emitted.
The signal handler should return a GST_TYPE_AUTOPLUG_SELECT_RESULT enum value indicating what decodebin should do next.
A value of GST_AUTOPLUG_SELECT_TRY will try to autoplug an element from
factory
.
A value of GST_AUTOPLUG_SELECT_EXPOSE will expose pad
 without plugging
any element to it.
A value of GST_AUTOPLUG_SELECT_SKIP will skip factory
 and move to the
next factory.
| bin | The decodebin. | |
| pad | The GstPad. | |
| caps | The GstCaps. | |
| factory | A GstElementFactory to use. | |
| user_data | user data set when the signal handler was connected. | 
a GST_TYPE_AUTOPLUG_SELECT_RESULT that indicates the required operation. the default handler will always return GST_AUTOPLUG_SELECT_TRY.
Flags: Run Last
“autoplug-sort” signalGValueArray* user_function (GstDecodeBin *bin, GstPad *pad, GstCaps *caps, GValueArray *factories, gpointer user_data)
Once decodebin has found the possible GstElementFactory objects to try
for caps
 on pad
, this signal is emited. The purpose of the signal is for
the application to perform additional sorting or filtering on the element
factory array.
The callee should copy and modify factories
 or return NULL if the
order should not change.
| bin | The decodebin. | |
| pad | The GstPad. | |
| caps | The GstCaps. | |
| factories | A GValueArray of possible GstElementFactory to use. | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
“drained” signalvoid user_function (GstDecodeBin *bin, gpointer user_data)
This signal is emitted once decodebin has finished decoding all the data.
Flags: Run Last
Since 0.10.16
“autoplug-query” signalgboolean user_function (GstDecodeBin *bin, GstPad *child, GstElement *pad, GstQuery *query, gpointer user_data)
This signal is emitted whenever an autoplugged element that is not linked downstream yet and not exposed does a query. It can be used to tell the element about the downstream supported caps for example.
Flags: Run Last