2004-01-28 15:51:14 +00:00
|
|
|
<chapter id="chapter-statemanage-states">
|
2002-09-27 18:34:33 +00:00
|
|
|
<title>
|
|
|
|
What are states?
|
|
|
|
</title>
|
|
|
|
<para>
|
2004-01-27 14:58:21 +00:00
|
|
|
A state describes whether the element instance is initialized, whether it
|
|
|
|
is ready to transfer data and whether it is currently handling data. There
|
2004-07-27 15:01:10 +00:00
|
|
|
are four states defined in &GStreamer;: <symbol>GST_STATE_NULL</symbol>,
|
|
|
|
<symbol>GST_STATE_READY</symbol>, <symbol>GST_STATE_PAUSED</symbol>
|
|
|
|
and <symbol>GST_STATE_PLAYING</symbol>.
|
2004-01-27 14:58:21 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2004-07-27 15:01:10 +00:00
|
|
|
<symbol>GST_STATE_NULL</symbol> (from now on referred to as
|
2004-01-27 14:58:21 +00:00
|
|
|
<quote>NULL</quote>) is the default state of an element. In this state, it
|
|
|
|
has not allocated any runtime resources, it has not loaded any runtime
|
|
|
|
libraries and it can obviously not handle data.
|
|
|
|
</para>
|
|
|
|
<para>
|
2004-07-27 15:01:10 +00:00
|
|
|
<symbol>GST_STATE_READY</symbol> (from now on referred to as
|
2004-01-27 14:58:21 +00:00
|
|
|
<quote>READY</quote>) is the next state that an element can be in. In the
|
|
|
|
READY state, an element has all default resources (runtime-libraries,
|
|
|
|
runtime-memory) allocated. However, it has not yet allocated or defined
|
|
|
|
anything that is stream-specific. When going from NULL to READY state
|
2004-07-27 15:01:10 +00:00
|
|
|
(<symbol>GST_STATE_NULL_TO_READY</symbol>), an element should
|
2004-01-27 14:58:21 +00:00
|
|
|
allocate any non-stream-specific resources and should load runtime-loadable
|
|
|
|
libraries (if any). When going the other way around (from READY to NULL,
|
2004-07-27 15:01:10 +00:00
|
|
|
<symbol>GST_STATE_READY_TO_NULL</symbol>), an element should unload
|
2004-01-27 14:58:21 +00:00
|
|
|
these libraries and free all allocated resources. Examples of such
|
|
|
|
resources are hardware devices. Note that files are generally streams,
|
|
|
|
and these should thus be considered as stream-specific resources; therefore,
|
|
|
|
they should <emphasis>not</emphasis> be allocated in this state.
|
|
|
|
</para>
|
|
|
|
<para>
|
2004-07-27 15:01:10 +00:00
|
|
|
<symbol>GST_STATE_PAUSED</symbol> (from now on referred to as
|
2004-01-27 14:58:21 +00:00
|
|
|
<quote>PAUSED</quote>) is a state in which an element is by all means able
|
|
|
|
to handle data; the only 'but' here is that it doesn't actually handle
|
|
|
|
any data. When going from the READY state into the PAUSED state
|
2004-07-27 15:01:10 +00:00
|
|
|
(<symbol>GST_STATE_READY_TO_PAUSED</symbol>), the element will
|
2004-01-27 14:58:21 +00:00
|
|
|
usually not do anything at all: all stream-specific info is generally
|
|
|
|
handled in the <function>_link ()</function>, which is called during caps
|
|
|
|
negotiation. Exceptions to this rule are, for example, files: these are
|
|
|
|
considered stream-specific data (since one file is one stream), and should
|
|
|
|
thus be opened in this state change. When going from the PAUSED back to
|
2004-07-27 15:01:10 +00:00
|
|
|
READY (<symbol>GST_STATE_PAUSED_TO_READY</symbol>), all
|
2004-01-27 14:58:21 +00:00
|
|
|
stream-specific data should be discarded.
|
|
|
|
</para>
|
|
|
|
<para>
|
2004-07-27 15:01:10 +00:00
|
|
|
<symbol>GST_STATE_PLAYING</symbol> (from now on referred to as
|
2004-01-27 14:58:21 +00:00
|
|
|
<quote>PLAYING</quote>) is the highest state that an element can be in. It
|
|
|
|
is similar to PAUSED, except that now, data is actually passing over the
|
|
|
|
pipeline. The transition from PAUSED to PLAYING
|
2004-07-27 15:01:10 +00:00
|
|
|
(<symbol>GST_STATE_PAUSED_TO_PLAYING</symbol>) should be as small
|
2004-01-27 14:58:21 +00:00
|
|
|
as possible and would ideally cause no delay at all. The same goes for the
|
2004-07-27 15:01:10 +00:00
|
|
|
reverse transition (<symbol>GST_STATE_PLAYING_TO_PAUSED</symbol>).
|
2002-09-27 18:34:33 +00:00
|
|
|
</para>
|
2004-01-28 10:03:51 +00:00
|
|
|
|
2004-01-28 15:51:14 +00:00
|
|
|
<sect1 id="section-statemanage-filters">
|
2002-09-27 18:34:33 +00:00
|
|
|
<title>
|
|
|
|
Mangaging filter state
|
|
|
|
</title>
|
|
|
|
<para>
|
2004-01-27 14:58:21 +00:00
|
|
|
An element can be notified of state changes through a virtual function
|
|
|
|
pointer. Inside this function, the element can initialize any sort of
|
|
|
|
specific data needed by the element, and it can optionally fail to
|
|
|
|
go from one state to another.
|
2002-09-27 18:34:33 +00:00
|
|
|
</para>
|
2004-07-09 11:20:59 +00:00
|
|
|
<para>
|
|
|
|
Do not g_assert for unhandled state changes; this is taken care of by
|
|
|
|
the GstElement base class.
|
|
|
|
</para>
|
2004-01-27 14:58:21 +00:00
|
|
|
<programlisting>
|
|
|
|
static GstElementStateReturn
|
|
|
|
gst_my_filter_change_state (GstElement *element);
|
|
|
|
|
|
|
|
static void
|
|
|
|
gst_my_filter_class_init (GstMyFilterClass *klass)
|
|
|
|
{
|
|
|
|
GstElementClass *element_class = GST_ELEMENT_CLASS (klass);
|
|
|
|
|
|
|
|
element_class->change_state = gst_my_filter_change_state;
|
|
|
|
}
|
|
|
|
|
|
|
|
static GstElementStateReturn
|
|
|
|
gst_my_filter_change_state (GstElement *element)
|
|
|
|
{
|
|
|
|
GstMyFilter *filter = GST_MY_FILTER (element);
|
|
|
|
|
|
|
|
switch (GST_STATE_TRANSITION (element)) {
|
|
|
|
case GST_STATE_NULL_TO_READY:
|
|
|
|
if (!gst_my_filter_allocate_memory (filter))
|
|
|
|
return GST_STATE_FAILURE;
|
|
|
|
break;
|
|
|
|
case GST_STATE_READY_TO_NULL:
|
|
|
|
gst_my_filter_free_memory (filter);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GST_ELEMENT_CLASS (parent_class)->change_state)
|
|
|
|
return GST_ELEMENT_CLASS (parent_class)->change_state (element);
|
|
|
|
|
|
|
|
return GST_STATE_SUCCESS;
|
|
|
|
}
|
|
|
|
</programlisting>
|
2004-01-28 10:03:51 +00:00
|
|
|
</sect1>
|
2002-09-27 18:34:33 +00:00
|
|
|
</chapter>
|