2000-12-30 16:13:17 +00:00
|
|
|
<!-- ##### SECTION Title ##### -->
|
|
|
|
GstAutoplug
|
|
|
|
|
|
|
|
<!-- ##### SECTION Short_Description ##### -->
|
2001-03-21 21:43:56 +00:00
|
|
|
Automatically create and connect elements
|
2000-12-30 16:13:17 +00:00
|
|
|
|
|
|
|
<!-- ##### SECTION Long_Description ##### -->
|
|
|
|
<para>
|
2001-03-21 21:43:56 +00:00
|
|
|
GstAutoplug is an abstract class that is used for constructing and
|
2001-10-19 22:49:35 +00:00
|
|
|
connecting elements. Two types of autopluggers exist: renderer ones and non
|
2001-04-17 21:14:55 +00:00
|
|
|
renderer ones. the renderer autopluggers will not have any src pads while the
|
|
|
|
non renderer ones do.
|
2000-12-30 16:13:17 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2001-10-24 21:44:48 +00:00
|
|
|
You first need to create a suitable autoplugger with gst_autoplugfactory_make()
|
|
|
|
(see #GstAutoplugFactory).
|
2001-04-17 21:14:55 +00:00
|
|
|
The name of the autoplugger must be one of the registered autopluggers
|
|
|
|
(see #GstStaticAutoplug and #GstStaticAutoplugRender).
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
If the autoplugger supports the RENDERER API, use gst_autoplug_to_renderers() call to
|
|
|
|
create a bin that connectes the src caps to the specified rendrer elements. You can
|
|
|
|
then add the bin to a pipeline and run it.
|
|
|
|
|
|
|
|
<programlisting>
|
|
|
|
GstAutoplug *autoplug;
|
|
|
|
GstElement *element;
|
|
|
|
GstElement *sink;
|
|
|
|
|
|
|
|
/* create a static autoplugger */
|
|
|
|
autoplug = gst_autoplugfactory_make ("staticrender");
|
|
|
|
|
|
|
|
/* create an osssink */
|
|
|
|
sink = gst_elementfactory_make ("osssink", "our_sink");
|
|
|
|
|
|
|
|
/* create an element that can play audio/mp3 through osssink */
|
|
|
|
element = gst_autoplug_to_renderers (autoplug,
|
|
|
|
gst_caps_new (
|
|
|
|
"sink_audio_caps",
|
|
|
|
"audio/mp3",
|
|
|
|
NULL
|
|
|
|
),
|
|
|
|
sink,
|
|
|
|
NULL);
|
|
|
|
|
|
|
|
/* add the element to a bin and connect the sink pad */
|
|
|
|
...
|
|
|
|
</programlisting>
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
If the autoplugger supports the CAPS API, use gst_autoplug_to_caps() call to
|
|
|
|
connect the src caps to the destination caps. The created bin will have src pads
|
|
|
|
compatible with the provided sink caps.
|
|
|
|
|
|
|
|
<programlisting>
|
|
|
|
GstAutoplug *autoplug;
|
|
|
|
GstElement *element;
|
|
|
|
|
|
|
|
/* create a static autoplugger */
|
|
|
|
autoplug = gst_autoplugfactory_make ("static");
|
|
|
|
|
|
|
|
/* create an element that converts audio/mp3 to audio/raw */
|
|
|
|
element = gst_autoplug_to_caps (autoplug,
|
|
|
|
gst_caps_new (
|
|
|
|
"sink_audio_caps",
|
|
|
|
"audio/mp3",
|
|
|
|
NULL
|
|
|
|
),
|
|
|
|
gst_caps_new (
|
|
|
|
"src_audio_caps",
|
|
|
|
"audio/raw",
|
|
|
|
NULL
|
|
|
|
),
|
|
|
|
NULL);
|
|
|
|
|
|
|
|
/* add the element to a bin and connect the src/sink pads */
|
|
|
|
...
|
|
|
|
</programlisting>
|
|
|
|
</para>
|
2000-12-30 16:13:17 +00:00
|
|
|
|
2001-04-17 21:14:55 +00:00
|
|
|
<para>
|
|
|
|
Optionally you can get a notification when a new object is added to the created
|
2001-10-24 21:44:48 +00:00
|
|
|
pipeline with a g_signal_connect to the "new_object" signal.
|
2001-04-17 21:14:55 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Use the regular gst_object_destroy() call to destroy the autoplugger.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<!-- ##### SECTION See_Also ##### -->
|
|
|
|
<para>
|
2001-10-19 22:49:35 +00:00
|
|
|
#GstStaticAutoplug, #GstStaticAutoplugRender
|
2000-12-30 16:13:17 +00:00
|
|
|
</para>
|
|
|
|
|
2001-03-21 21:43:56 +00:00
|
|
|
<!-- ##### STRUCT GstAutoplug ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### ENUM GstAutoplugFlags ##### -->
|
|
|
|
<para>
|
2001-04-17 21:14:55 +00:00
|
|
|
The type of the autoplugger.
|
2001-03-21 21:43:56 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
@GST_AUTOPLUG_TO_CAPS:
|
|
|
|
@GST_AUTOPLUG_TO_RENDERER:
|
|
|
|
@GST_AUTOPLUG_FLAG_LAST:
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gst_autoplug_signal_new_object ##### -->
|
2000-12-31 17:02:47 +00:00
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
2001-03-07 21:52:56 +00:00
|
|
|
@autoplug:
|
2001-03-21 21:43:56 +00:00
|
|
|
@object:
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gst_autoplug_to_caps ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
@autoplug:
|
|
|
|
@srccaps:
|
|
|
|
@sinkcaps:
|
2001-03-07 21:52:56 +00:00
|
|
|
@Varargs:
|
2000-12-31 17:02:47 +00:00
|
|
|
@Returns:
|
2001-03-21 21:43:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gst_autoplug_to_renderers ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
@autoplug:
|
2000-12-31 17:02:47 +00:00
|
|
|
@srccaps:
|
2001-03-21 21:43:56 +00:00
|
|
|
@target:
|
|
|
|
@Varargs:
|
|
|
|
@Returns:
|
|
|
|
|
|
|
|
|