mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
ges : add a track-object(removed signal to the track
API: GESTrack::track-object-removed signal
This commit is contained in:
parent
8f405d6a4d
commit
76f256f0bd
1 changed files with 18 additions and 0 deletions
|
@ -57,6 +57,7 @@ enum
|
||||||
ARG_DURATION,
|
ARG_DURATION,
|
||||||
ARG_LAST,
|
ARG_LAST,
|
||||||
TRACK_OBJECT_ADDED,
|
TRACK_OBJECT_ADDED,
|
||||||
|
TRACK_OBJECT_REMOVED,
|
||||||
LAST_SIGNAL
|
LAST_SIGNAL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -214,6 +215,19 @@ ges_track_class_init (GESTrackClass * klass)
|
||||||
G_SIGNAL_RUN_FIRST, 0, NULL, NULL, ges_marshal_VOID__OBJECT,
|
G_SIGNAL_RUN_FIRST, 0, NULL, NULL, ges_marshal_VOID__OBJECT,
|
||||||
G_TYPE_NONE, 1, GES_TYPE_TRACK_OBJECT);
|
G_TYPE_NONE, 1, GES_TYPE_TRACK_OBJECT);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GESTrack::track-object-removed
|
||||||
|
* @object: the #GESTrack
|
||||||
|
* @effect: the #GESTrackObject that was removed.
|
||||||
|
*
|
||||||
|
* Will be emitted after a track object was removed from the track.
|
||||||
|
*
|
||||||
|
* Since: 0.10.2
|
||||||
|
*/
|
||||||
|
ges_track_signals[TRACK_OBJECT_REMOVED] =
|
||||||
|
g_signal_new ("track-object-removed", G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_FIRST, 0, NULL, NULL, ges_marshal_VOID__OBJECT,
|
||||||
|
G_TYPE_NONE, 1, GES_TYPE_TRACK_OBJECT);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -409,6 +423,7 @@ ges_track_add_object (GESTrack * track, GESTrackObject * object)
|
||||||
track->priv->trackobjects =
|
track->priv->trackobjects =
|
||||||
g_list_insert_sorted (track->priv->trackobjects, object,
|
g_list_insert_sorted (track->priv->trackobjects, object,
|
||||||
(GCompareFunc) objects_start_compare);
|
(GCompareFunc) objects_start_compare);
|
||||||
|
|
||||||
g_signal_emit (track, ges_track_signals[TRACK_OBJECT_ADDED], 0,
|
g_signal_emit (track, ges_track_signals[TRACK_OBJECT_ADDED], 0,
|
||||||
GES_TRACK_OBJECT (object));
|
GES_TRACK_OBJECT (object));
|
||||||
|
|
||||||
|
@ -481,6 +496,9 @@ ges_track_remove_object (GESTrack * track, GESTrackObject * object)
|
||||||
ges_track_object_set_track (object, NULL);
|
ges_track_object_set_track (object, NULL);
|
||||||
priv->trackobjects = g_list_remove (priv->trackobjects, object);
|
priv->trackobjects = g_list_remove (priv->trackobjects, object);
|
||||||
|
|
||||||
|
g_signal_emit (track, ges_track_signals[TRACK_OBJECT_REMOVED], 0,
|
||||||
|
GES_TRACK_OBJECT (object));
|
||||||
|
|
||||||
g_object_unref (object);
|
g_object_unref (object);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
Loading…
Reference in a new issue