2000-08-22 21:18:18 +00:00
|
|
|
<chapter id="cha-queues">
|
|
|
|
<title>Queues</title>
|
|
|
|
<para>
|
2001-01-05 18:50:41 +00:00
|
|
|
A <classname>GstQueue</classname> is a filter element.
|
2000-09-09 16:36:10 +00:00
|
|
|
Queues can be used to connect two elements in such way that the data can
|
|
|
|
be buffered.
|
2000-08-22 21:18:18 +00:00
|
|
|
</para>
|
2000-09-09 16:36:10 +00:00
|
|
|
<para>
|
|
|
|
A buffer that is sinked to a Queue will not automatically be pushed to the
|
|
|
|
next connected element but will be buffered. It will be pushed to the next
|
2002-09-14 14:13:34 +00:00
|
|
|
element as soon as a gst_pad_pull () is called on the queue's source pad.
|
2000-09-09 16:36:10 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Queues are mostly used in conjunction with a <classname>GstThread</classname> to
|
|
|
|
provide an external connection for the thread elements. You could have one
|
|
|
|
thread feeding buffers into a <classname>GstQueue</classname> and another
|
2001-01-08 22:08:40 +00:00
|
|
|
thread repeadedly calling gst_pad_pull () on the queue to feed its
|
2000-09-09 16:36:10 +00:00
|
|
|
internal elements.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Below is a figure of a two-threaded decoder. We have one thread (the main execution
|
|
|
|
thread) reading the data from a file, and another thread decoding the data.
|
|
|
|
</para>
|
|
|
|
<figure float="1" id="sec-queues-img">
|
|
|
|
<title>a two-threaded decoder with a queue</title>
|
2001-12-13 15:24:00 +00:00
|
|
|
<mediaobject>
|
|
|
|
<imageobject>
|
2001-12-15 23:13:04 +00:00
|
|
|
<imagedata fileref="images/queue.&magic;" format="&magic;" />
|
2001-12-13 15:24:00 +00:00
|
|
|
</imageobject>
|
|
|
|
</mediaobject>
|
2000-09-09 16:36:10 +00:00
|
|
|
</figure>
|
|
|
|
|
2001-01-08 22:08:40 +00:00
|
|
|
<para>
|
|
|
|
The standard <application>GStreamer</application> queue implementation has some
|
2001-07-07 11:34:54 +00:00
|
|
|
properties that can be changed using the g_objet_set () method. To set the
|
2001-01-08 22:08:40 +00:00
|
|
|
maximum number of buffers that can be queued to 30, do:
|
|
|
|
</para>
|
|
|
|
<programlisting>
|
2001-07-07 11:34:54 +00:00
|
|
|
g_object_set (G_OBJECT (queue), "max_level", 30, NULL);
|
2001-01-08 22:08:40 +00:00
|
|
|
</programlisting>
|
|
|
|
|
|
|
|
<para>
|
2002-09-14 14:13:34 +00:00
|
|
|
The following MP3 player shows you how to create the above pipeline
|
2002-09-08 21:17:16 +00:00
|
|
|
using a thread and a queue.
|
2001-01-08 22:08:40 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<programlisting>
|
2002-09-15 21:33:26 +00:00
|
|
|
/* example-begin queue.c */
|
2001-01-08 22:08:40 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <gst/gst.h>
|
|
|
|
|
|
|
|
gboolean playing;
|
|
|
|
|
|
|
|
/* eos will be called when the src element has an end of stream */
|
|
|
|
void
|
|
|
|
eos (GstElement *element, gpointer data)
|
|
|
|
{
|
|
|
|
g_print ("have eos, quitting\n");
|
|
|
|
|
|
|
|
playing = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
main (int argc, char *argv[])
|
|
|
|
{
|
2002-09-15 21:33:26 +00:00
|
|
|
GstElement *filesrc, *audiosink, *queue, *decode;
|
2001-01-08 22:08:40 +00:00
|
|
|
GstElement *bin;
|
|
|
|
GstElement *thread;
|
|
|
|
|
|
|
|
gst_init (&argc,&argv);
|
|
|
|
|
|
|
|
if (argc != 2) {
|
2002-09-15 21:33:26 +00:00
|
|
|
g_print ("usage: %s <mp3 filename>\n", argv[0]);
|
2001-01-08 22:08:40 +00:00
|
|
|
exit (-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* create a new thread to hold the elements */
|
|
|
|
thread = gst_thread_new ("thread");
|
|
|
|
g_assert (thread != NULL);
|
|
|
|
|
|
|
|
/* create a new bin to hold the elements */
|
|
|
|
bin = gst_bin_new ("bin");
|
|
|
|
g_assert (bin != NULL);
|
|
|
|
|
|
|
|
/* create a disk reader */
|
2002-04-11 20:35:18 +00:00
|
|
|
filesrc = gst_element_factory_make ("filesrc", "disk_source");
|
2002-01-06 04:26:37 +00:00
|
|
|
g_assert (filesrc != NULL);
|
|
|
|
g_object_set (G_OBJECT (filesrc), "location", argv[1], NULL);
|
|
|
|
g_signal_connect (G_OBJECT (filesrc), "eos",
|
2002-09-15 21:33:26 +00:00
|
|
|
G_CALLBACK (eos), thread);
|
2001-01-08 22:08:40 +00:00
|
|
|
|
2002-04-11 20:35:18 +00:00
|
|
|
queue = gst_element_factory_make ("queue", "queue");
|
2002-09-15 21:33:26 +00:00
|
|
|
g_assert (queue != NULL);
|
2001-01-08 22:08:40 +00:00
|
|
|
|
|
|
|
/* and an audio sink */
|
2002-09-15 21:33:26 +00:00
|
|
|
audiosink = gst_element_factory_make ("osssink", "play_audio");
|
2001-01-08 22:08:40 +00:00
|
|
|
g_assert (audiosink != NULL);
|
|
|
|
|
2002-09-15 21:33:26 +00:00
|
|
|
decode = gst_element_factory_make ("mad", "decode");
|
2001-01-08 22:08:40 +00:00
|
|
|
|
|
|
|
/* add objects to the main bin */
|
2002-09-15 21:33:26 +00:00
|
|
|
gst_bin_add_many (GST_BIN (thread), decode, audiosink, NULL);
|
2001-01-08 22:08:40 +00:00
|
|
|
|
2002-09-15 21:33:26 +00:00
|
|
|
gst_bin_add_many (GST_BIN (bin), filesrc, queue, thread, NULL);
|
2001-01-08 22:08:40 +00:00
|
|
|
|
2002-09-15 21:33:26 +00:00
|
|
|
|
|
|
|
gst_element_connect (filesrc, queue);
|
|
|
|
gst_element_connect_many (queue, decode, audiosink, NULL);
|
2001-01-08 22:08:40 +00:00
|
|
|
|
|
|
|
/* start playing */
|
|
|
|
gst_element_set_state (GST_ELEMENT (bin), GST_STATE_PLAYING);
|
|
|
|
|
|
|
|
playing = TRUE;
|
|
|
|
|
|
|
|
while (playing) {
|
|
|
|
gst_bin_iterate (GST_BIN (bin));
|
|
|
|
}
|
|
|
|
|
|
|
|
gst_element_set_state (GST_ELEMENT (bin), GST_STATE_NULL);
|
|
|
|
|
2002-09-15 21:33:26 +00:00
|
|
|
return 0;
|
2001-01-08 22:08:40 +00:00
|
|
|
}
|
2002-09-15 21:33:26 +00:00
|
|
|
/* example-end queue.c */
|
2001-01-08 22:08:40 +00:00
|
|
|
</programlisting>
|
|
|
|
|
2000-09-09 16:36:10 +00:00
|
|
|
|
2000-08-22 21:18:18 +00:00
|
|
|
|
|
|
|
</chapter>
|