Top |
GObject ╰── GInitiallyUnowned ╰── GstObject ╰── GstElement ╰── GstBaseSrc ╰── GstPushSrc
This class is mostly useful for elements that cannot do random access, or at least very slowly. The source usually prefers to push out a fixed size buffer.
Subclasses usually operate in a format that is different from the default GST_FORMAT_BYTES format of GstBaseSrc.
Classes extending this base class will usually be scheduled in a push based mode. If the peer accepts to operate without offsets and within the limits of the allowed block size, this class can operate in getrange based mode automatically. To make this possible, the subclass should implement and override the SCHEDULING query.
The subclass should extend the methods from the baseclass in addition to the ::create method.
Seeking, flushing, scheduling and sync is all handled by this base class.
struct GstPushSrcClass { GstBaseSrcClass parent_class; /* ask the subclass to create a buffer, the default implementation * uses alloc and fill */ GstFlowReturn (*create) (GstPushSrc *src, GstBuffer **buf); /* allocate memory for a buffer */ GstFlowReturn (*alloc) (GstPushSrc *src, GstBuffer **buf); /* ask the subclass to fill a buffer */ GstFlowReturn (*fill) (GstPushSrc *src, GstBuffer *buf); };
Subclasses can override any of the available virtual methods or not, as
needed. At the minimum, the fill
method should be overridden to produce
buffers.
Ask the subclass to create a buffer. The subclass decides which
size this buffer should be. Other then that, refer to
GstBaseSrc.create() for more details. If this method is
not implemented, |
||
Ask the subclass to allocate a buffer. The subclass decides which size this buffer should be. The default implementation will create a new buffer from the negotiated allocator. |
||
Ask the subclass to fill the buffer with data. |