theoraparse

theoraparse

Types and Values

Object Hierarchy

    GObject
    ╰── GInitiallyUnowned
        ╰── GstObject
            ╰── GstElement
                ╰── GstTheoraParse

Description

The theoraparse element will parse the header packets of the Theora stream and put them as the streamheader in the caps. This is used in the multifdsink case where you want to stream live theora streams to multiple clients, each client has to receive the streamheaders first before they can consume the theora packets.

This element also makes sure that the buffers that it pushes out are properly timestamped and that their offset and offset_end are set. The buffers that theoraparse outputs have all of the metadata that oggmux expects to receive, which allows you to (for example) remux an ogg/theora file.

In addition, this element allows you to fix badly synchronized streams. You pass in an array of (granule time, buffer time) synchronization points via the synchronization-points GValueArray property, and this element will adjust the granulepos values that it outputs. The adjustment will be made by offsetting all buffers that it outputs by a specified amount, and updating that offset from the value array whenever a keyframe is processed.

Example pipelines

1
gst-launch-1.0 -v filesrc location=video.ogg ! oggdemux ! theoraparse ! fakesink
This pipeline shows that the streamheader is set in the caps, and that each buffer has the timestamp, duration, offset, and offset_end set.
1
2
gst-launch-1.0 filesrc location=video.ogg ! oggdemux ! theoraparse \
           ! oggmux ! filesink location=video-remuxed.ogg
This pipeline shows remuxing. video-remuxed.ogg might not be exactly the same as video.ogg, but they should produce exactly the same decoded data.

Synopsis

Element Information

plugin

theora

author

Andy Wingo <wingo@pobox.com>

class

Codec/Parser/Video

Element Pads

name

sink

direction

sink

presence

always

details

video/x-theora

name

src

direction

source

presence

always

details

video/x-theora

Functions

Types and Values

struct GstTheoraParse

struct GstTheoraParse;

Opaque data structure.

See Also

theoradec, oggdemux, vorbisparse