Gst::Bin - Base class and element that can contain other elements. More...
Inherits Gst::Element, and Gst::ChildProxy.
Inherited by Gst::DecodeBin, Gst::DecodeBin2, Gst::Pipeline, and Gst::UriDecodeBin.

| Public Member Functions | |
| virtual | ~Bin () | 
| GstBin* | gobj () | 
| Provides access to the underlying C GObject. | |
| const GstBin* | gobj () const | 
| Provides access to the underlying C GObject. | |
| GstBin* | gobj_copy () | 
| Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. | |
| Glib::RefPtr< Gst::Bin > | add (const Glib::RefPtr< Gst::Element >& element) | 
| Adds the given element to the bin. | |
| Glib::RefPtr< Gst::Bin > | remove (const Glib::RefPtr< Gst::Element >& element) | 
| Removes the element from the bin, unparenting it as well. | |
| Glib::RefPtr< Gst::Element > | get_element (const Glib::ustring& name) | 
| Gets the element with the given name from a bin. | |
| Glib::RefPtr< const Gst::Element > | get_element (const Glib::ustring& name) const | 
| Gets the element with the given name from a bin. | |
| Glib::RefPtr< Gst::Element > | get_element_recurse_up (const Glib::ustring& name) | 
| Gets the element with the given name from this bin. | |
| Glib::RefPtr< const Gst::Element > | get_element_recurse_up (const Glib::ustring& name) const | 
| Gets the element with the given name from this bin. | |
| Glib::RefPtr< Gst::Element > | get_element (GType interface) | 
| Looks for an element inside the bin that implements the given interface. | |
| Glib::RefPtr< const Gst::Element > | get_element (GType interface) const | 
| Looks for an element inside the bin that implements the given interface. | |
| Glib::RefPtr< Gst::GhostPad > | add_ghost_pad (const Glib::RefPtr< Gst::Element >& element, const Glib::ustring& pad_name, const Glib::ustring& name=Glib::ustring()) | 
| Adds a ghost pad to the bin using an element's static pad as a target. | |
| Glib::RefPtr< Gst::Pad > | find_unlinked_pad (PadDirection dir) | 
| Recursively looks for elements with an unlinked pad of the given direction within the specified bin and returns an unlinked pad if one is found, or 0otherwise. | |
| Glib::RefPtr< const Gst::Pad > | find_unlinked_pad (PadDirection dir) const | 
| Recursively looks for elements with an unlinked pad of the given direction within the specified bin and returns an unlinked pad if one is found, or 0otherwise. | |
| Gst::Iterator< Gst::Element > | iterate_elements () | 
| Gets an iterator for the elements in this bin. | |
| Gst::Iterator< const Gst::Element > | iterate_elements () const | 
| Gets an iterator for the elements in this bin. | |
| Gst::Iterator< Gst::Element > | iterate_recurse () | 
| Gets an iterator for the elements in this bin. | |
| Gst::Iterator< const Gst::Element > | iterate_recurse () const | 
| Gets an iterator for the elements in this bin. | |
| Gst::Iterator< Gst::Element > | iterate_sorted () | 
| Gets an iterator for the elements in this bin in topologically sorted order. | |
| Gst::Iterator< const Gst::Element > | iterate_sorted () const | 
| Gets an iterator for the elements in this bin in topologically sorted order. | |
| Gst::Iterator< Gst::Element > | iterate_sources () | 
| Gets an iterator for all elements in the bin that have no sinkpads and have the Gst::ELEMENT_IS_SINK flag unset. | |
| Gst::Iterator< const Gst::Element > | iterate_sources () const | 
| Gets an iterator for all elements in the bin that have no sinkpads and have the Gst::ELEMENT_IS_SINK flag unset. | |
| Gst::Iterator< Gst::Element > | iterate_sinks () | 
| Gets an iterator for all elements in the bin that have the Gst::ELEMENT_IS_SINK flag set. | |
| Gst::Iterator< const Gst::Element > | iterate_sinks () const | 
| Gets an iterator for all elements in the bin that have the Gst::ELEMENT_IS_SINK flag set. | |
| Gst::Iterator< Gst::Element > | iterate_by_interface (GType iface) | 
| Looks for all elements inside the bin that implements the given interface. | |
| Gst::Iterator< const Gst::Element > | iterate_by_interface (GType iface) const | 
| Looks for all elements inside the bin that implements the given interface. | |
| bool | recalculate_latency () | 
| Query bin for the current latency using and reconfigures this latency to all the elements with a LATENCY event. | |
| Glib::ListHandle< Glib::RefPtr < Gst::Element > > | get_children () const | 
| Gets the bin's list of children. | |
| int | get_num_children () const | 
| Gets the number of children in the bin. | |
| Glib::SignalProxy1< void, const Glib::RefPtr < Gst::Element >& > | signal_element_added () | 
| Will be emitted after the element was added to the bin. | |
| Glib::SignalProxy1< void, const Glib::RefPtr < Gst::Element >& > | signal_element_removed () | 
| Will be emitted after the element was removed from the bin. | |
| Glib::SignalProxy0< bool > | signal_do_latency () | 
| Glib::PropertyProxy< bool > | property_async_handling () | 
| The bin will handle Asynchronous state changes. | |
| Glib::PropertyProxy_ReadOnly < bool > | property_async_handling () const | 
| The bin will handle Asynchronous state changes. | |
| virtual bool | add_element_vfunc (const Glib::RefPtr< Gst::Element >& element) | 
| Method to add an element to a bin. | |
| virtual bool | remove_element_vfunc (const Glib::RefPtr< Gst::Element >& element) | 
| Method to remove an element from a bin. | |
| virtual void | handle_message_vfunc (const Glib::RefPtr< Gst::Message >& message) | 
| Method to handle a message from the children. | |
| Static Public Member Functions | |
| static Glib::RefPtr< Bin > | create (const Glib::ustring& name) | 
| Creates a new bin with the given name. | |
| static Glib::RefPtr< Bin > | create () | 
| Creates a new bin with a unique generic name. | |
| Protected Member Functions | |
| Bin (const Glib::ustring& name) | |
| Bin () | |
| virtual void | on_element_added (const Glib::RefPtr< Gst::Element >& element) | 
| virtual void | on_element_removed (const Glib::RefPtr< Gst::Element >& element) | 
| virtual bool | on_do_latency () | 
| Related Functions | |
| (Note that these are not member functions.) | |
| Glib::RefPtr< Gst::Bin > | wrap (GstBin* object, bool take_copy=false) | 
| A Glib::wrap() method for this object. | |
Gst::Bin - Base class and element that can contain other elements.
Gst::Bin is an element that can contain other Gst::Element, allowing them to be managed as a group. Pads from the child elements can be ghosted to the bin, see Gst::GhostPad. This makes the bin look like any other elements and enables creation of higher-level abstraction elements.
A new Gst::Bin is created with create(). Use a Gst::Pipeline instead if you want to create a toplevel bin because a normal bin doesn't have a bus or handle clock distribution of its own.
After the bin has been created you will typically add elements to it with add(). You can remove elements with remove().
An element can be retrieved from a bin with get_element(), using the elements name. get_element_recurse_up() is mainly used for internal purposes and will query the parent bins when the element is not found in the current bin.
An iterator of elements in a bin can be retrieved with iterate_elements(). Various other iterators exist to retrieve the elements in a bin.
The element-added signal is fired whenever a new element is added to the bin. Likewise the element-removed signal is fired whenever an element is removed from the bin.
Notes:
A Gst::Bin internally intercepts every Gst::Message posted by its children and implements the following default behaviour for each of them:
A Gst::Bin implements the following default behaviour for answering to a Gst::Query:
A Gst::Bin will by default forward any event sent to it to all sink elements. If all the sinks return true, the bin will also return true, else false is returned. If no sinks are in the bin, the event handler will return true.
Last reviewed on 2006-04-28 (0.10.6)
| virtual Gst::Bin::~Bin | ( | ) |  [virtual] | 
| Gst::Bin::Bin | ( | const Glib::ustring & | name | ) |  [explicit, protected] | 
| Gst::Bin::Bin | ( | ) |  [protected] | 
| Glib::RefPtr<Gst::Bin> Gst::Bin::add | ( | const Glib::RefPtr< Gst::Element >& | element | ) | 
Adds the given element to the bin.
This sets the element's parent, and thus takes ownership of the element. An element can only be added to one bin.
If the element's pads are linked to other pads then the pads will be unlinked before the element is added to the bin.
MT safe.
| element | The Gst::Element to add. | 
| std::runtime_error | if the Bin does not want to accept the Element. | 
| virtual bool Gst::Bin::add_element_vfunc | ( | const Glib::RefPtr< Gst::Element >& | element | ) |  [virtual] | 
Method to add an element to a bin.
| Glib::RefPtr<Gst::GhostPad> Gst::Bin::add_ghost_pad | ( | const Glib::RefPtr< Gst::Element >& | element, | |
| const Glib::ustring & | pad_name, | |||
| const Glib::ustring & | name = Glib::ustring() | |||
| ) | 
Adds a ghost pad to the bin using an element's static pad as a target.
| element | The element with the target static pad. | |
| pad_name | The static pad to use as the target. | |
| name | An optional name for the ghost pad. | 
| static Glib::RefPtr<Bin> Gst::Bin::create | ( | ) |  [static] | 
Creates a new bin with a unique generic name.
Reimplemented in Gst::Pipeline, Gst::DecodeBin2, Gst::DecodeBin, Gst::PlayBin2, Gst::PlayBin, and Gst::UriDecodeBin.
| static Glib::RefPtr<Bin> Gst::Bin::create | ( | const Glib::ustring & | name | ) |  [static] | 
Creates a new bin with the given name.
| name | The name of the new bin. | 
Reimplemented in Gst::Pipeline, Gst::DecodeBin2, Gst::DecodeBin, Gst::PlayBin2, Gst::PlayBin, and Gst::UriDecodeBin.
| Glib::RefPtr<const Gst::Pad> Gst::Bin::find_unlinked_pad | ( | PadDirection | dir | ) | const | 
Recursively looks for elements with an unlinked pad of the given direction within the specified bin and returns an unlinked pad if one is found, or 0 otherwise. 
If a pad is found, the caller owns a reference to it and should use Gst::Object::unref() on the pad when it is not needed any longer.
| direction | Whether to look for an unlinked source or sink pad. | 
0.| Glib::RefPtr<Gst::Pad> Gst::Bin::find_unlinked_pad | ( | PadDirection | dir | ) | 
Recursively looks for elements with an unlinked pad of the given direction within the specified bin and returns an unlinked pad if one is found, or 0 otherwise. 
If a pad is found, the caller owns a reference to it and should use Gst::Object::unref() on the pad when it is not needed any longer.
| direction | Whether to look for an unlinked source or sink pad. | 
0.| Glib::ListHandle< Glib::RefPtr<Gst::Element> > Gst::Bin::get_children | ( | ) | const | 
Gets the bin's list of children.
| Glib::RefPtr<const Gst::Element> Gst::Bin::get_element | ( | GType | interface | ) | const | 
Looks for an element inside the bin that implements the given interface.
If such an element is found, it returns the element. You can cast this element to the given interface afterwards. If you want all elements that implement the interface, use iterate_all_by_interface(). This function recurses into child bins.
MT safe. Caller owns returned reference.
| iface | The Type of an interface. | 
| Glib::RefPtr<Gst::Element> Gst::Bin::get_element | ( | GType | interface | ) | 
Looks for an element inside the bin that implements the given interface.
If such an element is found, it returns the element. You can cast this element to the given interface afterwards. If you want all elements that implement the interface, use iterate_all_by_interface(). This function recurses into child bins.
MT safe. Caller owns returned reference.
| iface | The Type of an interface. | 
| Glib::RefPtr<const Gst::Element> Gst::Bin::get_element | ( | const Glib::ustring & | name | ) | const | 
Gets the element with the given name from a bin.
This function recurses into child bins.
Returns: the Gst::Element with the given name, or 0 
| name | The element name to search for. | 
0. | Glib::RefPtr<Gst::Element> Gst::Bin::get_element | ( | const Glib::ustring & | name | ) | 
Gets the element with the given name from a bin.
This function recurses into child bins.
Returns: the Gst::Element with the given name, or 0 
| name | The element name to search for. | 
0. | Glib::RefPtr<const Gst::Element> Gst::Bin::get_element_recurse_up | ( | const Glib::ustring & | name | ) | const | 
Gets the element with the given name from this bin.
If the element is not found, a recursion is performed on the parent bin.
Returns: the Gst::Element with the given name, or 0 
| name | The element name to search for. | 
0. | Glib::RefPtr<Gst::Element> Gst::Bin::get_element_recurse_up | ( | const Glib::ustring & | name | ) | 
Gets the element with the given name from this bin.
If the element is not found, a recursion is performed on the parent bin.
Returns: the Gst::Element with the given name, or 0 
| name | The element name to search for. | 
0. | int Gst::Bin::get_num_children | ( | ) | const | 
Gets the number of children in the bin.
| const GstBin* Gst::Bin::gobj | ( | ) | const  [inline] | 
Provides access to the underlying C GObject.
Reimplemented from Gst::ChildProxy.
Reimplemented in Gst::Pipeline, Gst::DecodeBin2, Gst::DecodeBin, Gst::PlayBin2, Gst::PlayBin, and Gst::UriDecodeBin.
| GstBin* Gst::Bin::gobj | ( | ) |  [inline] | 
Provides access to the underlying C GObject.
Reimplemented from Gst::ChildProxy.
Reimplemented in Gst::Pipeline, Gst::DecodeBin2, Gst::DecodeBin, Gst::PlayBin2, Gst::PlayBin, and Gst::UriDecodeBin.
| GstBin* Gst::Bin::gobj_copy | ( | ) | 
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
Reimplemented from Gst::Element.
Reimplemented in Gst::Pipeline, Gst::DecodeBin2, Gst::DecodeBin, Gst::PlayBin2, Gst::PlayBin, and Gst::UriDecodeBin.
| virtual void Gst::Bin::handle_message_vfunc | ( | const Glib::RefPtr< Gst::Message >& | message | ) |  [virtual] | 
Method to handle a message from the children.
| Gst::Iterator<const Gst::Element> Gst::Bin::iterate_by_interface | ( | GType | iface | ) | const | 
Looks for all elements inside the bin that implements the given interface.
You can safely cast all returned elements to the given interface. The function recurses inside child bins. The iterator will yield a series of Gst::Element that should be unreffed after use.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
| iface | The Type of an interface. | 
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_by_interface | ( | GType | iface | ) | 
Looks for all elements inside the bin that implements the given interface.
You can safely cast all returned elements to the given interface. The function recurses inside child bins. The iterator will yield a series of Gst::Element that should be unreffed after use.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
| iface | The Type of an interface. | 
0. | Gst::Iterator<const Gst::Element> Gst::Bin::iterate_elements | ( | ) | const | 
Gets an iterator for the elements in this bin.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_elements | ( | ) | 
Gets an iterator for the elements in this bin.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<const Gst::Element> Gst::Bin::iterate_recurse | ( | ) | const | 
Gets an iterator for the elements in this bin.
This iterator recurses into GstBin children.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_recurse | ( | ) | 
Gets an iterator for the elements in this bin.
This iterator recurses into GstBin children.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<const Gst::Element> Gst::Bin::iterate_sinks | ( | ) | const | 
Gets an iterator for all elements in the bin that have the Gst::ELEMENT_IS_SINK flag set.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_sinks | ( | ) | 
Gets an iterator for all elements in the bin that have the Gst::ELEMENT_IS_SINK flag set.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<const Gst::Element> Gst::Bin::iterate_sorted | ( | ) | const | 
Gets an iterator for the elements in this bin in topologically sorted order.
This means that the elements are returned from the most downstream elements (sinks) to the sources.
This function is used internally to perform the state changes of the bin elements and for clock selection.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_sorted | ( | ) | 
Gets an iterator for the elements in this bin in topologically sorted order.
This means that the elements are returned from the most downstream elements (sinks) to the sources.
This function is used internally to perform the state changes of the bin elements and for clock selection.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<const Gst::Element> Gst::Bin::iterate_sources | ( | ) | const | 
Gets an iterator for all elements in the bin that have no sinkpads and have the Gst::ELEMENT_IS_SINK flag unset.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | Gst::Iterator<Gst::Element> Gst::Bin::iterate_sources | ( | ) | 
Gets an iterator for all elements in the bin that have no sinkpads and have the Gst::ELEMENT_IS_SINK flag unset.
Each element yielded by the iterator will have its refcount increased, so unref after use.
MT safe. Caller owns returned value.
0. | virtual bool Gst::Bin::on_do_latency | ( | ) |  [protected, virtual] | 
| virtual void Gst::Bin::on_element_added | ( | const Glib::RefPtr< Gst::Element >& | element | ) |  [protected, virtual] | 
| virtual void Gst::Bin::on_element_removed | ( | const Glib::RefPtr< Gst::Element >& | element | ) |  [protected, virtual] | 
| Glib::PropertyProxy_ReadOnly<bool> Gst::Bin::property_async_handling | ( | ) | const | 
The bin will handle Asynchronous state changes.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
| Glib::PropertyProxy<bool> Gst::Bin::property_async_handling | ( | ) | 
The bin will handle Asynchronous state changes.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
| bool Gst::Bin::recalculate_latency | ( | ) | 
Query bin for the current latency using and reconfigures this latency to all the elements with a LATENCY event.
This method is typically called on the pipeline when a Gst::MESSAGE_LATENCY is posted on the bus.
This function simply emits the 'do-latency' signal so any custom latency calculations will be performed.
true if the latency could be queried and reconfigured.| Glib::RefPtr<Gst::Bin> Gst::Bin::remove | ( | const Glib::RefPtr< Gst::Element >& | element | ) | 
Removes the element from the bin, unparenting it as well.
Unparenting the element means that the element will be dereferenced, so if the bin holds the only reference to the element, the element will be freed in the process of removing it from the bin.
If the element's pads are linked to other pads, the pads will be unlinked before the element is removed from the bin.
MT safe.
element the Gst::Element to remove Returns this Gst::Bin if successful, for chained calls to remove().
| std::runtime_error | if the Bin does not want to remove the Element. | 
| virtual bool Gst::Bin::remove_element_vfunc | ( | const Glib::RefPtr< Gst::Element >& | element | ) |  [virtual] | 
Method to remove an element from a bin.
| Glib::SignalProxy0< bool > Gst::Bin::signal_do_latency | ( | ) | 
bool on_my_do_latency() | Glib::SignalProxy1< void,const Glib::RefPtr<Gst::Element>& > Gst::Bin::signal_element_added | ( | ) | 
Will be emitted after the element was added to the bin.
void on_my_element_added(const Glib::RefPtr<Gst::Element>& element) | Glib::SignalProxy1< void,const Glib::RefPtr<Gst::Element>& > Gst::Bin::signal_element_removed | ( | ) | 
Will be emitted after the element was removed from the bin.
void on_my_element_removed(const Glib::RefPtr<Gst::Element>& element) | Glib::RefPtr< Gst::Bin > wrap | ( | GstBin * | object, | |
| bool | take_copy = false | |||
| ) |  [related] | 
A Glib::wrap() method for this object.
| object | The C instance. | |
| take_copy | False if the result should take ownership of the C instance. True if it should take a new copy or ref. | 
 1.6.1
 1.6.1