mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
libs/gst/base/gstbasesrc.c: Document how applications can stop recording from live sources (see #330996).
Original commit message from CVS: * libs/gst/base/gstbasesrc.c: Document how applications can stop recording from live sources (see #330996).
This commit is contained in:
parent
083e7eb417
commit
32aff01e8d
2 changed files with 67 additions and 10 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
2006-02-24 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* libs/gst/base/gstbasesrc.c:
|
||||||
|
Document how applications can stop recording from
|
||||||
|
live sources (see #330996).
|
||||||
|
|
||||||
2006-02-23 Tim-Philipp Müller <tim at centricular dot net>
|
2006-02-23 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* docs/gst/tmpl/.cvsignore:
|
* docs/gst/tmpl/.cvsignore:
|
||||||
|
|
|
@ -33,18 +33,22 @@
|
||||||
* <listitem><para>live sources</para></listitem>
|
* <listitem><para>live sources</para></listitem>
|
||||||
* </itemizedlist>
|
* </itemizedlist>
|
||||||
*
|
*
|
||||||
|
* <refsect2>
|
||||||
|
* <para>
|
||||||
* The source can be configured to operate in a any #GstFormat with the
|
* The source can be configured to operate in a any #GstFormat with the
|
||||||
* gst_base_src_set_format(). This format determines the format of the
|
* gst_base_src_set_format(). This format determines the format of the
|
||||||
* internal #GstSegment and the #GST_EVENT_NEW_SEGMENT. The default format for
|
* internal #GstSegment and the #GST_EVENT_NEW_SEGMENT. The default format for
|
||||||
* #GstBaseSrc is GST_FORMAT_BYTES.
|
* #GstBaseSrc is GST_FORMAT_BYTES.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* #GstBaseSrc always supports the push mode scheduling. If the following
|
* #GstBaseSrc always supports the push mode scheduling. If the following
|
||||||
* conditions are met, it also supports pull mode scheduling:
|
* conditions are met, it also supports pull mode scheduling:
|
||||||
* <itemizedlist>
|
* <itemizedlist>
|
||||||
* <listitem><para>the format is set to GST_FORMAT_BYTES (default).</para></listitem>
|
* <listitem><para>the format is set to GST_FORMAT_BYTES (default).</para></listitem>
|
||||||
* <listitem><para>#GstBaseSrc::is_seekable returns TRUE.</para></listitem>
|
* <listitem><para>#GstBaseSrc::is_seekable returns TRUE.</para></listitem>
|
||||||
* </itemizedlist>
|
* </itemizedlist>
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* If all the conditions are met for operating in pull mode, #GstBaseSrc is
|
* If all the conditions are met for operating in pull mode, #GstBaseSrc is
|
||||||
* automatically seekable in push mode as well. The following conditions must be
|
* automatically seekable in push mode as well. The following conditions must be
|
||||||
* met to make the element seekable in push mode when the format is not
|
* met to make the element seekable in push mode when the format is not
|
||||||
|
@ -61,34 +65,41 @@
|
||||||
* #GstBaseSrc::do_seek is implemented, performs the seek and returns TRUE.
|
* #GstBaseSrc::do_seek is implemented, performs the seek and returns TRUE.
|
||||||
* </para></listitem>
|
* </para></listitem>
|
||||||
* </itemizedlist>
|
* </itemizedlist>
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* When the default format is not GST_FORMAT_BYTES, the element should ignore the
|
* When the default format is not GST_FORMAT_BYTES, the element should ignore the
|
||||||
* offset and length in the #GstBaseSrc::create method. It is recommended to subclass
|
* offset and length in the #GstBaseSrc::create method. It is recommended to subclass
|
||||||
* #GstPushSrc instead in this situation.
|
* #GstPushSrc instead in this situation.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* #GstBaseSrc has support for live sources. Live sources are sources that produce
|
* #GstBaseSrc has support for live sources. Live sources are sources that produce
|
||||||
* data at a fixed rate, such as audio or video capture. A typical live source also
|
* data at a fixed rate, such as audio or video capture. A typical live source also
|
||||||
* provides a clock to export the rate at which they produce data.
|
* provides a clock to export the rate at which they produce data.
|
||||||
* Use gst_base_src_set_live() to activate the live source mode.
|
* Use gst_base_src_set_live() to activate the live source mode.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* A live source does not produce data in the PAUSED state, this means that the
|
* A live source does not produce data in the PAUSED state, this means that the
|
||||||
* #GstBaseSrc::create method will not be called in PAUSED but only in PLAYING.
|
* #GstBaseSrc::create method will not be called in PAUSED but only in PLAYING.
|
||||||
* To signal the pipeline that the element will not produce data, its return
|
* To signal the pipeline that the element will not produce data, its return
|
||||||
* value from the READY to PAUSED state will be GST_STATE_CHANGE_NO_PREROLL.
|
* value from the READY to PAUSED state will be GST_STATE_CHANGE_NO_PREROLL.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* A typical live source will timestamp the buffers they create with the current
|
* A typical live source will timestamp the buffers they create with the current
|
||||||
* stream time of the pipeline. This is why they can only produce data in PLAYING,
|
* stream time of the pipeline. This is why they can only produce data in PLAYING,
|
||||||
* when the clock is actually distributed and running.
|
* when the clock is actually distributed and running.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* The #GstBaseSrc::get_times method can be used to implement pseudo-live sources.
|
* The #GstBaseSrc::get_times method can be used to implement pseudo-live sources.
|
||||||
* The base source will wait for the specified stream time returned in
|
* The base source will wait for the specified stream time returned in
|
||||||
* #GstBaseSrc::get_times before pushing out the buffer. It only makes sense to implement
|
* #GstBaseSrc::get_times before pushing out the buffer. It only makes sense to implement
|
||||||
* the ::get_times function if the source is a live source.
|
* the ::get_times function if the source is a live source.
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* There is only support in GstBaseSrc for one source pad, which should be named
|
* There is only support in GstBaseSrc for one source pad, which should be named
|
||||||
* "src". A source implementation (subclass of GstBaseSrc) should install a pad
|
* "src". A source implementation (subclass of GstBaseSrc) should install a pad
|
||||||
* template in its base_init function, like so:
|
* template in its base_init function, like so:
|
||||||
*
|
* </para>
|
||||||
|
* <para>
|
||||||
* <programlisting>
|
* <programlisting>
|
||||||
* static void
|
* static void
|
||||||
* my_element_base_init (gpointer g_class)
|
* my_element_base_init (gpointer g_class)
|
||||||
|
@ -102,8 +113,48 @@
|
||||||
* gst_element_class_set_details (gstelement_class, &details);
|
* gst_element_class_set_details (gstelement_class, &details);
|
||||||
* }
|
* }
|
||||||
* </programlisting>
|
* </programlisting>
|
||||||
*
|
* </para>
|
||||||
|
* <title>Controlled shutdown of live sources in applications</title>
|
||||||
|
* <para>
|
||||||
|
* Applications that record from a live source may want to stop recording
|
||||||
|
* in a controlled way, so that the recording is stopped, but the data
|
||||||
|
* already in the pipeline processed to the end (remember that many live
|
||||||
|
* sources would go on recording forever otherwise). For that to happen the
|
||||||
|
* application needs to make the source stop recording and send an EOS
|
||||||
|
* event down the pipeline. The application would then wait for an
|
||||||
|
* EOS message posted on the pipeline's bus to know when all data has
|
||||||
|
* been processed and the pipeline can safely be stopped.
|
||||||
|
* </para>
|
||||||
|
* <para>
|
||||||
|
* Since GStreamer 0.10.3 an application may simply set the source
|
||||||
|
* element to NULL or READY state to make it send an EOS event downstream.
|
||||||
|
* The application should lock the state of the source afterwards, so that
|
||||||
|
* shutting down the pipeline from PLAYING doesn't temporarily start up the
|
||||||
|
* source element for a second time:
|
||||||
|
* <programlisting>
|
||||||
|
* ...
|
||||||
|
* // stop recording
|
||||||
|
* gst_element_set_state (audio_source, GST_STATE_NULL);
|
||||||
|
* gst_element_get_state (audio_source, NULL, NULL, -1);
|
||||||
|
* gst_element_set_locked_state (audio_source, TRUE);
|
||||||
|
* ...
|
||||||
|
* </programlisting>
|
||||||
|
* Now the application should wait for an EOS message
|
||||||
|
* to be posted on the pipeline's bus. Once it has received
|
||||||
|
* an EOS message, it may safely shut down the entire pipeline:
|
||||||
|
* <programlisting>
|
||||||
|
* ...
|
||||||
|
* // everything done - shut down pipeline
|
||||||
|
* gst_element_set_state (pipeline, GST_STATE_NULL);
|
||||||
|
* gst_element_get_state (pipeline, NULL, NULL, -1);
|
||||||
|
* gst_element_set_locked_state (audio_source, FALSE);
|
||||||
|
* ...
|
||||||
|
* </programlisting>
|
||||||
|
* </para>
|
||||||
|
* <para>
|
||||||
* Last reviewed on 2005-12-18 (0.10.0)
|
* Last reviewed on 2005-12-18 (0.10.0)
|
||||||
|
* </para>
|
||||||
|
* </refsect2>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
Loading…
Reference in a new issue