clip: Make sure to remove and re add effects when adding clips to layer

And make re add them in the same order.

And enhance tests to check that
This commit is contained in:
Thibault Saunier 2019-02-21 17:24:51 -03:00 committed by Thibault Saunier
parent 23d3e69f2b
commit 430719d172
2 changed files with 22 additions and 7 deletions

View file

@ -939,6 +939,7 @@ ges_clip_create_track_elements (GESClip * clip, GESTrackType type)
GList *result = NULL, *tmp, *children; GList *result = NULL, *tmp, *children;
GESClipClass *klass; GESClipClass *klass;
guint max_prio, min_prio; guint max_prio, min_prio;
gboolean readding_effects_only = TRUE;
g_return_val_if_fail (GES_IS_CLIP (clip), NULL); g_return_val_if_fail (GES_IS_CLIP (clip), NULL);
@ -955,18 +956,20 @@ ges_clip_create_track_elements (GESClip * clip, GESTrackType type)
for (tmp = children; tmp; tmp = tmp->next) { for (tmp = children; tmp; tmp = tmp->next) {
GESTrackElement *child = GES_TRACK_ELEMENT (tmp->data); GESTrackElement *child = GES_TRACK_ELEMENT (tmp->data);
if (!GES_IS_BASE_EFFECT (child) && !ges_track_element_get_track (child) && if (!ges_track_element_get_track (child)
ges_track_element_get_track_type (child) & type) { && ges_track_element_get_track_type (child) & type) {
GST_DEBUG_OBJECT (clip, "Removing for reusage: %" GST_PTR_FORMAT, child); GST_DEBUG_OBJECT (clip, "Removing for reusage: %" GST_PTR_FORMAT, child);
result = g_list_prepend (result, g_object_ref (child)); result = g_list_append (result, g_object_ref (child));
ges_container_remove (GES_CONTAINER (clip), tmp->data); ges_container_remove (GES_CONTAINER (clip), tmp->data);
if (!GES_IS_BASE_EFFECT (child))
readding_effects_only = FALSE;
} }
} }
g_list_free_full (children, gst_object_unref); g_list_free_full (children, gst_object_unref);
if (!result) { if (readding_effects_only) {
result = klass->create_track_elements (clip, type); result = g_list_concat (result, klass->create_track_elements (clip, type));
} }
_get_priority_range (GES_CONTAINER (clip), &min_prio, &max_prio); _get_priority_range (GES_CONTAINER (clip), &min_prio, &max_prio);

View file

@ -143,31 +143,43 @@ class TestTrackElements(common.GESTest):
def test_add_to_layer_with_effect_remove_add(self): def test_add_to_layer_with_effect_remove_add(self):
timeline = GES.Timeline.new_audio_video() timeline = GES.Timeline.new_audio_video()
self.assertEqual(len(timeline.get_tracks()), 2) video_track, audio_track = timeline.get_tracks()
layer = timeline.append_layer() layer = timeline.append_layer()
test_clip = GES.TestClip() test_clip = GES.TestClip()
self.assertEqual(test_clip.get_children(True), []) self.assertEqual(test_clip.get_children(True), [])
self.assertTrue(layer.add_clip(test_clip)) self.assertTrue(layer.add_clip(test_clip))
audio_source = test_clip.find_track_element(None, GES.AudioSource) audio_source = test_clip.find_track_element(None, GES.AudioSource)
self.assertIsNotNone(audio_source) video_source = test_clip.find_track_element(None, GES.VideoSource)
self.assertTrue(test_clip.set_child_property("volume", 0.0)) self.assertTrue(test_clip.set_child_property("volume", 0.0))
self.assertEqual(audio_source.get_child_property("volume")[1], 0.0) self.assertEqual(audio_source.get_child_property("volume")[1], 0.0)
effect = GES.Effect.new("agingtv") effect = GES.Effect.new("agingtv")
test_clip.add(effect) test_clip.add(effect)
self.assertEqual(audio_source.props.track, audio_track)
self.assertEqual(video_source.props.track, video_track)
self.assertEqual(effect.props.track, video_track)
children = test_clip.get_children(True) children = test_clip.get_children(True)
layer.remove_clip(test_clip) layer.remove_clip(test_clip)
self.assertEqual(test_clip.get_children(True), children) self.assertEqual(test_clip.get_children(True), children)
self.assertEqual(audio_source.props.track, None)
self.assertEqual(video_source.props.track, None)
self.assertEqual(effect.props.track, None)
self.assertTrue(layer.add_clip(test_clip)) self.assertTrue(layer.add_clip(test_clip))
self.assertEqual(test_clip.get_children(True), children) self.assertEqual(test_clip.get_children(True), children)
self.assertEqual(audio_source.props.track, audio_track)
self.assertEqual(video_source.props.track, video_track)
self.assertEqual(effect.props.track, video_track)
audio_source = test_clip.find_track_element(None, GES.AudioSource) audio_source = test_clip.find_track_element(None, GES.AudioSource)
self.assertFalse(audio_source is None) self.assertFalse(audio_source is None)
self.assertEqual(audio_source.get_child_property("volume")[1], 0.0) self.assertEqual(audio_source.get_child_property("volume")[1], 0.0)
self.assertEqual(audio_source.props.track, audio_track)
self.assertEqual(video_source.props.track, video_track)
self.assertEqual(effect.props.track, video_track)
def test_effects_priority(self): def test_effects_priority(self):
timeline = GES.Timeline.new_audio_video() timeline = GES.Timeline.new_audio_video()