mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
docs/manual/basics-pads.xml: Expand a bit on caps and filtered links and update examples that were still using the no...
Original commit message from CVS: * docs/manual/basics-pads.xml: Expand a bit on caps and filtered links and update examples that were still using the no longer existing gst_pad_link_filtered() (#338206).
This commit is contained in:
parent
d81a21da50
commit
4f89b26095
2 changed files with 133 additions and 30 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
2006-05-10 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* docs/manual/basics-pads.xml:
|
||||||
|
Expand a bit on caps and filtered links and update
|
||||||
|
examples that were still using the no longer existing
|
||||||
|
gst_pad_link_filtered() (#338206).
|
||||||
|
|
||||||
2006-05-10 Wim Taymans <wim@fluendo.com>
|
2006-05-10 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
* libs/gst/base/gstcollectpads.c: (gst_collect_pads_finalize),
|
* libs/gst/base/gstcollectpads.c: (gst_collect_pads_finalize),
|
||||||
|
|
|
@ -301,6 +301,13 @@ Pad Templates:
|
||||||
the property contains a UTF-8 string.
|
the property contains a UTF-8 string.
|
||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
A fraction value (<classname>GST_TYPE_FRACTION</classname>):
|
||||||
|
contains a fraction expressed by an integer numerator and
|
||||||
|
denominator.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
</itemizedlist>
|
</itemizedlist>
|
||||||
</listitem>
|
</listitem>
|
||||||
<listitem>
|
<listitem>
|
||||||
|
@ -330,6 +337,14 @@ Pad Templates:
|
||||||
lower and an upper boundary.
|
lower and an upper boundary.
|
||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
A fraction range value
|
||||||
|
(<classname>GST_TYPE_FRACTION_RANGE</classname>): the property
|
||||||
|
denotes a range of possible fraction values, with a
|
||||||
|
lower and an upper boundary.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
</itemizedlist>
|
</itemizedlist>
|
||||||
</listitem>
|
</listitem>
|
||||||
<listitem>
|
<listitem>
|
||||||
|
@ -338,10 +353,16 @@ Pad Templates:
|
||||||
property can take any value from a list of basic values
|
property can take any value from a list of basic values
|
||||||
given in this list.
|
given in this list.
|
||||||
</para>
|
</para>
|
||||||
|
<para>
|
||||||
|
Example: caps that express that either
|
||||||
|
a sample rate of 44100 Hz and a sample rate of 48000 Hz
|
||||||
|
is supported would use a list of integer values, with
|
||||||
|
one value being 44100 and one value being 48000.
|
||||||
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
An array value (<classname>GST_TYPE_FIXED_LIST</classname>): the
|
An array value (<classname>GST_TYPE_ARRAY</classname>): the
|
||||||
property is an array of values. Each value in the array is a
|
property is an array of values. Each value in the array is a
|
||||||
full value on its own, too. All values in the array should be
|
full value on its own, too. All values in the array should be
|
||||||
of the same elementary type. This means that an array can
|
of the same elementary type. This means that an array can
|
||||||
|
@ -349,6 +370,15 @@ Pad Templates:
|
||||||
ranges together, and the same for floats or strings, but it can
|
ranges together, and the same for floats or strings, but it can
|
||||||
not contain both floats and ints at the same time.
|
not contain both floats and ints at the same time.
|
||||||
</para>
|
</para>
|
||||||
|
<para>
|
||||||
|
Example: for audio where there are more than two channels involved
|
||||||
|
the channel layout needs to be specified (for one and two channel
|
||||||
|
audio the channel layout is implicit unless stated otherwise in the
|
||||||
|
caps). So the channel layout would be an array of integer enum
|
||||||
|
values where each enum value represents a loudspeaker position.
|
||||||
|
Unlike a <classname>GST_TYPE_LIST</classname>, the values in an
|
||||||
|
array will be interpreted as a whole.
|
||||||
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
</itemizedlist>
|
</itemizedlist>
|
||||||
</sect2>
|
</sect2>
|
||||||
|
@ -357,8 +387,8 @@ Pad Templates:
|
||||||
<sect1 id="section-caps-api">
|
<sect1 id="section-caps-api">
|
||||||
<title>What capabilities are used for</title>
|
<title>What capabilities are used for</title>
|
||||||
<para>
|
<para>
|
||||||
Capabilities describe the type of data that is streamed between
|
Capabilities (short: caps) describe the type of data that is streamed
|
||||||
two pads, or that one pad (template) supports. This makes them
|
between two pads, or that one pad (template) supports. This makes them
|
||||||
very useful for various purposes:
|
very useful for various purposes:
|
||||||
</para>
|
</para>
|
||||||
<itemizedlist>
|
<itemizedlist>
|
||||||
|
@ -391,9 +421,15 @@ Pad Templates:
|
||||||
possible media types that can stream between two pads to a
|
possible media types that can stream between two pads to a
|
||||||
specific subset of their supported stream types. An application
|
specific subset of their supported stream types. An application
|
||||||
can, for example, use <quote>filtered caps</quote> to set a
|
can, for example, use <quote>filtered caps</quote> to set a
|
||||||
specific (non-fixed) video size that will stream between two
|
specific (fixed or non-fixed) video size that should stream
|
||||||
pads. You will see an example of filtered caps further on in
|
between two pads. You will see an example of filtered caps
|
||||||
this manual, in <xref linkend="section-data-spoof"/>.
|
later in this manual, in <xref linkend="section-data-spoof"/>.
|
||||||
|
You can do caps filtering by inserting a capsfilter element into
|
||||||
|
your pipeline and setting its <quote>caps</quote> property. Caps
|
||||||
|
filters are often placed after converter elements like audioconvert,
|
||||||
|
audioresample, ffmpegcolorspace or videoscale to force those
|
||||||
|
converters to convert data to a specific output format at a
|
||||||
|
certain point in a stream.
|
||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
</itemizedlist>
|
</itemizedlist>
|
||||||
|
@ -402,11 +438,42 @@ Pad Templates:
|
||||||
<title>Using capabilities for metadata</title>
|
<title>Using capabilities for metadata</title>
|
||||||
<para>
|
<para>
|
||||||
A pad can have a set (i.e. one or more) of capabilities attached
|
A pad can have a set (i.e. one or more) of capabilities attached
|
||||||
to it. You can get values of properties in a set of capabilities
|
to it. Capabilities (<classname>GstCaps</classname>) are represented
|
||||||
|
as an array of one or more <classname>GstStructure</classname>s, and
|
||||||
|
each <classname>GstStructure</classname> is an array of fields where
|
||||||
|
each field consists of a field name string (e.g. "width") and a
|
||||||
|
typed value (e.g. <classname>G_TYPE_INT</classname> or
|
||||||
|
<classname>GST_TYPE_INT_RANGE</classname>).
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that there is a distinct difference between the
|
||||||
|
<emphasis>possible</emphasis> capabilities of a pad (ie. usually what
|
||||||
|
you find as caps of pad templates as they are shown in gst-inspect),
|
||||||
|
the <emphasis>allowed</emphasis> caps of a pad (can be the same as
|
||||||
|
the pad's template caps or a subset of them, depending on the possible
|
||||||
|
caps of the peer pad) and lastly <emphasis>negotiated</emphasis> caps
|
||||||
|
(these describe the exact format of a stream or buffer and contain
|
||||||
|
exactly one structure and have no variable bits like ranges or lists,
|
||||||
|
ie. they are fixed caps).
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
You can get values of properties in a set of capabilities
|
||||||
by querying individual properties of one structure. You can get
|
by querying individual properties of one structure. You can get
|
||||||
a structure from a caps using
|
a structure from a caps using
|
||||||
<function>gst_caps_get_structure ()</function>:
|
<function>gst_caps_get_structure ()</function> and the number of
|
||||||
|
structures in a <classname>GstCaps</classname> using
|
||||||
|
<function>gst_caps_get_size ()</function>.
|
||||||
</para>
|
</para>
|
||||||
|
<para>
|
||||||
|
Caps are called <emphasis>simple caps</emphasis> when they contain
|
||||||
|
only one structure, and <emphasis>fixed caps</emphasis> when they
|
||||||
|
contain only one structure and have no variable field types (like
|
||||||
|
ranges or lists of possible values). Two other special types of caps
|
||||||
|
are <emphasis>ANY caps</emphasis> and <emphasis>empty caps</emphasis>.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Here is an example of how to extract the width and height from
|
||||||
|
a set of fixed video caps:
|
||||||
<programlisting>
|
<programlisting>
|
||||||
static void
|
static void
|
||||||
read_video_props (GstCaps *caps)
|
read_video_props (GstCaps *caps)
|
||||||
|
@ -414,7 +481,9 @@ read_video_props (GstCaps *caps)
|
||||||
gint width, height;
|
gint width, height;
|
||||||
const GstStructure *str;
|
const GstStructure *str;
|
||||||
|
|
||||||
str = gst_caps_get_structure (caps);
|
g_return_if_fail (gst_caps_is_fixed (caps));
|
||||||
|
|
||||||
|
str = gst_caps_get_structure (caps, 0);
|
||||||
if (!gst_structure_get_int (str, "width", &width) ||
|
if (!gst_structure_get_int (str, "width", &width) ||
|
||||||
!gst_structure_get_int (str, "height", &height)) {
|
!gst_structure_get_int (str, "height", &height)) {
|
||||||
g_print ("No width/height available\n");
|
g_print ("No width/height available\n");
|
||||||
|
@ -425,38 +494,58 @@ read_video_props (GstCaps *caps)
|
||||||
width, height);
|
width, height);
|
||||||
}
|
}
|
||||||
</programlisting>
|
</programlisting>
|
||||||
|
</para>
|
||||||
</sect2>
|
</sect2>
|
||||||
|
|
||||||
<sect2 id="section-caps-filter">
|
<sect2 id="section-caps-filter">
|
||||||
<title>Creating capabilities for filtering</title>
|
<title>Creating capabilities for filtering</title>
|
||||||
<para>
|
<para>
|
||||||
While capabilities are mainly used inside a plugin to describe the
|
While capabilities are mainly used inside a plugin to describe the
|
||||||
media type of the pads, the application programmer also has to have
|
media type of the pads, the application programmer often also has
|
||||||
basic understanding of capabilities in order to interface with the
|
to have basic understanding of capabilities in order to interface
|
||||||
plugins, especially when using filtered caps. When you're using
|
with the plugins, especially when using filtered caps. When you're
|
||||||
filtered caps or fixation, you're limiting the allowed types of
|
using filtered caps or fixation, you're limiting the allowed types of
|
||||||
media that can stream between two pads to a subset of their supported
|
media that can stream between two pads to a subset of their supported
|
||||||
media types. You do this by filtering using your own set of
|
media types. You do this using a <classname>capsfilter</classname>
|
||||||
capabilities. In order to do this, you need to create your own
|
element in your pipeline. In order to do this, you also need to
|
||||||
<classname>GstCaps</classname>. The simplest way to do this is by
|
create your own <classname>GstCaps</classname>. The easiest way to
|
||||||
using the convenience function <function>gst_caps_new_simple
|
do this is by using the convenience function
|
||||||
()</function>:
|
<function>gst_caps_new_simple ()</function>:
|
||||||
</para>
|
</para>
|
||||||
|
<para>
|
||||||
<programlisting>
|
<programlisting>
|
||||||
static void
|
static gboolean
|
||||||
link_pads_with_filter (GstPad *one,
|
link_elements_with_filter (GstElement *element1, GstElement *element2)
|
||||||
GstPad *other)
|
|
||||||
{
|
{
|
||||||
|
gboolean link_ok;
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
|
|
||||||
caps = gst_caps_new_simple ("video/x-raw-yuv",
|
caps = gst_caps_new_simple ("video/x-raw-yuv",
|
||||||
|
"format", GST_TYPE_FOURCC, GST_MAKE_FOURCC ('I', '4', '2', '0'),
|
||||||
"width", G_TYPE_INT, 384,
|
"width", G_TYPE_INT, 384,
|
||||||
"height", G_TYPE_INT, 288,
|
"height", G_TYPE_INT, 288,
|
||||||
"framerate", GST_TYPE_FRACTION, 25, 1,
|
"framerate", GST_TYPE_FRACTION, 25, 1,
|
||||||
NULL);
|
NULL);
|
||||||
gst_pad_link_filtered (one, other, caps);
|
|
||||||
|
link_ok = gst_element_link_filtered (element1, element2, caps);
|
||||||
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
|
if (!link_ok) {
|
||||||
|
g_warning ("Failed to link element1 and element2!");
|
||||||
|
}
|
||||||
|
|
||||||
|
return link_ok;
|
||||||
}
|
}
|
||||||
</programlisting>
|
</programlisting>
|
||||||
|
This will force the data flow between those two elements to a
|
||||||
|
a certain video format, width, height and framerate (or the linking
|
||||||
|
will fail if that cannot be achieved in the context of the elments
|
||||||
|
involved). Keep in mind that when you use <function>
|
||||||
|
gst_element_link_filtered ()</function> it will automatically create
|
||||||
|
a <classname>capsfilter</classname> element for you and insert it into
|
||||||
|
your bin or pipeline between the two elements you want to connect (this
|
||||||
|
is important if you ever want to disconnect those elements).
|
||||||
|
</para>
|
||||||
<para>
|
<para>
|
||||||
In some cases, you will want to create a more elaborate set of
|
In some cases, you will want to create a more elaborate set of
|
||||||
capabilities to filter a link between two pads. Then, this function
|
capabilities to filter a link between two pads. Then, this function
|
||||||
|
@ -464,10 +553,10 @@ link_pads_with_filter (GstPad *one,
|
||||||
<function>gst_caps_new_full ()</function>:
|
<function>gst_caps_new_full ()</function>:
|
||||||
</para>
|
</para>
|
||||||
<programlisting>
|
<programlisting>
|
||||||
static void
|
static gboolean
|
||||||
link_pads_with_filter (GstPad *one,
|
link_elements_with_filter (GstElement *element1, GstElement *element2)
|
||||||
GstPad *other)
|
|
||||||
{
|
{
|
||||||
|
gboolean link_ok;
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
|
|
||||||
caps = gst_caps_new_full (
|
caps = gst_caps_new_full (
|
||||||
|
@ -483,7 +572,14 @@ link_pads_with_filter (GstPad *one,
|
||||||
NULL),
|
NULL),
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
gst_pad_link_filtered (one, other, caps);
|
link_ok = gst_element_link_filtered (element1, element2, caps);
|
||||||
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
|
if (!link_ok) {
|
||||||
|
g_warning ("Failed to link element1 and element2!");
|
||||||
|
}
|
||||||
|
|
||||||
|
return link_ok;
|
||||||
}
|
}
|
||||||
</programlisting>
|
</programlisting>
|
||||||
<para>
|
<para>
|
||||||
|
|
Loading…
Reference in a new issue