Top |
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.