Module: Gst::TagSetter

Defined in:
(unknown)

Overview

Element interface that allows setting of media metadata.

Elements that support changing a stream's metadata will implement this interface. Examples of such elements are 'vorbisenc', 'theoraenc' and 'id3v2mux'.

If you just want to retrieve metadata in your application then all you need to do is watch for tag messages on your pipeline's bus. This interface is only for setting metadata, not for extracting it. To set tags from the application, find tagsetter elements and set tags using e.g. gst_tag_setter_merge_tags() or gst_tag_setter_add_tags(). Also consider setting the Gst::TagMergeMode that is used for tag events that arrive at the tagsetter element (default mode is to keep existing tags). The application should do that before the element goes to %GST_STATE_PAUSED.

Elements implementing the Gst::TagSetter interface often have to merge any tags received from upstream and the tags set by the application via the interface. This can be done like this:

GstTagMergeMode merge_mode;
const GstTagList *application_tags;
const GstTagList *event_tags;
GstTagSetter *tagsetter;
GstTagList *result;

tagsetter = GST_TAG_SETTER (element);

merge_mode = gst_tag_setter_get_tag_merge_mode (tagsetter);
application_tags = gst_tag_setter_get_tag_list (tagsetter);
event_tags = (const GstTagList *) element->event_tags;

GST_LOG_OBJECT (tagsetter, "merging tags, merge mode = %d", merge_mode);
GST_LOG_OBJECT (tagsetter, "event tags: %" GST_PTR_FORMAT, event_tags);
GST_LOG_OBJECT (tagsetter, "set   tags: %" GST_PTR_FORMAT, application_tags);

result = gst_tag_list_merge (application_tags, event_tags, merge_mode);

GST_LOG_OBJECT (tagsetter, "final tags: %" GST_PTR_FORMAT, result);

Instance Method Summary collapse

Instance Method Details

#add_tag_valist(mode, tag, var_args) ⇒ nil

Adds the given tag / value pairs on the setter using the given merge mode. The list must be terminated with nil.

Parameters:

  • mode (Gst::TagMergeMode)

    the mode to use

  • tag (String)

    tag to set

  • var_args (Gst::va_list)

    tag / value pairs to set

Returns:

  • (nil)

#add_tag_valist_values(mode, tag, var_args) ⇒ nil

Adds the given tag / GValue pairs on the setter using the given merge mode. The list must be terminated with nil.

Parameters:

  • mode (Gst::TagMergeMode)

    the mode to use

  • tag (String)

    tag to set

  • var_args (Gst::va_list)

    tag / GValue pairs to set

Returns:

  • (nil)

#add_tag_value(mode, tag, value) ⇒ nil

Adds the given tag / GValue pair on the setter using the given merge mode.

Parameters:

  • mode (Gst::TagMergeMode)

    the mode to use

  • tag (String)

    tag to set

  • value (GObject::Value)

    GValue to set for the tag

Returns:

  • (nil)

#add_tag_values(mode, tag, array) ⇒ nil

Adds the given tag / GValue pairs on the setter using the given merge mode. The list must be terminated with nil.

Parameters:

  • mode (Gst::TagMergeMode)

    the mode to use

  • tag (String)

    tag to set

  • array (Array)

    more tag / GValue pairs to set

Returns:

  • (nil)

#add_tags(mode, tag, array) ⇒ nil

Adds the given tag / value pairs on the setter using the given merge mode. The list must be terminated with nil.

Parameters:

  • mode (Gst::TagMergeMode)

    the mode to use

  • tag (String)

    tag to set

  • array (Array)

    more tag / value pairs to set

Returns:

  • (nil)

#merge_tags(list, mode) ⇒ nil

Merges the given list into the setter's list using the given mode.

Parameters:

Returns:

  • (nil)

#reset_tagsnil

Reset the internal taglist. Elements should call this from within the state-change handler.

Returns:

  • (nil)

#tag_listGst::TagList

Returns the current list of tags the setter uses. The list should not be modified or freed.

This function is not thread-safe.

Returns:

  • (Gst::TagList)

    a current snapshot of the taglist used in the setter or nil if none is used.

#tag_merge_modeGst::TagMergeMode

Queries the mode by which tags inside the setter are overwritten by tags from events

Returns:

#tag_merge_mode=(mode) ⇒ nil

Sets the given merge mode that is used for adding tags from events to tags specified by this interface. The default is #GST_TAG_MERGE_KEEP, which keeps the tags set with this interface and discards tags from events.

Parameters:

Returns:

  • (nil)