2000-08-16 21:38:57 +00:00
|
|
|
<chapter id="cha-elements">
|
|
|
|
<title>GstElement</title>
|
|
|
|
<para>
|
2001-05-02 23:46:27 +00:00
|
|
|
The most important object in <application>GStreamer</application> for the
|
|
|
|
application programmer is the <classname>GstElement</classname> object.
|
2000-08-16 21:38:57 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<sect1 id="sec-elements-design">
|
|
|
|
<title>What is a GstElement</title>
|
|
|
|
<para>
|
|
|
|
The GstElement is the basic building block for the media pipeline. All the
|
|
|
|
different components you are going to use are derived from this GstElement.
|
|
|
|
This means that a lot of functions you are going to use operate on this object.
|
|
|
|
</para>
|
|
|
|
<para>
|
2001-01-04 23:35:50 +00:00
|
|
|
You will see that those elements have pads. These are the elements
|
|
|
|
connections with the 'outside' world. Depending on the number and direction of
|
|
|
|
the pads, we can see three types of elements: source, filter and sink element.
|
2000-08-16 21:38:57 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2001-01-04 23:35:50 +00:00
|
|
|
These three types are all the same GstElement object, they just differ in how
|
|
|
|
the pads are.
|
2000-08-16 21:38:57 +00:00
|
|
|
</para>
|
2001-01-04 23:35:50 +00:00
|
|
|
|
2000-08-16 21:38:57 +00:00
|
|
|
<sect2 id="sec-elements-src">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>GStreamer source elements</title>
|
2000-08-16 21:38:57 +00:00
|
|
|
<para>
|
|
|
|
This element will generate data that will be used by the pipeline. It is
|
|
|
|
typically a file or an audio source.
|
|
|
|
</para>
|
|
|
|
<para>
|
2001-01-04 23:35:50 +00:00
|
|
|
Below you see how we will visualize the element.
|
2000-08-16 21:38:57 +00:00
|
|
|
We always draw a src pad to the right of the element.
|
|
|
|
</para>
|
|
|
|
<figure float="1" id="sec-element-srcimg">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>Visualisation of a source element</title>
|
2001-12-13 15:24:00 +00:00
|
|
|
<mediaobject>
|
|
|
|
<imageobject>
|
|
|
|
<imagedata fileref="images/src-element" format="PNG">
|
|
|
|
</imageobject>
|
|
|
|
</mediaobject>
|
2000-08-16 21:38:57 +00:00
|
|
|
</figure>
|
|
|
|
<para>
|
|
|
|
Source elements do not accept data, they only generate data. You can see
|
|
|
|
this in the figure because it only has a src pad. A src pad can only
|
|
|
|
generate buffers.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
2001-01-04 23:35:50 +00:00
|
|
|
|
2000-08-16 21:38:57 +00:00
|
|
|
<sect2 id="sec-elements-filter">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>GStreamer filter elements</title>
|
2000-08-16 21:38:57 +00:00
|
|
|
<para>
|
|
|
|
Filter elements both have an input and an output pad. They operate on data
|
|
|
|
they receive in the sink pad and send the result to the src pad.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Examples of a filter element might include: an MPEG decoder, volume filter,...
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Filters may also contain any number of input pads and output pads. For example,
|
|
|
|
a video mixer might have to input pads (the images of the two different video
|
|
|
|
streams) and one output pad.
|
|
|
|
</para>
|
|
|
|
<figure float="1" id="sec-element-filterimg">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>Visualisation of a filter element</title>
|
2001-12-13 15:24:00 +00:00
|
|
|
<mediaobject>
|
|
|
|
<imageobject>
|
|
|
|
<imagedata fileref="images/filter-element" format="PNG">
|
|
|
|
</imageobject>
|
|
|
|
</mediaobject>
|
2000-08-16 21:38:57 +00:00
|
|
|
</figure>
|
|
|
|
<para>
|
|
|
|
The above figure shows the visualisation of a filter element. This element has
|
|
|
|
one sink pad (input) and one src (output) pad. Sink pads are drawn on the left
|
|
|
|
of the element.
|
|
|
|
</para>
|
|
|
|
<figure float="1" id="sec-element-multifilterimg">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>Visualisation of a filter element with
|
2000-08-16 21:38:57 +00:00
|
|
|
more than one output pad</title>
|
2001-12-13 15:24:00 +00:00
|
|
|
<mediaobject>
|
|
|
|
<imageobject>
|
|
|
|
<imagedata fileref="images/filter-element-multi" format="PNG">
|
|
|
|
</imageobject>
|
|
|
|
</mediaobject>
|
2000-08-16 21:38:57 +00:00
|
|
|
</figure>
|
|
|
|
<para>
|
|
|
|
The above figure shows the visualisation of a filter element with more than one
|
|
|
|
output pad. An example of such a filter is the AVI splitter. This element will
|
|
|
|
parse the input data and extracts the audio and video data. Most of these filters
|
|
|
|
dynamically send out a signal when a new pad is created so that the application
|
|
|
|
programmer can connect an arbitrary element to the newly created pad.
|
|
|
|
</para>
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
<sect2 id="sec-elements-sink">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>GStreamer sink elements</title>
|
2000-08-16 21:38:57 +00:00
|
|
|
<para>
|
|
|
|
This element accepts data but will not generate any new data. A sink element
|
|
|
|
is typically a file on disk, a soundcard, a display,... It is presented as
|
|
|
|
below:
|
|
|
|
</para>
|
|
|
|
<figure float="1" id="sec-element-sinkimg">
|
2001-01-04 23:35:50 +00:00
|
|
|
<title>Visualisation of a sink element</title>
|
2001-12-13 15:24:00 +00:00
|
|
|
<mediaobject>
|
|
|
|
<imageobject>
|
|
|
|
<imagedata fileref="images/sink-element" format="PNG">
|
|
|
|
</imageobject>
|
|
|
|
</mediaobject>
|
2000-08-16 21:38:57 +00:00
|
|
|
</figure>
|
|
|
|
</sect2>
|
|
|
|
</sect1>
|
2001-01-06 02:35:17 +00:00
|
|
|
<sect1 id="sec-elements-create">
|
|
|
|
<title>Creating a GstElement</title>
|
|
|
|
<para>
|
|
|
|
GstElements are created from factories. To create an element, one has to get
|
|
|
|
access the a <classname>GstElementFactory</classname> using a unique factoryname.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The following code example is used to get a factory that can be used to create the
|
|
|
|
mpg123 element, an mp3 decoder.
|
|
|
|
</para>
|
|
|
|
<programlisting>
|
|
|
|
GstElementFactory *factory;
|
|
|
|
|
|
|
|
factory = gst_elementfactory_find ("mpg123");
|
|
|
|
</programlisting>
|
|
|
|
<para>
|
|
|
|
Once you have the handle to the elementfactory, you can create a real element with
|
|
|
|
the following code fragment:
|
|
|
|
</para>
|
|
|
|
<programlisting>
|
|
|
|
GstElement *element;
|
|
|
|
|
|
|
|
element = gst_elementfactory_create (factory, "decoder");
|
|
|
|
</programlisting>
|
|
|
|
<para>
|
|
|
|
gst_elementfactory_create () will use the elementfactory to create an element with the
|
|
|
|
given name. The name of the element is something you can use later on to lookup the
|
|
|
|
element in a bin, for example.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
A simple shortcut exists for creating an element from a factory. The following example
|
|
|
|
creates an element, named "decoder" from the elementfactory named "mpg123". This
|
|
|
|
convenient function is most widly used to create an element.
|
|
|
|
</para>
|
|
|
|
<programlisting>
|
|
|
|
GstElement *element;
|
|
|
|
|
|
|
|
element = gst_elementfactory_make ("mpg123", "decoder");
|
|
|
|
</programlisting>
|
|
|
|
<para>
|
|
|
|
An element can be destroyed with:
|
|
|
|
</para>
|
|
|
|
<programlisting>
|
|
|
|
GstElement *element;
|
|
|
|
|
|
|
|
...
|
|
|
|
gst_element_destroy (element);
|
|
|
|
</programlisting>
|
|
|
|
</sect1>
|
2000-08-16 21:38:57 +00:00
|
|
|
</chapter>
|