id3demux

id3demux accepts data streams with either (or both) ID3v2 regions at the start, or ID3v1 at the end. The mime type of the data between the tag blocks is detected using typefind functions, and the appropriate output mime type set on outgoing buffers.

The element is only able to read ID3v1 tags from a seekable stream, because they are at the end of the stream. That is, when get_range mode is supported by the upstream elements. If get_range operation is available, id3demux makes it available downstream. This means that elements which require get_range mode, such as wavparse, can operate on files containing ID3 tag information.

This id3demux element replaced an older element with the same name which relied on libid3tag from the MAD project.

Example launch line

 gst-launch-1.0 filesrc location=file.mp3 ! id3demux ! fakesink -t

This pipeline should read any available ID3 tag information and output it. The contents of the file inside the ID3 tag regions should be detected, and the appropriate mime type set on buffers produced from id3demux.

Hierarchy

GObject
    ╰──GInitiallyUnowned
        ╰──GstObject
            ╰──GstElement
                ╰──GstTagDemux
                    ╰──id3demux

Factory details

Authors: – Jan Schmidt

Classification:Codec/Demuxer/Metadata

Rank – primary

Plugin – id3demux

Package – GStreamer Good Plug-ins

Pad Templates

sink

application/x-id3:

Presencealways

Directionsink

Object typeGstPad


src

ANY

Presencealways

Directionsrc

Object typeGstPad


Properties

prefer-v1

“prefer-v1” gboolean

Prefer tags from ID3v1 tag at end of file when both ID3v1 and ID3v2 tags are present

Flags : Read / Write / Construct

Default value : false


The results of the search are