mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
gst/base/gstbasesink.c: Add the beginning of docs here -- have to work on something else now tho...
Original commit message from CVS: 2005-11-09 Andy Wingo <wingo@pobox.com> * gst/base/gstbasesink.c: Add the beginning of docs here -- have to work on something else now tho...
This commit is contained in:
parent
0ae7675f7e
commit
179f6c4f3b
3 changed files with 95 additions and 20 deletions
|
@ -1,5 +1,8 @@
|
||||||
2005-11-09 Andy Wingo <wingo@pobox.com>
|
2005-11-09 Andy Wingo <wingo@pobox.com>
|
||||||
|
|
||||||
|
* gst/base/gstbasesink.c: Add the beginning of docs here -- have
|
||||||
|
to work on something else now tho...
|
||||||
|
|
||||||
* gst/base/gstadapter.c: More adapter docs.
|
* gst/base/gstadapter.c: More adapter docs.
|
||||||
|
|
||||||
* gst/elements/gstfilesink.c (gst_file_sink_start)
|
* gst/elements/gstfilesink.c (gst_file_sink_start)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
|
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
|
||||||
*
|
*
|
||||||
* gstbasesink.c:
|
* gstbasesink.c: Base class for sink elements
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -24,16 +24,52 @@
|
||||||
* @short_description: Base class for sink elements
|
* @short_description: Base class for sink elements
|
||||||
* @see_also: #GstBaseTransform, #GstBaseSource
|
* @see_also: #GstBaseTransform, #GstBaseSource
|
||||||
*
|
*
|
||||||
* This class is for elements that do output operations.
|
* GstBaseSink is the base class for sink elements in GStreamer, such as
|
||||||
|
* xvimagesink or filesink. It is a layer on top of #GstElement that provides a
|
||||||
|
* simplified interface to plugin writers. GstBaseSink handles many details for
|
||||||
|
* you, for example preroll, clock synchronization, state changes, activation in
|
||||||
|
* push or pull mode, and queries. In most cases, when writing sink elements,
|
||||||
|
* there is no need to implement class methods from #GstElement or to set
|
||||||
|
* functions on pads, because the GstBaseSink infrastructure is sufficient.
|
||||||
*
|
*
|
||||||
* <itemizedlist>
|
* There is only support in GstBaseSink for one sink pad, which should be named
|
||||||
* <listitem><para>one sinkpad</para></listitem>
|
* "sink". A sink implementation (subclass of GstBaseSink) should install a pad
|
||||||
* <listitem><para>handles state changes</para></listitem>
|
* template in its base_init function, like so:
|
||||||
* <listitem><para>pull/push mode</para></listitem>
|
* <programlisting>
|
||||||
* <listitem><para>handles seeking/query</para></listitem>
|
* static void
|
||||||
* <listitem><para>handles preroll</para></listitem>
|
* my_element_base_init (gpointer g_class)
|
||||||
* <listitem><para>EOS handling</para></listitem>
|
* {
|
||||||
* </itemizedlist>
|
* GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class);
|
||||||
|
*
|
||||||
|
* // sinktemplate should be a #GstStaticPadTemplate with direction
|
||||||
|
* // #GST_PAD_SINK and name "sink"
|
||||||
|
* gst_element_class_add_pad_template (gstelement_class,
|
||||||
|
* gst_static_pad_template_get (&sinktemplate));
|
||||||
|
* // see #GstElementDetails
|
||||||
|
* gst_element_class_set_details (gstelement_class, &details);
|
||||||
|
* }
|
||||||
|
* </programlisting>
|
||||||
|
*
|
||||||
|
* The one method which all subclasses of GstBaseSink must implement is
|
||||||
|
* GstBaseSink::render. This method will be called...
|
||||||
|
*
|
||||||
|
* preroll()
|
||||||
|
*
|
||||||
|
* event(): mostly useful for file-like sinks (seeking or flushing)
|
||||||
|
*
|
||||||
|
* get_caps/set_caps/buffer_alloc
|
||||||
|
*
|
||||||
|
* start/stop for resource allocation
|
||||||
|
*
|
||||||
|
* unlock if you block on an fd, for example
|
||||||
|
*
|
||||||
|
* get_times i'm sure is for something :P
|
||||||
|
*
|
||||||
|
* provide example of textsink
|
||||||
|
*
|
||||||
|
* admonishment not to try to implement your own sink with prerolling...
|
||||||
|
*
|
||||||
|
* extending via subclassing, setting pad functions, gstelement vmethods.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
|
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
|
||||||
*
|
*
|
||||||
* gstbasesink.c:
|
* gstbasesink.c: Base class for sink elements
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -24,16 +24,52 @@
|
||||||
* @short_description: Base class for sink elements
|
* @short_description: Base class for sink elements
|
||||||
* @see_also: #GstBaseTransform, #GstBaseSource
|
* @see_also: #GstBaseTransform, #GstBaseSource
|
||||||
*
|
*
|
||||||
* This class is for elements that do output operations.
|
* GstBaseSink is the base class for sink elements in GStreamer, such as
|
||||||
|
* xvimagesink or filesink. It is a layer on top of #GstElement that provides a
|
||||||
|
* simplified interface to plugin writers. GstBaseSink handles many details for
|
||||||
|
* you, for example preroll, clock synchronization, state changes, activation in
|
||||||
|
* push or pull mode, and queries. In most cases, when writing sink elements,
|
||||||
|
* there is no need to implement class methods from #GstElement or to set
|
||||||
|
* functions on pads, because the GstBaseSink infrastructure is sufficient.
|
||||||
*
|
*
|
||||||
* <itemizedlist>
|
* There is only support in GstBaseSink for one sink pad, which should be named
|
||||||
* <listitem><para>one sinkpad</para></listitem>
|
* "sink". A sink implementation (subclass of GstBaseSink) should install a pad
|
||||||
* <listitem><para>handles state changes</para></listitem>
|
* template in its base_init function, like so:
|
||||||
* <listitem><para>pull/push mode</para></listitem>
|
* <programlisting>
|
||||||
* <listitem><para>handles seeking/query</para></listitem>
|
* static void
|
||||||
* <listitem><para>handles preroll</para></listitem>
|
* my_element_base_init (gpointer g_class)
|
||||||
* <listitem><para>EOS handling</para></listitem>
|
* {
|
||||||
* </itemizedlist>
|
* GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class);
|
||||||
|
*
|
||||||
|
* // sinktemplate should be a #GstStaticPadTemplate with direction
|
||||||
|
* // #GST_PAD_SINK and name "sink"
|
||||||
|
* gst_element_class_add_pad_template (gstelement_class,
|
||||||
|
* gst_static_pad_template_get (&sinktemplate));
|
||||||
|
* // see #GstElementDetails
|
||||||
|
* gst_element_class_set_details (gstelement_class, &details);
|
||||||
|
* }
|
||||||
|
* </programlisting>
|
||||||
|
*
|
||||||
|
* The one method which all subclasses of GstBaseSink must implement is
|
||||||
|
* GstBaseSink::render. This method will be called...
|
||||||
|
*
|
||||||
|
* preroll()
|
||||||
|
*
|
||||||
|
* event(): mostly useful for file-like sinks (seeking or flushing)
|
||||||
|
*
|
||||||
|
* get_caps/set_caps/buffer_alloc
|
||||||
|
*
|
||||||
|
* start/stop for resource allocation
|
||||||
|
*
|
||||||
|
* unlock if you block on an fd, for example
|
||||||
|
*
|
||||||
|
* get_times i'm sure is for something :P
|
||||||
|
*
|
||||||
|
* provide example of textsink
|
||||||
|
*
|
||||||
|
* admonishment not to try to implement your own sink with prerolling...
|
||||||
|
*
|
||||||
|
* extending via subclassing, setting pad functions, gstelement vmethods.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
|
|
Loading…
Reference in a new issue