mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
Rename GESTimelineLayer to GESLayer
This commit is contained in:
parent
b5c52a17ec
commit
b2b96c743d
67 changed files with 875 additions and 913 deletions
|
@ -11,9 +11,9 @@ LOCAL_SRC_FILES := \
|
||||||
ges.c \
|
ges.c \
|
||||||
ges-enums.c \
|
ges-enums.c \
|
||||||
ges-custom-source-clip.c \
|
ges-custom-source-clip.c \
|
||||||
ges-simple-timeline-layer.c \
|
ges-simple-layer.c \
|
||||||
ges-timeline.c \
|
ges-timeline.c \
|
||||||
ges-timeline-layer.c \
|
ges-layer.c \
|
||||||
ges-clip.c \
|
ges-clip.c \
|
||||||
ges-timeline-pipeline.c \
|
ges-timeline-pipeline.c \
|
||||||
ges-source-clip.c \
|
ges-source-clip.c \
|
||||||
|
|
|
@ -6,7 +6,7 @@ class Simple:
|
||||||
def __init__(self, uri):
|
def __init__(self, uri):
|
||||||
timeline = GES.Timeline()
|
timeline = GES.Timeline()
|
||||||
trackv = GES.Track.video_raw_new()
|
trackv = GES.Track.video_raw_new()
|
||||||
self.layer = GES.TimelineLayer()
|
self.layer = GES.Layer()
|
||||||
self.pipeline = GES.TimelinePipeline()
|
self.pipeline = GES.TimelinePipeline()
|
||||||
self.pipeline.add_timeline(timeline)
|
self.pipeline.add_timeline(timeline)
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ class Simple:
|
||||||
def __init__(self, uri):
|
def __init__(self, uri):
|
||||||
timeline = GES.Timeline()
|
timeline = GES.Timeline()
|
||||||
trackv = GES.Track.video_raw_new()
|
trackv = GES.Track.video_raw_new()
|
||||||
layer = GES.TimelineLayer()
|
layer = GES.Layer()
|
||||||
self.pipeline = GES.TimelinePipeline()
|
self.pipeline = GES.TimelinePipeline()
|
||||||
self.pipeline.add_timeline(timeline)
|
self.pipeline.add_timeline(timeline)
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@ platform as well as Windows. It is released under the GNU Library General Public
|
||||||
<chapter>
|
<chapter>
|
||||||
<title>Base Classes</title>
|
<title>Base Classes</title>
|
||||||
<xi:include href="xml/ges-timeline.xml"/>
|
<xi:include href="xml/ges-timeline.xml"/>
|
||||||
<xi:include href="xml/ges-timeline-layer.xml"/>
|
<xi:include href="xml/ges-layer.xml"/>
|
||||||
<xi:include href="xml/ges-timeline-element.xml"/>
|
<xi:include href="xml/ges-timeline-element.xml"/>
|
||||||
<xi:include href="xml/ges-container.xml"/>
|
<xi:include href="xml/ges-container.xml"/>
|
||||||
<xi:include href="xml/ges-clip.xml"/>
|
<xi:include href="xml/ges-clip.xml"/>
|
||||||
|
@ -79,7 +79,7 @@ platform as well as Windows. It is released under the GNU Library General Public
|
||||||
|
|
||||||
<chapter>
|
<chapter>
|
||||||
<title>Simple Timeline interface</title>
|
<title>Simple Timeline interface</title>
|
||||||
<xi:include href="xml/ges-simple-timeline-layer.xml"/>
|
<xi:include href="xml/ges-simple-layer.xml"/>
|
||||||
</chapter>
|
</chapter>
|
||||||
|
|
||||||
<chapter>
|
<chapter>
|
||||||
|
|
|
@ -288,35 +288,35 @@ GES_TYPE_TIMELINE
|
||||||
|
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
<FILE>ges-timeline-layer</FILE>
|
<FILE>ges-layer</FILE>
|
||||||
<TITLE>GESTimelineLayer</TITLE>
|
<TITLE>GESLayer</TITLE>
|
||||||
GESTimelineLayer
|
GESLayer
|
||||||
GESTimelineLayerClass
|
GESLayerClass
|
||||||
ges_timeline_layer_add_clip
|
ges_layer_add_clip
|
||||||
ges_timeline_layer_add_asset
|
ges_layer_add_asset
|
||||||
ges_timeline_layer_new
|
ges_layer_new
|
||||||
ges_timeline_layer_remove_clip
|
ges_layer_remove_clip
|
||||||
ges_timeline_layer_set_priority
|
ges_layer_set_priority
|
||||||
ges_timeline_layer_get_priority
|
ges_layer_get_priority
|
||||||
ges_timeline_layer_get_clips
|
ges_layer_get_clips
|
||||||
ges_timeline_layer_get_timeline
|
ges_layer_get_timeline
|
||||||
ges_timeline_layer_get_auto_transition
|
ges_layer_get_auto_transition
|
||||||
ges_timeline_layer_set_auto_transition
|
ges_layer_set_auto_transition
|
||||||
ges_timeline_layer_is_empty
|
ges_layer_is_empty
|
||||||
|
|
||||||
GES_TIMELINE_GET_LAYERS
|
GES_TIMELINE_GET_LAYERS
|
||||||
GES_TIMELINE_GET_TRACKS
|
GES_TIMELINE_GET_TRACKS
|
||||||
|
|
||||||
<SUBSECTION Standard>
|
<SUBSECTION Standard>
|
||||||
GESTimelineLayerPrivate
|
GESLayerPrivate
|
||||||
ges_timeline_layer_set_timeline
|
ges_layer_set_timeline
|
||||||
ges_timeline_layer_get_type
|
ges_layer_get_type
|
||||||
GES_IS_TIMELINE_LAYER
|
GES_IS_LAYER
|
||||||
GES_IS_TIMELINE_LAYER_CLASS
|
GES_IS_LAYER_CLASS
|
||||||
GES_TIMELINE_LAYER
|
GES_LAYER
|
||||||
GES_TIMELINE_LAYER_CLASS
|
GES_LAYER_CLASS
|
||||||
GES_TIMELINE_LAYER_GET_CLASS
|
GES_LAYER_GET_CLASS
|
||||||
GES_TYPE_TIMELINE_LAYER
|
GES_TYPE_LAYER
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
|
@ -605,25 +605,25 @@ GES_TYPE_CUSTOM_SOURCE_CLIP
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
<FILE>ges-simple-timeline-layer</FILE>
|
<FILE>ges-simple-layer</FILE>
|
||||||
<TITLE>GESSimpleTimelineLayer</TITLE>
|
<TITLE>GESSimpleLayer</TITLE>
|
||||||
GESSimpleTimelineLayer
|
GESSimpleLayer
|
||||||
ges_simple_timeline_layer_new
|
ges_simple_layer_new
|
||||||
ges_simple_timeline_layer_add_object
|
ges_simple_layer_add_object
|
||||||
ges_simple_timeline_layer_move_object
|
ges_simple_layer_move_object
|
||||||
ges_simple_timeline_layer_nth
|
ges_simple_layer_nth
|
||||||
ges_simple_timeline_layer_index
|
ges_simple_layer_index
|
||||||
ges_simple_timeline_layer_is_valid
|
ges_simple_layer_is_valid
|
||||||
<SUBSECTION Standard>
|
<SUBSECTION Standard>
|
||||||
GESSimpleTimelineLayerClass
|
GESSimpleLayerClass
|
||||||
ges_simple_timeline_layer_get_type
|
ges_simple_layer_get_type
|
||||||
GESSimpleTimelineLayerPrivate
|
GESSimpleLayerPrivate
|
||||||
GES_IS_SIMPLE_TIMELINE_LAYER
|
GES_IS_SIMPLE_LAYER
|
||||||
GES_IS_SIMPLE_TIMELINE_LAYER_CLASS
|
GES_IS_SIMPLE_LAYER_CLASS
|
||||||
GES_SIMPLE_TIMELINE_LAYER
|
GES_SIMPLE_LAYER
|
||||||
GES_SIMPLE_TIMELINE_LAYER_CLASS
|
GES_SIMPLE_LAYER_CLASS
|
||||||
GES_SIMPLE_TIMELINE_LAYER_GET_CLASS
|
GES_SIMPLE_LAYER_GET_CLASS
|
||||||
GES_TYPE_SIMPLE_TIMELINE_LAYER
|
GES_TYPE_SIMPLE_LAYER
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
|
|
|
@ -3,11 +3,11 @@
|
||||||
|
|
||||||
ges_custom_source_clip_get_type
|
ges_custom_source_clip_get_type
|
||||||
ges_formatter_get_type
|
ges_formatter_get_type
|
||||||
ges_simple_timeline_layer_get_type
|
ges_simple_layer_get_type
|
||||||
%ges_text_halign_get_type
|
%ges_text_halign_get_type
|
||||||
%ges_text_valign_get_type
|
%ges_text_valign_get_type
|
||||||
ges_timeline_get_type
|
ges_timeline_get_type
|
||||||
ges_timeline_layer_get_type
|
ges_layer_get_type
|
||||||
ges_clip_get_type
|
ges_clip_get_type
|
||||||
ges_operation_clip_get_type
|
ges_operation_clip_get_type
|
||||||
ges_overlay_clip_get_type
|
ges_overlay_clip_get_type
|
||||||
|
|
|
@ -13,9 +13,9 @@ libges_@GST_API_VERSION@_la_SOURCES = \
|
||||||
ges-enums.c \
|
ges-enums.c \
|
||||||
ges-custom-source-clip.c \
|
ges-custom-source-clip.c \
|
||||||
ges-meta-container.c \
|
ges-meta-container.c \
|
||||||
ges-simple-timeline-layer.c \
|
ges-simple-layer.c \
|
||||||
ges-timeline.c \
|
ges-timeline.c \
|
||||||
ges-timeline-layer.c \
|
ges-layer.c \
|
||||||
ges-clip.c \
|
ges-clip.c \
|
||||||
ges-timeline-pipeline.c \
|
ges-timeline-pipeline.c \
|
||||||
ges-source-clip.c \
|
ges-source-clip.c \
|
||||||
|
@ -70,9 +70,9 @@ libges_@GST_API_VERSION@include_HEADERS = \
|
||||||
ges-gerror.h \
|
ges-gerror.h \
|
||||||
ges-custom-source-clip.h \
|
ges-custom-source-clip.h \
|
||||||
ges-meta-container.h \
|
ges-meta-container.h \
|
||||||
ges-simple-timeline-layer.h \
|
ges-simple-layer.h \
|
||||||
ges-timeline.h \
|
ges-timeline.h \
|
||||||
ges-timeline-layer.h \
|
ges-layer.h \
|
||||||
ges-clip.h \
|
ges-clip.h \
|
||||||
ges-timeline-pipeline.h \
|
ges-timeline-pipeline.h \
|
||||||
ges-source-clip.h \
|
ges-source-clip.h \
|
||||||
|
|
|
@ -71,7 +71,7 @@ _height_changed_cb (GESClip * clip, GParamSpec * arg G_GNUC_UNUSED,
|
||||||
GESAutoTransition * self)
|
GESAutoTransition * self)
|
||||||
{
|
{
|
||||||
/* FIXME This is really not smart and we should properly implement clip
|
/* FIXME This is really not smart and we should properly implement clip
|
||||||
* priority management at the TimelineLayer level */
|
* priority management at the Layer level */
|
||||||
_set_priority0 (GES_TIMELINE_ELEMENT (self->next_clip),
|
_set_priority0 (GES_TIMELINE_ELEMENT (self->next_clip),
|
||||||
_PRIORITY (self->previous_clip) +
|
_PRIORITY (self->previous_clip) +
|
||||||
GES_CONTAINER_HEIGHT (self->previous_clip));
|
GES_CONTAINER_HEIGHT (self->previous_clip));
|
||||||
|
@ -170,7 +170,7 @@ ges_auto_transition_new (GESTrackElement * transition,
|
||||||
" between %" GST_PTR_FORMAT " and: %" GST_PTR_FORMAT
|
" between %" GST_PTR_FORMAT " and: %" GST_PTR_FORMAT
|
||||||
" in layer nb %i, start: %" GST_TIME_FORMAT " duration: %"
|
" in layer nb %i, start: %" GST_TIME_FORMAT " duration: %"
|
||||||
GST_TIME_FORMAT, transition, next_source, previous_source,
|
GST_TIME_FORMAT, transition, next_source, previous_source,
|
||||||
ges_timeline_layer_get_priority (ges_clip_get_layer
|
ges_layer_get_priority (ges_clip_get_layer
|
||||||
(self->previous_clip)),
|
(self->previous_clip)),
|
||||||
GST_TIME_ARGS (_START (transition)),
|
GST_TIME_ARGS (_START (transition)),
|
||||||
GST_TIME_ARGS (_DURATION (transition)));
|
GST_TIME_ARGS (_DURATION (transition)));
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include <glib-object.h>
|
#include <glib-object.h>
|
||||||
#include "ges-track-element.h"
|
#include "ges-track-element.h"
|
||||||
#include "ges-clip.h"
|
#include "ges-clip.h"
|
||||||
#include "ges-timeline-layer.h"
|
#include "ges-layer.h"
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ struct _GESAutoTransition
|
||||||
GESTrackElement *next_source;
|
GESTrackElement *next_source;
|
||||||
GESTrackElement *transition;
|
GESTrackElement *transition;
|
||||||
|
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
GESClip *previous_clip;
|
GESClip *previous_clip;
|
||||||
GESClip *next_clip;
|
GESClip *next_clip;
|
||||||
|
|
|
@ -19,13 +19,13 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION: ges-base-effect-clip
|
* SECTION: ges-base-effect-clip
|
||||||
* @short_description: An effect in a GESTimelineLayer
|
* @short_description: An effect in a GESLayer
|
||||||
*
|
*
|
||||||
* The effect will be applied on the sources that have lower priorities
|
* The effect will be applied on the sources that have lower priorities
|
||||||
* (higher number) between the inpoint and the end of it.
|
* (higher number) between the inpoint and the end of it.
|
||||||
*
|
*
|
||||||
* In a #GESSimpleTimelineLayer, the priorities will be set for you but if
|
* In a #GESSimpleLayer, the priorities will be set for you but if
|
||||||
* you use another type of #GESTimelineLayer, you will have to handle it
|
* you use another type of #GESLayer, you will have to handle it
|
||||||
* yourself.
|
* yourself.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-base-effect
|
* SECTION:ges-base-effect
|
||||||
* @short_description: adds an effect to a stream in a GESSourceClip or a
|
* @short_description: adds an effect to a stream in a GESSourceClip or a
|
||||||
* #GESTimelineLayer
|
* #GESLayer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <glib/gprintf.h>
|
#include <glib/gprintf.h>
|
||||||
|
|
|
@ -49,7 +49,7 @@ typedef struct PendingClip
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GstClockTime duration;
|
GstClockTime duration;
|
||||||
GESTrackType track_types;
|
GESTrackType track_types;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
GstStructure *properties;
|
GstStructure *properties;
|
||||||
gchar *metadatas;
|
gchar *metadatas;
|
||||||
|
@ -62,7 +62,7 @@ typedef struct PendingClip
|
||||||
|
|
||||||
typedef struct LayerEntry
|
typedef struct LayerEntry
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gboolean auto_trans;
|
gboolean auto_trans;
|
||||||
} LayerEntry;
|
} LayerEntry;
|
||||||
|
|
||||||
|
@ -366,7 +366,7 @@ ges_base_xml_formatter_class_init (GESBaseXmlFormatterClass * self_class)
|
||||||
static void
|
static void
|
||||||
_set_auto_transition (gpointer prio, LayerEntry * entry, gpointer udata)
|
_set_auto_transition (gpointer prio, LayerEntry * entry, gpointer udata)
|
||||||
{
|
{
|
||||||
ges_timeline_layer_set_auto_transition (entry->layer, entry->auto_trans);
|
ges_layer_set_auto_transition (entry->layer, entry->auto_trans);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -406,12 +406,12 @@ set_property_foreach (GQuark field_id, const GValue * value, GObject * object)
|
||||||
|
|
||||||
static inline GESClip *
|
static inline GESClip *
|
||||||
_add_object_to_layer (GESBaseXmlFormatterPrivate * priv, const gchar * id,
|
_add_object_to_layer (GESBaseXmlFormatterPrivate * priv, const gchar * id,
|
||||||
GESTimelineLayer * layer, GESAsset * asset, GstClockTime start,
|
GESLayer * layer, GESAsset * asset, GstClockTime start,
|
||||||
GstClockTime inpoint, GstClockTime duration,
|
GstClockTime inpoint, GstClockTime duration,
|
||||||
GESTrackType track_types, const gchar * metadatas,
|
GESTrackType track_types, const gchar * metadatas,
|
||||||
GstStructure * properties)
|
GstStructure * properties)
|
||||||
{
|
{
|
||||||
GESClip *clip = ges_timeline_layer_add_asset (layer,
|
GESClip *clip = ges_layer_add_asset (layer,
|
||||||
asset, start, inpoint, duration, track_types);
|
asset, start, inpoint, duration, track_types);
|
||||||
|
|
||||||
if (clip == NULL) {
|
if (clip == NULL) {
|
||||||
|
@ -753,7 +753,7 @@ ges_base_xml_formatter_add_layer (GESBaseXmlFormatter * self,
|
||||||
{
|
{
|
||||||
LayerEntry *entry;
|
LayerEntry *entry;
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gboolean auto_transition = FALSE;
|
gboolean auto_transition = FALSE;
|
||||||
GESBaseXmlFormatterPrivate *priv = _GET_PRIV (self);
|
GESBaseXmlFormatterPrivate *priv = _GET_PRIV (self);
|
||||||
|
|
||||||
|
@ -761,7 +761,7 @@ ges_base_xml_formatter_add_layer (GESBaseXmlFormatter * self,
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (extractable_type == G_TYPE_NONE)
|
if (extractable_type == G_TYPE_NONE)
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
else {
|
else {
|
||||||
asset = ges_asset_request (extractable_type, NULL, error);
|
asset = ges_asset_request (extractable_type, NULL, error);
|
||||||
if (asset == NULL) {
|
if (asset == NULL) {
|
||||||
|
@ -773,10 +773,10 @@ ges_base_xml_formatter_add_layer (GESBaseXmlFormatter * self,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
layer = GES_TIMELINE_LAYER (ges_asset_extract (asset, error));
|
layer = GES_LAYER (ges_asset_extract (asset, error));
|
||||||
}
|
}
|
||||||
|
|
||||||
ges_timeline_layer_set_priority (layer, priority);
|
ges_layer_set_priority (layer, priority);
|
||||||
ges_timeline_add_layer (GES_FORMATTER (self)->timeline, layer);
|
ges_timeline_add_layer (GES_FORMATTER (self)->timeline, layer);
|
||||||
if (properties) {
|
if (properties) {
|
||||||
if (gst_structure_get_boolean (properties, "auto-transition",
|
if (gst_structure_get_boolean (properties, "auto-transition",
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-clip
|
* SECTION:ges-clip
|
||||||
* @short_description: Base Class for objects in a GESTimelineLayer
|
* @short_description: Base Class for objects in a GESLayer
|
||||||
*
|
*
|
||||||
* A #GESClip is a 'natural' object which controls one or more
|
* A #GESClip is a 'natural' object which controls one or more
|
||||||
* #GESTrackElement(s) in one or more #GESTrack(s).
|
* #GESTrackElement(s) in one or more #GESTrack(s).
|
||||||
|
@ -53,7 +53,7 @@ G_DEFINE_ABSTRACT_TYPE (GESClip, ges_clip, GES_TYPE_CONTAINER);
|
||||||
struct _GESClipPrivate
|
struct _GESClipPrivate
|
||||||
{
|
{
|
||||||
/*< public > */
|
/*< public > */
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
/*< private > */
|
/*< private > */
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ static void
|
||||||
_get_priority_range (GESContainer * container, guint32 * min_priority,
|
_get_priority_range (GESContainer * container, guint32 * min_priority,
|
||||||
guint32 * max_priority)
|
guint32 * max_priority)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer = GES_CLIP (container)->priv->layer;
|
GESLayer *layer = GES_CLIP (container)->priv->layer;
|
||||||
|
|
||||||
if (layer) {
|
if (layer) {
|
||||||
*min_priority = layer->min_gnl_priority;
|
*min_priority = layer->min_gnl_priority;
|
||||||
|
@ -204,7 +204,7 @@ _ungroup (GESContainer * container, gboolean recursive)
|
||||||
gboolean first_obj = TRUE;
|
gboolean first_obj = TRUE;
|
||||||
GESClip *clip = GES_CLIP (container);
|
GESClip *clip = GES_CLIP (container);
|
||||||
GESTimelineElement *element = GES_TIMELINE_ELEMENT (container);
|
GESTimelineElement *element = GES_TIMELINE_ELEMENT (container);
|
||||||
GESTimelineLayer *layer = clip->priv->layer;
|
GESLayer *layer = clip->priv->layer;
|
||||||
GHashTable *_tracktype_clip = g_hash_table_new (g_int_hash, g_int_equal);
|
GHashTable *_tracktype_clip = g_hash_table_new (g_int_hash, g_int_equal);
|
||||||
|
|
||||||
/* If there is no TrackElement, just return @container in a list */
|
/* If there is no TrackElement, just return @container in a list */
|
||||||
|
@ -228,7 +228,7 @@ _ungroup (GESContainer * container, gboolean recursive)
|
||||||
if (layer) {
|
if (layer) {
|
||||||
/* Add new container to the same layer as @container */
|
/* Add new container to the same layer as @container */
|
||||||
ges_clip_set_moving_from_layer (tmpclip, TRUE);
|
ges_clip_set_moving_from_layer (tmpclip, TRUE);
|
||||||
ges_timeline_layer_add_clip (layer, tmpclip);
|
ges_layer_add_clip (layer, tmpclip);
|
||||||
ges_clip_set_moving_from_layer (tmpclip, FALSE);
|
ges_clip_set_moving_from_layer (tmpclip, FALSE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -259,7 +259,7 @@ _group (GList * containers)
|
||||||
CheckTrack *tracks = NULL;
|
CheckTrack *tracks = NULL;
|
||||||
GESTimeline *timeline = NULL;
|
GESTimeline *timeline = NULL;
|
||||||
GESTrackType supported_formats;
|
GESTrackType supported_formats;
|
||||||
GESTimelineLayer *layer = NULL;
|
GESLayer *layer = NULL;
|
||||||
GList *tmp, *tmpclip, *tmpelement;
|
GList *tmp, *tmpclip, *tmpelement;
|
||||||
GstClockTime start, inpoint, duration;
|
GstClockTime start, inpoint, duration;
|
||||||
|
|
||||||
|
@ -390,7 +390,7 @@ _group (GList * containers)
|
||||||
ges_track_element_get_track_type (GES_TRACK_ELEMENT (celement));
|
ges_track_element_get_track_type (GES_TRACK_ELEMENT (celement));
|
||||||
}
|
}
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, tmpclip->data);
|
ges_layer_remove_clip (layer, tmpclip->data);
|
||||||
}
|
}
|
||||||
|
|
||||||
ges_clip_set_supported_formats (GES_CLIP (ret), supported_formats);
|
ges_clip_set_supported_formats (GES_CLIP (ret), supported_formats);
|
||||||
|
@ -475,11 +475,11 @@ ges_clip_class_init (GESClipClass * klass)
|
||||||
/**
|
/**
|
||||||
* GESClip:layer:
|
* GESClip:layer:
|
||||||
*
|
*
|
||||||
* The GESTimelineLayer where this clip is being used.
|
* The GESLayer where this clip is being used.
|
||||||
*/
|
*/
|
||||||
properties[PROP_LAYER] = g_param_spec_object ("layer", "Layer",
|
properties[PROP_LAYER] = g_param_spec_object ("layer", "Layer",
|
||||||
"The GESTimelineLayer where this clip is being used.",
|
"The GESLayer where this clip is being used.",
|
||||||
GES_TYPE_TIMELINE_LAYER, G_PARAM_READABLE);
|
GES_TYPE_LAYER, G_PARAM_READABLE);
|
||||||
g_object_class_install_property (object_class, PROP_LAYER,
|
g_object_class_install_property (object_class, PROP_LAYER,
|
||||||
properties[PROP_LAYER]);
|
properties[PROP_LAYER]);
|
||||||
|
|
||||||
|
@ -624,7 +624,7 @@ ges_clip_create_track_elements_func (GESClip * clip, GESTrackType type)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ges_clip_set_layer (GESClip * clip, GESTimelineLayer * layer)
|
ges_clip_set_layer (GESClip * clip, GESLayer * layer)
|
||||||
{
|
{
|
||||||
GST_DEBUG ("clip:%p, layer:%p", clip, layer);
|
GST_DEBUG ("clip:%p, layer:%p", clip, layer);
|
||||||
|
|
||||||
|
@ -714,7 +714,7 @@ ges_clip_is_moving_from_layer (GESClip * clip)
|
||||||
/**
|
/**
|
||||||
* ges_clip_move_to_layer:
|
* ges_clip_move_to_layer:
|
||||||
* @clip: a #GESClip
|
* @clip: a #GESClip
|
||||||
* @layer: the new #GESTimelineLayer
|
* @layer: the new #GESLayer
|
||||||
*
|
*
|
||||||
* Moves @clip to @layer. If @clip is not in any layer, it adds it to
|
* Moves @clip to @layer. If @clip is not in any layer, it adds it to
|
||||||
* @layer, else, it removes it from its current layer, and adds it to @layer.
|
* @layer, else, it removes it from its current layer, and adds it to @layer.
|
||||||
|
@ -722,35 +722,35 @@ ges_clip_is_moving_from_layer (GESClip * clip)
|
||||||
* Returns: %TRUE if @clip could be moved %FALSE otherwize
|
* Returns: %TRUE if @clip could be moved %FALSE otherwize
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_clip_move_to_layer (GESClip * clip, GESTimelineLayer * layer)
|
ges_clip_move_to_layer (GESClip * clip, GESLayer * layer)
|
||||||
{
|
{
|
||||||
gboolean ret;
|
gboolean ret;
|
||||||
GESTimelineLayer *current_layer;
|
GESLayer *current_layer;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), FALSE);
|
g_return_val_if_fail (GES_IS_LAYER (layer), FALSE);
|
||||||
|
|
||||||
current_layer = clip->priv->layer;
|
current_layer = clip->priv->layer;
|
||||||
|
|
||||||
if (current_layer == NULL) {
|
if (current_layer == NULL) {
|
||||||
GST_DEBUG ("Not moving %p, only adding it to %p", clip, layer);
|
GST_DEBUG ("Not moving %p, only adding it to %p", clip, layer);
|
||||||
|
|
||||||
return ges_timeline_layer_add_clip (layer, clip);
|
return ges_layer_add_clip (layer, clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (clip, "moving to layer %p, priority: %d", layer,
|
GST_DEBUG_OBJECT (clip, "moving to layer %p, priority: %d", layer,
|
||||||
ges_timeline_layer_get_priority (layer));
|
ges_layer_get_priority (layer));
|
||||||
|
|
||||||
clip->priv->is_moving = TRUE;
|
clip->priv->is_moving = TRUE;
|
||||||
gst_object_ref (clip);
|
gst_object_ref (clip);
|
||||||
ret = ges_timeline_layer_remove_clip (current_layer, clip);
|
ret = ges_layer_remove_clip (current_layer, clip);
|
||||||
|
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
gst_object_unref (clip);
|
gst_object_unref (clip);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = ges_timeline_layer_add_clip (layer, clip);
|
ret = ges_layer_add_clip (layer, clip);
|
||||||
clip->priv->is_moving = FALSE;
|
clip->priv->is_moving = FALSE;
|
||||||
|
|
||||||
gst_object_unref (clip);
|
gst_object_unref (clip);
|
||||||
|
@ -806,13 +806,13 @@ ges_clip_find_track_element (GESClip * clip, GESTrack * track, GType type)
|
||||||
* ges_clip_get_layer:
|
* ges_clip_get_layer:
|
||||||
* @clip: a #GESClip
|
* @clip: a #GESClip
|
||||||
*
|
*
|
||||||
* Get the #GESTimelineLayer to which this clip belongs.
|
* Get the #GESLayer to which this clip belongs.
|
||||||
*
|
*
|
||||||
* Returns: (transfer full): The #GESTimelineLayer where this @clip is being
|
* Returns: (transfer full): The #GESLayer where this @clip is being
|
||||||
* used, or %NULL if it is not used on any layer. The caller should unref it
|
* used, or %NULL if it is not used on any layer. The caller should unref it
|
||||||
* usage.
|
* usage.
|
||||||
*/
|
*/
|
||||||
GESTimelineLayer *
|
GESLayer *
|
||||||
ges_clip_get_layer (GESClip * clip)
|
ges_clip_get_layer (GESClip * clip)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GES_IS_CLIP (clip), NULL);
|
g_return_val_if_fail (GES_IS_CLIP (clip), NULL);
|
||||||
|
@ -952,9 +952,9 @@ ges_clip_set_top_effect_priority (GESClip * clip,
|
||||||
/**
|
/**
|
||||||
* ges_clip_edit:
|
* ges_clip_edit:
|
||||||
* @clip: the #GESClip to edit
|
* @clip: the #GESClip to edit
|
||||||
* @layers: (element-type GESTimelineLayer): The layers you want the edit to
|
* @layers: (element-type GESLayer): The layers you want the edit to
|
||||||
* happen in, %NULL means that the edition is done in all the
|
* happen in, %NULL means that the edition is done in all the
|
||||||
* #GESTimelineLayers contained in the current timeline.
|
* #GESLayers contained in the current timeline.
|
||||||
* @new_layer_priority: The priority of the layer @clip should land in.
|
* @new_layer_priority: The priority of the layer @clip should land in.
|
||||||
* If the layer you're trying to move the clip to doesn't exist, it will
|
* If the layer you're trying to move the clip to doesn't exist, it will
|
||||||
* be created automatically. -1 means no move.
|
* be created automatically. -1 means no move.
|
||||||
|
@ -976,7 +976,7 @@ ges_clip_edit (GESClip * clip, GList * layers,
|
||||||
{
|
{
|
||||||
GList *tmp;
|
GList *tmp;
|
||||||
gboolean ret = TRUE;
|
gboolean ret = TRUE;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
||||||
|
|
||||||
|
@ -1005,8 +1005,7 @@ ges_clip_edit (GESClip * clip, GList * layers,
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
priority_offset = new_layer_priority -
|
priority_offset = new_layer_priority - ges_layer_get_priority (layer);
|
||||||
ges_timeline_layer_get_priority (layer);
|
|
||||||
|
|
||||||
ret &= timeline_context_to_layer (layer->timeline, priority_offset);
|
ret &= timeline_context_to_layer (layer->timeline, priority_offset);
|
||||||
}
|
}
|
||||||
|
@ -1022,7 +1021,7 @@ ges_clip_edit (GESClip * clip, GList * layers,
|
||||||
* The function modifies @clip, and creates another #GESClip so
|
* The function modifies @clip, and creates another #GESClip so
|
||||||
* we have two clips at the end, splitted at the time specified by @position.
|
* we have two clips at the end, splitted at the time specified by @position.
|
||||||
* The newly created clip will be added to the same layer as @clip is in.
|
* The newly created clip will be added to the same layer as @clip is in.
|
||||||
* This implies that @clip must be in a #GESTimelineLayer for the operation to
|
* This implies that @clip must be in a #GESLayer for the operation to
|
||||||
* be possible.
|
* be possible.
|
||||||
*
|
*
|
||||||
* Returns: (transfer none): The newly created #GESClip resulting from the
|
* Returns: (transfer none): The newly created #GESClip resulting from the
|
||||||
|
@ -1067,7 +1066,7 @@ ges_clip_split (GESClip * clip, guint64 position)
|
||||||
|
|
||||||
/* We do not want the timeline to create again TrackElement-s */
|
/* We do not want the timeline to create again TrackElement-s */
|
||||||
ges_clip_set_moving_from_layer (new_object, TRUE);
|
ges_clip_set_moving_from_layer (new_object, TRUE);
|
||||||
ges_timeline_layer_add_clip (clip->priv->layer, new_object);
|
ges_layer_add_clip (clip->priv->layer, new_object);
|
||||||
ges_clip_set_moving_from_layer (new_object, FALSE);
|
ges_clip_set_moving_from_layer (new_object, FALSE);
|
||||||
|
|
||||||
_set_duration0 (GES_TIMELINE_ELEMENT (clip), position - _START (clip));
|
_set_duration0 (GES_TIMELINE_ELEMENT (clip), position - _START (clip));
|
||||||
|
@ -1139,7 +1138,7 @@ _ripple (GESTimelineElement * element, GstClockTime start)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESClip *clip = GES_CLIP (element);
|
GESClip *clip = GES_CLIP (element);
|
||||||
|
|
||||||
timeline = ges_timeline_layer_get_timeline (clip->priv->layer);
|
timeline = ges_layer_get_timeline (clip->priv->layer);
|
||||||
|
|
||||||
if (timeline == NULL) {
|
if (timeline == NULL) {
|
||||||
GST_DEBUG ("Not in a timeline yet");
|
GST_DEBUG ("Not in a timeline yet");
|
||||||
|
@ -1164,7 +1163,7 @@ _ripple_end (GESTimelineElement * element, GstClockTime end)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESClip *clip = GES_CLIP (element);
|
GESClip *clip = GES_CLIP (element);
|
||||||
|
|
||||||
timeline = ges_timeline_layer_get_timeline (clip->priv->layer);
|
timeline = ges_layer_get_timeline (clip->priv->layer);
|
||||||
|
|
||||||
if (timeline == NULL) {
|
if (timeline == NULL) {
|
||||||
GST_DEBUG ("Not in a timeline yet");
|
GST_DEBUG ("Not in a timeline yet");
|
||||||
|
@ -1190,7 +1189,7 @@ _roll_start (GESTimelineElement * element, GstClockTime start)
|
||||||
|
|
||||||
GESClip *clip = GES_CLIP (element);
|
GESClip *clip = GES_CLIP (element);
|
||||||
|
|
||||||
timeline = ges_timeline_layer_get_timeline (clip->priv->layer);
|
timeline = ges_layer_get_timeline (clip->priv->layer);
|
||||||
|
|
||||||
if (timeline == NULL) {
|
if (timeline == NULL) {
|
||||||
GST_DEBUG ("Not in a timeline yet");
|
GST_DEBUG ("Not in a timeline yet");
|
||||||
|
@ -1216,7 +1215,7 @@ _roll_end (GESTimelineElement * element, GstClockTime end)
|
||||||
|
|
||||||
GESClip *clip = GES_CLIP (element);
|
GESClip *clip = GES_CLIP (element);
|
||||||
|
|
||||||
timeline = ges_timeline_layer_get_timeline (clip->priv->layer);
|
timeline = ges_layer_get_timeline (clip->priv->layer);
|
||||||
if (timeline == NULL) {
|
if (timeline == NULL) {
|
||||||
GST_DEBUG ("Not in a timeline yet");
|
GST_DEBUG ("Not in a timeline yet");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -1242,7 +1241,7 @@ _trim (GESTimelineElement * element, GstClockTime start)
|
||||||
|
|
||||||
GESClip *clip = GES_CLIP (element);
|
GESClip *clip = GES_CLIP (element);
|
||||||
|
|
||||||
timeline = ges_timeline_layer_get_timeline (clip->priv->layer);
|
timeline = ges_layer_get_timeline (clip->priv->layer);
|
||||||
|
|
||||||
if (timeline == NULL) {
|
if (timeline == NULL) {
|
||||||
GST_DEBUG ("Not in a timeline yet");
|
GST_DEBUG ("Not in a timeline yet");
|
||||||
|
|
|
@ -157,8 +157,8 @@ GESTrackElement* ges_clip_find_track_element (GESClip *clip, GESTrack *trac
|
||||||
/****************************************************
|
/****************************************************
|
||||||
* Layer *
|
* Layer *
|
||||||
****************************************************/
|
****************************************************/
|
||||||
GESTimelineLayer* ges_clip_get_layer (GESClip *clip);
|
GESLayer* ges_clip_get_layer (GESClip *clip);
|
||||||
gboolean ges_clip_move_to_layer (GESClip *clip, GESTimelineLayer *layer);
|
gboolean ges_clip_move_to_layer (GESClip *clip, GESLayer *layer);
|
||||||
|
|
||||||
/****************************************************
|
/****************************************************
|
||||||
* Effects *
|
* Effects *
|
||||||
|
|
|
@ -70,7 +70,7 @@ static guint ges_container_signals[LAST_SIGNAL] = { 0 };
|
||||||
struct _GESContainerPrivate
|
struct _GESContainerPrivate
|
||||||
{
|
{
|
||||||
/*< public > */
|
/*< public > */
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
/*< private > */
|
/*< private > */
|
||||||
/* Set to TRUE when the container is doing updates of track object
|
/* Set to TRUE when the container is doing updates of track object
|
||||||
|
|
|
@ -20,13 +20,13 @@
|
||||||
/**
|
/**
|
||||||
* SECTION: ges-effect-clip
|
* SECTION: ges-effect-clip
|
||||||
* @short_description: An effect created by parse-launch style bin descriptions
|
* @short_description: An effect created by parse-launch style bin descriptions
|
||||||
* in a #GESTimelineLayer
|
* in a #GESLayer
|
||||||
*
|
*
|
||||||
* The effect will be applied on the sources that have lower priorities
|
* The effect will be applied on the sources that have lower priorities
|
||||||
* (higher number) between the inpoint and the end of it.
|
* (higher number) between the inpoint and the end of it.
|
||||||
*
|
*
|
||||||
* In a #GESSimpleTimelineLayer, the priorities will be set for you but if
|
* In a #GESSimpleLayer, the priorities will be set for you but if
|
||||||
* you use another type of #GESTimelineLayer, you will have to handle it
|
* you use another type of #GESLayer, you will have to handle it
|
||||||
* yourself.
|
* yourself.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-effect
|
* SECTION:ges-effect
|
||||||
* @short_description: adds an effect build from a parse-launch style
|
* @short_description: adds an effect build from a parse-launch style
|
||||||
* bin description to a stream in a #GESSourceClip or a #GESTimelineLayer
|
* bin description to a stream in a #GESSourceClip or a #GESLayer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ges-internal.h"
|
#include "ges-internal.h"
|
||||||
|
|
|
@ -247,7 +247,7 @@ G_GNUC_INTERNAL void _ges_container_sort_children_by_end (GESContainer *contain
|
||||||
/****************************************************
|
/****************************************************
|
||||||
* GESClip *
|
* GESClip *
|
||||||
****************************************************/
|
****************************************************/
|
||||||
void ges_clip_set_layer (GESClip *clip, GESTimelineLayer *layer);
|
void ges_clip_set_layer (GESClip *clip, GESLayer *layer);
|
||||||
gboolean ges_clip_is_moving_from_layer (GESClip *clip);
|
gboolean ges_clip_is_moving_from_layer (GESClip *clip);
|
||||||
void ges_clip_set_moving_from_layer (GESClip *clip, gboolean is_moving);
|
void ges_clip_set_moving_from_layer (GESClip *clip, gboolean is_moving);
|
||||||
GESTrackElement* ges_clip_create_track_element (GESClip *clip, GESTrackType type);
|
GESTrackElement* ges_clip_create_track_element (GESClip *clip, GESTrackType type);
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-timeline-layer
|
* SECTION:ges-layer
|
||||||
* @short_description: Non-overlapping sequence of GESClip
|
* @short_description: Non-overlapping sequence of GESClip
|
||||||
*
|
*
|
||||||
* Responsible for the ordering of the various contained Clip(s). A
|
* Responsible for the ordering of the various contained Clip(s). A
|
||||||
|
@ -31,19 +31,19 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ges-internal.h"
|
#include "ges-internal.h"
|
||||||
#include "ges-timeline-layer.h"
|
#include "ges-layer.h"
|
||||||
#include "ges.h"
|
#include "ges.h"
|
||||||
#include "ges-source-clip.h"
|
#include "ges-source-clip.h"
|
||||||
|
|
||||||
static void ges_meta_container_interface_init
|
static void ges_meta_container_interface_init
|
||||||
(GESMetaContainerInterface * iface);
|
(GESMetaContainerInterface * iface);
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_CODE (GESTimelineLayer, ges_timeline_layer,
|
G_DEFINE_TYPE_WITH_CODE (GESLayer, ges_layer,
|
||||||
G_TYPE_INITIALLY_UNOWNED, G_IMPLEMENT_INTERFACE (GES_TYPE_EXTRACTABLE, NULL)
|
G_TYPE_INITIALLY_UNOWNED, G_IMPLEMENT_INTERFACE (GES_TYPE_EXTRACTABLE, NULL)
|
||||||
G_IMPLEMENT_INTERFACE (GES_TYPE_META_CONTAINER,
|
G_IMPLEMENT_INTERFACE (GES_TYPE_META_CONTAINER,
|
||||||
ges_meta_container_interface_init));
|
ges_meta_container_interface_init));
|
||||||
|
|
||||||
struct _GESTimelineLayerPrivate
|
struct _GESLayerPrivate
|
||||||
{
|
{
|
||||||
/*< private > */
|
/*< private > */
|
||||||
GList *clips_start; /* The Clips sorted by start and
|
GList *clips_start; /* The Clips sorted by start and
|
||||||
|
@ -57,7 +57,7 @@ struct _GESTimelineLayerPrivate
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
} NewAssetUData;
|
} NewAssetUData;
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
@ -75,14 +75,14 @@ enum
|
||||||
LAST_SIGNAL
|
LAST_SIGNAL
|
||||||
};
|
};
|
||||||
|
|
||||||
static guint ges_timeline_layer_signals[LAST_SIGNAL] = { 0 };
|
static guint ges_layer_signals[LAST_SIGNAL] = { 0 };
|
||||||
|
|
||||||
/* GObject standard vmethods */
|
/* GObject standard vmethods */
|
||||||
static void
|
static void
|
||||||
ges_timeline_layer_get_property (GObject * object, guint property_id,
|
ges_layer_get_property (GObject * object, guint property_id,
|
||||||
GValue * value, GParamSpec * pspec)
|
GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer = GES_TIMELINE_LAYER (object);
|
GESLayer *layer = GES_LAYER (object);
|
||||||
|
|
||||||
switch (property_id) {
|
switch (property_id) {
|
||||||
case PROP_PRIORITY:
|
case PROP_PRIORITY:
|
||||||
|
@ -97,18 +97,17 @@ ges_timeline_layer_get_property (GObject * object, guint property_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_timeline_layer_set_property (GObject * object, guint property_id,
|
ges_layer_set_property (GObject * object, guint property_id,
|
||||||
const GValue * value, GParamSpec * pspec)
|
const GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer = GES_TIMELINE_LAYER (object);
|
GESLayer *layer = GES_LAYER (object);
|
||||||
|
|
||||||
switch (property_id) {
|
switch (property_id) {
|
||||||
case PROP_PRIORITY:
|
case PROP_PRIORITY:
|
||||||
ges_timeline_layer_set_priority (layer, g_value_get_uint (value));
|
ges_layer_set_priority (layer, g_value_get_uint (value));
|
||||||
break;
|
break;
|
||||||
case PROP_AUTO_TRANSITION:
|
case PROP_AUTO_TRANSITION:
|
||||||
ges_timeline_layer_set_auto_transition (layer,
|
ges_layer_set_auto_transition (layer, g_value_get_boolean (value));
|
||||||
g_value_get_boolean (value));
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
||||||
|
@ -116,17 +115,17 @@ ges_timeline_layer_set_property (GObject * object, guint property_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_timeline_layer_dispose (GObject * object)
|
ges_layer_dispose (GObject * object)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer = GES_TIMELINE_LAYER (object);
|
GESLayer *layer = GES_LAYER (object);
|
||||||
GESTimelineLayerPrivate *priv = layer->priv;
|
GESLayerPrivate *priv = layer->priv;
|
||||||
|
|
||||||
GST_DEBUG ("Disposing layer");
|
GST_DEBUG ("Disposing layer");
|
||||||
|
|
||||||
while (priv->clips_start)
|
while (priv->clips_start)
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) priv->clips_start->data);
|
ges_layer_remove_clip (layer, (GESClip *) priv->clips_start->data);
|
||||||
|
|
||||||
G_OBJECT_CLASS (ges_timeline_layer_parent_class)->dispose (object);
|
G_OBJECT_CLASS (ges_layer_parent_class)->dispose (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -136,21 +135,21 @@ ges_meta_container_interface_init (GESMetaContainerInterface * iface)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_timeline_layer_class_init (GESTimelineLayerClass * klass)
|
ges_layer_class_init (GESLayerClass * klass)
|
||||||
{
|
{
|
||||||
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
g_type_class_add_private (klass, sizeof (GESTimelineLayerPrivate));
|
g_type_class_add_private (klass, sizeof (GESLayerPrivate));
|
||||||
|
|
||||||
object_class->get_property = ges_timeline_layer_get_property;
|
object_class->get_property = ges_layer_get_property;
|
||||||
object_class->set_property = ges_timeline_layer_set_property;
|
object_class->set_property = ges_layer_set_property;
|
||||||
object_class->dispose = ges_timeline_layer_dispose;
|
object_class->dispose = ges_layer_dispose;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayer:priority:
|
* GESLayer:priority:
|
||||||
*
|
*
|
||||||
* The priority of the layer in the #GESTimeline. 0 is the highest
|
* The priority of the layer in the #GESTimeline. 0 is the highest
|
||||||
* priority. Conceptually, a #GESTimeline is a stack of GESTimelineLayers,
|
* priority. Conceptually, a #GESTimeline is a stack of GESLayers,
|
||||||
* and the priority of the layer represents its position in the stack. Two
|
* and the priority of the layer represents its position in the stack. Two
|
||||||
* layers should not have the same priority within a given GESTimeline.
|
* layers should not have the same priority within a given GESTimeline.
|
||||||
*/
|
*/
|
||||||
|
@ -159,7 +158,7 @@ ges_timeline_layer_class_init (GESTimelineLayerClass * klass)
|
||||||
"The priority of the layer", 0, G_MAXUINT, 0, G_PARAM_READWRITE));
|
"The priority of the layer", 0, G_MAXUINT, 0, G_PARAM_READWRITE));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayer:auto-transition:
|
* GESLayer:auto-transition:
|
||||||
*
|
*
|
||||||
* Sets whether transitions are added automagically when clips overlap.
|
* Sets whether transitions are added automagically when clips overlap.
|
||||||
*/
|
*/
|
||||||
|
@ -168,36 +167,36 @@ ges_timeline_layer_class_init (GESTimelineLayerClass * klass)
|
||||||
"whether the transitions are added", FALSE, G_PARAM_READWRITE));
|
"whether the transitions are added", FALSE, G_PARAM_READWRITE));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayer::clip-added:
|
* GESLayer::clip-added:
|
||||||
* @layer: the #GESTimelineLayer
|
* @layer: the #GESLayer
|
||||||
* @clip: the #GESClip that was added.
|
* @clip: the #GESClip that was added.
|
||||||
*
|
*
|
||||||
* Will be emitted after the clip was added to the layer.
|
* Will be emitted after the clip was added to the layer.
|
||||||
*/
|
*/
|
||||||
ges_timeline_layer_signals[OBJECT_ADDED] =
|
ges_layer_signals[OBJECT_ADDED] =
|
||||||
g_signal_new ("clip-added", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("clip-added", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineLayerClass, object_added),
|
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESLayerClass, object_added),
|
||||||
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1, GES_TYPE_CLIP);
|
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1, GES_TYPE_CLIP);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayer::clip-removed:
|
* GESLayer::clip-removed:
|
||||||
* @layer: the #GESTimelineLayer
|
* @layer: the #GESLayer
|
||||||
* @clip: the #GESClip that was removed
|
* @clip: the #GESClip that was removed
|
||||||
*
|
*
|
||||||
* Will be emitted after the clip was removed from the layer.
|
* Will be emitted after the clip was removed from the layer.
|
||||||
*/
|
*/
|
||||||
ges_timeline_layer_signals[OBJECT_REMOVED] =
|
ges_layer_signals[OBJECT_REMOVED] =
|
||||||
g_signal_new ("clip-removed", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("clip-removed", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineLayerClass,
|
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESLayerClass,
|
||||||
object_removed), NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE,
|
object_removed), NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE,
|
||||||
1, GES_TYPE_CLIP);
|
1, GES_TYPE_CLIP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_timeline_layer_init (GESTimelineLayer * self)
|
ges_layer_init (GESLayer * self)
|
||||||
{
|
{
|
||||||
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
||||||
GES_TYPE_TIMELINE_LAYER, GESTimelineLayerPrivate);
|
GES_TYPE_LAYER, GESLayerPrivate);
|
||||||
|
|
||||||
self->priv->priority = 0;
|
self->priv->priority = 0;
|
||||||
self->priv->auto_transition = FALSE;
|
self->priv->auto_transition = FALSE;
|
||||||
|
@ -206,14 +205,14 @@ ges_timeline_layer_init (GESTimelineLayer * self)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_resync_priorities:
|
* ges_layer_resync_priorities:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
*
|
*
|
||||||
* Resyncs the priorities of the objects controlled by @layer.
|
* Resyncs the priorities of the objects controlled by @layer.
|
||||||
* This method
|
* This method
|
||||||
*/
|
*/
|
||||||
static gboolean
|
static gboolean
|
||||||
ges_timeline_layer_resync_priorities (GESTimelineLayer * layer)
|
ges_layer_resync_priorities (GESLayer * layer)
|
||||||
{
|
{
|
||||||
GList *tmp;
|
GList *tmp;
|
||||||
GESTimelineElement *track_element;
|
GESTimelineElement *track_element;
|
||||||
|
@ -268,7 +267,7 @@ new_asset_cb (GESAsset * source, GAsyncResult * res, NewAssetUData * udata)
|
||||||
ges_extractable_set_asset (GES_EXTRACTABLE (udata->clip), asset);
|
ges_extractable_set_asset (GES_EXTRACTABLE (udata->clip), asset);
|
||||||
|
|
||||||
ges_project_add_asset (project, asset);
|
ges_project_add_asset (project, asset);
|
||||||
ges_timeline_layer_add_clip (udata->layer, udata->clip);
|
ges_layer_add_clip (udata->layer, udata->clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_object_unref (asset);
|
gst_object_unref (asset);
|
||||||
|
@ -277,8 +276,8 @@ new_asset_cb (GESAsset * source, GAsyncResult * res, NewAssetUData * udata)
|
||||||
|
|
||||||
/* Public methods */
|
/* Public methods */
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_remove_clip:
|
* ges_layer_remove_clip:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
* @clip: the #GESClip to remove
|
* @clip: the #GESClip to remove
|
||||||
*
|
*
|
||||||
* Removes the given @clip from the @layer and unparents it.
|
* Removes the given @clip from the @layer and unparents it.
|
||||||
|
@ -290,11 +289,11 @@ new_asset_cb (GESAsset * source, GAsyncResult * res, NewAssetUData * udata)
|
||||||
* not want to remove the clip.
|
* not want to remove the clip.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_layer_remove_clip (GESTimelineLayer * layer, GESClip * clip)
|
ges_layer_remove_clip (GESLayer * layer, GESClip * clip)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *current_layer;
|
GESLayer *current_layer;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), FALSE);
|
g_return_val_if_fail (GES_IS_LAYER (layer), FALSE);
|
||||||
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
||||||
|
|
||||||
GST_DEBUG ("layer:%p, clip:%p", layer, clip);
|
GST_DEBUG ("layer:%p, clip:%p", layer, clip);
|
||||||
|
@ -311,7 +310,7 @@ ges_timeline_layer_remove_clip (GESTimelineLayer * layer, GESClip * clip)
|
||||||
gst_object_unref (current_layer);
|
gst_object_unref (current_layer);
|
||||||
|
|
||||||
/* emit 'clip-removed' */
|
/* emit 'clip-removed' */
|
||||||
g_signal_emit (layer, ges_timeline_layer_signals[OBJECT_REMOVED], 0, clip);
|
g_signal_emit (layer, ges_layer_signals[OBJECT_REMOVED], 0, clip);
|
||||||
|
|
||||||
/* inform the clip it's no longer in a layer */
|
/* inform the clip it's no longer in a layer */
|
||||||
ges_clip_set_layer (clip, NULL);
|
ges_clip_set_layer (clip, NULL);
|
||||||
|
@ -328,17 +327,17 @@ ges_timeline_layer_remove_clip (GESTimelineLayer * layer, GESClip * clip)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_set_priority:
|
* ges_layer_set_priority:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
* @priority: the priority to set
|
* @priority: the priority to set
|
||||||
*
|
*
|
||||||
* Sets the layer to the given @priority. See the documentation of the
|
* Sets the layer to the given @priority. See the documentation of the
|
||||||
* priority property for more information.
|
* priority property for more information.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ges_timeline_layer_set_priority (GESTimelineLayer * layer, guint priority)
|
ges_layer_set_priority (GESLayer * layer, guint priority)
|
||||||
{
|
{
|
||||||
g_return_if_fail (GES_IS_TIMELINE_LAYER (layer));
|
g_return_if_fail (GES_IS_LAYER (layer));
|
||||||
|
|
||||||
GST_DEBUG ("layer:%p, priority:%d", layer, priority);
|
GST_DEBUG ("layer:%p, priority:%d", layer, priority);
|
||||||
|
|
||||||
|
@ -347,13 +346,13 @@ ges_timeline_layer_set_priority (GESTimelineLayer * layer, guint priority)
|
||||||
layer->min_gnl_priority = (priority * LAYER_HEIGHT);
|
layer->min_gnl_priority = (priority * LAYER_HEIGHT);
|
||||||
layer->max_gnl_priority = ((priority + 1) * LAYER_HEIGHT) - 1;
|
layer->max_gnl_priority = ((priority + 1) * LAYER_HEIGHT) - 1;
|
||||||
|
|
||||||
ges_timeline_layer_resync_priorities (layer);
|
ges_layer_resync_priorities (layer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_get_auto_transition:
|
* ges_layer_get_auto_transition:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
*
|
*
|
||||||
* Gets whether transitions are automatically added when objects
|
* Gets whether transitions are automatically added when objects
|
||||||
* overlap or not.
|
* overlap or not.
|
||||||
|
@ -361,51 +360,50 @@ ges_timeline_layer_set_priority (GESTimelineLayer * layer, guint priority)
|
||||||
* Returns: %TRUE if transitions are automatically added, else %FALSE.
|
* Returns: %TRUE if transitions are automatically added, else %FALSE.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_layer_get_auto_transition (GESTimelineLayer * layer)
|
ges_layer_get_auto_transition (GESLayer * layer)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), 0);
|
g_return_val_if_fail (GES_IS_LAYER (layer), 0);
|
||||||
|
|
||||||
return layer->priv->auto_transition;
|
return layer->priv->auto_transition;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_set_auto_transition:
|
* ges_layer_set_auto_transition:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
* @auto_transition: whether the auto_transition is active
|
* @auto_transition: whether the auto_transition is active
|
||||||
*
|
*
|
||||||
* Sets the layer to the given @auto_transition. See the documentation of the
|
* Sets the layer to the given @auto_transition. See the documentation of the
|
||||||
* property auto_transition for more information.
|
* property auto_transition for more information.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ges_timeline_layer_set_auto_transition (GESTimelineLayer * layer,
|
ges_layer_set_auto_transition (GESLayer * layer, gboolean auto_transition)
|
||||||
gboolean auto_transition)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
g_return_if_fail (GES_IS_TIMELINE_LAYER (layer));
|
g_return_if_fail (GES_IS_LAYER (layer));
|
||||||
|
|
||||||
layer->priv->auto_transition = auto_transition;
|
layer->priv->auto_transition = auto_transition;
|
||||||
g_object_notify (G_OBJECT (layer), "auto-transition");
|
g_object_notify (G_OBJECT (layer), "auto-transition");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_get_priority:
|
* ges_layer_get_priority:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
*
|
*
|
||||||
* Get the priority of @layer within the timeline.
|
* Get the priority of @layer within the timeline.
|
||||||
*
|
*
|
||||||
* Returns: The priority of the @layer within the timeline.
|
* Returns: The priority of the @layer within the timeline.
|
||||||
*/
|
*/
|
||||||
guint
|
guint
|
||||||
ges_timeline_layer_get_priority (GESTimelineLayer * layer)
|
ges_layer_get_priority (GESLayer * layer)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), 0);
|
g_return_val_if_fail (GES_IS_LAYER (layer), 0);
|
||||||
|
|
||||||
return layer->priv->priority;
|
return layer->priv->priority;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_get_clips:
|
* ges_layer_get_clips:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
*
|
*
|
||||||
* Get the clips this layer contains.
|
* Get the clips this layer contains.
|
||||||
*
|
*
|
||||||
|
@ -415,13 +413,13 @@ ges_timeline_layer_get_priority (GESTimelineLayer * layer)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GList *
|
GList *
|
||||||
ges_timeline_layer_get_clips (GESTimelineLayer * layer)
|
ges_layer_get_clips (GESLayer * layer)
|
||||||
{
|
{
|
||||||
GESTimelineLayerClass *klass;
|
GESLayerClass *klass;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), NULL);
|
g_return_val_if_fail (GES_IS_LAYER (layer), NULL);
|
||||||
|
|
||||||
klass = GES_TIMELINE_LAYER_GET_CLASS (layer);
|
klass = GES_LAYER_GET_CLASS (layer);
|
||||||
|
|
||||||
if (klass->get_objects) {
|
if (klass->get_objects) {
|
||||||
return klass->get_objects (layer);
|
return klass->get_objects (layer);
|
||||||
|
@ -433,8 +431,8 @@ ges_timeline_layer_get_clips (GESTimelineLayer * layer)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_is_empty:
|
* ges_layer_is_empty:
|
||||||
* @layer: The #GESTimelineLayer to check
|
* @layer: The #GESLayer to check
|
||||||
*
|
*
|
||||||
* Convenience method to check if @layer is empty (doesn't contain any clip),
|
* Convenience method to check if @layer is empty (doesn't contain any clip),
|
||||||
* or not.
|
* or not.
|
||||||
|
@ -443,16 +441,16 @@ ges_timeline_layer_get_clips (GESTimelineLayer * layer)
|
||||||
* one #GESClip
|
* one #GESClip
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_layer_is_empty (GESTimelineLayer * layer)
|
ges_layer_is_empty (GESLayer * layer)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), FALSE);
|
g_return_val_if_fail (GES_IS_LAYER (layer), FALSE);
|
||||||
|
|
||||||
return (layer->priv->clips_start == NULL);
|
return (layer->priv->clips_start == NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_add_clip:
|
* ges_layer_add_clip:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
* @clip: (transfer full): the #GESClip to add.
|
* @clip: (transfer full): the #GESClip to add.
|
||||||
*
|
*
|
||||||
* Adds the given clip to the layer. Sets the clip's parent, and thus
|
* Adds the given clip to the layer. Sets the clip's parent, and thus
|
||||||
|
@ -469,14 +467,14 @@ ges_timeline_layer_is_empty (GESTimelineLayer * layer)
|
||||||
* if the @layer refuses to add the clip.
|
* if the @layer refuses to add the clip.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_layer_add_clip (GESTimelineLayer * layer, GESClip * clip)
|
ges_layer_add_clip (GESLayer * layer, GESClip * clip)
|
||||||
{
|
{
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESTimelineLayerPrivate *priv;
|
GESLayerPrivate *priv;
|
||||||
GESTimelineLayer *current_layer;
|
GESLayer *current_layer;
|
||||||
guint32 maxprio, minprio, prio;
|
guint32 maxprio, minprio, prio;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), FALSE);
|
g_return_val_if_fail (GES_IS_LAYER (layer), FALSE);
|
||||||
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
g_return_val_if_fail (GES_IS_CLIP (clip), FALSE);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (layer, "adding clip:%p", clip);
|
GST_DEBUG_OBJECT (layer, "adding clip:%p", clip);
|
||||||
|
@ -553,19 +551,19 @@ ges_timeline_layer_add_clip (GESTimelineLayer * layer, GESClip * clip)
|
||||||
|
|
||||||
/* If the clip has an acceptable priority, we just let it with its current
|
/* If the clip has an acceptable priority, we just let it with its current
|
||||||
* priority */
|
* priority */
|
||||||
ges_timeline_layer_resync_priorities (layer);
|
ges_layer_resync_priorities (layer);
|
||||||
ges_timeline_element_set_timeline (GES_TIMELINE_ELEMENT (clip),
|
ges_timeline_element_set_timeline (GES_TIMELINE_ELEMENT (clip),
|
||||||
layer->timeline);
|
layer->timeline);
|
||||||
|
|
||||||
/* emit 'clip-added' */
|
/* emit 'clip-added' */
|
||||||
g_signal_emit (layer, ges_timeline_layer_signals[OBJECT_ADDED], 0, clip);
|
g_signal_emit (layer, ges_layer_signals[OBJECT_ADDED], 0, clip);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_add_asset:
|
* ges_layer_add_asset:
|
||||||
* @layer: a #GESTimelineLayer
|
* @layer: a #GESLayer
|
||||||
* @asset: The asset to add to
|
* @asset: The asset to add to
|
||||||
* @start: The start value to set on the new #GESClip
|
* @start: The start value to set on the new #GESClip
|
||||||
* @inpoint: The inpoint value to set on the new #GESClip
|
* @inpoint: The inpoint value to set on the new #GESClip
|
||||||
|
@ -578,13 +576,13 @@ ges_timeline_layer_add_clip (GESTimelineLayer * layer, GESClip * clip)
|
||||||
* Returns: (transfer none): Created #GESClip
|
* Returns: (transfer none): Created #GESClip
|
||||||
*/
|
*/
|
||||||
GESClip *
|
GESClip *
|
||||||
ges_timeline_layer_add_asset (GESTimelineLayer * layer,
|
ges_layer_add_asset (GESLayer * layer,
|
||||||
GESAsset * asset, GstClockTime start, GstClockTime inpoint,
|
GESAsset * asset, GstClockTime start, GstClockTime inpoint,
|
||||||
GstClockTime duration, GESTrackType track_types)
|
GstClockTime duration, GESTrackType track_types)
|
||||||
{
|
{
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
|
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), NULL);
|
g_return_val_if_fail (GES_IS_LAYER (layer), NULL);
|
||||||
g_return_val_if_fail (GES_IS_ASSET (asset), NULL);
|
g_return_val_if_fail (GES_IS_ASSET (asset), NULL);
|
||||||
g_return_val_if_fail (g_type_is_a (ges_asset_get_extractable_type
|
g_return_val_if_fail (g_type_is_a (ges_asset_get_extractable_type
|
||||||
(asset), GES_TYPE_CLIP), NULL);
|
(asset), GES_TYPE_CLIP), NULL);
|
||||||
|
@ -605,7 +603,7 @@ ges_timeline_layer_add_asset (GESTimelineLayer * layer,
|
||||||
_set_duration0 (GES_TIMELINE_ELEMENT (clip), duration);
|
_set_duration0 (GES_TIMELINE_ELEMENT (clip), duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ges_timeline_layer_add_clip (layer, clip)) {
|
if (!ges_layer_add_clip (layer, clip)) {
|
||||||
gst_object_unref (clip);
|
gst_object_unref (clip);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -615,38 +613,37 @@ ges_timeline_layer_add_asset (GESTimelineLayer * layer,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_new:
|
* ges_layer_new:
|
||||||
*
|
*
|
||||||
* Creates a new #GESTimelineLayer.
|
* Creates a new #GESLayer.
|
||||||
*
|
*
|
||||||
* Returns: A new #GESTimelineLayer
|
* Returns: A new #GESLayer
|
||||||
*/
|
*/
|
||||||
GESTimelineLayer *
|
GESLayer *
|
||||||
ges_timeline_layer_new (void)
|
ges_layer_new (void)
|
||||||
{
|
{
|
||||||
return g_object_new (GES_TYPE_TIMELINE_LAYER, NULL);
|
return g_object_new (GES_TYPE_LAYER, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_timeline_layer_get_timeline:
|
* ges_layer_get_timeline:
|
||||||
* @layer: The #GESTimelineLayer to get the parent #GESTimeline from
|
* @layer: The #GESLayer to get the parent #GESTimeline from
|
||||||
*
|
*
|
||||||
* Get the #GESTimeline in which #GESTimelineLayer currently is.
|
* Get the #GESTimeline in which #GESLayer currently is.
|
||||||
*
|
*
|
||||||
* Returns: (transfer none): the #GESTimeline in which #GESTimelineLayer
|
* Returns: (transfer none): the #GESTimeline in which #GESLayer
|
||||||
* currently is or %NULL if not in any timeline yet.
|
* currently is or %NULL if not in any timeline yet.
|
||||||
*/
|
*/
|
||||||
GESTimeline *
|
GESTimeline *
|
||||||
ges_timeline_layer_get_timeline (GESTimelineLayer * layer)
|
ges_layer_get_timeline (GESLayer * layer)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (layer), NULL);
|
g_return_val_if_fail (GES_IS_LAYER (layer), NULL);
|
||||||
|
|
||||||
return layer->timeline;
|
return layer->timeline;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ges_timeline_layer_set_timeline (GESTimelineLayer * layer,
|
ges_layer_set_timeline (GESLayer * layer, GESTimeline * timeline)
|
||||||
GESTimeline * timeline)
|
|
||||||
{
|
{
|
||||||
GST_DEBUG ("layer:%p, timeline:%p", layer, timeline);
|
GST_DEBUG ("layer:%p, timeline:%p", layer, timeline);
|
||||||
|
|
|
@ -18,38 +18,38 @@
|
||||||
* Boston, MA 02110-1301, USA.
|
* Boston, MA 02110-1301, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _GES_TIMELINE_LAYER
|
#ifndef _GES_LAYER
|
||||||
#define _GES_TIMELINE_LAYER
|
#define _GES_LAYER
|
||||||
|
|
||||||
#include <glib-object.h>
|
#include <glib-object.h>
|
||||||
#include <ges/ges-types.h>
|
#include <ges/ges-types.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
#define GES_TYPE_TIMELINE_LAYER ges_timeline_layer_get_type()
|
#define GES_TYPE_LAYER ges_layer_get_type()
|
||||||
|
|
||||||
#define GES_TIMELINE_LAYER(obj) \
|
#define GES_LAYER(obj) \
|
||||||
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_TIMELINE_LAYER, GESTimelineLayer))
|
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_LAYER, GESLayer))
|
||||||
|
|
||||||
#define GES_TIMELINE_LAYER_CLASS(klass) \
|
#define GES_LAYER_CLASS(klass) \
|
||||||
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_TIMELINE_LAYER, GESTimelineLayerClass))
|
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_LAYER, GESLayerClass))
|
||||||
|
|
||||||
#define GES_IS_TIMELINE_LAYER(obj) \
|
#define GES_IS_LAYER(obj) \
|
||||||
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_TIMELINE_LAYER))
|
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_LAYER))
|
||||||
|
|
||||||
#define GES_IS_TIMELINE_LAYER_CLASS(klass) \
|
#define GES_IS_LAYER_CLASS(klass) \
|
||||||
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_TIMELINE_LAYER))
|
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_LAYER))
|
||||||
|
|
||||||
#define GES_TIMELINE_LAYER_GET_CLASS(obj) \
|
#define GES_LAYER_GET_CLASS(obj) \
|
||||||
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_TIMELINE_LAYER, GESTimelineLayerClass))
|
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_LAYER, GESLayerClass))
|
||||||
|
|
||||||
typedef struct _GESTimelineLayerPrivate GESTimelineLayerPrivate;
|
typedef struct _GESLayerPrivate GESLayerPrivate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayer:
|
* GESLayer:
|
||||||
* @timeline: the #GESTimeline where this layer is being used.
|
* @timeline: the #GESTimeline where this layer is being used.
|
||||||
*/
|
*/
|
||||||
struct _GESTimelineLayer {
|
struct _GESLayer {
|
||||||
GInitiallyUnowned parent;
|
GInitiallyUnowned parent;
|
||||||
|
|
||||||
/*< public >*/
|
/*< public >*/
|
||||||
|
@ -59,73 +59,73 @@ struct _GESTimelineLayer {
|
||||||
/*< protected >*/
|
/*< protected >*/
|
||||||
guint32 min_gnl_priority, max_gnl_priority;
|
guint32 min_gnl_priority, max_gnl_priority;
|
||||||
|
|
||||||
GESTimelineLayerPrivate *priv;
|
GESLayerPrivate *priv;
|
||||||
|
|
||||||
/* Padding for API extension */
|
/* Padding for API extension */
|
||||||
gpointer _ges_reserved[GES_PADDING];
|
gpointer _ges_reserved[GES_PADDING];
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimelineLayerClass:
|
* GESLayerClass:
|
||||||
* @get_objects: method to get the objects contained in the layer
|
* @get_objects: method to get the objects contained in the layer
|
||||||
*
|
*
|
||||||
* Subclasses can override the @get_objects if they can provide a more
|
* Subclasses can override the @get_objects if they can provide a more
|
||||||
* efficient way of providing the list of contained #GESClip(s).
|
* efficient way of providing the list of contained #GESClip(s).
|
||||||
*/
|
*/
|
||||||
struct _GESTimelineLayerClass {
|
struct _GESLayerClass {
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
GInitiallyUnownedClass parent_class;
|
GInitiallyUnownedClass parent_class;
|
||||||
|
|
||||||
/*< public >*/
|
/*< public >*/
|
||||||
/* virtual methods for subclasses */
|
/* virtual methods for subclasses */
|
||||||
GList *(*get_objects) (GESTimelineLayer * layer);
|
GList *(*get_objects) (GESLayer * layer);
|
||||||
|
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
/* Signals */
|
/* Signals */
|
||||||
void (*object_added) (GESTimelineLayer * layer, GESClip * object);
|
void (*object_added) (GESLayer * layer, GESClip * object);
|
||||||
void (*object_removed) (GESTimelineLayer * layer, GESClip * object);
|
void (*object_removed) (GESLayer * layer, GESClip * object);
|
||||||
|
|
||||||
/* Padding for API extension */
|
/* Padding for API extension */
|
||||||
gpointer _ges_reserved[GES_PADDING];
|
gpointer _ges_reserved[GES_PADDING];
|
||||||
};
|
};
|
||||||
|
|
||||||
GType ges_timeline_layer_get_type (void);
|
GType ges_layer_get_type (void);
|
||||||
|
|
||||||
GESTimelineLayer* ges_timeline_layer_new (void);
|
GESLayer* ges_layer_new (void);
|
||||||
|
|
||||||
void ges_timeline_layer_set_timeline (GESTimelineLayer * layer,
|
void ges_layer_set_timeline (GESLayer * layer,
|
||||||
GESTimeline * timeline);
|
GESTimeline * timeline);
|
||||||
|
|
||||||
GESTimeline *
|
GESTimeline *
|
||||||
ges_timeline_layer_get_timeline (GESTimelineLayer * layer);
|
ges_layer_get_timeline (GESLayer * layer);
|
||||||
|
|
||||||
gboolean ges_timeline_layer_add_clip (GESTimelineLayer * layer,
|
gboolean ges_layer_add_clip (GESLayer * layer,
|
||||||
GESClip * clip);
|
GESClip * clip);
|
||||||
GESClip * ges_timeline_layer_add_asset (GESTimelineLayer *layer,
|
GESClip * ges_layer_add_asset (GESLayer *layer,
|
||||||
GESAsset *asset,
|
GESAsset *asset,
|
||||||
GstClockTime start,
|
GstClockTime start,
|
||||||
GstClockTime inpoint,
|
GstClockTime inpoint,
|
||||||
GstClockTime duration,
|
GstClockTime duration,
|
||||||
GESTrackType track_types);
|
GESTrackType track_types);
|
||||||
|
|
||||||
gboolean ges_timeline_layer_remove_clip (GESTimelineLayer * layer,
|
gboolean ges_layer_remove_clip (GESLayer * layer,
|
||||||
GESClip * clip);
|
GESClip * clip);
|
||||||
|
|
||||||
void ges_timeline_layer_set_priority (GESTimelineLayer * layer,
|
void ges_layer_set_priority (GESLayer * layer,
|
||||||
guint priority);
|
guint priority);
|
||||||
|
|
||||||
gboolean ges_timeline_layer_is_empty (GESTimelineLayer * layer);
|
gboolean ges_layer_is_empty (GESLayer * layer);
|
||||||
|
|
||||||
guint ges_timeline_layer_get_priority (GESTimelineLayer * layer);
|
guint ges_layer_get_priority (GESLayer * layer);
|
||||||
|
|
||||||
gboolean ges_timeline_layer_get_auto_transition (GESTimelineLayer * layer);
|
gboolean ges_layer_get_auto_transition (GESLayer * layer);
|
||||||
|
|
||||||
void ges_timeline_layer_set_auto_transition (GESTimelineLayer * layer,
|
void ges_layer_set_auto_transition (GESLayer * layer,
|
||||||
gboolean auto_transition);
|
gboolean auto_transition);
|
||||||
|
|
||||||
GList* ges_timeline_layer_get_clips (GESTimelineLayer * layer);
|
GList* ges_layer_get_clips (GESLayer * layer);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* _GES_TIMELINE_LAYER */
|
#endif /* _GES_LAYER */
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-operation-clip
|
* SECTION:ges-operation-clip
|
||||||
* @short_description: Base Class for operations in a GESTimelineLayer
|
* @short_description: Base Class for operations in a GESLayer
|
||||||
*
|
*
|
||||||
* Operations are any kind of object that both outputs AND consumes data.
|
* Operations are any kind of object that both outputs AND consumes data.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-overlay-clip
|
* SECTION:ges-overlay-clip
|
||||||
* @short_description: Base Class for overlays in a GESTimelineLayer
|
* @short_description: Base Class for overlays in a GESLayer
|
||||||
*
|
*
|
||||||
* Overlays are objects which modify the underlying layer(s).
|
* Overlays are objects which modify the underlying layer(s).
|
||||||
*
|
*
|
||||||
|
|
|
@ -444,7 +444,7 @@ make_source (GESFormatter * self, GList * reflist, GHashTable * source_table)
|
||||||
{
|
{
|
||||||
GHashTable *props_table, *effect_table;
|
GHashTable *props_table, *effect_table;
|
||||||
gchar **prio_array;
|
gchar **prio_array;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESPitiviFormatterPrivate *priv = GES_PITIVI_FORMATTER (self)->priv;
|
GESPitiviFormatterPrivate *priv = GES_PITIVI_FORMATTER (self)->priv;
|
||||||
|
|
||||||
gchar *fac_ref = NULL, *media_type = NULL, *filename = NULL, *prio_str;
|
gchar *fac_ref = NULL, *media_type = NULL, *filename = NULL, *prio_str;
|
||||||
|
@ -465,7 +465,7 @@ make_source (GESFormatter * self, GList * reflist, GHashTable * source_table)
|
||||||
|
|
||||||
/* If we do not have any layer with this priority, create it */
|
/* If we do not have any layer with this priority, create it */
|
||||||
if (!(layer = g_hash_table_lookup (priv->layers_table, &prio))) {
|
if (!(layer = g_hash_table_lookup (priv->layers_table, &prio))) {
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
g_object_set (layer, "auto-transition", TRUE, "priority", prio, NULL);
|
g_object_set (layer, "auto-transition", TRUE, "priority", prio, NULL);
|
||||||
ges_timeline_add_layer (self->timeline, layer);
|
ges_timeline_add_layer (self->timeline, layer);
|
||||||
g_hash_table_insert (priv->layers_table, g_memdup (&prio,
|
g_hash_table_insert (priv->layers_table, g_memdup (&prio,
|
||||||
|
@ -514,7 +514,7 @@ make_source (GESFormatter * self, GList * reflist, GHashTable * source_table)
|
||||||
}
|
}
|
||||||
|
|
||||||
set_properties (G_OBJECT (src), props_table);
|
set_properties (G_OBJECT (src), props_table);
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (src));
|
ges_layer_add_clip (layer, GES_CLIP (src));
|
||||||
|
|
||||||
g_signal_connect (src, "child-added",
|
g_signal_connect (src, "child-added",
|
||||||
G_CALLBACK (track_element_added_cb), props_table);
|
G_CALLBACK (track_element_added_cb), props_table);
|
||||||
|
@ -609,14 +609,14 @@ load_pitivi_file_from_uri (GESFormatter * self,
|
||||||
GESTimeline * timeline, const gchar * uri, GError ** error)
|
GESTimeline * timeline, const gchar * uri, GError ** error)
|
||||||
{
|
{
|
||||||
xmlDocPtr doc;
|
xmlDocPtr doc;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESPitiviFormatterPrivate *priv = GES_PITIVI_FORMATTER (self)->priv;
|
GESPitiviFormatterPrivate *priv = GES_PITIVI_FORMATTER (self)->priv;
|
||||||
|
|
||||||
gboolean ret = TRUE;
|
gboolean ret = TRUE;
|
||||||
gint *prio = malloc (sizeof (gint));
|
gint *prio = malloc (sizeof (gint));
|
||||||
|
|
||||||
*prio = 0;
|
*prio = 0;
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
g_object_set (layer, "auto-transition", TRUE, NULL);
|
g_object_set (layer, "auto-transition", TRUE, NULL);
|
||||||
|
|
||||||
g_hash_table_insert (priv->layers_table, prio, layer);
|
g_hash_table_insert (priv->layers_table, prio, layer);
|
||||||
|
|
|
@ -19,12 +19,12 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-simple-timeline-layer
|
* SECTION:ges-simple-layer
|
||||||
* @short_description: High-level GESTimelineLayer
|
* @short_description: High-level GESLayer
|
||||||
*
|
*
|
||||||
* #GESSimpleTimelineLayer allows using #GESClip(s) with a list-like
|
* #GESSimpleLayer allows using #GESClip(s) with a list-like
|
||||||
* API. Clients can add any type of GESClip to a
|
* API. Clients can add any type of GESClip to a
|
||||||
* GESSimpleTimelineLayer, and the layer will automatically compute the
|
* GESSimpleLayer, and the layer will automatically compute the
|
||||||
* appropriate start times.
|
* appropriate start times.
|
||||||
*
|
*
|
||||||
* Users should be aware that GESBaseTransitionClip objects are considered to
|
* Users should be aware that GESBaseTransitionClip objects are considered to
|
||||||
|
@ -36,24 +36,19 @@
|
||||||
#include <ges/ges.h>
|
#include <ges/ges.h>
|
||||||
#include "ges-internal.h"
|
#include "ges-internal.h"
|
||||||
|
|
||||||
static void
|
static void ges_simple_layer_object_removed (GESLayer * layer, GESClip * clip);
|
||||||
ges_simple_timeline_layer_object_removed (GESTimelineLayer * layer,
|
|
||||||
GESClip * clip);
|
|
||||||
|
|
||||||
static void
|
static void ges_simple_layer_object_added (GESLayer * layer, GESClip * clip);
|
||||||
ges_simple_timeline_layer_object_added (GESTimelineLayer * layer,
|
|
||||||
GESClip * clip);
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
clip_height_changed_cb (GESClip * clip G_GNUC_UNUSED,
|
clip_height_changed_cb (GESClip * clip G_GNUC_UNUSED,
|
||||||
GParamSpec * arg G_GNUC_UNUSED, GESSimpleTimelineLayer * layer);
|
GParamSpec * arg G_GNUC_UNUSED, GESSimpleLayer * layer);
|
||||||
|
|
||||||
static GList *get_objects (GESTimelineLayer * layer);
|
static GList *get_objects (GESLayer * layer);
|
||||||
|
|
||||||
G_DEFINE_TYPE (GESSimpleTimelineLayer, ges_simple_timeline_layer,
|
G_DEFINE_TYPE (GESSimpleLayer, ges_simple_layer, GES_TYPE_LAYER);
|
||||||
GES_TYPE_TIMELINE_LAYER);
|
|
||||||
|
|
||||||
struct _GESSimpleTimelineLayerPrivate
|
struct _GESSimpleLayerPrivate
|
||||||
{
|
{
|
||||||
/* Sorted list of objects */
|
/* Sorted list of objects */
|
||||||
GList *objects;
|
GList *objects;
|
||||||
|
@ -78,11 +73,11 @@ enum
|
||||||
static guint gstl_signals[LAST_SIGNAL] = { 0 };
|
static guint gstl_signals[LAST_SIGNAL] = { 0 };
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_get_property (GObject * object,
|
ges_simple_layer_get_property (GObject * object,
|
||||||
guint property_id, GValue * value, GParamSpec * pspec)
|
guint property_id, GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
GESSimpleTimelineLayer *self;
|
GESSimpleLayer *self;
|
||||||
self = GES_SIMPLE_TIMELINE_LAYER (object);
|
self = GES_SIMPLE_LAYER (object);
|
||||||
|
|
||||||
switch (property_id) {
|
switch (property_id) {
|
||||||
case PROP_VALID:
|
case PROP_VALID:
|
||||||
|
@ -94,7 +89,7 @@ ges_simple_timeline_layer_get_property (GObject * object,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_set_property (GObject * object, guint property_id,
|
ges_simple_layer_set_property (GObject * object, guint property_id,
|
||||||
const GValue * value, GParamSpec * pspec)
|
const GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
switch (property_id) {
|
switch (property_id) {
|
||||||
|
@ -104,23 +99,23 @@ ges_simple_timeline_layer_set_property (GObject * object, guint property_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_class_init (GESSimpleTimelineLayerClass * klass)
|
ges_simple_layer_class_init (GESSimpleLayerClass * klass)
|
||||||
{
|
{
|
||||||
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
GESTimelineLayerClass *layer_class = GES_TIMELINE_LAYER_CLASS (klass);
|
GESLayerClass *layer_class = GES_LAYER_CLASS (klass);
|
||||||
|
|
||||||
g_type_class_add_private (klass, sizeof (GESSimpleTimelineLayerPrivate));
|
g_type_class_add_private (klass, sizeof (GESSimpleLayerPrivate));
|
||||||
|
|
||||||
object_class->get_property = ges_simple_timeline_layer_get_property;
|
object_class->get_property = ges_simple_layer_get_property;
|
||||||
object_class->set_property = ges_simple_timeline_layer_set_property;
|
object_class->set_property = ges_simple_layer_set_property;
|
||||||
|
|
||||||
/* Be informed when objects are being added/removed from elsewhere */
|
/* Be informed when objects are being added/removed from elsewhere */
|
||||||
layer_class->object_removed = ges_simple_timeline_layer_object_removed;
|
layer_class->object_removed = ges_simple_layer_object_removed;
|
||||||
layer_class->object_added = ges_simple_timeline_layer_object_added;
|
layer_class->object_added = ges_simple_layer_object_added;
|
||||||
layer_class->get_objects = get_objects;
|
layer_class->get_objects = get_objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESSimpleTimelineLayer:valid:
|
* GESSimpleLayer:valid:
|
||||||
*
|
*
|
||||||
* FALSE when the arrangement of objects in the layer would cause errors or
|
* FALSE when the arrangement of objects in the layer would cause errors or
|
||||||
* unexpected output during playback. Do not set the containing pipeline
|
* unexpected output during playback. Do not set the containing pipeline
|
||||||
|
@ -131,34 +126,34 @@ ges_simple_timeline_layer_class_init (GESSimpleTimelineLayerClass * klass)
|
||||||
"Layer is in a valid configuration", FALSE, G_PARAM_READABLE));
|
"Layer is in a valid configuration", FALSE, G_PARAM_READABLE));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESSimpleTimelineLayer::object-moved:
|
* GESSimpleLayer::object-moved:
|
||||||
* @layer: the #GESSimpleTimelineLayer
|
* @layer: the #GESSimpleLayer
|
||||||
* @object: the #GESClip that was added
|
* @object: the #GESClip that was added
|
||||||
* @old: the previous position of the object
|
* @old: the previous position of the object
|
||||||
* @new: the new position of the object
|
* @new: the new position of the object
|
||||||
*
|
*
|
||||||
* Will be emitted when an object is moved with
|
* Will be emitted when an object is moved with
|
||||||
* #ges_simple_timeline_layer_move_object.
|
* #ges_simple_layer_move_object.
|
||||||
*/
|
*/
|
||||||
gstl_signals[OBJECT_MOVED] =
|
gstl_signals[OBJECT_MOVED] =
|
||||||
g_signal_new ("object-moved", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("object-moved", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESSimpleTimelineLayerClass,
|
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESSimpleLayerClass,
|
||||||
object_moved),
|
object_moved),
|
||||||
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 3,
|
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 3,
|
||||||
GES_TYPE_CLIP, G_TYPE_INT, G_TYPE_INT);
|
GES_TYPE_CLIP, G_TYPE_INT, G_TYPE_INT);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_init (GESSimpleTimelineLayer * self)
|
ges_simple_layer_init (GESSimpleLayer * self)
|
||||||
{
|
{
|
||||||
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
||||||
GES_TYPE_SIMPLE_TIMELINE_LAYER, GESSimpleTimelineLayerPrivate);
|
GES_TYPE_SIMPLE_LAYER, GESSimpleLayerPrivate);
|
||||||
|
|
||||||
self->priv->objects = NULL;
|
self->priv->objects = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gstl_recalculate (GESSimpleTimelineLayer * self)
|
gstl_recalculate (GESSimpleLayer * self)
|
||||||
{
|
{
|
||||||
GList *tmp;
|
GList *tmp;
|
||||||
gint64 pos = 0;
|
gint64 pos = 0;
|
||||||
|
@ -168,9 +163,9 @@ gstl_recalculate (GESSimpleTimelineLayer * self)
|
||||||
GESClip *prev_object = NULL;
|
GESClip *prev_object = NULL;
|
||||||
GESClip *prev_transition = NULL;
|
GESClip *prev_transition = NULL;
|
||||||
gboolean valid = TRUE;
|
gboolean valid = TRUE;
|
||||||
GESSimpleTimelineLayerPrivate *priv = self->priv;
|
GESSimpleLayerPrivate *priv = self->priv;
|
||||||
|
|
||||||
priority = GES_TIMELINE_LAYER (self)->min_gnl_priority + 2;
|
priority = GES_LAYER (self)->min_gnl_priority + 2;
|
||||||
|
|
||||||
GST_DEBUG ("recalculating values");
|
GST_DEBUG ("recalculating values");
|
||||||
|
|
||||||
|
@ -268,7 +263,7 @@ gstl_recalculate (GESSimpleTimelineLayer * self)
|
||||||
GST_DEBUG ("Finished recalculating: final start pos is: %" GST_TIME_FORMAT,
|
GST_DEBUG ("Finished recalculating: final start pos is: %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (pos));
|
GST_TIME_ARGS (pos));
|
||||||
|
|
||||||
GES_TIMELINE_LAYER (self)->max_gnl_priority = priority;
|
GES_LAYER (self)->max_gnl_priority = priority;
|
||||||
|
|
||||||
if (valid != self->priv->valid) {
|
if (valid != self->priv->valid) {
|
||||||
self->priv->valid = valid;
|
self->priv->valid = valid;
|
||||||
|
@ -277,8 +272,8 @@ gstl_recalculate (GESSimpleTimelineLayer * self)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_add_object:
|
* ges_simple_layer_add_object:
|
||||||
* @layer: a #GESSimpleTimelineLayer
|
* @layer: a #GESSimpleLayer
|
||||||
* @object: the #GESClip to add
|
* @object: the #GESClip to add
|
||||||
* @position: the position at which to add the object
|
* @position: the position at which to add the object
|
||||||
*
|
*
|
||||||
|
@ -296,12 +291,12 @@ gstl_recalculate (GESSimpleTimelineLayer * self)
|
||||||
* Returns: TRUE if the object was successfuly added, else FALSE.
|
* Returns: TRUE if the object was successfuly added, else FALSE.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_simple_timeline_layer_add_object (GESSimpleTimelineLayer * layer,
|
ges_simple_layer_add_object (GESSimpleLayer * layer,
|
||||||
GESClip * clip, gint position)
|
GESClip * clip, gint position)
|
||||||
{
|
{
|
||||||
gboolean res;
|
gboolean res;
|
||||||
GList *nth;
|
GList *nth;
|
||||||
GESSimpleTimelineLayerPrivate *priv = layer->priv;
|
GESSimpleLayerPrivate *priv = layer->priv;
|
||||||
|
|
||||||
GST_DEBUG ("layer:%p, clip:%p, position:%d", layer, clip, position);
|
GST_DEBUG ("layer:%p, clip:%p, position:%d", layer, clip, position);
|
||||||
|
|
||||||
|
@ -327,7 +322,7 @@ ges_simple_timeline_layer_add_object (GESSimpleTimelineLayer * layer,
|
||||||
/* provisionally insert the clip */
|
/* provisionally insert the clip */
|
||||||
priv->objects = g_list_insert (priv->objects, clip, position);
|
priv->objects = g_list_insert (priv->objects, clip, position);
|
||||||
|
|
||||||
res = ges_timeline_layer_add_clip ((GESTimelineLayer *) layer, clip);
|
res = ges_layer_add_clip ((GESLayer *) layer, clip);
|
||||||
|
|
||||||
/* Add to layer */
|
/* Add to layer */
|
||||||
if (G_UNLIKELY (!res)) {
|
if (G_UNLIKELY (!res)) {
|
||||||
|
@ -352,8 +347,8 @@ ges_simple_timeline_layer_add_object (GESSimpleTimelineLayer * layer,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_nth:
|
* ges_simple_layer_nth:
|
||||||
* @layer: a #GESSimpleTimelineLayer
|
* @layer: a #GESSimpleLayer
|
||||||
* @position: The position in position to get, starting from 0.
|
* @position: The position in position to get, starting from 0.
|
||||||
*
|
*
|
||||||
* Gets the clip at the given position.
|
* Gets the clip at the given position.
|
||||||
|
@ -363,10 +358,10 @@ ges_simple_timeline_layer_add_object (GESSimpleTimelineLayer * layer,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GESClip *
|
GESClip *
|
||||||
ges_simple_timeline_layer_nth (GESSimpleTimelineLayer * layer, gint position)
|
ges_simple_layer_nth (GESSimpleLayer * layer, gint position)
|
||||||
{
|
{
|
||||||
GList *list;
|
GList *list;
|
||||||
GESSimpleTimelineLayerPrivate *priv = layer->priv;
|
GESSimpleLayerPrivate *priv = layer->priv;
|
||||||
|
|
||||||
list = g_list_nth (priv->objects, position);
|
list = g_list_nth (priv->objects, position);
|
||||||
|
|
||||||
|
@ -377,8 +372,8 @@ ges_simple_timeline_layer_nth (GESSimpleTimelineLayer * layer, gint position)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_index:
|
* ges_simple_layer_index:
|
||||||
* @layer: a #GESSimpleTimelineLayer
|
* @layer: a #GESSimpleLayer
|
||||||
* @clip: a #GESClip in the layer
|
* @clip: a #GESClip in the layer
|
||||||
*
|
*
|
||||||
* Gets the position of the given clip within the given layer.
|
* Gets the position of the given clip within the given layer.
|
||||||
|
@ -387,15 +382,15 @@ ges_simple_timeline_layer_nth (GESSimpleTimelineLayer * layer, gint position)
|
||||||
* clip was not found.
|
* clip was not found.
|
||||||
*/
|
*/
|
||||||
gint
|
gint
|
||||||
ges_simple_timeline_layer_index (GESSimpleTimelineLayer * layer, GESClip * clip)
|
ges_simple_layer_index (GESSimpleLayer * layer, GESClip * clip)
|
||||||
{
|
{
|
||||||
GESSimpleTimelineLayerPrivate *priv = layer->priv;
|
GESSimpleLayerPrivate *priv = layer->priv;
|
||||||
return g_list_index (priv->objects, clip);
|
return g_list_index (priv->objects, clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_move_object:
|
* ges_simple_layer_move_object:
|
||||||
* @layer: a #GESSimpleTimelineLayer
|
* @layer: a #GESSimpleLayer
|
||||||
* @clip: the #GESClip to move
|
* @clip: the #GESClip to move
|
||||||
* @newposition: the new position at which to move the clip
|
* @newposition: the new position at which to move the clip
|
||||||
*
|
*
|
||||||
|
@ -406,17 +401,17 @@ ges_simple_timeline_layer_index (GESSimpleTimelineLayer * layer, GESClip * clip)
|
||||||
* Returns: TRUE if the clip was successfuly moved, else FALSE.
|
* Returns: TRUE if the clip was successfuly moved, else FALSE.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_simple_timeline_layer_move_object (GESSimpleTimelineLayer * layer,
|
ges_simple_layer_move_object (GESSimpleLayer * layer,
|
||||||
GESClip * clip, gint newposition)
|
GESClip * clip, gint newposition)
|
||||||
{
|
{
|
||||||
gint idx;
|
gint idx;
|
||||||
GESSimpleTimelineLayerPrivate *priv = layer->priv;
|
GESSimpleLayerPrivate *priv = layer->priv;
|
||||||
GESTimelineLayer *clip_layer;
|
GESLayer *clip_layer;
|
||||||
|
|
||||||
GST_DEBUG ("layer:%p, clip:%p, newposition:%d", layer, clip, newposition);
|
GST_DEBUG ("layer:%p, clip:%p, newposition:%d", layer, clip, newposition);
|
||||||
|
|
||||||
clip_layer = ges_clip_get_layer (clip);
|
clip_layer = ges_clip_get_layer (clip);
|
||||||
if (G_UNLIKELY (clip_layer != (GESTimelineLayer *) layer)) {
|
if (G_UNLIKELY (clip_layer != (GESLayer *) layer)) {
|
||||||
GST_WARNING ("Clip doesn't belong to this layer");
|
GST_WARNING ("Clip doesn't belong to this layer");
|
||||||
if (clip_layer != NULL)
|
if (clip_layer != NULL)
|
||||||
gst_object_unref (clip_layer);
|
gst_object_unref (clip_layer);
|
||||||
|
@ -453,22 +448,22 @@ ges_simple_timeline_layer_move_object (GESSimpleTimelineLayer * layer,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_new:
|
* ges_simple_layer_new:
|
||||||
*
|
*
|
||||||
* Creates a new #GESSimpleTimelineLayer.
|
* Creates a new #GESSimpleLayer.
|
||||||
*
|
*
|
||||||
* Returns: The new #GESSimpleTimelineLayer
|
* Returns: The new #GESSimpleLayer
|
||||||
*/
|
*/
|
||||||
GESSimpleTimelineLayer *
|
GESSimpleLayer *
|
||||||
ges_simple_timeline_layer_new (void)
|
ges_simple_layer_new (void)
|
||||||
{
|
{
|
||||||
return g_object_new (GES_TYPE_SIMPLE_TIMELINE_LAYER, NULL);
|
return g_object_new (GES_TYPE_SIMPLE_LAYER, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ges_simple_timeline_layer_is_valid:
|
* ges_simple_layer_is_valid:
|
||||||
* @layer: a #GESSimpleTimelineLayer
|
* @layer: a #GESSimpleLayer
|
||||||
*
|
*
|
||||||
* Checks whether the arrangement of objects in the layer would cause errors
|
* Checks whether the arrangement of objects in the layer would cause errors
|
||||||
* or unexpected output during playback. Do not set the containing pipeline
|
* or unexpected output during playback. Do not set the containing pipeline
|
||||||
|
@ -477,16 +472,15 @@ ges_simple_timeline_layer_new (void)
|
||||||
* Returns: #TRUE if current arrangement of the layer is valid else #FALSE.
|
* Returns: #TRUE if current arrangement of the layer is valid else #FALSE.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_simple_timeline_layer_is_valid (GESSimpleTimelineLayer * layer)
|
ges_simple_layer_is_valid (GESSimpleLayer * layer)
|
||||||
{
|
{
|
||||||
return layer->priv->valid;
|
return layer->priv->valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_object_removed (GESTimelineLayer * layer,
|
ges_simple_layer_object_removed (GESLayer * layer, GESClip * clip)
|
||||||
GESClip * clip)
|
|
||||||
{
|
{
|
||||||
GESSimpleTimelineLayer *sl = (GESSimpleTimelineLayer *) layer;
|
GESSimpleLayer *sl = (GESSimpleLayer *) layer;
|
||||||
|
|
||||||
/* remove clip from our list */
|
/* remove clip from our list */
|
||||||
sl->priv->objects = g_list_remove (sl->priv->objects, clip);
|
sl->priv->objects = g_list_remove (sl->priv->objects, clip);
|
||||||
|
@ -494,10 +488,9 @@ ges_simple_timeline_layer_object_removed (GESTimelineLayer * layer,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ges_simple_timeline_layer_object_added (GESTimelineLayer * layer,
|
ges_simple_layer_object_added (GESLayer * layer, GESClip * clip)
|
||||||
GESClip * clip)
|
|
||||||
{
|
{
|
||||||
GESSimpleTimelineLayer *sl = (GESSimpleTimelineLayer *) layer;
|
GESSimpleLayer *sl = (GESSimpleLayer *) layer;
|
||||||
|
|
||||||
if (sl->priv->adding_object == FALSE) {
|
if (sl->priv->adding_object == FALSE) {
|
||||||
/* remove clip from our list */
|
/* remove clip from our list */
|
||||||
|
@ -510,18 +503,18 @@ ges_simple_timeline_layer_object_added (GESTimelineLayer * layer,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
clip_height_changed_cb (GESClip * clip,
|
clip_height_changed_cb (GESClip * clip,
|
||||||
GParamSpec * arg G_GNUC_UNUSED, GESSimpleTimelineLayer * layer)
|
GParamSpec * arg G_GNUC_UNUSED, GESSimpleLayer * layer)
|
||||||
{
|
{
|
||||||
GST_LOG ("layer %p: notify height changed %p", layer, clip);
|
GST_LOG ("layer %p: notify height changed %p", layer, clip);
|
||||||
gstl_recalculate (layer);
|
gstl_recalculate (layer);
|
||||||
}
|
}
|
||||||
|
|
||||||
static GList *
|
static GList *
|
||||||
get_objects (GESTimelineLayer * l)
|
get_objects (GESLayer * l)
|
||||||
{
|
{
|
||||||
GList *ret;
|
GList *ret;
|
||||||
GList *tmp;
|
GList *tmp;
|
||||||
GESSimpleTimelineLayer *layer = (GESSimpleTimelineLayer *) l;
|
GESSimpleLayer *layer = (GESSimpleLayer *) l;
|
||||||
|
|
||||||
ret = g_list_copy (layer->priv->objects);
|
ret = g_list_copy (layer->priv->objects);
|
||||||
|
|
101
ges/ges-simple-layer.h
Normal file
101
ges/ges-simple-layer.h
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
/* GStreamer Editing Services
|
||||||
|
* Copyright (C) 2009 Edward Hervey <edward.hervey@collabora.co.uk>
|
||||||
|
* 2009 Nokia Corporation
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Library General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Library General Public
|
||||||
|
* License along with this library; if not, write to the
|
||||||
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _GES_SIMPLE_LAYER
|
||||||
|
#define _GES_SIMPLE_LAYER
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
#include <ges/ges-types.h>
|
||||||
|
#include <ges/ges-layer.h>
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
#define GES_TYPE_SIMPLE_LAYER ges_simple_layer_get_type()
|
||||||
|
|
||||||
|
#define GES_SIMPLE_LAYER(obj) \
|
||||||
|
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_SIMPLE_LAYER, GESSimpleLayer))
|
||||||
|
|
||||||
|
#define GES_SIMPLE_LAYER_CLASS(klass) \
|
||||||
|
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_SIMPLE_LAYER, GESSimpleLayerClass))
|
||||||
|
|
||||||
|
#define GES_IS_SIMPLE_LAYER(obj) \
|
||||||
|
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_SIMPLE_LAYER))
|
||||||
|
|
||||||
|
#define GES_IS_SIMPLE_LAYER_CLASS(klass) \
|
||||||
|
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_SIMPLE_LAYER))
|
||||||
|
|
||||||
|
#define GES_SIMPLE_LAYER_GET_CLASS(obj) \
|
||||||
|
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_SIMPLE_LAYER, GESSimpleLayerClass))
|
||||||
|
|
||||||
|
typedef struct _GESSimpleLayerPrivate GESSimpleLayerPrivate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GESSimpleLayer:
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct _GESSimpleLayer {
|
||||||
|
/*< private >*/
|
||||||
|
GESLayer parent;
|
||||||
|
|
||||||
|
GESSimpleLayerPrivate *priv;
|
||||||
|
|
||||||
|
/* Padding for API extension */
|
||||||
|
gpointer _ges_reserved[GES_PADDING];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _GESSimpleLayerClass {
|
||||||
|
/*< private >*/
|
||||||
|
GESLayerClass parent_class;
|
||||||
|
|
||||||
|
/*< signals >*/
|
||||||
|
void (*object_moved) (GESLayer * layer, GESClip * object,
|
||||||
|
gint old_position, gint new_position);
|
||||||
|
|
||||||
|
/* Padding for API extension */
|
||||||
|
gpointer _ges_reserved[GES_PADDING];
|
||||||
|
};
|
||||||
|
|
||||||
|
GType ges_simple_layer_get_type (void);
|
||||||
|
|
||||||
|
GESSimpleLayer* ges_simple_layer_new (void);
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
ges_simple_layer_add_object (GESSimpleLayer *layer,
|
||||||
|
GESClip *object, gint position);
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
ges_simple_layer_move_object (GESSimpleLayer *layer,
|
||||||
|
GESClip *clip, gint newposition);
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
ges_simple_layer_is_valid (GESSimpleLayer *layer);
|
||||||
|
|
||||||
|
GESClip *
|
||||||
|
ges_simple_layer_nth (GESSimpleLayer *layer,
|
||||||
|
gint position);
|
||||||
|
|
||||||
|
gint
|
||||||
|
ges_simple_layer_index (GESSimpleLayer *layer,
|
||||||
|
GESClip *clip);
|
||||||
|
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* _GES_SIMPLE_LAYER */
|
||||||
|
|
|
@ -1,101 +0,0 @@
|
||||||
/* GStreamer Editing Services
|
|
||||||
* Copyright (C) 2009 Edward Hervey <edward.hervey@collabora.co.uk>
|
|
||||||
* 2009 Nokia Corporation
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Library General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
* Library General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Library General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
||||||
* Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _GES_SIMPLE_TIMELINE_LAYER
|
|
||||||
#define _GES_SIMPLE_TIMELINE_LAYER
|
|
||||||
|
|
||||||
#include <glib-object.h>
|
|
||||||
#include <ges/ges-types.h>
|
|
||||||
#include <ges/ges-timeline-layer.h>
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
|
||||||
|
|
||||||
#define GES_TYPE_SIMPLE_TIMELINE_LAYER ges_simple_timeline_layer_get_type()
|
|
||||||
|
|
||||||
#define GES_SIMPLE_TIMELINE_LAYER(obj) \
|
|
||||||
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_SIMPLE_TIMELINE_LAYER, GESSimpleTimelineLayer))
|
|
||||||
|
|
||||||
#define GES_SIMPLE_TIMELINE_LAYER_CLASS(klass) \
|
|
||||||
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_SIMPLE_TIMELINE_LAYER, GESSimpleTimelineLayerClass))
|
|
||||||
|
|
||||||
#define GES_IS_SIMPLE_TIMELINE_LAYER(obj) \
|
|
||||||
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_SIMPLE_TIMELINE_LAYER))
|
|
||||||
|
|
||||||
#define GES_IS_SIMPLE_TIMELINE_LAYER_CLASS(klass) \
|
|
||||||
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_SIMPLE_TIMELINE_LAYER))
|
|
||||||
|
|
||||||
#define GES_SIMPLE_TIMELINE_LAYER_GET_CLASS(obj) \
|
|
||||||
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_SIMPLE_TIMELINE_LAYER, GESSimpleTimelineLayerClass))
|
|
||||||
|
|
||||||
typedef struct _GESSimpleTimelineLayerPrivate GESSimpleTimelineLayerPrivate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GESSimpleTimelineLayer:
|
|
||||||
*/
|
|
||||||
|
|
||||||
struct _GESSimpleTimelineLayer {
|
|
||||||
/*< private >*/
|
|
||||||
GESTimelineLayer parent;
|
|
||||||
|
|
||||||
GESSimpleTimelineLayerPrivate *priv;
|
|
||||||
|
|
||||||
/* Padding for API extension */
|
|
||||||
gpointer _ges_reserved[GES_PADDING];
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _GESSimpleTimelineLayerClass {
|
|
||||||
/*< private >*/
|
|
||||||
GESTimelineLayerClass parent_class;
|
|
||||||
|
|
||||||
/*< signals >*/
|
|
||||||
void (*object_moved) (GESTimelineLayer * layer, GESClip * object,
|
|
||||||
gint old_position, gint new_position);
|
|
||||||
|
|
||||||
/* Padding for API extension */
|
|
||||||
gpointer _ges_reserved[GES_PADDING];
|
|
||||||
};
|
|
||||||
|
|
||||||
GType ges_simple_timeline_layer_get_type (void);
|
|
||||||
|
|
||||||
GESSimpleTimelineLayer* ges_simple_timeline_layer_new (void);
|
|
||||||
|
|
||||||
gboolean
|
|
||||||
ges_simple_timeline_layer_add_object (GESSimpleTimelineLayer *layer,
|
|
||||||
GESClip *object, gint position);
|
|
||||||
|
|
||||||
gboolean
|
|
||||||
ges_simple_timeline_layer_move_object (GESSimpleTimelineLayer *layer,
|
|
||||||
GESClip *clip, gint newposition);
|
|
||||||
|
|
||||||
gboolean
|
|
||||||
ges_simple_timeline_layer_is_valid (GESSimpleTimelineLayer *layer);
|
|
||||||
|
|
||||||
GESClip *
|
|
||||||
ges_simple_timeline_layer_nth (GESSimpleTimelineLayer *layer,
|
|
||||||
gint position);
|
|
||||||
|
|
||||||
gint
|
|
||||||
ges_simple_timeline_layer_index (GESSimpleTimelineLayer *layer,
|
|
||||||
GESClip *clip);
|
|
||||||
|
|
||||||
G_END_DECLS
|
|
||||||
|
|
||||||
#endif /* _GES_SIMPLE_TIMELINE_LAYER */
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-source-clip
|
* SECTION:ges-source-clip
|
||||||
* @short_description: Base Class for sources of a GESTimelineLayer
|
* @short_description: Base Class for sources of a GESLayer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ges-internal.h"
|
#include "ges-internal.h"
|
||||||
|
|
|
@ -50,7 +50,7 @@ typedef struct _GESSourceClipPrivate GESSourceClipPrivate;
|
||||||
/**
|
/**
|
||||||
* GESSourceClip:
|
* GESSourceClip:
|
||||||
*
|
*
|
||||||
* Base class for sources of a #GESTimelineLayer
|
* Base class for sources of a #GESLayer
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct _GESSourceClip {
|
struct _GESSourceClip {
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-test-clip
|
* SECTION:ges-test-clip
|
||||||
* @short_description: Render video and audio test patterns in a
|
* @short_description: Render video and audio test patterns in a
|
||||||
* #GESTimelineLayer
|
* #GESLayer
|
||||||
*
|
*
|
||||||
* Useful for testing purposes.
|
* Useful for testing purposes.
|
||||||
*
|
*
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-text-overlay-clip
|
* SECTION:ges-text-overlay-clip
|
||||||
* @short_description: Render text onto another stream in a GESTimelineLayer
|
* @short_description: Render text onto another stream in a GESLayer
|
||||||
*
|
*
|
||||||
* Renders text onto the next lower priority stream using textrender.
|
* Renders text onto the next lower priority stream using textrender.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-text-overlay
|
* SECTION:ges-text-overlay
|
||||||
* @short_description: render text onto another video stream in a
|
* @short_description: render text onto another video stream in a
|
||||||
* #GESTimelineLayer
|
* #GESLayer
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
*
|
*
|
||||||
* #GESTimeline is the central object for any multimedia timeline.
|
* #GESTimeline is the central object for any multimedia timeline.
|
||||||
*
|
*
|
||||||
* Contains a list of #GESTimelineLayer which users should use to arrange the
|
* Contains a list of #GESLayer which users should use to arrange the
|
||||||
* various clips through time.
|
* various clips through time.
|
||||||
*
|
*
|
||||||
* The output type is determined by the #GESTrack that are set on
|
* The output type is determined by the #GESTrack that are set on
|
||||||
|
@ -42,7 +42,7 @@
|
||||||
#include "ges-container.h"
|
#include "ges-container.h"
|
||||||
#include "ges-timeline.h"
|
#include "ges-timeline.h"
|
||||||
#include "ges-track.h"
|
#include "ges-track.h"
|
||||||
#include "ges-timeline-layer.h"
|
#include "ges-layer.h"
|
||||||
#include "ges-auto-transition.h"
|
#include "ges-auto-transition.h"
|
||||||
#include "ges.h"
|
#include "ges.h"
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ typedef struct TrackObjIters
|
||||||
GSequenceIter *iter_obj;
|
GSequenceIter *iter_obj;
|
||||||
GSequenceIter *iter_by_layer;
|
GSequenceIter *iter_by_layer;
|
||||||
|
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
} TrackObjIters;
|
} TrackObjIters;
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ struct _GESTimelinePrivate
|
||||||
|
|
||||||
GList *priv_tracks;
|
GList *priv_tracks;
|
||||||
/* FIXME: We should definitly offer an API over this,
|
/* FIXME: We should definitly offer an API over this,
|
||||||
* probably through a ges_timeline_layer_get_track_elements () method */
|
* probably through a ges_layer_get_track_elements () method */
|
||||||
GHashTable *by_layer; /* {layer: GSequence of TrackElement by start/priorities} */
|
GHashTable *by_layer; /* {layer: GSequence of TrackElement by start/priorities} */
|
||||||
|
|
||||||
/* The set of auto_transitions we control, currently the key is
|
/* The set of auto_transitions we control, currently the key is
|
||||||
|
@ -291,7 +291,7 @@ ges_timeline_dispose (GObject * object)
|
||||||
GESTimelinePrivate *priv = tl->priv;
|
GESTimelinePrivate *priv = tl->priv;
|
||||||
|
|
||||||
while (tl->layers) {
|
while (tl->layers) {
|
||||||
GESTimelineLayer *layer = (GESTimelineLayer *) tl->layers->data;
|
GESLayer *layer = (GESLayer *) tl->layers->data;
|
||||||
ges_timeline_remove_layer (GES_TIMELINE (object), layer);
|
ges_timeline_remove_layer (GES_TIMELINE (object), layer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -429,28 +429,26 @@ ges_timeline_class_init (GESTimelineClass * klass)
|
||||||
/**
|
/**
|
||||||
* GESTimeline::layer-added:
|
* GESTimeline::layer-added:
|
||||||
* @timeline: the #GESTimeline
|
* @timeline: the #GESTimeline
|
||||||
* @layer: the #GESTimelineLayer that was added to the timeline
|
* @layer: the #GESLayer that was added to the timeline
|
||||||
*
|
*
|
||||||
* Will be emitted after the layer was added to the timeline.
|
* Will be emitted after the layer was added to the timeline.
|
||||||
*/
|
*/
|
||||||
ges_timeline_signals[LAYER_ADDED] =
|
ges_timeline_signals[LAYER_ADDED] =
|
||||||
g_signal_new ("layer-added", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("layer-added", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineClass, layer_added), NULL,
|
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineClass, layer_added), NULL,
|
||||||
NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1,
|
NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1, GES_TYPE_LAYER);
|
||||||
GES_TYPE_TIMELINE_LAYER);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimeline::layer-removed:
|
* GESTimeline::layer-removed:
|
||||||
* @timeline: the #GESTimeline
|
* @timeline: the #GESTimeline
|
||||||
* @layer: the #GESTimelineLayer that was removed from the timeline
|
* @layer: the #GESLayer that was removed from the timeline
|
||||||
*
|
*
|
||||||
* Will be emitted after the layer was removed from the timeline.
|
* Will be emitted after the layer was removed from the timeline.
|
||||||
*/
|
*/
|
||||||
ges_timeline_signals[LAYER_REMOVED] =
|
ges_timeline_signals[LAYER_REMOVED] =
|
||||||
g_signal_new ("layer-removed", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("layer-removed", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineClass, layer_removed),
|
G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESTimelineClass, layer_removed),
|
||||||
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1,
|
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1, GES_TYPE_LAYER);
|
||||||
GES_TYPE_TIMELINE_LAYER);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimeline::track-elements-snapping:
|
* GESTimeline::track-elements-snapping:
|
||||||
|
@ -547,14 +545,14 @@ ges_timeline_init (GESTimeline * self)
|
||||||
static gint
|
static gint
|
||||||
sort_layers (gpointer a, gpointer b)
|
sort_layers (gpointer a, gpointer b)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer_a, *layer_b;
|
GESLayer *layer_a, *layer_b;
|
||||||
guint prio_a, prio_b;
|
guint prio_a, prio_b;
|
||||||
|
|
||||||
layer_a = GES_TIMELINE_LAYER (a);
|
layer_a = GES_LAYER (a);
|
||||||
layer_b = GES_TIMELINE_LAYER (b);
|
layer_b = GES_LAYER (b);
|
||||||
|
|
||||||
prio_a = ges_timeline_layer_get_priority (layer_a);
|
prio_a = ges_layer_get_priority (layer_a);
|
||||||
prio_b = ges_timeline_layer_get_priority (layer_b);
|
prio_b = ges_layer_get_priority (layer_b);
|
||||||
|
|
||||||
if ((gint) prio_a > (guint) prio_b)
|
if ((gint) prio_a > (guint) prio_b)
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -587,10 +585,9 @@ timeline_update_duration (GESTimeline * timeline)
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
find_layer_by_prio (GESTimelineLayer * a, gpointer pprio)
|
find_layer_by_prio (GESLayer * a, gpointer pprio)
|
||||||
{
|
{
|
||||||
gint prio = GPOINTER_TO_INT (pprio), lprio =
|
gint prio = GPOINTER_TO_INT (pprio), lprio = ges_layer_get_priority (a);
|
||||||
ges_timeline_layer_get_priority (a);
|
|
||||||
|
|
||||||
if (lprio < prio)
|
if (lprio < prio)
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -659,9 +656,9 @@ _destroy_auto_transition_cb (GESAutoTransition * auto_transition,
|
||||||
{
|
{
|
||||||
GESTimelinePrivate *priv = timeline->priv;
|
GESTimelinePrivate *priv = timeline->priv;
|
||||||
GESClip *transition = auto_transition->transition_clip;
|
GESClip *transition = auto_transition->transition_clip;
|
||||||
GESTimelineLayer *layer = ges_clip_get_layer (transition);
|
GESLayer *layer = ges_clip_get_layer (transition);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, transition);
|
ges_layer_remove_clip (layer, transition);
|
||||||
g_signal_handlers_disconnect_by_func (auto_transition,
|
g_signal_handlers_disconnect_by_func (auto_transition,
|
||||||
_destroy_auto_transition_cb, timeline);
|
_destroy_auto_transition_cb, timeline);
|
||||||
|
|
||||||
|
@ -673,7 +670,7 @@ _destroy_auto_transition_cb (GESAutoTransition * auto_transition,
|
||||||
static GESAutoTransition *
|
static GESAutoTransition *
|
||||||
create_transition (GESTimeline * timeline, GESTrackElement * previous,
|
create_transition (GESTimeline * timeline, GESTrackElement * previous,
|
||||||
GESTrackElement * next, GESClip * transition,
|
GESTrackElement * next, GESClip * transition,
|
||||||
GESTimelineLayer * layer, guint64 start, guint64 duration)
|
GESLayer * layer, guint64 start, guint64 duration)
|
||||||
{
|
{
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESAutoTransition *auto_transition;
|
GESAutoTransition *auto_transition;
|
||||||
|
@ -682,7 +679,7 @@ create_transition (GESTimeline * timeline, GESTrackElement * previous,
|
||||||
/* TODO make it possible to specify a Transition asset in the API */
|
/* TODO make it possible to specify a Transition asset in the API */
|
||||||
asset = ges_asset_request (GES_TYPE_TRANSITION_CLIP, "crossfade", NULL);
|
asset = ges_asset_request (GES_TYPE_TRANSITION_CLIP, "crossfade", NULL);
|
||||||
transition =
|
transition =
|
||||||
ges_timeline_layer_add_asset (layer, asset, start, 0, duration,
|
ges_layer_add_asset (layer, asset, start, 0, duration,
|
||||||
ges_track_element_get_track_type (next));
|
ges_track_element_get_track_type (next));
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG_OBJECT (timeline,
|
GST_DEBUG_OBJECT (timeline,
|
||||||
|
@ -704,12 +701,12 @@ create_transition (GESTimeline * timeline, GESTrackElement * previous,
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef GESAutoTransition *(*GetAutoTransitionFunc) (GESTimeline * timeline,
|
typedef GESAutoTransition *(*GetAutoTransitionFunc) (GESTimeline * timeline,
|
||||||
GESTimelineLayer * layer, GESTrack * track, GESTrackElement * previous,
|
GESLayer * layer, GESTrack * track, GESTrackElement * previous,
|
||||||
GESTrackElement * next, GstClockTime transition_duration);
|
GESTrackElement * next, GstClockTime transition_duration);
|
||||||
|
|
||||||
static GESAutoTransition *
|
static GESAutoTransition *
|
||||||
_find_transition_from_auto_transitions (GESTimeline * timeline,
|
_find_transition_from_auto_transitions (GESTimeline * timeline,
|
||||||
GESTimelineLayer * layer, GESTrack * track, GESTrackElement * prev,
|
GESLayer * layer, GESTrack * track, GESTrackElement * prev,
|
||||||
GESTrackElement * next, GstClockTime transition_duration)
|
GESTrackElement * next, GstClockTime transition_duration)
|
||||||
{
|
{
|
||||||
GESAutoTransition *auto_transition;
|
GESAutoTransition *auto_transition;
|
||||||
|
@ -724,7 +721,7 @@ _find_transition_from_auto_transitions (GESTimeline * timeline,
|
||||||
|
|
||||||
static GESAutoTransition *
|
static GESAutoTransition *
|
||||||
_create_auto_transition_from_transitions (GESTimeline * timeline,
|
_create_auto_transition_from_transitions (GESTimeline * timeline,
|
||||||
GESTimelineLayer * layer, GESTrack * track, GESTrackElement * prev,
|
GESLayer * layer, GESTrack * track, GESTrackElement * prev,
|
||||||
GESTrackElement * next, GstClockTime transition_duration)
|
GESTrackElement * next, GstClockTime transition_duration)
|
||||||
{
|
{
|
||||||
GSequenceIter *tmp_iter;
|
GSequenceIter *tmp_iter;
|
||||||
|
@ -775,7 +772,7 @@ _create_auto_transition_from_transitions (GESTimeline * timeline,
|
||||||
* if @ track is specified, we will create the transitions only for that particular
|
* if @ track is specified, we will create the transitions only for that particular
|
||||||
* track */
|
* track */
|
||||||
static void
|
static void
|
||||||
_create_transitions_on_layer (GESTimeline * timeline, GESTimelineLayer * layer,
|
_create_transitions_on_layer (GESTimeline * timeline, GESLayer * layer,
|
||||||
GESTrack * track, GESTrackElement * initiating_obj,
|
GESTrack * track, GESTrackElement * initiating_obj,
|
||||||
GetAutoTransitionFunc get_auto_transition)
|
GetAutoTransitionFunc get_auto_transition)
|
||||||
{
|
{
|
||||||
|
@ -788,10 +785,10 @@ _create_transitions_on_layer (GESTimeline * timeline, GESTimelineLayer * layer,
|
||||||
* "start" but not the "end" in the starts_ends list */
|
* "start" but not the "end" in the starts_ends list */
|
||||||
GESTimelinePrivate *priv = timeline->priv;
|
GESTimelinePrivate *priv = timeline->priv;
|
||||||
|
|
||||||
if (!layer || !ges_timeline_layer_get_auto_transition (layer))
|
if (!layer || !ges_layer_get_auto_transition (layer))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
layer_prio = ges_timeline_layer_get_priority (layer);
|
layer_prio = ges_layer_get_priority (layer);
|
||||||
for (iter = g_sequence_get_begin_iter (priv->starts_ends);
|
for (iter = g_sequence_get_begin_iter (priv->starts_ends);
|
||||||
iter && !g_sequence_iter_is_end (iter);
|
iter && !g_sequence_iter_is_end (iter);
|
||||||
iter = g_sequence_iter_next (iter)) {
|
iter = g_sequence_iter_next (iter)) {
|
||||||
|
@ -940,7 +937,7 @@ start_tracking_track_element (GESTimeline * timeline,
|
||||||
guint layer_prio = _PRIORITY (trackelement) / LAYER_HEIGHT;
|
guint layer_prio = _PRIORITY (trackelement) / LAYER_HEIGHT;
|
||||||
GList *layer_node = g_list_find_custom (timeline->layers,
|
GList *layer_node = g_list_find_custom (timeline->layers,
|
||||||
GINT_TO_POINTER (layer_prio), (GCompareFunc) find_layer_by_prio);
|
GINT_TO_POINTER (layer_prio), (GCompareFunc) find_layer_by_prio);
|
||||||
GESTimelineLayer *layer = layer_node ? layer_node->data : NULL;
|
GESLayer *layer = layer_node ? layer_node->data : NULL;
|
||||||
|
|
||||||
iters = g_slice_new0 (TrackObjIters);
|
iters = g_slice_new0 (TrackObjIters);
|
||||||
|
|
||||||
|
@ -1135,7 +1132,7 @@ static inline GESClip *
|
||||||
add_moving_clip (MoveContext * mv_ctx, GESTrackElement * trackelement)
|
add_moving_clip (MoveContext * mv_ctx, GESTrackElement * trackelement)
|
||||||
{
|
{
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
guint layer_prio;
|
guint layer_prio;
|
||||||
|
|
||||||
clip = GES_CLIP (GES_TIMELINE_ELEMENT_PARENT (trackelement));
|
clip = GES_CLIP (GES_TIMELINE_ELEMENT_PARENT (trackelement));
|
||||||
|
@ -1151,7 +1148,7 @@ add_moving_clip (MoveContext * mv_ctx, GESTrackElement * trackelement)
|
||||||
|
|
||||||
g_hash_table_insert (mv_ctx->moving_clips, clip, clip);
|
g_hash_table_insert (mv_ctx->moving_clips, clip, clip);
|
||||||
|
|
||||||
layer_prio = ges_timeline_layer_get_priority (layer);
|
layer_prio = ges_layer_get_priority (layer);
|
||||||
mv_ctx->min_move_layer = MIN (mv_ctx->min_move_layer, layer_prio);
|
mv_ctx->min_move_layer = MIN (mv_ctx->min_move_layer, layer_prio);
|
||||||
mv_ctx->max_layer_prio = MAX (mv_ctx->max_layer_prio, layer_prio);
|
mv_ctx->max_layer_prio = MAX (mv_ctx->max_layer_prio, layer_prio);
|
||||||
|
|
||||||
|
@ -1697,7 +1694,7 @@ timeline_context_to_layer (GESTimeline * timeline, gint offset)
|
||||||
if (offset != 0 && (offset > 0 || mv_ctx->min_move_layer >= -offset)) {
|
if (offset != 0 && (offset > 0 || mv_ctx->min_move_layer >= -offset)) {
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
GESClip *key, *value;
|
GESClip *key, *value;
|
||||||
GESTimelineLayer *new_layer, *layer;
|
GESLayer *new_layer, *layer;
|
||||||
guint prio;
|
guint prio;
|
||||||
|
|
||||||
mv_ctx->ignore_needs_ctx = TRUE;
|
mv_ctx->ignore_needs_ctx = TRUE;
|
||||||
|
@ -1709,16 +1706,15 @@ timeline_context_to_layer (GESTimeline * timeline, gint offset)
|
||||||
while (g_hash_table_iter_next (&iter, (gpointer *) & key,
|
while (g_hash_table_iter_next (&iter, (gpointer *) & key,
|
||||||
(gpointer *) & value)) {
|
(gpointer *) & value)) {
|
||||||
layer = ges_clip_get_layer (value);
|
layer = ges_clip_get_layer (value);
|
||||||
prio = ges_timeline_layer_get_priority (layer);
|
prio = ges_layer_get_priority (layer);
|
||||||
|
|
||||||
/* We know that the layer exists as we created it */
|
/* We know that the layer exists as we created it */
|
||||||
new_layer = GES_TIMELINE_LAYER (g_list_nth_data (timeline->layers,
|
new_layer = GES_LAYER (g_list_nth_data (timeline->layers, prio + offset));
|
||||||
prio + offset));
|
|
||||||
|
|
||||||
if (new_layer == NULL) {
|
if (new_layer == NULL) {
|
||||||
do {
|
do {
|
||||||
new_layer = ges_timeline_append_layer (timeline);
|
new_layer = ges_timeline_append_layer (timeline);
|
||||||
} while (ges_timeline_layer_get_priority (new_layer) < prio + offset);
|
} while (ges_layer_get_priority (new_layer) < prio + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret &= ges_clip_move_to_layer (key, new_layer);
|
ret &= ges_clip_move_to_layer (key, new_layer);
|
||||||
|
@ -1784,7 +1780,7 @@ add_object_to_tracks (GESTimeline * timeline, GESClip * clip, GESTrack * track)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_auto_transition_changed_cb (GESTimelineLayer * layer,
|
layer_auto_transition_changed_cb (GESLayer * layer,
|
||||||
GParamSpec * arg G_GNUC_UNUSED, GESTimeline * timeline)
|
GParamSpec * arg G_GNUC_UNUSED, GESTimeline * timeline)
|
||||||
{
|
{
|
||||||
_create_transitions_on_layer (timeline, layer, NULL, NULL,
|
_create_transitions_on_layer (timeline, layer, NULL, NULL,
|
||||||
|
@ -1888,8 +1884,7 @@ clip_track_element_removed_cb (GESClip * clip, GESTrackElement * track_element,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_object_added_cb (GESTimelineLayer * layer, GESClip * clip,
|
layer_object_added_cb (GESLayer * layer, GESClip * clip, GESTimeline * timeline)
|
||||||
GESTimeline * timeline)
|
|
||||||
{
|
{
|
||||||
/* We make sure not to be connected twice */
|
/* We make sure not to be connected twice */
|
||||||
g_signal_handlers_disconnect_by_func (clip, clip_track_element_added_cb,
|
g_signal_handlers_disconnect_by_func (clip, clip_track_element_added_cb,
|
||||||
|
@ -1917,7 +1912,7 @@ layer_object_added_cb (GESTimelineLayer * layer, GESClip * clip,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_priority_changed_cb (GESTimelineLayer * layer,
|
layer_priority_changed_cb (GESLayer * layer,
|
||||||
GParamSpec * arg G_GNUC_UNUSED, GESTimeline * timeline)
|
GParamSpec * arg G_GNUC_UNUSED, GESTimeline * timeline)
|
||||||
{
|
{
|
||||||
timeline->layers = g_list_sort (timeline->layers, (GCompareFunc)
|
timeline->layers = g_list_sort (timeline->layers, (GCompareFunc)
|
||||||
|
@ -1925,7 +1920,7 @@ layer_priority_changed_cb (GESTimelineLayer * layer,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_object_removed_cb (GESTimelineLayer * layer, GESClip * clip,
|
layer_object_removed_cb (GESLayer * layer, GESClip * clip,
|
||||||
GESTimeline * timeline)
|
GESTimeline * timeline)
|
||||||
{
|
{
|
||||||
GList *trackelements, *tmp;
|
GList *trackelements, *tmp;
|
||||||
|
@ -2006,7 +2001,7 @@ trackelement_priority_changed_cb (GESTrackElement * child,
|
||||||
GList *layer_node = g_list_find_custom (timeline->layers,
|
GList *layer_node = g_list_find_custom (timeline->layers,
|
||||||
GINT_TO_POINTER (_PRIORITY (child) / LAYER_HEIGHT),
|
GINT_TO_POINTER (_PRIORITY (child) / LAYER_HEIGHT),
|
||||||
(GCompareFunc) find_layer_by_prio);
|
(GCompareFunc) find_layer_by_prio);
|
||||||
GESTimelineLayer *layer = layer_node ? layer_node->data : NULL;
|
GESLayer *layer = layer_node ? layer_node->data : NULL;
|
||||||
TrackObjIters *iters = g_hash_table_lookup (priv->obj_iters,
|
TrackObjIters *iters = g_hash_table_lookup (priv->obj_iters,
|
||||||
child);
|
child);
|
||||||
|
|
||||||
|
@ -2273,21 +2268,21 @@ ges_timeline_save_to_uri (GESTimeline * timeline, const gchar * uri,
|
||||||
* ges_timeline_append_layer:
|
* ges_timeline_append_layer:
|
||||||
* @timeline: a #GESTimeline
|
* @timeline: a #GESTimeline
|
||||||
*
|
*
|
||||||
* Append a newly created #GESTimelineLayer to @timeline
|
* Append a newly created #GESLayer to @timeline
|
||||||
* Note that you do not own any reference to the returned layer.
|
* Note that you do not own any reference to the returned layer.
|
||||||
*
|
*
|
||||||
* Returns: (transfer none): The newly created #GESTimelineLayer, or the last (empty)
|
* Returns: (transfer none): The newly created #GESLayer, or the last (empty)
|
||||||
* #GESTimelineLayer of @timeline.
|
* #GESLayer of @timeline.
|
||||||
*/
|
*/
|
||||||
GESTimelineLayer *
|
GESLayer *
|
||||||
ges_timeline_append_layer (GESTimeline * timeline)
|
ges_timeline_append_layer (GESTimeline * timeline)
|
||||||
{
|
{
|
||||||
guint32 priority;
|
guint32 priority;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
priority = g_list_length (timeline->layers);
|
priority = g_list_length (timeline->layers);
|
||||||
ges_timeline_layer_set_priority (layer, priority);
|
ges_layer_set_priority (layer, priority);
|
||||||
|
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
|
@ -2297,7 +2292,7 @@ ges_timeline_append_layer (GESTimeline * timeline)
|
||||||
/**
|
/**
|
||||||
* ges_timeline_add_layer:
|
* ges_timeline_add_layer:
|
||||||
* @timeline: a #GESTimeline
|
* @timeline: a #GESTimeline
|
||||||
* @layer: the #GESTimelineLayer to add
|
* @layer: the #GESLayer to add
|
||||||
*
|
*
|
||||||
* Add the layer to the timeline. The reference to the @layer will be stolen
|
* Add the layer to the timeline. The reference to the @layer will be stolen
|
||||||
* by the @timeline.
|
* by the @timeline.
|
||||||
|
@ -2305,7 +2300,7 @@ ges_timeline_append_layer (GESTimeline * timeline)
|
||||||
* Returns: TRUE if the layer was properly added, else FALSE.
|
* Returns: TRUE if the layer was properly added, else FALSE.
|
||||||
*/
|
*/
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_add_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
ges_timeline_add_layer (GESTimeline * timeline, GESLayer * layer)
|
||||||
{
|
{
|
||||||
GList *objects, *tmp;
|
GList *objects, *tmp;
|
||||||
|
|
||||||
|
@ -2328,7 +2323,7 @@ ges_timeline_add_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
(GCompareFunc) sort_layers);
|
(GCompareFunc) sort_layers);
|
||||||
|
|
||||||
/* Inform the layer that it belongs to a new timeline */
|
/* Inform the layer that it belongs to a new timeline */
|
||||||
ges_timeline_layer_set_timeline (layer, timeline);
|
ges_layer_set_timeline (layer, timeline);
|
||||||
|
|
||||||
g_hash_table_insert (timeline->priv->by_layer, layer, g_sequence_new (NULL));
|
g_hash_table_insert (timeline->priv->by_layer, layer, g_sequence_new (NULL));
|
||||||
|
|
||||||
|
@ -2346,7 +2341,7 @@ ges_timeline_add_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
g_signal_emit (timeline, ges_timeline_signals[LAYER_ADDED], 0, layer);
|
g_signal_emit (timeline, ges_timeline_signals[LAYER_ADDED], 0, layer);
|
||||||
|
|
||||||
/* add any existing clips to the timeline */
|
/* add any existing clips to the timeline */
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
for (tmp = objects; tmp; tmp = tmp->next) {
|
for (tmp = objects; tmp; tmp = tmp->next) {
|
||||||
layer_object_added_cb (layer, tmp->data, timeline);
|
layer_object_added_cb (layer, tmp->data, timeline);
|
||||||
gst_object_unref (tmp->data);
|
gst_object_unref (tmp->data);
|
||||||
|
@ -2360,7 +2355,7 @@ ges_timeline_add_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
/**
|
/**
|
||||||
* ges_timeline_remove_layer:
|
* ges_timeline_remove_layer:
|
||||||
* @timeline: a #GESTimeline
|
* @timeline: a #GESTimeline
|
||||||
* @layer: the #GESTimelineLayer to remove
|
* @layer: the #GESLayer to remove
|
||||||
*
|
*
|
||||||
* Removes the layer from the timeline. The reference that the @timeline holds on
|
* Removes the layer from the timeline. The reference that the @timeline holds on
|
||||||
* the layer will be dropped. If you wish to use the @layer after calling this
|
* the layer will be dropped. If you wish to use the @layer after calling this
|
||||||
|
@ -2370,7 +2365,7 @@ ges_timeline_add_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
ges_timeline_remove_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
ges_timeline_remove_layer (GESTimeline * timeline, GESLayer * layer)
|
||||||
{
|
{
|
||||||
GList *layer_objects, *tmp;
|
GList *layer_objects, *tmp;
|
||||||
|
|
||||||
|
@ -2383,7 +2378,7 @@ ges_timeline_remove_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
|
|
||||||
/* remove objects from any private data structures */
|
/* remove objects from any private data structures */
|
||||||
|
|
||||||
layer_objects = ges_timeline_layer_get_clips (layer);
|
layer_objects = ges_layer_get_clips (layer);
|
||||||
for (tmp = layer_objects; tmp; tmp = tmp->next) {
|
for (tmp = layer_objects; tmp; tmp = tmp->next) {
|
||||||
layer_object_removed_cb (layer, GES_CLIP (tmp->data), timeline);
|
layer_object_removed_cb (layer, GES_CLIP (tmp->data), timeline);
|
||||||
gst_object_unref (G_OBJECT (tmp->data));
|
gst_object_unref (G_OBJECT (tmp->data));
|
||||||
|
@ -2403,7 +2398,7 @@ ges_timeline_remove_layer (GESTimeline * timeline, GESTimelineLayer * layer)
|
||||||
|
|
||||||
g_hash_table_remove (timeline->priv->by_layer, layer);
|
g_hash_table_remove (timeline->priv->by_layer, layer);
|
||||||
timeline->layers = g_list_remove (timeline->layers, layer);
|
timeline->layers = g_list_remove (timeline->layers, layer);
|
||||||
ges_timeline_layer_set_timeline (layer, NULL);
|
ges_layer_set_timeline (layer, NULL);
|
||||||
|
|
||||||
g_signal_emit (timeline, ges_timeline_signals[LAYER_REMOVED], 0, layer);
|
g_signal_emit (timeline, ges_timeline_signals[LAYER_REMOVED], 0, layer);
|
||||||
|
|
||||||
|
@ -2480,7 +2475,7 @@ ges_timeline_add_track (GESTimeline * timeline, GESTrack * track)
|
||||||
|
|
||||||
for (tmp = timeline->layers; tmp; tmp = tmp->next) {
|
for (tmp = timeline->layers; tmp; tmp = tmp->next) {
|
||||||
GList *objects, *obj;
|
GList *objects, *obj;
|
||||||
objects = ges_timeline_layer_get_clips (tmp->data);
|
objects = ges_layer_get_clips (tmp->data);
|
||||||
|
|
||||||
for (obj = objects; obj; obj = obj->next) {
|
for (obj = objects; obj; obj = obj->next) {
|
||||||
GESClip *clip = obj->data;
|
GESClip *clip = obj->data;
|
||||||
|
@ -2622,10 +2617,10 @@ ges_timeline_get_tracks (GESTimeline * timeline)
|
||||||
* ges_timeline_get_layers:
|
* ges_timeline_get_layers:
|
||||||
* @timeline: a #GESTimeline
|
* @timeline: a #GESTimeline
|
||||||
*
|
*
|
||||||
* Get the list of #GESTimelineLayer present in the Timeline.
|
* Get the list of #GESLayer present in the Timeline.
|
||||||
*
|
*
|
||||||
* Returns: (transfer full) (element-type GESTimelineLayer): the list of
|
* Returns: (transfer full) (element-type GESLayer): the list of
|
||||||
* #GESTimelineLayer present in the Timeline sorted by priority.
|
* #GESLayer present in the Timeline sorted by priority.
|
||||||
* The caller should unref each Layer once he is done with them.
|
* The caller should unref each Layer once he is done with them.
|
||||||
*/
|
*/
|
||||||
GList *
|
GList *
|
||||||
|
@ -2694,7 +2689,7 @@ ges_timeline_enable_update (GESTimeline * timeline, gboolean enabled)
|
||||||
timeline->priv->updates_enabled = enabled;
|
timeline->priv->updates_enabled = enabled;
|
||||||
|
|
||||||
for (tmp = timeline->layers; tmp; tmp = tmp->next) {
|
for (tmp = timeline->layers; tmp; tmp = tmp->next) {
|
||||||
_create_transitions_on_layer (timeline, GES_TIMELINE_LAYER (tmp->data),
|
_create_transitions_on_layer (timeline, GES_LAYER (tmp->data),
|
||||||
NULL, NULL, _find_transition_from_auto_transitions);
|
NULL, NULL, _find_transition_from_auto_transitions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,7 @@ typedef struct _GESTimelinePrivate GESTimelinePrivate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GESTimeline:
|
* GESTimeline:
|
||||||
* @layers: (element-type GES.TimelineLayer): A list of #GESTimelineLayer sorted by priority NOTE: Do not modify.
|
* @layers: (element-type GES.Layer): A list of #GESLayer sorted by priority NOTE: Do not modify.
|
||||||
* @tracks: (element-type GES.Track): A list of #GESTrack sorted by priority NOTE: Do not modify.
|
* @tracks: (element-type GES.Track): A list of #GESTrack sorted by priority NOTE: Do not modify.
|
||||||
*/
|
*/
|
||||||
struct _GESTimeline {
|
struct _GESTimeline {
|
||||||
|
@ -90,8 +90,8 @@ struct _GESTimelineClass {
|
||||||
|
|
||||||
void (*track_added) (GESTimeline *timeline, GESTrack * track);
|
void (*track_added) (GESTimeline *timeline, GESTrack * track);
|
||||||
void (*track_removed) (GESTimeline *timeline, GESTrack * track);
|
void (*track_removed) (GESTimeline *timeline, GESTrack * track);
|
||||||
void (*layer_added) (GESTimeline *timeline, GESTimelineLayer *layer);
|
void (*layer_added) (GESTimeline *timeline, GESLayer *layer);
|
||||||
void (*layer_removed) (GESTimeline *timeline, GESTimelineLayer *layer);
|
void (*layer_removed) (GESTimeline *timeline, GESLayer *layer);
|
||||||
|
|
||||||
/* Padding for API extension */
|
/* Padding for API extension */
|
||||||
gpointer _ges_reserved[GES_PADDING];
|
gpointer _ges_reserved[GES_PADDING];
|
||||||
|
@ -105,9 +105,9 @@ GESTimeline* ges_timeline_new_from_uri (const gchar *uri, GError **error);
|
||||||
gboolean ges_timeline_load_from_uri (GESTimeline *timeline, const gchar *uri, GError **error);
|
gboolean ges_timeline_load_from_uri (GESTimeline *timeline, const gchar *uri, GError **error);
|
||||||
gboolean ges_timeline_save_to_uri (GESTimeline * timeline, const gchar * uri,
|
gboolean ges_timeline_save_to_uri (GESTimeline * timeline, const gchar * uri,
|
||||||
GESAsset *formatter_asset, gboolean overwrite, GError ** error);
|
GESAsset *formatter_asset, gboolean overwrite, GError ** error);
|
||||||
gboolean ges_timeline_add_layer (GESTimeline *timeline, GESTimelineLayer *layer);
|
gboolean ges_timeline_add_layer (GESTimeline *timeline, GESLayer *layer);
|
||||||
GESTimelineLayer * ges_timeline_append_layer (GESTimeline * timeline);
|
GESLayer * ges_timeline_append_layer (GESTimeline * timeline);
|
||||||
gboolean ges_timeline_remove_layer (GESTimeline *timeline, GESTimelineLayer *layer);
|
gboolean ges_timeline_remove_layer (GESTimeline *timeline, GESLayer *layer);
|
||||||
GList* ges_timeline_get_layers (GESTimeline *timeline);
|
GList* ges_timeline_get_layers (GESTimeline *timeline);
|
||||||
|
|
||||||
gboolean ges_timeline_add_track (GESTimeline *timeline, GESTrack *track);
|
gboolean ges_timeline_add_track (GESTimeline *timeline, GESTrack *track);
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:ges-title-clip
|
* SECTION:ges-title-clip
|
||||||
* @short_description: Render stand-alone titles in GESTimelineLayer.
|
* @short_description: Render stand-alone titles in GESLayer.
|
||||||
*
|
*
|
||||||
* Renders the given text in the specified font, at specified position, and
|
* Renders the given text in the specified font, at specified position, and
|
||||||
* with the specified background pattern.
|
* with the specified background pattern.
|
||||||
|
|
|
@ -50,7 +50,7 @@ typedef struct _GESTitleClipPrivate GESTitleClipPrivate;
|
||||||
/**
|
/**
|
||||||
* GESTitleClip:
|
* GESTitleClip:
|
||||||
*
|
*
|
||||||
* Render stand-alone titles in GESTimelineLayer.
|
* Render stand-alone titles in GESLayer.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct _GESTitleClip {
|
struct _GESTitleClip {
|
||||||
|
|
|
@ -1366,9 +1366,9 @@ _deep_copy (GESTimelineElement * element, GESTimelineElement * elementcopy)
|
||||||
/**
|
/**
|
||||||
* ges_track_element_edit:
|
* ges_track_element_edit:
|
||||||
* @object: the #GESTrackElement to edit
|
* @object: the #GESTrackElement to edit
|
||||||
* @layers: (element-type GESTimelineLayer): The layers you want the edit to
|
* @layers: (element-type GESLayer): The layers you want the edit to
|
||||||
* happen in, %NULL means that the edition is done in all the
|
* happen in, %NULL means that the edition is done in all the
|
||||||
* #GESTimelineLayers contained in the current timeline.
|
* #GESLayers contained in the current timeline.
|
||||||
* FIXME: This is not implemented yet.
|
* FIXME: This is not implemented yet.
|
||||||
* @mode: The #GESEditMode in which the editition will happen.
|
* @mode: The #GESEditMode in which the editition will happen.
|
||||||
* @edge: The #GESEdge the edit should happen on.
|
* @edge: The #GESEdge the edit should happen on.
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
/**
|
/**
|
||||||
* SECTION: ges-transition-clip
|
* SECTION: ges-transition-clip
|
||||||
* @short_description: Transition from one clip to another in a
|
* @short_description: Transition from one clip to another in a
|
||||||
* #GESTimelineLayer
|
* #GESLayer
|
||||||
*
|
*
|
||||||
* Creates an object that mixes together the two underlying objects, A and B.
|
* Creates an object that mixes together the two underlying objects, A and B.
|
||||||
* The A object is assumed to have a higher prioirity (lower number) than the
|
* The A object is assumed to have a higher prioirity (lower number) than the
|
||||||
|
@ -32,9 +32,9 @@
|
||||||
* property. The default value is "crossfade". For audio, only "crossfade" is
|
* property. The default value is "crossfade". For audio, only "crossfade" is
|
||||||
* supported.
|
* supported.
|
||||||
*
|
*
|
||||||
* #GESSimpleTimelineLayer will automatically manage the priorities of sources
|
* #GESSimpleLayer will automatically manage the priorities of sources
|
||||||
* and transitions. If you use #GESTransitionClips in another type of
|
* and transitions. If you use #GESTransitionClips in another type of
|
||||||
* #GESTimelineLayer, you will need to manage priorities yourself.
|
* #GESLayer, you will need to manage priorities yourself.
|
||||||
*
|
*
|
||||||
* The ID of the ExtractableType is the nickname of the vtype property value. Note
|
* The ID of the ExtractableType is the nickname of the vtype property value. Note
|
||||||
* that this value can be changed after creation and the GESExtractable.asset value
|
* that this value can be changed after creation and the GESExtractable.asset value
|
||||||
|
|
|
@ -32,14 +32,14 @@
|
||||||
typedef struct _GESCustomSourceClip GESCustomSourceClip;
|
typedef struct _GESCustomSourceClip GESCustomSourceClip;
|
||||||
typedef struct _GESCustomSourceClipClass GESCustomSourceClipClass;
|
typedef struct _GESCustomSourceClipClass GESCustomSourceClipClass;
|
||||||
|
|
||||||
typedef struct _GESSimpleTimelineLayer GESSimpleTimelineLayer;
|
typedef struct _GESSimpleLayer GESSimpleLayer;
|
||||||
typedef struct _GESSimpleTimelineLayerClass GESSimpleTimelineLayerClass;
|
typedef struct _GESSimpleLayerClass GESSimpleLayerClass;
|
||||||
|
|
||||||
typedef struct _GESTimeline GESTimeline;
|
typedef struct _GESTimeline GESTimeline;
|
||||||
typedef struct _GESTimelineClass GESTimelineClass;
|
typedef struct _GESTimelineClass GESTimelineClass;
|
||||||
|
|
||||||
typedef struct _GESTimelineLayer GESTimelineLayer;
|
typedef struct _GESLayer GESLayer;
|
||||||
typedef struct _GESTimelineLayerClass GESTimelineLayerClass;
|
typedef struct _GESLayerClass GESLayerClass;
|
||||||
|
|
||||||
typedef struct _GESTimelineElementClass GESTimelineElementClass;
|
typedef struct _GESTimelineElementClass GESTimelineElementClass;
|
||||||
typedef struct _GESTimelineElement GESTimelineElement;
|
typedef struct _GESTimelineElement GESTimelineElement;
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "ges-internal.h"
|
#include "ges-internal.h"
|
||||||
#include "ges-timeline.h"
|
#include "ges-timeline.h"
|
||||||
#include "ges-track.h"
|
#include "ges-track.h"
|
||||||
#include "ges-timeline-layer.h"
|
#include "ges-layer.h"
|
||||||
#include "ges.h"
|
#include "ges.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -927,7 +927,7 @@ static inline void
|
||||||
_save_layers (GString * str, GESTimeline * timeline)
|
_save_layers (GString * str, GESTimeline * timeline)
|
||||||
{
|
{
|
||||||
gchar *properties, *metas;
|
gchar *properties, *metas;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GList *tmplayer, *tmpclip, *clips;
|
GList *tmplayer, *tmpclip, *clips;
|
||||||
|
|
||||||
|
@ -935,9 +935,9 @@ _save_layers (GString * str, GESTimeline * timeline)
|
||||||
|
|
||||||
for (tmplayer = timeline->layers; tmplayer; tmplayer = tmplayer->next) {
|
for (tmplayer = timeline->layers; tmplayer; tmplayer = tmplayer->next) {
|
||||||
guint priority;
|
guint priority;
|
||||||
layer = GES_TIMELINE_LAYER (tmplayer->data);
|
layer = GES_LAYER (tmplayer->data);
|
||||||
|
|
||||||
priority = ges_timeline_layer_get_priority (layer);
|
priority = ges_layer_get_priority (layer);
|
||||||
properties = _serialize_properties (G_OBJECT (layer), "priority", NULL);
|
properties = _serialize_properties (G_OBJECT (layer), "priority", NULL);
|
||||||
metas = ges_meta_container_metas_to_string (GES_META_CONTAINER (layer));
|
metas = ges_meta_container_metas_to_string (GES_META_CONTAINER (layer));
|
||||||
append_escaped (str,
|
append_escaped (str,
|
||||||
|
@ -947,7 +947,7 @@ _save_layers (GString * str, GESTimeline * timeline)
|
||||||
g_free (properties);
|
g_free (properties);
|
||||||
g_free (metas);
|
g_free (metas);
|
||||||
|
|
||||||
clips = ges_timeline_layer_get_clips (layer);
|
clips = ges_layer_get_clips (layer);
|
||||||
for (tmpclip = clips; tmpclip; tmpclip = tmpclip->next) {
|
for (tmpclip = clips; tmpclip; tmpclip = tmpclip->next) {
|
||||||
GList *effects, *tmpeffect;
|
GList *effects, *tmpeffect;
|
||||||
|
|
||||||
|
|
|
@ -27,8 +27,8 @@
|
||||||
#include <ges/ges-enums.h>
|
#include <ges/ges-enums.h>
|
||||||
|
|
||||||
#include <ges/ges-timeline.h>
|
#include <ges/ges-timeline.h>
|
||||||
#include <ges/ges-timeline-layer.h>
|
#include <ges/ges-layer.h>
|
||||||
#include <ges/ges-simple-timeline-layer.h>
|
#include <ges/ges-simple-layer.h>
|
||||||
#include <ges/ges-timeline-element.h>
|
#include <ges/ges-timeline-element.h>
|
||||||
#include <ges/ges-clip.h>
|
#include <ges/ges-clip.h>
|
||||||
#include <ges/ges-timeline-pipeline.h>
|
#include <ges/ges-timeline-pipeline.h>
|
||||||
|
|
|
@ -29,7 +29,7 @@ main (gint argc, gchar * argv[])
|
||||||
guint i;
|
guint i;
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GstClockTime start, start_ripple, end, end_ripple, max_rippling_time = 0,
|
GstClockTime start, start_ripple, end, end_ripple, max_rippling_time = 0,
|
||||||
min_rippling_time = GST_CLOCK_TIME_NONE;
|
min_rippling_time = GST_CLOCK_TIME_NONE;
|
||||||
|
@ -38,16 +38,16 @@ main (gint argc, gchar * argv[])
|
||||||
ges_init ();
|
ges_init ();
|
||||||
asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
start = gst_util_get_timestamp ();
|
start = gst_util_get_timestamp ();
|
||||||
clip = GES_CLIP (ges_timeline_layer_add_asset (layer, asset, 0,
|
clip = GES_CLIP (ges_layer_add_asset (layer, asset, 0,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
|
|
||||||
for (i = 1; i < NUM_OBJECTS; i++)
|
for (i = 1; i < NUM_OBJECTS; i++)
|
||||||
ges_timeline_layer_add_asset (layer, asset, i * 1000, 0,
|
ges_layer_add_asset (layer, asset, i * 1000, 0,
|
||||||
1000, GES_TRACK_TYPE_UNKNOWN);
|
1000, GES_TRACK_TYPE_UNKNOWN);
|
||||||
end = gst_util_get_timestamp ();
|
end = gst_util_get_timestamp ();
|
||||||
g_print ("%" GST_TIME_FORMAT " - adding %d clip to the timeline\n",
|
g_print ("%" GST_TIME_FORMAT " - adding %d clip to the timeline\n",
|
||||||
|
@ -71,7 +71,7 @@ main (gint argc, gchar * argv[])
|
||||||
|
|
||||||
min_rippling_time = GST_CLOCK_TIME_NONE;
|
min_rippling_time = GST_CLOCK_TIME_NONE;
|
||||||
max_rippling_time = 0;
|
max_rippling_time = 0;
|
||||||
ges_timeline_layer_set_auto_transition (layer, TRUE);
|
ges_layer_set_auto_transition (layer, TRUE);
|
||||||
start_ripple = gst_util_get_timestamp ();
|
start_ripple = gst_util_get_timestamp ();
|
||||||
for (i = 1; i < 501; i++) {
|
for (i = 1; i < 501; i++) {
|
||||||
start = gst_util_get_timestamp ();
|
start = gst_util_get_timestamp ();
|
||||||
|
|
|
@ -40,7 +40,7 @@ GST_START_TEST (test_test_source_properties)
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -48,7 +48,7 @@ GST_START_TEST (test_test_source_properties)
|
||||||
track = ges_track_new (GES_TRACK_TYPE_AUDIO, gst_caps_ref (GST_CAPS_ANY));
|
track = ges_track_new (GES_TRACK_TYPE_AUDIO, gst_caps_ref (GST_CAPS_ANY));
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
|
@ -67,7 +67,7 @@ GST_START_TEST (test_test_source_properties)
|
||||||
assert_equals_uint64 (_DURATION (clip), 51);
|
assert_equals_uint64 (_DURATION (clip), 51);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -116,7 +116,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_test_source_in_layer)
|
GST_START_TEST (test_test_source_in_layer)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *a, *v;
|
GESTrack *a, *v;
|
||||||
GESTrackElement *track_element;
|
GESTrackElement *track_element;
|
||||||
GESTestClip *source;
|
GESTestClip *source;
|
||||||
|
@ -126,7 +126,7 @@ GST_START_TEST (test_test_source_in_layer)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
a = ges_track_audio_raw_new ();
|
a = ges_track_audio_raw_new ();
|
||||||
v = ges_track_video_raw_new ();
|
v = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -140,8 +140,7 @@ GST_START_TEST (test_test_source_in_layer)
|
||||||
|
|
||||||
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) layer,
|
ges_simple_layer_add_object ((GESSimpleLayer *) layer, (GESClip *) source, 0);
|
||||||
(GESClip *) source, 0);
|
|
||||||
|
|
||||||
/* specifically test the vpattern property */
|
/* specifically test the vpattern property */
|
||||||
g_object_set (source, "vpattern", (gint) GES_VIDEO_TEST_PATTERN_WHITE, NULL);
|
g_object_set (source, "vpattern", (gint) GES_VIDEO_TEST_PATTERN_WHITE, NULL);
|
||||||
|
@ -193,7 +192,7 @@ GST_START_TEST (test_test_source_in_layer)
|
||||||
|
|
||||||
gst_object_unref (track_element);
|
gst_object_unref (track_element);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
GST_DEBUG ("removing the layer");
|
GST_DEBUG ("removing the layer");
|
||||||
|
|
||||||
|
@ -247,7 +246,7 @@ GST_START_TEST (test_gap_filling_basic)
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GstElement *composition;
|
GstElement *composition;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESClip *clip, *clip1, *clip2;
|
GESClip *clip, *clip1, *clip2;
|
||||||
|
|
||||||
GstElement *gnlsrc, *gnlsrc1, *gap = NULL;
|
GstElement *gnlsrc, *gnlsrc1, *gap = NULL;
|
||||||
|
@ -261,7 +260,7 @@ GST_START_TEST (test_gap_filling_basic)
|
||||||
composition = find_composition (track);
|
composition = find_composition (track);
|
||||||
fail_unless (composition != NULL);
|
fail_unless (composition != NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
|
@ -277,7 +276,7 @@ GST_START_TEST (test_gap_filling_basic)
|
||||||
assert_equals_uint64 (_START (clip), 0);
|
assert_equals_uint64 (_START (clip), 0);
|
||||||
assert_equals_uint64 (_DURATION (clip), 5);
|
assert_equals_uint64 (_DURATION (clip), 5);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -300,7 +299,7 @@ GST_START_TEST (test_gap_filling_basic)
|
||||||
assert_equals_uint64 (_START (clip1), 15);
|
assert_equals_uint64 (_START (clip1), 15);
|
||||||
assert_equals_uint64 (_DURATION (clip1), 5);
|
assert_equals_uint64 (_DURATION (clip1), 5);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip1));
|
ges_layer_add_clip (layer, GES_CLIP (clip1));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip1)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip1)), 1);
|
||||||
trackelement1 = GES_CONTAINER_CHILDREN (clip1)->data;
|
trackelement1 = GES_CONTAINER_CHILDREN (clip1)->data;
|
||||||
fail_unless (trackelement1 != NULL);
|
fail_unless (trackelement1 != NULL);
|
||||||
|
@ -328,7 +327,7 @@ GST_START_TEST (test_gap_filling_basic)
|
||||||
clip2 = GES_CLIP (ges_test_clip_new ());
|
clip2 = GES_CLIP (ges_test_clip_new ());
|
||||||
fail_unless (clip2 != NULL);
|
fail_unless (clip2 != NULL);
|
||||||
g_object_set (clip2, "start", (guint64) 35, "duration", (guint64) 5, NULL);
|
g_object_set (clip2, "start", (guint64) 35, "duration", (guint64) 5, NULL);
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip2));
|
ges_layer_add_clip (layer, GES_CLIP (clip2));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip2)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip2)), 1);
|
||||||
trackelement2 = GES_CONTAINER_CHILDREN (clip2)->data;
|
trackelement2 = GES_CONTAINER_CHILDREN (clip2)->data;
|
||||||
fail_unless (trackelement2 != NULL);
|
fail_unless (trackelement2 != NULL);
|
||||||
|
|
|
@ -52,7 +52,7 @@ my_fill_track_func (GESClip * clip,
|
||||||
GST_START_TEST (test_ges_scenario)
|
GST_START_TEST (test_ges_scenario)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer, *tmp_layer;
|
GESLayer *layer, *tmp_layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *source;
|
GESCustomSourceClip *source;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
@ -67,7 +67,7 @@ GST_START_TEST (test_ges_scenario)
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
|
||||||
GST_DEBUG ("Create a layer");
|
GST_DEBUG ("Create a layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
|
|
||||||
GST_DEBUG ("Add the layer to the timeline");
|
GST_DEBUG ("Add the layer to the timeline");
|
||||||
|
@ -102,7 +102,7 @@ GST_START_TEST (test_ges_scenario)
|
||||||
/* The source will be floating before added to the layer... */
|
/* The source will be floating before added to the layer... */
|
||||||
fail_unless (g_object_is_floating (source));
|
fail_unless (g_object_is_floating (source));
|
||||||
GST_DEBUG ("Adding the source to the timeline layer");
|
GST_DEBUG ("Adding the source to the timeline layer");
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (source)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (source)));
|
||||||
fail_if (g_object_is_floating (source));
|
fail_if (g_object_is_floating (source));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (source));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (source));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
|
@ -131,7 +131,7 @@ GST_START_TEST (test_ges_scenario)
|
||||||
/* Now remove the clip */
|
/* Now remove the clip */
|
||||||
gst_object_ref (source);
|
gst_object_ref (source);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "layer", 1);
|
ASSERT_OBJECT_REFCOUNT (layer, "layer", 1);
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source)));
|
||||||
ASSERT_OBJECT_REFCOUNT (source, "source", 1);
|
ASSERT_OBJECT_REFCOUNT (source, "source", 1);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "layer", 1);
|
ASSERT_OBJECT_REFCOUNT (layer, "layer", 1);
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (source));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (source));
|
||||||
|
@ -176,7 +176,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_ges_timeline_add_layer)
|
GST_START_TEST (test_ges_timeline_add_layer)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer, *tmp_layer;
|
GESLayer *layer, *tmp_layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *s1, *s2, *s3;
|
GESCustomSourceClip *s1, *s2, *s3;
|
||||||
GList *trackelements, *layers;
|
GList *trackelements, *layers;
|
||||||
|
@ -190,7 +190,7 @@ GST_START_TEST (test_ges_timeline_add_layer)
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
|
||||||
GST_DEBUG ("Create a layer");
|
GST_DEBUG ("Create a layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
/* Give the Timeline a Track */
|
/* Give the Timeline a Track */
|
||||||
GST_DEBUG ("Create a Track");
|
GST_DEBUG ("Create a Track");
|
||||||
|
@ -208,7 +208,7 @@ GST_START_TEST (test_ges_timeline_add_layer)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s1 != NULL);
|
fail_unless (s1 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s1)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s1)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
||||||
|
@ -217,7 +217,7 @@ GST_START_TEST (test_ges_timeline_add_layer)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s2 != NULL);
|
fail_unless (s2 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s2)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s2)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
||||||
|
@ -226,7 +226,7 @@ GST_START_TEST (test_ges_timeline_add_layer)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s3 != NULL);
|
fail_unless (s3 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s3)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s3)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
ASSERT_OBJECT_REFCOUNT (layer, "layer", 2);
|
||||||
|
@ -288,7 +288,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_ges_timeline_add_layer_first)
|
GST_START_TEST (test_ges_timeline_add_layer_first)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer, *tmp_layer;
|
GESLayer *layer, *tmp_layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *s1, *s2, *s3;
|
GESCustomSourceClip *s1, *s2, *s3;
|
||||||
GList *trackelements, *tmp, *layers;
|
GList *trackelements, *tmp, *layers;
|
||||||
|
@ -301,7 +301,7 @@ GST_START_TEST (test_ges_timeline_add_layer_first)
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
|
||||||
GST_DEBUG ("Create a layer");
|
GST_DEBUG ("Create a layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
/* Give the Timeline a Track */
|
/* Give the Timeline a Track */
|
||||||
GST_DEBUG ("Create a Track");
|
GST_DEBUG ("Create a Track");
|
||||||
|
@ -312,7 +312,7 @@ GST_START_TEST (test_ges_timeline_add_layer_first)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s1 != NULL);
|
fail_unless (s1 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s1)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s1)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -320,7 +320,7 @@ GST_START_TEST (test_ges_timeline_add_layer_first)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s2 != NULL);
|
fail_unless (s2 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s2)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s2)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -328,7 +328,7 @@ GST_START_TEST (test_ges_timeline_add_layer_first)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s3 != NULL);
|
fail_unless (s3 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s3)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s3)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -389,7 +389,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_ges_timeline_remove_track)
|
GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer, *tmp_layer;
|
GESLayer *layer, *tmp_layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *s1, *s2, *s3;
|
GESCustomSourceClip *s1, *s2, *s3;
|
||||||
GESTrackElement *t1, *t2, *t3;
|
GESTrackElement *t1, *t2, *t3;
|
||||||
|
@ -403,7 +403,7 @@ GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
|
||||||
GST_DEBUG ("Create a layer");
|
GST_DEBUG ("Create a layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
/* Give the Timeline a Track */
|
/* Give the Timeline a Track */
|
||||||
GST_DEBUG ("Create a Track");
|
GST_DEBUG ("Create a Track");
|
||||||
|
@ -414,7 +414,7 @@ GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s1 != NULL);
|
fail_unless (s1 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s1)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s1)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -422,7 +422,7 @@ GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s2 != NULL);
|
fail_unless (s2 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s2)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s2)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -430,7 +430,7 @@ GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s3 != NULL);
|
fail_unless (s3 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s3)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s3)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -509,7 +509,7 @@ GST_START_TEST (test_ges_timeline_remove_track)
|
||||||
ASSERT_OBJECT_REFCOUNT (t3, "trackelement", 2);
|
ASSERT_OBJECT_REFCOUNT (t3, "trackelement", 2);
|
||||||
ASSERT_OBJECT_REFCOUNT (layer, "1 for the timeline", 1);
|
ASSERT_OBJECT_REFCOUNT (layer, "1 for the timeline", 1);
|
||||||
ASSERT_OBJECT_REFCOUNT (timeline, "1 for the us", 1);
|
ASSERT_OBJECT_REFCOUNT (timeline, "1 for the us", 1);
|
||||||
tmp = ges_timeline_layer_get_clips (layer);
|
tmp = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (tmp), 3);
|
assert_equals_int (g_list_length (tmp), 3);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
|
@ -546,7 +546,7 @@ select_tracks_cb (GESTimeline * timeline, GESClip * clip,
|
||||||
GST_START_TEST (test_ges_timeline_multiple_tracks)
|
GST_START_TEST (test_ges_timeline_multiple_tracks)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer, *tmp_layer;
|
GESLayer *layer, *tmp_layer;
|
||||||
GESTrack *track1, *track2;
|
GESTrack *track1, *track2;
|
||||||
GESCustomSourceClip *s1, *s2, *s3;
|
GESCustomSourceClip *s1, *s2, *s3;
|
||||||
GESTrackElement *t1, *t2, *t3;
|
GESTrackElement *t1, *t2, *t3;
|
||||||
|
@ -564,7 +564,7 @@ GST_START_TEST (test_ges_timeline_multiple_tracks)
|
||||||
G_CALLBACK (select_tracks_cb), &st_data);
|
G_CALLBACK (select_tracks_cb), &st_data);
|
||||||
|
|
||||||
GST_DEBUG ("Create a layer");
|
GST_DEBUG ("Create a layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
/* Give the Timeline a Track */
|
/* Give the Timeline a Track */
|
||||||
GST_DEBUG ("Create Track 1");
|
GST_DEBUG ("Create Track 1");
|
||||||
|
@ -590,7 +590,7 @@ GST_START_TEST (test_ges_timeline_multiple_tracks)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s1 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s1 != NULL);
|
fail_unless (s1 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s1)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s1)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s1));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -598,7 +598,7 @@ GST_START_TEST (test_ges_timeline_multiple_tracks)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s2 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s2 != NULL);
|
fail_unless (s2 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s2)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s2)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s2));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
@ -606,7 +606,7 @@ GST_START_TEST (test_ges_timeline_multiple_tracks)
|
||||||
GST_DEBUG ("Creating a source");
|
GST_DEBUG ("Creating a source");
|
||||||
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
s3 = ges_custom_source_clip_new (my_fill_track_func, NULL);
|
||||||
fail_unless (s3 != NULL);
|
fail_unless (s3 != NULL);
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (s3)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (s3)));
|
||||||
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
tmp_layer = ges_clip_get_layer (GES_CLIP (s3));
|
||||||
fail_unless (tmp_layer == layer);
|
fail_unless (tmp_layer == layer);
|
||||||
gst_object_unref (tmp_layer);
|
gst_object_unref (tmp_layer);
|
||||||
|
|
|
@ -44,7 +44,7 @@ GST_START_TEST (test_object_properties)
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -52,7 +52,7 @@ GST_START_TEST (test_object_properties)
|
||||||
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_ref (GST_CAPS_ANY));
|
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_ref (GST_CAPS_ANY));
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
@ -69,7 +69,7 @@ GST_START_TEST (test_object_properties)
|
||||||
assert_equals_uint64 (_DURATION (clip), 51);
|
assert_equals_uint64 (_DURATION (clip), 51);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -120,14 +120,14 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_split_object)
|
GST_START_TEST (test_split_object)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESClip *clip, *splitclip;
|
GESClip *clip, *splitclip;
|
||||||
GList *splittrackelements;
|
GList *splittrackelements;
|
||||||
GESTrackElement *trackelement, *splittrackelement;
|
GESTrackElement *trackelement, *splittrackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
@ -146,7 +146,7 @@ GST_START_TEST (test_split_object)
|
||||||
assert_equals_uint64 (_DURATION (clip), 50);
|
assert_equals_uint64 (_DURATION (clip), 50);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 2);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 2);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -213,14 +213,14 @@ GST_START_TEST (test_clip_group_ungroup)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESClip *clip, *clip2;
|
GESClip *clip, *clip2;
|
||||||
GList *containers, *tmp;
|
GList *containers, *tmp;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESContainer *regrouped_clip;
|
GESContainer *regrouped_clip;
|
||||||
GESTrack *audio_track, *video_track;
|
GESTrack *audio_track, *video_track;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
audio_track = ges_track_audio_raw_new ();
|
audio_track = ges_track_audio_raw_new ();
|
||||||
video_track = ges_track_video_raw_new ();
|
video_track = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -231,8 +231,7 @@ GST_START_TEST (test_clip_group_ungroup)
|
||||||
asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
||||||
assert_is_type (asset, GES_TYPE_ASSET);
|
assert_is_type (asset, GES_TYPE_ASSET);
|
||||||
|
|
||||||
clip = ges_timeline_layer_add_asset (layer, asset, 0, 0, 10,
|
clip = ges_layer_add_asset (layer, asset, 0, 0, 10, GES_TRACK_TYPE_UNKNOWN);
|
||||||
GES_TRACK_TYPE_UNKNOWN);
|
|
||||||
ASSERT_OBJECT_REFCOUNT (clip, "1 layer", 1);
|
ASSERT_OBJECT_REFCOUNT (clip, "1 layer", 1);
|
||||||
assert_equals_uint64 (_START (clip), 0);
|
assert_equals_uint64 (_START (clip), 0);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 0);
|
assert_equals_uint64 (_INPOINT (clip), 0);
|
||||||
|
@ -298,7 +297,7 @@ GST_START_TEST (test_clip_group_ungroup)
|
||||||
g_list_free_full (containers, gst_object_unref);
|
g_list_free_full (containers, gst_object_unref);
|
||||||
|
|
||||||
GST_DEBUG ("Check clips in the layer");
|
GST_DEBUG ("Check clips in the layer");
|
||||||
tmp = ges_timeline_layer_get_clips (layer);
|
tmp = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (tmp), 1);
|
assert_equals_int (g_list_length (tmp), 1);
|
||||||
g_list_free_full (tmp, gst_object_unref);
|
g_list_free_full (tmp, gst_object_unref);
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_add_effect_to_clip)
|
GST_START_TEST (test_add_effect_to_clip)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track_audio, *track_video;
|
GESTrack *track_audio, *track_video;
|
||||||
GESEffect *effect;
|
GESEffect *effect;
|
||||||
GESTestClip *source;
|
GESTestClip *source;
|
||||||
|
@ -49,7 +49,7 @@ GST_START_TEST (test_add_effect_to_clip)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_audio = ges_track_audio_raw_new ();
|
track_audio = ges_track_audio_raw_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ GST_START_TEST (test_add_effect_to_clip)
|
||||||
|
|
||||||
g_object_set (source, "duration", 10 * GST_SECOND, NULL);
|
g_object_set (source, "duration", 10 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) source, 0);
|
(GESClip *) source, 0);
|
||||||
|
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ GST_START_TEST (test_add_effect_to_clip)
|
||||||
|
|
||||||
assert_equals_int (GES_TRACK_ELEMENT (effect)->active, TRUE);
|
assert_equals_int (GES_TRACK_ELEMENT (effect)->active, TRUE);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_get_effects_from_tl)
|
GST_START_TEST (test_get_effects_from_tl)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track_video;
|
GESTrack *track_video;
|
||||||
GESEffect *effect, *effect1, *effect2;
|
GESEffect *effect, *effect1, *effect2;
|
||||||
GESTestClip *source;
|
GESTestClip *source;
|
||||||
|
@ -96,7 +96,7 @@ GST_START_TEST (test_get_effects_from_tl)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
ges_timeline_add_track (timeline, track_video);
|
ges_timeline_add_track (timeline, track_video);
|
||||||
|
@ -106,7 +106,7 @@ GST_START_TEST (test_get_effects_from_tl)
|
||||||
|
|
||||||
g_object_set (source, "duration", 10 * GST_SECOND, NULL);
|
g_object_set (source, "duration", 10 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) source, 0);
|
(GESClip *) source, 0);
|
||||||
|
|
||||||
|
|
||||||
|
@ -148,7 +148,7 @@ GST_START_TEST (test_get_effects_from_tl)
|
||||||
}
|
}
|
||||||
g_list_free (effects);
|
g_list_free (effects);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
@ -158,7 +158,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_effect_clip)
|
GST_START_TEST (test_effect_clip)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track_audio, *track_video;
|
GESTrack *track_audio, *track_video;
|
||||||
GESEffectClip *effect_clip;
|
GESEffectClip *effect_clip;
|
||||||
GESEffect *effect, *effect1;
|
GESEffect *effect, *effect1;
|
||||||
|
@ -174,7 +174,7 @@ GST_START_TEST (test_effect_clip)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_audio = ges_track_audio_raw_new ();
|
track_audio = ges_track_audio_raw_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -187,7 +187,7 @@ GST_START_TEST (test_effect_clip)
|
||||||
|
|
||||||
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) effect_clip, 0);
|
(GESClip *) effect_clip, 0);
|
||||||
|
|
||||||
effect = ges_effect_new ("agingtv");
|
effect = ges_effect_new ("agingtv");
|
||||||
|
@ -222,7 +222,7 @@ GST_START_TEST (test_effect_clip)
|
||||||
}
|
}
|
||||||
g_list_free (effects);
|
g_list_free (effects);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) effect_clip);
|
ges_layer_remove_clip (layer, (GESClip *) effect_clip);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
@ -234,7 +234,7 @@ GST_START_TEST (test_priorities_clip)
|
||||||
gint i;
|
gint i;
|
||||||
GList *effects, *tmp;
|
GList *effects, *tmp;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESEffectClip *effect_clip;
|
GESEffectClip *effect_clip;
|
||||||
GESTrack *track_audio, *track_video;
|
GESTrack *track_audio, *track_video;
|
||||||
GESEffect *effect, *effect1, *audio_effect = NULL, *video_effect = NULL;
|
GESEffect *effect, *effect1, *audio_effect = NULL, *video_effect = NULL;
|
||||||
|
@ -244,7 +244,7 @@ GST_START_TEST (test_priorities_clip)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_audio = ges_track_audio_raw_new ();
|
track_audio = ges_track_audio_raw_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -257,7 +257,7 @@ GST_START_TEST (test_priorities_clip)
|
||||||
|
|
||||||
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) effect_clip, 0);
|
(GESClip *) effect_clip, 0);
|
||||||
|
|
||||||
for (tmp = GES_CONTAINER_CHILDREN (effect_clip); tmp; tmp = tmp->next) {
|
for (tmp = GES_CONTAINER_CHILDREN (effect_clip); tmp; tmp = tmp->next) {
|
||||||
|
@ -317,7 +317,7 @@ GST_START_TEST (test_priorities_clip)
|
||||||
}
|
}
|
||||||
g_list_free (effects);
|
g_list_free (effects);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) effect_clip);
|
ges_layer_remove_clip (layer, (GESClip *) effect_clip);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
@ -327,7 +327,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_effect_set_properties)
|
GST_START_TEST (test_effect_set_properties)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track_video;
|
GESTrack *track_video;
|
||||||
GESEffectClip *effect_clip;
|
GESEffectClip *effect_clip;
|
||||||
GESTrackElement *effect;
|
GESTrackElement *effect;
|
||||||
|
@ -340,7 +340,7 @@ GST_START_TEST (test_effect_set_properties)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
ges_timeline_add_track (timeline, track_video);
|
ges_timeline_add_track (timeline, track_video);
|
||||||
|
@ -351,7 +351,7 @@ GST_START_TEST (test_effect_set_properties)
|
||||||
|
|
||||||
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) effect_clip, 0);
|
(GESClip *) effect_clip, 0);
|
||||||
|
|
||||||
effect = GES_TRACK_ELEMENT (ges_effect_new ("agingtv"));
|
effect = GES_TRACK_ELEMENT (ges_effect_new ("agingtv"));
|
||||||
|
@ -390,7 +390,7 @@ GST_START_TEST (test_effect_set_properties)
|
||||||
}
|
}
|
||||||
g_free (pspecs);
|
g_free (pspecs);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) effect_clip);
|
ges_layer_remove_clip (layer, (GESClip *) effect_clip);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
@ -418,7 +418,7 @@ deep_prop_changed_cb (GESTrackElement * track_element, GstElement * element,
|
||||||
GST_START_TEST (test_clip_signals)
|
GST_START_TEST (test_clip_signals)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track_video;
|
GESTrack *track_video;
|
||||||
GESEffectClip *effect_clip;
|
GESEffectClip *effect_clip;
|
||||||
GESEffect *effect;
|
GESEffect *effect;
|
||||||
|
@ -428,7 +428,7 @@ GST_START_TEST (test_clip_signals)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
track_video = ges_track_video_raw_new ();
|
track_video = ges_track_video_raw_new ();
|
||||||
|
|
||||||
ges_timeline_add_track (timeline, track_video);
|
ges_timeline_add_track (timeline, track_video);
|
||||||
|
@ -441,7 +441,7 @@ GST_START_TEST (test_clip_signals)
|
||||||
|
|
||||||
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
g_object_set (effect_clip, "duration", 25 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
|
ges_simple_layer_add_object ((GESSimpleLayer *) (layer),
|
||||||
(GESClip *) effect_clip, 0);
|
(GESClip *) effect_clip, 0);
|
||||||
|
|
||||||
effect = ges_effect_new ("agingtv");
|
effect = ges_effect_new ("agingtv");
|
||||||
|
@ -464,7 +464,7 @@ GST_START_TEST (test_clip_signals)
|
||||||
fail_unless (G_VALUE_HOLDS_UINT (&val));
|
fail_unless (G_VALUE_HOLDS_UINT (&val));
|
||||||
g_value_unset (&val);
|
g_value_unset (&val);
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) effect_clip);
|
ges_layer_remove_clip (layer, (GESClip *) effect_clip);
|
||||||
|
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,7 @@ my_fill_track_func (GESClip * clip,
|
||||||
GST_START_TEST (test_layer_properties)
|
GST_START_TEST (test_layer_properties)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
|
@ -54,10 +54,10 @@ GST_START_TEST (test_layer_properties)
|
||||||
|
|
||||||
/* Timeline and 1 Layer */
|
/* Timeline and 1 Layer */
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_timeline_layer_new ();
|
layer = (GESLayer *) ges_layer_new ();
|
||||||
|
|
||||||
/* The default priority is 0 */
|
/* The default priority is 0 */
|
||||||
fail_unless_equals_int (ges_timeline_layer_get_priority (layer), 0);
|
fail_unless_equals_int (ges_layer_get_priority (layer), 0);
|
||||||
|
|
||||||
/* Layers are initially floating, once we add them to the timeline,
|
/* Layers are initially floating, once we add them to the timeline,
|
||||||
* the timeline will take that reference. */
|
* the timeline will take that reference. */
|
||||||
|
@ -82,7 +82,7 @@ GST_START_TEST (test_layer_properties)
|
||||||
|
|
||||||
/* Add the clip to the timeline */
|
/* Add the clip to the timeline */
|
||||||
fail_unless (g_object_is_floating (clip));
|
fail_unless (g_object_is_floating (clip));
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (clip)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (clip)));
|
||||||
fail_if (g_object_is_floating (clip));
|
fail_if (g_object_is_floating (clip));
|
||||||
trackelement = ges_clip_find_track_element (clip, track, G_TYPE_NONE);
|
trackelement = ges_clip_find_track_element (clip, track, G_TYPE_NONE);
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -97,27 +97,27 @@ GST_START_TEST (test_layer_properties)
|
||||||
|
|
||||||
/* Change the priority of the layer */
|
/* Change the priority of the layer */
|
||||||
g_object_set (layer, "priority", 1, NULL);
|
g_object_set (layer, "priority", 1, NULL);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 1);
|
assert_equals_int (ges_layer_get_priority (layer), 1);
|
||||||
assert_equals_uint64 (_PRIORITY (clip), 0);
|
assert_equals_uint64 (_PRIORITY (clip), 0);
|
||||||
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
||||||
51, LAYER_HEIGHT, TRUE);
|
51, LAYER_HEIGHT, TRUE);
|
||||||
|
|
||||||
/* Change it to an insanely high value */
|
/* Change it to an insanely high value */
|
||||||
g_object_set (layer, "priority", 31, NULL);
|
g_object_set (layer, "priority", 31, NULL);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 31);
|
assert_equals_int (ges_layer_get_priority (layer), 31);
|
||||||
assert_equals_uint64 (_PRIORITY (clip), 0);
|
assert_equals_uint64 (_PRIORITY (clip), 0);
|
||||||
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
||||||
51, LAYER_HEIGHT * 31, TRUE);
|
51, LAYER_HEIGHT * 31, TRUE);
|
||||||
|
|
||||||
/* and back to 0 */
|
/* and back to 0 */
|
||||||
g_object_set (layer, "priority", 0, NULL);
|
g_object_set (layer, "priority", 0, NULL);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 0);
|
assert_equals_int (ges_layer_get_priority (layer), 0);
|
||||||
assert_equals_uint64 (_PRIORITY (clip), 0);
|
assert_equals_uint64 (_PRIORITY (clip), 0);
|
||||||
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
gnl_object_check (ges_track_element_get_gnlobject (trackelement), 42, 51, 12,
|
||||||
51, 0, TRUE);
|
51, 0, TRUE);
|
||||||
|
|
||||||
gst_object_unref (trackelement);
|
gst_object_unref (trackelement);
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, clip));
|
fail_unless (ges_layer_remove_clip (layer, clip));
|
||||||
fail_unless (ges_timeline_remove_track (timeline, track));
|
fail_unless (ges_timeline_remove_track (timeline, track));
|
||||||
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
|
@ -129,7 +129,7 @@ GST_START_TEST (test_layer_priorities)
|
||||||
{
|
{
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer1, *layer2, *layer3;
|
GESLayer *layer1, *layer2, *layer3;
|
||||||
GESTrackElement *trackelement1, *trackelement2, *trackelement3;
|
GESTrackElement *trackelement1, *trackelement2, *trackelement3;
|
||||||
GESClip *clip1, *clip2, *clip3;
|
GESClip *clip1, *clip2, *clip3;
|
||||||
GstElement *gnlobj1, *gnlobj2, *gnlobj3;
|
GstElement *gnlobj1, *gnlobj2, *gnlobj3;
|
||||||
|
@ -140,19 +140,19 @@ GST_START_TEST (test_layer_priorities)
|
||||||
|
|
||||||
/* Timeline and 3 Layer */
|
/* Timeline and 3 Layer */
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer1 = (GESTimelineLayer *) ges_timeline_layer_new ();
|
layer1 = (GESLayer *) ges_layer_new ();
|
||||||
layer2 = (GESTimelineLayer *) ges_timeline_layer_new ();
|
layer2 = (GESLayer *) ges_layer_new ();
|
||||||
layer3 = (GESTimelineLayer *) ges_timeline_layer_new ();
|
layer3 = (GESLayer *) ges_layer_new ();
|
||||||
|
|
||||||
ges_timeline_layer_set_priority (layer2, 1);
|
ges_layer_set_priority (layer2, 1);
|
||||||
ges_timeline_layer_set_priority (layer3, 2);
|
ges_layer_set_priority (layer3, 2);
|
||||||
|
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer1));
|
fail_unless (ges_timeline_add_layer (timeline, layer1));
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer2));
|
fail_unless (ges_timeline_add_layer (timeline, layer2));
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer3));
|
fail_unless (ges_timeline_add_layer (timeline, layer3));
|
||||||
fail_unless_equals_int (ges_timeline_layer_get_priority (layer1), 0);
|
fail_unless_equals_int (ges_layer_get_priority (layer1), 0);
|
||||||
fail_unless_equals_int (ges_timeline_layer_get_priority (layer2), 1);
|
fail_unless_equals_int (ges_layer_get_priority (layer2), 1);
|
||||||
fail_unless_equals_int (ges_timeline_layer_get_priority (layer3), 2);
|
fail_unless_equals_int (ges_layer_get_priority (layer3), 2);
|
||||||
|
|
||||||
track = ges_track_video_raw_new ();
|
track = ges_track_video_raw_new ();
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
|
@ -180,15 +180,15 @@ GST_START_TEST (test_layer_priorities)
|
||||||
assert_equals_int (_PRIORITY (clip3), LAYER_HEIGHT + 1);
|
assert_equals_int (_PRIORITY (clip3), LAYER_HEIGHT + 1);
|
||||||
|
|
||||||
/* Add objects to the timeline */
|
/* Add objects to the timeline */
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer1, clip1));
|
fail_unless (ges_layer_add_clip (layer1, clip1));
|
||||||
trackelement1 = ges_clip_find_track_element (clip1, track, G_TYPE_NONE);
|
trackelement1 = ges_clip_find_track_element (clip1, track, G_TYPE_NONE);
|
||||||
fail_unless (trackelement1 != NULL);
|
fail_unless (trackelement1 != NULL);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer2, clip2));
|
fail_unless (ges_layer_add_clip (layer2, clip2));
|
||||||
trackelement2 = ges_clip_find_track_element (clip2, track, G_TYPE_NONE);
|
trackelement2 = ges_clip_find_track_element (clip2, track, G_TYPE_NONE);
|
||||||
fail_unless (trackelement2 != NULL);
|
fail_unless (trackelement2 != NULL);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer3, clip3));
|
fail_unless (ges_layer_add_clip (layer3, clip3));
|
||||||
trackelement3 = ges_clip_find_track_element (clip3, track, G_TYPE_NONE);
|
trackelement3 = ges_clip_find_track_element (clip3, track, G_TYPE_NONE);
|
||||||
fail_unless (trackelement3 != NULL);
|
fail_unless (trackelement3 != NULL);
|
||||||
|
|
||||||
|
@ -219,9 +219,9 @@ GST_START_TEST (test_layer_priorities)
|
||||||
g_object_set (layer3, "priority", 1, NULL);
|
g_object_set (layer3, "priority", 1, NULL);
|
||||||
|
|
||||||
/* And check the new priorities */
|
/* And check the new priorities */
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer1), 2);
|
assert_equals_int (ges_layer_get_priority (layer1), 2);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer2), 0);
|
assert_equals_int (ges_layer_get_priority (layer2), 0);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer3), 1);
|
assert_equals_int (ges_layer_get_priority (layer3), 1);
|
||||||
assert_equals_int (_PRIORITY (clip1), 0);
|
assert_equals_int (_PRIORITY (clip1), 0);
|
||||||
assert_equals_int (_PRIORITY (clip2), 1);
|
assert_equals_int (_PRIORITY (clip2), 1);
|
||||||
assert_equals_int (_PRIORITY (clip3), LAYER_HEIGHT - 1);
|
assert_equals_int (_PRIORITY (clip3), LAYER_HEIGHT - 1);
|
||||||
|
@ -236,10 +236,10 @@ GST_START_TEST (test_layer_priorities)
|
||||||
fail_unless (ges_clip_move_to_layer (clip2, layer1));
|
fail_unless (ges_clip_move_to_layer (clip2, layer1));
|
||||||
fail_unless (ges_clip_move_to_layer (clip3, layer1));
|
fail_unless (ges_clip_move_to_layer (clip3, layer1));
|
||||||
|
|
||||||
objs = ges_timeline_layer_get_clips (layer1);
|
objs = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objs), 3);
|
assert_equals_int (g_list_length (objs), 3);
|
||||||
fail_unless (ges_timeline_layer_get_clips (layer2) == NULL);
|
fail_unless (ges_layer_get_clips (layer2) == NULL);
|
||||||
fail_unless (ges_timeline_layer_get_clips (layer3) == NULL);
|
fail_unless (ges_layer_get_clips (layer3) == NULL);
|
||||||
|
|
||||||
for (tmp = objs; tmp; tmp = g_list_next (tmp)) {
|
for (tmp = objs; tmp; tmp = g_list_next (tmp)) {
|
||||||
gst_object_unref (tmp->data);
|
gst_object_unref (tmp->data);
|
||||||
|
@ -279,7 +279,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GList *objects, *current;
|
GList *objects, *current;
|
||||||
GESClip *transition;
|
GESClip *transition;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTimelineElement *src, *src1, *src2;
|
GESTimelineElement *src, *src1, *src2;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -292,26 +292,26 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_is_type (timeline, GES_TYPE_TIMELINE);
|
assert_is_type (timeline, GES_TYPE_TIMELINE);
|
||||||
|
|
||||||
GST_DEBUG ("Create first layer");
|
GST_DEBUG ("Create first layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
assert_is_type (layer, GES_TYPE_TIMELINE_LAYER);
|
assert_is_type (layer, GES_TYPE_LAYER);
|
||||||
|
|
||||||
GST_DEBUG ("Add first layer to timeline");
|
GST_DEBUG ("Add first layer to timeline");
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
|
|
||||||
GST_DEBUG ("Set auto transition to first layer");
|
GST_DEBUG ("Set auto transition to first layer");
|
||||||
ges_timeline_layer_set_auto_transition (layer, TRUE);
|
ges_layer_set_auto_transition (layer, TRUE);
|
||||||
|
|
||||||
GST_DEBUG ("Check that auto-transition was properly set");
|
GST_DEBUG ("Check that auto-transition was properly set");
|
||||||
fail_unless (ges_timeline_layer_get_auto_transition (layer));
|
fail_unless (ges_layer_get_auto_transition (layer));
|
||||||
|
|
||||||
GST_DEBUG ("Adding assets to first layer");
|
GST_DEBUG ("Adding assets to first layer");
|
||||||
GST_DEBUG ("Adding clip from 0 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 0 -- 1000 to first layer");
|
||||||
src = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 0, 0,
|
src = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 0, 0,
|
||||||
1000, GES_TRACK_TYPE_UNKNOWN));
|
1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src));
|
fail_unless (GES_IS_CLIP (src));
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
||||||
src1 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 500,
|
src1 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 500,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src1));
|
fail_unless (GES_IS_CLIP (src1));
|
||||||
|
|
||||||
|
@ -327,7 +327,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
||||||
|
|
||||||
GST_DEBUG ("Checking that a transition has been added");
|
GST_DEBUG ("Checking that a transition has been added");
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -357,7 +357,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -385,7 +385,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 250);
|
assert_equals_uint64 (_START (src1), 250);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 250);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 250);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -403,7 +403,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -431,11 +431,11 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -451,11 +451,11 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -470,18 +470,18 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
GST_DEBUG ("Adding asset to first layer");
|
GST_DEBUG ("Adding asset to first layer");
|
||||||
GST_DEBUG ("Adding clip from 1250 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 1250 -- 1000 to first layer");
|
||||||
src2 =
|
src2 =
|
||||||
GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 1250, 0,
|
GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 1250, 0,
|
||||||
1000, GES_TRACK_TYPE_UNKNOWN));
|
1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
assert_is_type (src2, GES_TYPE_TEST_CLIP);
|
assert_is_type (src2, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -496,7 +496,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src2), 1250);
|
assert_equals_uint64 (_START (src2), 1250);
|
||||||
assert_equals_uint64 (_DURATION (src2), 1000);
|
assert_equals_uint64 (_DURATION (src2), 1000);
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 3);
|
assert_equals_int (g_list_length (objects), 3);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -515,7 +515,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src1), 500);
|
assert_equals_uint64 (_START (src1), 500);
|
||||||
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1250 - 500);
|
||||||
|
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 7);
|
assert_equals_int (g_list_length (objects), 7);
|
||||||
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
||||||
fail_unless (objects->data == src1);
|
fail_unless (objects->data == src1);
|
||||||
|
@ -571,7 +571,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
/* We check that the transition as actually been freed */
|
/* We check that the transition as actually been freed */
|
||||||
fail_if (GES_IS_TRANSITION_CLIP (transition));
|
fail_if (GES_IS_TRANSITION_CLIP (transition));
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (layer);
|
objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 3);
|
assert_equals_int (g_list_length (objects), 3);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
|
@ -590,7 +590,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src2), 1100);
|
assert_equals_uint64 (_START (src2), 1100);
|
||||||
assert_equals_uint64 (_DURATION (src2), 1000);
|
assert_equals_uint64 (_DURATION (src2), 1000);
|
||||||
|
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 5);
|
assert_equals_int (g_list_length (objects), 5);
|
||||||
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
||||||
fail_unless (current->data == src1);
|
fail_unless (current->data == src1);
|
||||||
|
@ -630,7 +630,7 @@ GST_START_TEST (test_single_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_START (src2), 1000);
|
assert_equals_uint64 (_START (src2), 1000);
|
||||||
assert_equals_uint64 (_DURATION (src2), 1000);
|
assert_equals_uint64 (_DURATION (src2), 1000);
|
||||||
|
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
current = objects;
|
current = objects;
|
||||||
assert_equals_int (g_list_length (objects), 7);
|
assert_equals_int (g_list_length (objects), 7);
|
||||||
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (objects->data, GES_TYPE_TEST_CLIP);
|
||||||
|
@ -678,7 +678,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GList *objects, *current;
|
GList *objects, *current;
|
||||||
GESClip *transition;
|
GESClip *transition;
|
||||||
GESTimelineLayer *layer, *layer1;
|
GESLayer *layer, *layer1;
|
||||||
GESTimelineElement *src, *src1, *src2, *src3;
|
GESTimelineElement *src, *src1, *src2, *src3;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -691,31 +691,31 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_is_type (timeline, GES_TYPE_TIMELINE);
|
assert_is_type (timeline, GES_TYPE_TIMELINE);
|
||||||
|
|
||||||
GST_DEBUG ("Create first layer");
|
GST_DEBUG ("Create first layer");
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
assert_is_type (layer, GES_TYPE_TIMELINE_LAYER);
|
assert_is_type (layer, GES_TYPE_LAYER);
|
||||||
|
|
||||||
GST_DEBUG ("Add first layer to timeline");
|
GST_DEBUG ("Add first layer to timeline");
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
|
|
||||||
GST_DEBUG ("Append a new layer to the timeline");
|
GST_DEBUG ("Append a new layer to the timeline");
|
||||||
layer1 = ges_timeline_append_layer (timeline);
|
layer1 = ges_timeline_append_layer (timeline);
|
||||||
assert_is_type (layer1, GES_TYPE_TIMELINE_LAYER);
|
assert_is_type (layer1, GES_TYPE_LAYER);
|
||||||
|
|
||||||
GST_DEBUG ("Set auto transition to first layer");
|
GST_DEBUG ("Set auto transition to first layer");
|
||||||
ges_timeline_layer_set_auto_transition (layer, TRUE);
|
ges_layer_set_auto_transition (layer, TRUE);
|
||||||
|
|
||||||
GST_DEBUG ("Check that auto-transition was properly set");
|
GST_DEBUG ("Check that auto-transition was properly set");
|
||||||
fail_unless (ges_timeline_layer_get_auto_transition (layer));
|
fail_unless (ges_layer_get_auto_transition (layer));
|
||||||
fail_if (ges_timeline_layer_get_auto_transition (layer1));
|
fail_if (ges_layer_get_auto_transition (layer1));
|
||||||
|
|
||||||
GST_DEBUG ("Adding assets to first layer");
|
GST_DEBUG ("Adding assets to first layer");
|
||||||
GST_DEBUG ("Adding clip from 0 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 0 -- 1000 to first layer");
|
||||||
src = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 0, 0,
|
src = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 0, 0,
|
||||||
1000, GES_TRACK_TYPE_UNKNOWN));
|
1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src));
|
fail_unless (GES_IS_CLIP (src));
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
||||||
src1 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 500,
|
src1 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 500,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src1));
|
fail_unless (GES_IS_CLIP (src1));
|
||||||
|
|
||||||
|
@ -731,7 +731,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
assert_equals_uint64 (_DURATION (src1), 1500 - 500);
|
||||||
|
|
||||||
GST_DEBUG ("Checking that a transition has been added");
|
GST_DEBUG ("Checking that a transition has been added");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -750,10 +750,10 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip 2 from 500 -- 1000 to second layer");
|
GST_DEBUG ("Adding clip 2 from 500 -- 1000 to second layer");
|
||||||
src2 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer1, asset, 0,
|
src2 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer1, asset, 0,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
GST_DEBUG ("Adding clip 3 from 500 -- 1000 to second layer");
|
GST_DEBUG ("Adding clip 3 from 500 -- 1000 to second layer");
|
||||||
src3 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer1, asset, 500,
|
src3 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer1, asset, 500,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
assert_is_type (src3, GES_TYPE_TEST_CLIP);
|
assert_is_type (src3, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -775,7 +775,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 1500 - 500);
|
assert_equals_uint64 (_DURATION (src3), 1500 - 500);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -794,7 +794,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on second layer");
|
GST_DEBUG ("Checking transitions on second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
fail_unless (current->data == src2);
|
fail_unless (current->data == src2);
|
||||||
fail_unless (current->next->data == src3);
|
fail_unless (current->next->data == src3);
|
||||||
|
@ -802,7 +802,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
|
|
||||||
GST_DEBUG
|
GST_DEBUG
|
||||||
("Set auto transition to second layer, a new transition should be added");
|
("Set auto transition to second layer, a new transition should be added");
|
||||||
ges_timeline_layer_set_auto_transition (layer1, TRUE);
|
ges_layer_set_auto_transition (layer1, TRUE);
|
||||||
|
|
||||||
/* 500__transition__1000
|
/* 500__transition__1000
|
||||||
* 0___________src_________1000
|
* 0___________src_________1000
|
||||||
|
@ -823,7 +823,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 1500 - 500);
|
assert_equals_uint64 (_DURATION (src3), 1500 - 500);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -842,7 +842,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions has been added on second layer");
|
GST_DEBUG ("Checking transitions has been added on second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -881,7 +881,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
|
||||||
|
@ -900,7 +900,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions has been removed on second layer");
|
GST_DEBUG ("Checking transitions has been removed on second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
fail_unless (current->data == src2);
|
fail_unless (current->data == src2);
|
||||||
fail_unless (current->next->data == src3);
|
fail_unless (current->next->data == src3);
|
||||||
|
@ -929,7 +929,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 7);
|
assert_equals_int (g_list_length (objects), 7);
|
||||||
fail_unless (current->data == src);
|
fail_unless (current->data == src);
|
||||||
|
|
||||||
|
@ -967,7 +967,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking second layer");
|
GST_DEBUG ("Checking second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 1);
|
assert_equals_int (g_list_length (objects), 1);
|
||||||
fail_unless (current->data == src2);
|
fail_unless (current->data == src2);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
@ -995,7 +995,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
fail_unless (current->data == src1);
|
fail_unless (current->data == src1);
|
||||||
|
|
||||||
|
@ -1017,7 +1017,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking second layer");
|
GST_DEBUG ("Checking second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 2);
|
assert_equals_int (g_list_length (objects), 2);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
assert_is_type (current->next->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->next->data, GES_TYPE_TEST_CLIP);
|
||||||
|
@ -1046,7 +1046,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 7);
|
assert_equals_int (g_list_length (objects), 7);
|
||||||
fail_unless (current->data == src1);
|
fail_unless (current->data == src1);
|
||||||
|
|
||||||
|
@ -1083,7 +1083,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking second layer");
|
GST_DEBUG ("Checking second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 1);
|
assert_equals_int (g_list_length (objects), 1);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
@ -1111,7 +1111,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
assert_equals_uint64 (_DURATION (src3), 2000 - 1000);
|
||||||
|
|
||||||
GST_DEBUG ("Checking transitions on first layer");
|
GST_DEBUG ("Checking transitions on first layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 7);
|
assert_equals_int (g_list_length (objects), 7);
|
||||||
fail_unless (current->data == src1);
|
fail_unless (current->data == src1);
|
||||||
|
|
||||||
|
@ -1148,7 +1148,7 @@ GST_START_TEST (test_multi_layer_automatic_transition)
|
||||||
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1);
|
||||||
|
|
||||||
GST_DEBUG ("Checking second layer");
|
GST_DEBUG ("Checking second layer");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer1);
|
current = objects = ges_layer_get_clips (layer1);
|
||||||
assert_equals_int (g_list_length (objects), 1);
|
assert_equals_int (g_list_length (objects), 1);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
@ -1163,7 +1163,7 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
{
|
{
|
||||||
GESAsset *asset, *transition_asset;
|
GESAsset *asset, *transition_asset;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GList *objects, *current;
|
GList *objects, *current;
|
||||||
GESClip *transition;
|
GESClip *transition;
|
||||||
GESTimelineElement *src, *src1, *src2, *src3;
|
GESTimelineElement *src, *src1, *src2, *src3;
|
||||||
|
@ -1181,25 +1181,25 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
|
|
||||||
GST_DEBUG ("Append a layer to the timeline");
|
GST_DEBUG ("Append a layer to the timeline");
|
||||||
layer = ges_timeline_append_layer (timeline);
|
layer = ges_timeline_append_layer (timeline);
|
||||||
assert_is_type (layer, GES_TYPE_TIMELINE_LAYER);
|
assert_is_type (layer, GES_TYPE_LAYER);
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 0 -- 1000 to layer");
|
GST_DEBUG ("Adding clip from 0 -- 1000 to layer");
|
||||||
src = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 0, 0,
|
src = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 0, 0,
|
||||||
1000, GES_TRACK_TYPE_UNKNOWN));
|
1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src));
|
fail_unless (GES_IS_CLIP (src));
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
GST_DEBUG ("Adding clip from 500 -- 1000 to first layer");
|
||||||
src1 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 500,
|
src1 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 500,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src1));
|
fail_unless (GES_IS_CLIP (src1));
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 1000 -- 2000 to layer");
|
GST_DEBUG ("Adding clip from 1000 -- 2000 to layer");
|
||||||
src2 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 1000,
|
src2 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 1000,
|
||||||
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
0, 1000, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src2));
|
fail_unless (GES_IS_CLIP (src2));
|
||||||
|
|
||||||
GST_DEBUG ("Adding clip from 2000 -- 2500 to layer");
|
GST_DEBUG ("Adding clip from 2000 -- 2500 to layer");
|
||||||
src3 = GES_TIMELINE_ELEMENT (ges_timeline_layer_add_asset (layer, asset, 2000,
|
src3 = GES_TIMELINE_ELEMENT (ges_layer_add_asset (layer, asset, 2000,
|
||||||
0, 500, GES_TRACK_TYPE_UNKNOWN));
|
0, 500, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_CLIP (src3));
|
fail_unless (GES_IS_CLIP (src3));
|
||||||
|
|
||||||
|
@ -1220,14 +1220,14 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
assert_equals_uint64 (_DURATION (src3), 500);
|
assert_equals_uint64 (_DURATION (src3), 500);
|
||||||
|
|
||||||
GST_DEBUG ("Checking that no transition has been added");
|
GST_DEBUG ("Checking that no transition has been added");
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 4);
|
assert_equals_int (g_list_length (objects), 4);
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
GST_DEBUG ("Adding transition from 1000 -- 1500 to layer");
|
GST_DEBUG ("Adding transition from 1000 -- 1500 to layer");
|
||||||
transition =
|
transition =
|
||||||
GES_CLIP (ges_timeline_layer_add_asset (layer,
|
GES_CLIP (ges_layer_add_asset (layer,
|
||||||
transition_asset, 1000, 0, 500, GES_TRACK_TYPE_VIDEO));
|
transition_asset, 1000, 0, 500, GES_TRACK_TYPE_VIDEO));
|
||||||
fail_unless (GES_IS_TRANSITION_CLIP (transition));
|
fail_unless (GES_IS_TRANSITION_CLIP (transition));
|
||||||
objects = GES_CONTAINER_CHILDREN (transition);
|
objects = GES_CONTAINER_CHILDREN (transition);
|
||||||
|
@ -1241,7 +1241,7 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
* 1000____src2_______2000
|
* 1000____src2_______2000
|
||||||
* 2000_______src3_____2500
|
* 2000_______src3_____2500
|
||||||
*/
|
*/
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 5);
|
assert_equals_int (g_list_length (objects), 5);
|
||||||
current = current->next;
|
current = current->next;
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
|
@ -1253,7 +1253,7 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
assert_is_type (current->data, GES_TYPE_TEST_CLIP);
|
||||||
g_list_free_full (objects, gst_object_unref);
|
g_list_free_full (objects, gst_object_unref);
|
||||||
|
|
||||||
ges_timeline_layer_set_auto_transition (layer, TRUE);
|
ges_layer_set_auto_transition (layer, TRUE);
|
||||||
/*
|
/*
|
||||||
* 0___________src_________1000
|
* 0___________src_________1000
|
||||||
* 500______tr______1000
|
* 500______tr______1000
|
||||||
|
@ -1262,7 +1262,7 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
* 1000____src2_______2000
|
* 1000____src2_______2000
|
||||||
* 2000_______src3_____2500
|
* 2000_______src3_____2500
|
||||||
*/
|
*/
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 8);
|
assert_equals_int (g_list_length (objects), 8);
|
||||||
assert_equals_uint64 (_START (src), 0);
|
assert_equals_uint64 (_START (src), 0);
|
||||||
assert_equals_uint64 (_DURATION (src), 1000);
|
assert_equals_uint64 (_DURATION (src), 1000);
|
||||||
|
@ -1322,7 +1322,7 @@ GST_START_TEST (test_layer_activate_automatic_transition)
|
||||||
* !__tr__^
|
* !__tr__^
|
||||||
* 2000_______src3_____2500
|
* 2000_______src3_____2500
|
||||||
*/
|
*/
|
||||||
current = objects = ges_timeline_layer_get_clips (layer);
|
current = objects = ges_layer_get_clips (layer);
|
||||||
assert_equals_int (g_list_length (objects), 10);
|
assert_equals_int (g_list_length (objects), 10);
|
||||||
assert_equals_uint64 (_START (src), 0);
|
assert_equals_uint64 (_START (src), 0);
|
||||||
assert_equals_uint64 (_DURATION (src), 1000);
|
assert_equals_uint64 (_DURATION (src), 1000);
|
||||||
|
@ -1392,13 +1392,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_string)
|
GST_START_TEST (test_layer_meta_string)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
const gchar *result;
|
const gchar *result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_string (GES_META_CONTAINER (layer),
|
ges_meta_container_set_string (GES_META_CONTAINER (layer),
|
||||||
|
@ -1415,13 +1415,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_boolean)
|
GST_START_TEST (test_layer_meta_boolean)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gboolean result;
|
gboolean result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_boolean (GES_META_CONTAINER (layer), "ges-test", TRUE);
|
ges_meta_container_set_boolean (GES_META_CONTAINER (layer), "ges-test", TRUE);
|
||||||
|
@ -1437,13 +1437,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_int)
|
GST_START_TEST (test_layer_meta_int)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gint result;
|
gint result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_int (GES_META_CONTAINER (layer), "ges-test", 1234);
|
ges_meta_container_set_int (GES_META_CONTAINER (layer), "ges-test", 1234);
|
||||||
|
@ -1459,13 +1459,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_uint)
|
GST_START_TEST (test_layer_meta_uint)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
guint result;
|
guint result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_uint (GES_META_CONTAINER (layer), "ges-test", 42);
|
ges_meta_container_set_uint (GES_META_CONTAINER (layer), "ges-test", 42);
|
||||||
|
@ -1481,13 +1481,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_int64)
|
GST_START_TEST (test_layer_meta_int64)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gint64 result;
|
gint64 result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_int64 (GES_META_CONTAINER (layer), "ges-test", 1234);
|
ges_meta_container_set_int64 (GES_META_CONTAINER (layer), "ges-test", 1234);
|
||||||
|
@ -1503,13 +1503,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_uint64)
|
GST_START_TEST (test_layer_meta_uint64)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
guint64 result;
|
guint64 result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_uint64 (GES_META_CONTAINER (layer), "ges-test", 42);
|
ges_meta_container_set_uint64 (GES_META_CONTAINER (layer), "ges-test", 42);
|
||||||
|
@ -1525,13 +1525,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_float)
|
GST_START_TEST (test_layer_meta_float)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gfloat result;
|
gfloat result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
fail_unless (ges_meta_container_set_float (GES_META_CONTAINER (layer),
|
fail_unless (ges_meta_container_set_float (GES_META_CONTAINER (layer),
|
||||||
|
@ -1548,13 +1548,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_double)
|
GST_START_TEST (test_layer_meta_double)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
gdouble result;
|
gdouble result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_double (GES_META_CONTAINER (layer),
|
ges_meta_container_set_double (GES_META_CONTAINER (layer),
|
||||||
|
@ -1573,14 +1573,14 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_date)
|
GST_START_TEST (test_layer_meta_date)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GDate *input;
|
GDate *input;
|
||||||
GDate *result;
|
GDate *result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
input = g_date_new_dmy (1, 1, 2012);
|
input = g_date_new_dmy (1, 1, 2012);
|
||||||
|
@ -1601,14 +1601,14 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_date_time)
|
GST_START_TEST (test_layer_meta_date_time)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GstDateTime *input;
|
GstDateTime *input;
|
||||||
GstDateTime *result = NULL;
|
GstDateTime *result = NULL;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
input = gst_date_time_new_from_unix_epoch_local_time (123456789);
|
input = gst_date_time_new_from_unix_epoch_local_time (123456789);
|
||||||
|
@ -1634,14 +1634,14 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_value)
|
GST_START_TEST (test_layer_meta_value)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GValue data = G_VALUE_INIT;
|
GValue data = G_VALUE_INIT;
|
||||||
const GValue *result;
|
const GValue *result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
g_value_init (&data, G_TYPE_STRING);
|
g_value_init (&data, G_TYPE_STRING);
|
||||||
|
@ -1663,13 +1663,13 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_layer_meta_register)
|
GST_START_TEST (test_layer_meta_register)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
const gchar *result;
|
const gchar *result;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
fail_unless (ges_meta_container_register_meta_string (GES_META_CONTAINER
|
fail_unless (ges_meta_container_register_meta_string (GES_META_CONTAINER
|
||||||
|
@ -1700,12 +1700,12 @@ test_foreach (const GESMetaContainer * container, const gchar * key,
|
||||||
GST_START_TEST (test_layer_meta_foreach)
|
GST_START_TEST (test_layer_meta_foreach)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_meta_container_set_string (GES_META_CONTAINER (layer),
|
ges_meta_container_set_string (GES_META_CONTAINER (layer),
|
||||||
|
@ -1722,7 +1722,7 @@ GST_END_TEST;
|
||||||
static Suite *
|
static Suite *
|
||||||
ges_suite (void)
|
ges_suite (void)
|
||||||
{
|
{
|
||||||
Suite *s = suite_create ("ges-timeline-layer");
|
Suite *s = suite_create ("ges-layer");
|
||||||
TCase *tc_chain = tcase_create ("timeline-layer");
|
TCase *tc_chain = tcase_create ("timeline-layer");
|
||||||
|
|
||||||
suite_add_tcase (s, tc_chain);
|
suite_add_tcase (s, tc_chain);
|
||||||
|
|
|
@ -40,14 +40,14 @@ GST_START_TEST (test_overlay_properties)
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
track = ges_track_new (GES_TRACK_TYPE_VIDEO, gst_caps_ref (GST_CAPS_ANY));
|
track = ges_track_new (GES_TRACK_TYPE_VIDEO, gst_caps_ref (GST_CAPS_ANY));
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
@ -65,7 +65,7 @@ GST_START_TEST (test_overlay_properties)
|
||||||
assert_equals_uint64 (_DURATION (clip), 51);
|
assert_equals_uint64 (_DURATION (clip), 51);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -106,7 +106,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_overlay_in_layer)
|
GST_START_TEST (test_overlay_in_layer)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *a, *v;
|
GESTrack *a, *v;
|
||||||
GESTrackElement *track_element;
|
GESTrackElement *track_element;
|
||||||
GESTextOverlayClip *source;
|
GESTextOverlayClip *source;
|
||||||
|
@ -119,7 +119,7 @@ GST_START_TEST (test_overlay_in_layer)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
a = ges_track_audio_raw_new ();
|
a = ges_track_audio_raw_new ();
|
||||||
v = ges_track_video_raw_new ();
|
v = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -131,8 +131,7 @@ GST_START_TEST (test_overlay_in_layer)
|
||||||
|
|
||||||
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) layer,
|
ges_simple_layer_add_object ((GESSimpleLayer *) layer, (GESClip *) source, 0);
|
||||||
(GESClip *) source, 0);
|
|
||||||
|
|
||||||
/* specifically test the text property */
|
/* specifically test the text property */
|
||||||
g_object_set (source, "text", (gchar *) "some text", NULL);
|
g_object_set (source, "text", (gchar *) "some text", NULL);
|
||||||
|
@ -190,7 +189,7 @@ GST_START_TEST (test_overlay_in_layer)
|
||||||
|
|
||||||
GST_DEBUG ("removing the source");
|
GST_DEBUG ("removing the source");
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
GST_DEBUG ("removing the layer");
|
GST_DEBUG ("removing the layer");
|
||||||
|
|
||||||
|
|
|
@ -206,11 +206,9 @@ _test_project (GESProject * project, GESTimeline * timeline)
|
||||||
|
|
||||||
assert_equals_string (ges_meta_container_get_string (GES_META_CONTAINER
|
assert_equals_string (ges_meta_container_get_string (GES_META_CONTAINER
|
||||||
(project), "name"), "Example project");
|
(project), "name"), "Example project");
|
||||||
clips =
|
clips = ges_layer_get_clips (GES_LAYER (timeline->layers->data));
|
||||||
ges_timeline_layer_get_clips (GES_TIMELINE_LAYER (timeline->layers->
|
fail_unless (ges_meta_container_get_uint (GES_META_CONTAINER
|
||||||
data));
|
(timeline->layers->data), "a", &a_meta));
|
||||||
fail_unless (ges_meta_container_get_uint (GES_META_CONTAINER (timeline->
|
|
||||||
layers->data), "a", &a_meta));
|
|
||||||
assert_equals_int (a_meta, 3);
|
assert_equals_int (a_meta, 3);
|
||||||
assert_equals_int (g_list_length (clips), 1);
|
assert_equals_int (g_list_length (clips), 1);
|
||||||
media_uri = ges_test_file_uri ("audio_video.ogg");
|
media_uri = ges_test_file_uri ("audio_video.ogg");
|
||||||
|
|
|
@ -43,7 +43,7 @@ my_fill_track_func (GESClip * clip,
|
||||||
GST_START_TEST (test_gsl_add)
|
GST_START_TEST (test_gsl_add)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *source;
|
GESCustomSourceClip *source;
|
||||||
GESClip *source2;
|
GESClip *source2;
|
||||||
|
@ -54,7 +54,7 @@ GST_START_TEST (test_gsl_add)
|
||||||
|
|
||||||
/* Timeline and 1 Layer */
|
/* Timeline and 1 Layer */
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_ref (GST_CAPS_ANY));
|
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_ref (GST_CAPS_ANY));
|
||||||
fail_unless (ges_timeline_add_track (timeline, track));
|
fail_unless (ges_timeline_add_track (timeline, track));
|
||||||
|
@ -65,31 +65,28 @@ GST_START_TEST (test_gsl_add)
|
||||||
fail_unless_equals_uint64 (_DURATION (source), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source), 42);
|
fail_unless_equals_uint64 (_START (source), 42);
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_add_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source), -1));
|
(layer), GES_CLIP (source), -1));
|
||||||
fail_unless (ges_clip_get_layer (GES_CLIP (source)) == layer);
|
fail_unless (ges_clip_get_layer (GES_CLIP (source)) == layer);
|
||||||
fail_unless_equals_uint64 (_DURATION (source), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source), 0);
|
fail_unless_equals_uint64 (_START (source), 0);
|
||||||
|
|
||||||
/* test nth */
|
/* test nth */
|
||||||
source2 =
|
source2 = ges_simple_layer_nth ((GESSimpleLayer *) layer, -1);
|
||||||
ges_simple_timeline_layer_nth ((GESSimpleTimelineLayer *) layer, -1);
|
|
||||||
fail_if (source2);
|
fail_if (source2);
|
||||||
source2 = ges_simple_timeline_layer_nth ((GESSimpleTimelineLayer *) layer, 2);
|
source2 = ges_simple_layer_nth ((GESSimpleLayer *) layer, 2);
|
||||||
fail_if (source2);
|
fail_if (source2);
|
||||||
source2 = ges_simple_timeline_layer_nth ((GESSimpleTimelineLayer *) layer, 0);
|
source2 = ges_simple_layer_nth ((GESSimpleLayer *) layer, 0);
|
||||||
fail_unless ((GESClip *) source == source2);
|
fail_unless ((GESClip *) source == source2);
|
||||||
|
|
||||||
/* test position */
|
/* test position */
|
||||||
|
|
||||||
result = ges_simple_timeline_layer_index ((GESSimpleTimelineLayer *) layer,
|
result = ges_simple_layer_index ((GESSimpleLayer *) layer, source2);
|
||||||
source2);
|
|
||||||
fail_unless_equals_int (result, 0);
|
fail_unless_equals_int (result, 0);
|
||||||
result = ges_simple_timeline_layer_index ((GESSimpleTimelineLayer *) layer,
|
result = ges_simple_layer_index ((GESSimpleLayer *) layer, (GESClip *) NULL);
|
||||||
(GESClip *) NULL);
|
|
||||||
fail_unless_equals_int (result, -1);
|
fail_unless_equals_int (result, -1);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source)));
|
||||||
fail_unless (ges_timeline_remove_track (timeline, track));
|
fail_unless (ges_timeline_remove_track (timeline, track));
|
||||||
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
||||||
gst_object_unref (timeline);
|
gst_object_unref (timeline);
|
||||||
|
@ -104,7 +101,7 @@ typedef struct
|
||||||
} siginfo;
|
} siginfo;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
object_moved_cb (GESSimpleTimelineLayer * layer,
|
object_moved_cb (GESSimpleLayer * layer,
|
||||||
GESClip * clip, gint old, gint new, gpointer user)
|
GESClip * clip, gint old, gint new, gpointer user)
|
||||||
{
|
{
|
||||||
siginfo *info;
|
siginfo *info;
|
||||||
|
@ -116,7 +113,7 @@ object_moved_cb (GESSimpleTimelineLayer * layer,
|
||||||
GST_START_TEST (test_gsl_move_simple)
|
GST_START_TEST (test_gsl_move_simple)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESCustomSourceClip *source1, *source2;
|
GESCustomSourceClip *source1, *source2;
|
||||||
siginfo info = { 0, 0 };
|
siginfo info = { 0, 0 };
|
||||||
|
@ -125,7 +122,7 @@ GST_START_TEST (test_gsl_move_simple)
|
||||||
|
|
||||||
/* Timeline and 1 Layer */
|
/* Timeline and 1 Layer */
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_new_any ());
|
track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_new_any ());
|
||||||
fail_unless (ges_timeline_add_track (timeline, track));
|
fail_unless (ges_timeline_add_track (timeline, track));
|
||||||
|
@ -142,19 +139,19 @@ GST_START_TEST (test_gsl_move_simple)
|
||||||
|
|
||||||
/* Add source to any position */
|
/* Add source to any position */
|
||||||
GST_DEBUG ("Adding the source to the timeline layer");
|
GST_DEBUG ("Adding the source to the timeline layer");
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_add_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source1), -1));
|
(layer), GES_CLIP (source1), -1));
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
|
|
||||||
/* Add source2 to the end */
|
/* Add source2 to the end */
|
||||||
GST_DEBUG ("Adding the source to the timeline layer");
|
GST_DEBUG ("Adding the source to the timeline layer");
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_add_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source2), -1));
|
(layer), GES_CLIP (source2), -1));
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_START (source2), GST_SECOND);
|
fail_unless_equals_uint64 (_START (source2), GST_SECOND);
|
||||||
|
|
||||||
/* Move source2 before source 1 (newpos:0) */
|
/* Move source2 before source 1 (newpos:0) */
|
||||||
fail_unless (ges_simple_timeline_layer_move_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_move_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source2), 0));
|
(layer), GES_CLIP (source2), 0));
|
||||||
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source2), 0);
|
fail_unless_equals_uint64 (_START (source2), 0);
|
||||||
|
@ -162,7 +159,7 @@ GST_START_TEST (test_gsl_move_simple)
|
||||||
fail_unless_equals_int (info.old, 1);
|
fail_unless_equals_int (info.old, 1);
|
||||||
|
|
||||||
/* Move source2 after source 1 (newpos:0) */
|
/* Move source2 after source 1 (newpos:0) */
|
||||||
fail_unless (ges_simple_timeline_layer_move_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_move_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source2), 1));
|
(layer), GES_CLIP (source2), 1));
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_START (source2), GST_SECOND);
|
fail_unless_equals_uint64 (_START (source2), GST_SECOND);
|
||||||
|
@ -170,7 +167,7 @@ GST_START_TEST (test_gsl_move_simple)
|
||||||
fail_unless_equals_int (info.old, 0);
|
fail_unless_equals_int (info.old, 0);
|
||||||
|
|
||||||
/* Move source1 to end (newpos:-1) */
|
/* Move source1 to end (newpos:-1) */
|
||||||
fail_unless (ges_simple_timeline_layer_move_object (GES_SIMPLE_TIMELINE_LAYER
|
fail_unless (ges_simple_layer_move_object (GES_SIMPLE_LAYER
|
||||||
(layer), GES_CLIP (source1), -1));
|
(layer), GES_CLIP (source1), -1));
|
||||||
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source2), 0);
|
fail_unless_equals_uint64 (_START (source2), 0);
|
||||||
|
@ -180,21 +177,21 @@ GST_START_TEST (test_gsl_move_simple)
|
||||||
|
|
||||||
/* remove source1, source2 should be moved to the beginning */
|
/* remove source1, source2 should be moved to the beginning */
|
||||||
gst_object_ref (source1);
|
gst_object_ref (source1);
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source1)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source1)));
|
||||||
fail_unless_equals_uint64 (_START (source2), 0);
|
fail_unless_equals_uint64 (_START (source2), 0);
|
||||||
|
|
||||||
g_object_set (source1, "start", (guint64) 42, NULL);
|
g_object_set (source1, "start", (guint64) 42, NULL);
|
||||||
|
|
||||||
/* re-add source1... using the normal API, it should be added to the end */
|
/* re-add source1... using the normal API, it should be added to the end */
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (source1)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (source1)));
|
||||||
fail_unless_equals_uint64 (_START (source2), 0);
|
fail_unless_equals_uint64 (_START (source2), 0);
|
||||||
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_START (source1), GST_SECOND);
|
||||||
|
|
||||||
/* remove source1 ... */
|
/* remove source1 ... */
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source1)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source1)));
|
||||||
fail_unless_equals_uint64 (_START (source2), 0);
|
fail_unless_equals_uint64 (_START (source2), 0);
|
||||||
/* ... and source2 */
|
/* ... and source2 */
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source2)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source2)));
|
||||||
|
|
||||||
fail_unless (ges_timeline_remove_track (timeline, track));
|
fail_unless (ges_timeline_remove_track (timeline, track));
|
||||||
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
fail_unless (ges_timeline_remove_layer (timeline, layer));
|
||||||
|
@ -212,11 +209,11 @@ valid_notify_cb (GObject * obj, GParamSpec * unused G_GNUC_UNUSED, gint * count)
|
||||||
GST_START_TEST (test_gsl_with_transitions)
|
GST_START_TEST (test_gsl_with_transitions)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTestClip *source1, *source2, *source3, *source4;
|
GESTestClip *source1, *source2, *source3, *source4;
|
||||||
GESTransitionClip *tr1, *tr2, *tr3, *tr4, *tr5;
|
GESTransitionClip *tr1, *tr2, *tr3, *tr4, *tr5;
|
||||||
GESSimpleTimelineLayer *gstl;
|
GESSimpleLayer *gstl;
|
||||||
gboolean valid;
|
gboolean valid;
|
||||||
gint count = 0;
|
gint count = 0;
|
||||||
|
|
||||||
|
@ -224,13 +221,13 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
/* Timeline and 1 Layer */
|
/* Timeline and 1 Layer */
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
|
|
||||||
g_signal_connect (G_OBJECT (layer), "notify::valid",
|
g_signal_connect (G_OBJECT (layer), "notify::valid",
|
||||||
G_CALLBACK (valid_notify_cb), &count);
|
G_CALLBACK (valid_notify_cb), &count);
|
||||||
|
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
ges_timeline_layer_set_priority (layer, 0);
|
ges_layer_set_priority (layer, 0);
|
||||||
|
|
||||||
track = ges_track_new (GES_TRACK_TYPE_VIDEO, gst_caps_new_any ());
|
track = ges_track_new (GES_TRACK_TYPE_VIDEO, gst_caps_new_any ());
|
||||||
fail_unless (ges_timeline_add_track (timeline, track));
|
fail_unless (ges_timeline_add_track (timeline, track));
|
||||||
|
@ -294,19 +291,18 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
/* 5 [5---source4-----] */
|
/* 5 [5---source4-----] */
|
||||||
|
|
||||||
|
|
||||||
gstl = GES_SIMPLE_TIMELINE_LAYER (layer);
|
gstl = GES_SIMPLE_LAYER (layer);
|
||||||
|
|
||||||
/* add objects in sequence */
|
/* add objects in sequence */
|
||||||
|
|
||||||
GST_DEBUG ("Adding source1");
|
GST_DEBUG ("Adding source1");
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl,
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (source1), -1));
|
||||||
GES_CLIP (source1), -1));
|
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
|
||||||
GST_DEBUG ("Adding tr1");
|
GST_DEBUG ("Adding tr1");
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr1), -1));
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (tr1), -1));
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
@ -315,8 +311,7 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
fail_unless_equals_uint64 (_PRIORITY (tr1), 1);
|
fail_unless_equals_uint64 (_PRIORITY (tr1), 1);
|
||||||
|
|
||||||
GST_DEBUG ("Adding source2");
|
GST_DEBUG ("Adding source2");
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl,
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (source2), -1));
|
||||||
GES_CLIP (source2), -1));
|
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
@ -331,8 +326,7 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Adding source3");
|
GST_DEBUG ("Adding source3");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl,
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (source3), -1));
|
||||||
GES_CLIP (source3), -1));
|
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
@ -350,7 +344,7 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Adding tr2");
|
GST_DEBUG ("Adding tr2");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr2), 3));
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (tr2), 3));
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
@ -371,8 +365,7 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Adding source4");
|
GST_DEBUG ("Adding source4");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl,
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (source4), -1));
|
||||||
GES_CLIP (source4), -1));
|
|
||||||
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
fail_unless_equals_uint64 (_DURATION (source1), GST_SECOND);
|
||||||
fail_unless_equals_uint64 (_START (source1), 0);
|
fail_unless_equals_uint64 (_START (source1), 0);
|
||||||
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
fail_unless_equals_uint64 (_PRIORITY (source1), 2);
|
||||||
|
@ -397,19 +390,19 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Checking wrong insertion of tr3");
|
GST_DEBUG ("Checking wrong insertion of tr3");
|
||||||
|
|
||||||
fail_if (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr3), 1));
|
fail_if (ges_simple_layer_add_object (gstl, GES_CLIP (tr3), 1));
|
||||||
|
|
||||||
fail_if (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr3), 2));
|
fail_if (ges_simple_layer_add_object (gstl, GES_CLIP (tr3), 2));
|
||||||
|
|
||||||
fail_if (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr3), 3));
|
fail_if (ges_simple_layer_add_object (gstl, GES_CLIP (tr3), 3));
|
||||||
|
|
||||||
fail_if (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr3), 4));
|
fail_if (ges_simple_layer_add_object (gstl, GES_CLIP (tr3), 4));
|
||||||
|
|
||||||
/* check that insertions which don't cause problems still work */
|
/* check that insertions which don't cause problems still work */
|
||||||
|
|
||||||
GST_DEBUG ("Checking correct insertion of tr3");
|
GST_DEBUG ("Checking correct insertion of tr3");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr3), 5));
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (tr3), 5));
|
||||||
|
|
||||||
/* at this point the layer should still be valid */
|
/* at this point the layer should still be valid */
|
||||||
g_object_get (G_OBJECT (layer), "valid", &valid, NULL);
|
g_object_get (G_OBJECT (layer), "valid", &valid, NULL);
|
||||||
|
@ -418,18 +411,18 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Checking correct insertion of tr4");
|
GST_DEBUG ("Checking correct insertion of tr4");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr4), -1));
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (tr4), -1));
|
||||||
|
|
||||||
GST_DEBUG ("Checking correct insertion of tr5");
|
GST_DEBUG ("Checking correct insertion of tr5");
|
||||||
|
|
||||||
fail_unless (ges_simple_timeline_layer_add_object (gstl, GES_CLIP (tr5), 0));
|
fail_unless (ges_simple_layer_add_object (gstl, GES_CLIP (tr5), 0));
|
||||||
|
|
||||||
/* removals which result in two or more adjacent transitions will also
|
/* removals which result in two or more adjacent transitions will also
|
||||||
* print a warning on the console. This is expected */
|
* print a warning on the console. This is expected */
|
||||||
|
|
||||||
GST_DEBUG ("Removing source1");
|
GST_DEBUG ("Removing source1");
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source1)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source1)));
|
||||||
|
|
||||||
/* layer should now be invalid */
|
/* layer should now be invalid */
|
||||||
|
|
||||||
|
@ -439,9 +432,9 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Removing source2/3/4");
|
GST_DEBUG ("Removing source2/3/4");
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source2)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source2)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source3)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source3)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (source4)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (source4)));
|
||||||
|
|
||||||
g_object_get (G_OBJECT (layer), "valid", &valid, NULL);
|
g_object_get (G_OBJECT (layer), "valid", &valid, NULL);
|
||||||
fail_unless (!valid);
|
fail_unless (!valid);
|
||||||
|
@ -449,11 +442,11 @@ GST_START_TEST (test_gsl_with_transitions)
|
||||||
|
|
||||||
GST_DEBUG ("Removing transitions");
|
GST_DEBUG ("Removing transitions");
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (tr1)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (tr1)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (tr2)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (tr2)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (tr3)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (tr3)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (tr4)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (tr4)));
|
||||||
fail_unless (ges_timeline_layer_remove_clip (layer, GES_CLIP (tr5)));
|
fail_unless (ges_layer_remove_clip (layer, GES_CLIP (tr5)));
|
||||||
|
|
||||||
GST_DEBUG ("done removing transition");
|
GST_DEBUG ("done removing transition");
|
||||||
|
|
||||||
|
@ -465,7 +458,7 @@ GST_END_TEST;
|
||||||
static Suite *
|
static Suite *
|
||||||
ges_suite (void)
|
ges_suite (void)
|
||||||
{
|
{
|
||||||
Suite *s = suite_create ("ges-simple-timeline-layer");
|
Suite *s = suite_create ("ges-simple-layer");
|
||||||
TCase *tc_chain = tcase_create ("basic");
|
TCase *tc_chain = tcase_create ("basic");
|
||||||
|
|
||||||
suite_add_tcase (s, tc_chain);
|
suite_add_tcase (s, tc_chain);
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
GST_START_TEST (test_text_properties_in_layer)
|
GST_START_TEST (test_text_properties_in_layer)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *a, *v;
|
GESTrack *a, *v;
|
||||||
GESTrackElement *track_element;
|
GESTrackElement *track_element;
|
||||||
GESTestClip *source;
|
GESTestClip *source;
|
||||||
|
@ -34,7 +34,7 @@ GST_START_TEST (test_text_properties_in_layer)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
a = ges_track_audio_raw_new ();
|
a = ges_track_audio_raw_new ();
|
||||||
v = ges_track_video_raw_new ();
|
v = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -46,8 +46,7 @@ GST_START_TEST (test_text_properties_in_layer)
|
||||||
|
|
||||||
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) layer,
|
ges_simple_layer_add_object ((GESSimpleLayer *) layer, (GESClip *) source, 0);
|
||||||
(GESClip *) source, 0);
|
|
||||||
|
|
||||||
track_element =
|
track_element =
|
||||||
ges_clip_find_track_element (GES_CLIP (source), v, GES_TYPE_TEXT_OVERLAY);
|
ges_clip_find_track_element (GES_CLIP (source), v, GES_TYPE_TEXT_OVERLAY);
|
||||||
|
@ -89,7 +88,7 @@ GST_START_TEST (test_text_properties_in_layer)
|
||||||
|
|
||||||
GST_DEBUG ("removing the source");
|
GST_DEBUG ("removing the source");
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
GST_DEBUG ("removing the layer");
|
GST_DEBUG ("removing the layer");
|
||||||
|
|
||||||
|
|
|
@ -57,7 +57,7 @@ GST_START_TEST (test_basic_timeline_edition)
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
||||||
GESClip *clip, *clip1, *clip2;
|
GESClip *clip, *clip1, *clip2;
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ GST_START_TEST (test_basic_timeline_edition)
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
fail_unless (ges_timeline_add_track (timeline, track));
|
fail_unless (ges_timeline_add_track (timeline, track));
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
|
|
||||||
|
@ -84,18 +84,15 @@ GST_START_TEST (test_basic_timeline_edition)
|
||||||
* | clip | | clip1 | | clip2 |
|
* | clip | | clip1 | | clip2 |
|
||||||
* time 0------- 10 --------20 50---------60
|
* time 0------- 10 --------20 50---------60
|
||||||
*/
|
*/
|
||||||
clip = ges_timeline_layer_add_asset (layer, asset, 0, 0, 10,
|
clip = ges_layer_add_asset (layer, asset, 0, 0, 10, GES_TRACK_TYPE_UNKNOWN);
|
||||||
GES_TRACK_TYPE_UNKNOWN);
|
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (GES_IS_TRACK_ELEMENT (trackelement));
|
fail_unless (GES_IS_TRACK_ELEMENT (trackelement));
|
||||||
|
|
||||||
clip1 = ges_timeline_layer_add_asset (layer, asset, 10, 0, 10,
|
clip1 = ges_layer_add_asset (layer, asset, 10, 0, 10, GES_TRACK_TYPE_UNKNOWN);
|
||||||
GES_TRACK_TYPE_UNKNOWN);
|
|
||||||
trackelement1 = GES_CONTAINER_CHILDREN (clip1)->data;
|
trackelement1 = GES_CONTAINER_CHILDREN (clip1)->data;
|
||||||
fail_unless (GES_IS_TRACK_ELEMENT (trackelement1));
|
fail_unless (GES_IS_TRACK_ELEMENT (trackelement1));
|
||||||
|
|
||||||
clip2 = ges_timeline_layer_add_asset (layer, asset, 50, 0, 60,
|
clip2 = ges_layer_add_asset (layer, asset, 50, 0, 60, GES_TRACK_TYPE_UNKNOWN);
|
||||||
GES_TRACK_TYPE_UNKNOWN);
|
|
||||||
trackelement2 = GES_CONTAINER_CHILDREN (clip2)->data;
|
trackelement2 = GES_CONTAINER_CHILDREN (clip2)->data;
|
||||||
fail_unless (GES_IS_TRACK_ELEMENT (trackelement2));
|
fail_unless (GES_IS_TRACK_ELEMENT (trackelement2));
|
||||||
|
|
||||||
|
@ -248,7 +245,7 @@ GST_START_TEST (test_snapping)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
||||||
GESClip *clip, *clip1, *clip2;
|
GESClip *clip, *clip1, *clip2;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GList *trackelements;
|
GList *trackelements;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -282,10 +279,10 @@ GST_START_TEST (test_snapping)
|
||||||
"in-point", (guint64) 0, NULL);
|
"in-point", (guint64) 0, NULL);
|
||||||
|
|
||||||
fail_unless ((layer = ges_timeline_append_layer (timeline)) != NULL);
|
fail_unless ((layer = ges_timeline_append_layer (timeline)) != NULL);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 0);
|
assert_equals_int (ges_layer_get_priority (layer), 0);
|
||||||
|
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, clip));
|
fail_unless (ges_layer_add_clip (layer, clip));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip)) != NULL);
|
||||||
fail_unless ((trackelement =
|
fail_unless ((trackelement =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
|
@ -299,7 +296,7 @@ GST_START_TEST (test_snapping)
|
||||||
* + layer */
|
* + layer */
|
||||||
ASSERT_OBJECT_REFCOUNT (clip, "First clip", 1);
|
ASSERT_OBJECT_REFCOUNT (clip, "First clip", 1);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, clip1));
|
fail_unless (ges_layer_add_clip (layer, clip1));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip1)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip1)) != NULL);
|
||||||
fail_unless ((trackelement1 =
|
fail_unless ((trackelement1 =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
|
@ -310,7 +307,7 @@ GST_START_TEST (test_snapping)
|
||||||
ASSERT_OBJECT_REFCOUNT (trackelement1, "First trackelement", 3);
|
ASSERT_OBJECT_REFCOUNT (trackelement1, "First trackelement", 3);
|
||||||
ASSERT_OBJECT_REFCOUNT (clip1, "First clip", 1);
|
ASSERT_OBJECT_REFCOUNT (clip1, "First clip", 1);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, clip2));
|
fail_unless (ges_layer_add_clip (layer, clip2));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip2)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip2)) != NULL);
|
||||||
fail_unless ((trackelement2 =
|
fail_unless ((trackelement2 =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
|
@ -532,7 +529,7 @@ GST_START_TEST (test_simple_triming)
|
||||||
GESClipAsset *asset;
|
GESClipAsset *asset;
|
||||||
GESProject *project;
|
GESProject *project;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTimelineElement *element;
|
GESTimelineElement *element;
|
||||||
|
|
||||||
gchar *uri = ges_test_file_uri ("audio_video.ogg");
|
gchar *uri = ges_test_file_uri ("audio_video.ogg");
|
||||||
|
@ -557,13 +554,13 @@ GST_START_TEST (test_simple_triming)
|
||||||
assert_equals_int (g_list_length (assets), 1);
|
assert_equals_int (g_list_length (assets), 1);
|
||||||
asset = assets->data;
|
asset = assets->data;
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
ges_timeline_add_layer (timeline, layer);
|
ges_timeline_add_layer (timeline, layer);
|
||||||
|
|
||||||
ges_timeline_layer_add_asset (layer, GES_ASSET (asset), 0, 0, 10,
|
ges_layer_add_asset (layer, GES_ASSET (asset), 0, 0, 10,
|
||||||
ges_clip_asset_get_supported_formats (asset));
|
ges_clip_asset_get_supported_formats (asset));
|
||||||
|
|
||||||
element = ges_timeline_layer_get_clips (layer)->data;
|
element = ges_layer_get_clips (layer)->data;
|
||||||
|
|
||||||
deep_check (element, 0, 0, 10);
|
deep_check (element, 0, 0, 10);
|
||||||
ges_timeline_enable_update (timeline, FALSE);
|
ges_timeline_enable_update (timeline, FALSE);
|
||||||
|
@ -585,7 +582,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
GESTrackElement *trackelement, *trackelement1, *trackelement2;
|
||||||
GESClip *clip, *clip1, *clip2;
|
GESClip *clip, *clip1, *clip2;
|
||||||
GESTimelineLayer *layer, *layer1, *layer2;
|
GESLayer *layer, *layer1, *layer2;
|
||||||
GList *trackelements, *layers, *tmp;
|
GList *trackelements, *layers, *tmp;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -623,10 +620,10 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
"in-point", (guint64) 0, NULL);
|
"in-point", (guint64) 0, NULL);
|
||||||
|
|
||||||
fail_unless ((layer = ges_timeline_append_layer (timeline)) != NULL);
|
fail_unless ((layer = ges_timeline_append_layer (timeline)) != NULL);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 0);
|
assert_equals_int (ges_layer_get_priority (layer), 0);
|
||||||
|
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, clip));
|
fail_unless (ges_layer_add_clip (layer, clip));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip)) != NULL);
|
||||||
fail_unless ((trackelement =
|
fail_unless ((trackelement =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
|
@ -636,16 +633,16 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
/* Add a new layer and add clipects to it */
|
/* Add a new layer and add clipects to it */
|
||||||
fail_unless ((layer1 = ges_timeline_append_layer (timeline)) != NULL);
|
fail_unless ((layer1 = ges_timeline_append_layer (timeline)) != NULL);
|
||||||
fail_unless (layer != layer1);
|
fail_unless (layer != layer1);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer1), 1);
|
assert_equals_int (ges_layer_get_priority (layer1), 1);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer1, clip1));
|
fail_unless (ges_layer_add_clip (layer1, clip1));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip1)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip1)) != NULL);
|
||||||
fail_unless ((trackelement1 =
|
fail_unless ((trackelement1 =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
fail_unless (ges_track_element_get_track (trackelement1) == track);
|
fail_unless (ges_track_element_get_track (trackelement1) == track);
|
||||||
assert_equals_uint64 (_DURATION (trackelement1), 10);
|
assert_equals_uint64 (_DURATION (trackelement1), 10);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer1, clip2));
|
fail_unless (ges_layer_add_clip (layer1, clip2));
|
||||||
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip2)) != NULL);
|
fail_unless ((trackelements = GES_CONTAINER_CHILDREN (clip2)) != NULL);
|
||||||
fail_unless ((trackelement2 =
|
fail_unless ((trackelement2 =
|
||||||
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
GES_TRACK_ELEMENT (trackelements->data)) != NULL);
|
||||||
|
@ -681,7 +678,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 40, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 40, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 80, 0, 60);
|
CHECK_OBJECT_PROPS (trackelement2, 80, 0, 60);
|
||||||
layer2 = ges_clip_get_layer (clip1);
|
layer2 = ges_clip_get_layer (clip1);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer2), 3);
|
assert_equals_int (ges_layer_get_priority (layer2), 3);
|
||||||
/* clip2 should have moved layer too */
|
/* clip2 should have moved layer too */
|
||||||
fail_unless (ges_clip_get_layer (clip2) == layer2);
|
fail_unless (ges_clip_get_layer (clip2) == layer2);
|
||||||
/* We got 2 reference to the same clipect, unref them */
|
/* We got 2 reference to the same clipect, unref them */
|
||||||
|
@ -697,7 +694,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 60, 0, 60);
|
CHECK_OBJECT_PROPS (trackelement2, 60, 0, 60);
|
||||||
layer2 = ges_clip_get_layer (clip1);
|
layer2 = ges_clip_get_layer (clip1);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer2), 1);
|
assert_equals_int (ges_layer_get_priority (layer2), 1);
|
||||||
/* clip2 should have moved layer too */
|
/* clip2 should have moved layer too */
|
||||||
fail_unless (ges_clip_get_layer (clip2) == layer2);
|
fail_unless (ges_clip_get_layer (clip2) == layer2);
|
||||||
/* We got 2 reference to the same clipect, unref them */
|
/* We got 2 reference to the same clipect, unref them */
|
||||||
|
@ -764,7 +761,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 35, 0, 60);
|
CHECK_OBJECT_PROPS (trackelement2, 35, 0, 60);
|
||||||
layer = ges_clip_get_layer (clip);
|
layer = ges_clip_get_layer (clip);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 2);
|
assert_equals_int (ges_layer_get_priority (layer), 2);
|
||||||
gst_object_unref (layer);
|
gst_object_unref (layer);
|
||||||
|
|
||||||
/* Roll end clip to 50
|
/* Roll end clip to 50
|
||||||
|
@ -785,7 +782,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 50, 15, 45);
|
CHECK_OBJECT_PROPS (trackelement2, 50, 15, 45);
|
||||||
layer = ges_clip_get_layer (clip);
|
layer = ges_clip_get_layer (clip);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 2);
|
assert_equals_int (ges_layer_get_priority (layer), 2);
|
||||||
gst_object_unref (layer);
|
gst_object_unref (layer);
|
||||||
|
|
||||||
/* Some more intensive roll testing */
|
/* Some more intensive roll testing */
|
||||||
|
@ -818,7 +815,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 35, 0, 60);
|
CHECK_OBJECT_PROPS (trackelement2, 35, 0, 60);
|
||||||
layer = ges_clip_get_layer (clip);
|
layer = ges_clip_get_layer (clip);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 2);
|
assert_equals_int (ges_layer_get_priority (layer), 2);
|
||||||
gst_object_unref (layer);
|
gst_object_unref (layer);
|
||||||
|
|
||||||
/* Ripple clip end to 52
|
/* Ripple clip end to 52
|
||||||
|
@ -841,7 +838,7 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
CHECK_OBJECT_PROPS (trackelement1, 20, 0, 10);
|
||||||
CHECK_OBJECT_PROPS (trackelement2, 52, 0, 60)
|
CHECK_OBJECT_PROPS (trackelement2, 52, 0, 60)
|
||||||
layer = ges_clip_get_layer (clip);
|
layer = ges_clip_get_layer (clip);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 2);
|
assert_equals_int (ges_layer_get_priority (layer), 2);
|
||||||
gst_object_unref (layer);
|
gst_object_unref (layer);
|
||||||
|
|
||||||
|
|
||||||
|
@ -889,8 +886,8 @@ GST_START_TEST (test_timeline_edition_mode)
|
||||||
/* Check that movement between layer has been done properly */
|
/* Check that movement between layer has been done properly */
|
||||||
layer1 = ges_clip_get_layer (clip);
|
layer1 = ges_clip_get_layer (clip);
|
||||||
layer = ges_clip_get_layer (clip1);
|
layer = ges_clip_get_layer (clip1);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer1), 1);
|
assert_equals_int (ges_layer_get_priority (layer1), 1);
|
||||||
assert_equals_int (ges_timeline_layer_get_priority (layer), 0);
|
assert_equals_int (ges_layer_get_priority (layer), 0);
|
||||||
fail_unless (ges_clip_get_layer (clip2) == layer);
|
fail_unless (ges_clip_get_layer (clip2) == layer);
|
||||||
gst_object_unref (layer1);
|
gst_object_unref (layer1);
|
||||||
/* We have 2 references to @layer that we do not need anymore */ ;
|
/* We have 2 references to @layer that we do not need anymore */ ;
|
||||||
|
|
|
@ -40,14 +40,14 @@ GST_START_TEST (test_title_source_properties)
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
track = ges_track_video_raw_new ();
|
track = ges_track_video_raw_new ();
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
@ -65,7 +65,7 @@ GST_START_TEST (test_title_source_properties)
|
||||||
assert_equals_uint64 (_DURATION (clip), 51);
|
assert_equals_uint64 (_DURATION (clip), 51);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -106,7 +106,7 @@ GST_END_TEST;
|
||||||
GST_START_TEST (test_title_source_in_layer)
|
GST_START_TEST (test_title_source_in_layer)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *a, *v;
|
GESTrack *a, *v;
|
||||||
GESTrackElement *track_element;
|
GESTrackElement *track_element;
|
||||||
GESTitleClip *source;
|
GESTitleClip *source;
|
||||||
|
@ -119,7 +119,7 @@ GST_START_TEST (test_title_source_in_layer)
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
a = ges_track_audio_raw_new ();
|
a = ges_track_audio_raw_new ();
|
||||||
v = ges_track_video_raw_new ();
|
v = ges_track_video_raw_new ();
|
||||||
|
|
||||||
|
@ -131,8 +131,7 @@ GST_START_TEST (test_title_source_in_layer)
|
||||||
|
|
||||||
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
g_object_set (source, "duration", (guint64) GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) layer,
|
ges_simple_layer_add_object ((GESSimpleLayer *) layer, (GESClip *) source, 0);
|
||||||
(GESClip *) source, 0);
|
|
||||||
|
|
||||||
/* specifically test the text property */
|
/* specifically test the text property */
|
||||||
g_object_set (source, "text", (gchar *) "some text", NULL);
|
g_object_set (source, "text", (gchar *) "some text", NULL);
|
||||||
|
@ -194,7 +193,7 @@ GST_START_TEST (test_title_source_in_layer)
|
||||||
|
|
||||||
GST_DEBUG ("removing the source");
|
GST_DEBUG ("removing the source");
|
||||||
|
|
||||||
ges_timeline_layer_remove_clip (layer, (GESClip *) source);
|
ges_layer_remove_clip (layer, (GESClip *) source);
|
||||||
|
|
||||||
GST_DEBUG ("removing the layer");
|
GST_DEBUG ("removing the layer");
|
||||||
|
|
||||||
|
|
|
@ -29,14 +29,14 @@ GST_START_TEST (test_transition_basic)
|
||||||
{
|
{
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTransitionClip *tr1, *tr2;
|
GESTransitionClip *tr1, *tr2;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
|
||||||
track = ges_track_video_raw_new ();
|
track = ges_track_video_raw_new ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
|
@ -54,7 +54,7 @@ GST_START_TEST (test_transition_basic)
|
||||||
fail_unless (tr2->vtype == 1);
|
fail_unless (tr2->vtype == 1);
|
||||||
|
|
||||||
/* Make sure track element is created and vtype is set */
|
/* Make sure track element is created and vtype is set */
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (tr2)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (tr2)));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (tr2)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (tr2)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (tr2)->data;
|
trackelement = GES_CONTAINER_CHILDREN (tr2)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -71,7 +71,7 @@ GST_START_TEST (test_transition_properties)
|
||||||
GESClip *clip;
|
GESClip *clip;
|
||||||
GESTrack *track;
|
GESTrack *track;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -80,7 +80,7 @@ GST_START_TEST (test_transition_properties)
|
||||||
(GES_VIDEO_STANDARD_TRANSITION_TYPE_CROSSFADE));
|
(GES_VIDEO_STANDARD_TRANSITION_TYPE_CROSSFADE));
|
||||||
|
|
||||||
track = ges_track_video_raw_new ();
|
track = ges_track_video_raw_new ();
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
|
@ -97,7 +97,7 @@ GST_START_TEST (test_transition_properties)
|
||||||
assert_equals_uint64 (_DURATION (clip), 51);
|
assert_equals_uint64 (_DURATION (clip), 51);
|
||||||
assert_equals_uint64 (_INPOINT (clip), 12);
|
assert_equals_uint64 (_INPOINT (clip), 12);
|
||||||
|
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (clip)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (clip)));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (trackelement != NULL);
|
fail_unless (trackelement != NULL);
|
||||||
|
@ -146,11 +146,11 @@ GST_START_TEST (test_transition_properties)
|
||||||
|
|
||||||
GST_DEBUG ("Removing clip from layer");
|
GST_DEBUG ("Removing clip from layer");
|
||||||
gst_object_ref (clip); /* We do not want it to be destroyed */
|
gst_object_ref (clip); /* We do not want it to be destroyed */
|
||||||
ges_timeline_layer_remove_clip (layer, clip);
|
ges_layer_remove_clip (layer, clip);
|
||||||
|
|
||||||
g_object_set (clip, "vtype", 1, NULL);
|
g_object_set (clip, "vtype", 1, NULL);
|
||||||
GST_DEBUG ("Read it to the layer");
|
GST_DEBUG ("Read it to the layer");
|
||||||
fail_unless (ges_timeline_layer_add_clip (layer, GES_CLIP (clip)));
|
fail_unless (ges_layer_add_clip (layer, GES_CLIP (clip)));
|
||||||
g_object_unref (clip);
|
g_object_unref (clip);
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
trackelement = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
|
|
|
@ -40,7 +40,7 @@ asset_created_cb (GObject * source, GAsyncResult * res, gpointer udata)
|
||||||
{
|
{
|
||||||
GList *tracks, *tmp;
|
GList *tracks, *tmp;
|
||||||
GESAsset *asset;
|
GESAsset *asset;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESUriClip *tlfs;
|
GESUriClip *tlfs;
|
||||||
|
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
|
@ -51,8 +51,8 @@ asset_created_cb (GObject * source, GAsyncResult * res, gpointer udata)
|
||||||
fail_if (asset == NULL);
|
fail_if (asset == NULL);
|
||||||
fail_if (g_strcmp0 (ges_asset_get_id (asset), av_uri));
|
fail_if (g_strcmp0 (ges_asset_get_id (asset), av_uri));
|
||||||
|
|
||||||
layer = GES_TIMELINE_LAYER (g_async_result_get_user_data (res));
|
layer = GES_LAYER (g_async_result_get_user_data (res));
|
||||||
tlfs = GES_URI_CLIP (ges_timeline_layer_add_asset (layer,
|
tlfs = GES_URI_CLIP (ges_layer_add_asset (layer,
|
||||||
asset, 0, 0, GST_CLOCK_TIME_NONE, GES_TRACK_TYPE_UNKNOWN));
|
asset, 0, 0, GST_CLOCK_TIME_NONE, GES_TRACK_TYPE_UNKNOWN));
|
||||||
fail_unless (GES_IS_URI_CLIP (tlfs));
|
fail_unless (GES_IS_URI_CLIP (tlfs));
|
||||||
fail_if (g_strcmp0 (ges_uri_clip_get_uri (tlfs), av_uri));
|
fail_if (g_strcmp0 (ges_uri_clip_get_uri (tlfs), av_uri));
|
||||||
|
@ -63,7 +63,7 @@ asset_created_cb (GObject * source, GAsyncResult * res, gpointer udata)
|
||||||
fail_unless (ges_clip_get_supported_formats
|
fail_unless (ges_clip_get_supported_formats
|
||||||
(GES_CLIP (tlfs)) & GES_TRACK_TYPE_AUDIO);
|
(GES_CLIP (tlfs)) & GES_TRACK_TYPE_AUDIO);
|
||||||
|
|
||||||
tracks = ges_timeline_get_tracks (ges_timeline_layer_get_timeline (layer));
|
tracks = ges_timeline_get_tracks (ges_layer_get_timeline (layer));
|
||||||
for (tmp = tracks; tmp; tmp = tmp->next) {
|
for (tmp = tracks; tmp; tmp = tmp->next) {
|
||||||
GList *trackelements = ges_track_get_elements (GES_TRACK (tmp->data));
|
GList *trackelements = ges_track_get_elements (GES_TRACK (tmp->data));
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ asset_created_cb (GObject * source, GAsyncResult * res, gpointer udata)
|
||||||
GST_START_TEST (test_filesource_basic)
|
GST_START_TEST (test_filesource_basic)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
|
|
||||||
fail_unless (ges_init ());
|
fail_unless (ges_init ());
|
||||||
|
|
||||||
|
@ -89,7 +89,7 @@ GST_START_TEST (test_filesource_basic)
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
fail_unless (ges_timeline_add_layer (timeline, layer));
|
fail_unless (ges_timeline_add_layer (timeline, layer));
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ GST_START_TEST (test_filesource_properties)
|
||||||
AssetUri asset_uri;
|
AssetUri asset_uri;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESUriClipAsset *asset;
|
GESUriClipAsset *asset;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *trackelement;
|
GESTrackElement *trackelement;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -128,7 +128,7 @@ GST_START_TEST (test_filesource_properties)
|
||||||
track = ges_track_new (GES_TRACK_TYPE_AUDIO, GST_CAPS_ANY);
|
track = ges_track_new (GES_TRACK_TYPE_AUDIO, GST_CAPS_ANY);
|
||||||
fail_unless (track != NULL);
|
fail_unless (track != NULL);
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (GES_IS_TIMELINE (timeline));
|
fail_unless (GES_IS_TIMELINE (timeline));
|
||||||
|
@ -144,7 +144,7 @@ GST_START_TEST (test_filesource_properties)
|
||||||
|
|
||||||
asset = GES_URI_CLIP_ASSET (asset_uri.asset);
|
asset = GES_URI_CLIP_ASSET (asset_uri.asset);
|
||||||
fail_unless (GES_IS_ASSET (asset));
|
fail_unless (GES_IS_ASSET (asset));
|
||||||
clip = ges_timeline_layer_add_asset (layer, GES_ASSET (asset),
|
clip = ges_layer_add_asset (layer, GES_ASSET (asset),
|
||||||
42, 12, 51, GES_TRACK_TYPE_AUDIO);
|
42, 12, 51, GES_TRACK_TYPE_AUDIO);
|
||||||
assert_is_type (clip, GES_TYPE_URI_CLIP);
|
assert_is_type (clip, GES_TYPE_URI_CLIP);
|
||||||
assert_equals_uint64 (_START (clip), 42);
|
assert_equals_uint64 (_START (clip), 42);
|
||||||
|
@ -205,7 +205,7 @@ GST_START_TEST (test_filesource_images)
|
||||||
GESUriClip *uriclip;
|
GESUriClip *uriclip;
|
||||||
AssetUri asset_uri;
|
AssetUri asset_uri;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrackElement *track_element;
|
GESTrackElement *track_element;
|
||||||
|
|
||||||
ges_init ();
|
ges_init ();
|
||||||
|
@ -213,7 +213,7 @@ GST_START_TEST (test_filesource_images)
|
||||||
a = ges_track_audio_raw_new ();
|
a = ges_track_audio_raw_new ();
|
||||||
v = ges_track_video_raw_new ();
|
v = ges_track_video_raw_new ();
|
||||||
|
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
fail_unless (layer != NULL);
|
fail_unless (layer != NULL);
|
||||||
timeline = ges_timeline_new ();
|
timeline = ges_timeline_new ();
|
||||||
fail_unless (timeline != NULL);
|
fail_unless (timeline != NULL);
|
||||||
|
@ -242,7 +242,7 @@ GST_START_TEST (test_filesource_images)
|
||||||
|
|
||||||
/* the returned track element should be an image source */
|
/* the returned track element should be an image source */
|
||||||
/* the clip should not create any TrackElement in the audio track */
|
/* the clip should not create any TrackElement in the audio track */
|
||||||
ges_timeline_layer_add_clip (layer, GES_CLIP (clip));
|
ges_layer_add_clip (layer, GES_CLIP (clip));
|
||||||
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
assert_equals_int (g_list_length (GES_CONTAINER_CHILDREN (clip)), 1);
|
||||||
track_element = GES_CONTAINER_CHILDREN (clip)->data;
|
track_element = GES_CONTAINER_CHILDREN (clip)->data;
|
||||||
fail_unless (track_element != NULL);
|
fail_unless (track_element != NULL);
|
||||||
|
|
|
@ -71,7 +71,7 @@ main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
GMainLoop *mainloop = NULL;
|
GMainLoop *mainloop = NULL;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelineLayer *layer = NULL;
|
GESLayer *layer = NULL;
|
||||||
GstBus *bus = NULL;
|
GstBus *bus = NULL;
|
||||||
guint i;
|
guint i;
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ main (int argc, char **argv)
|
||||||
|
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
|
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
if (!ges_timeline_add_layer (timeline, layer))
|
if (!ges_timeline_add_layer (timeline, layer))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ typedef struct App
|
||||||
/* back-end objects */
|
/* back-end objects */
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *audio_track;
|
GESTrack *audio_track;
|
||||||
GESTrack *video_track;
|
GESTrack *video_track;
|
||||||
guint audio_tracks;
|
guint audio_tracks;
|
||||||
|
@ -339,7 +339,7 @@ title_source_text_changed_cb (GESClip * clip,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_object_added_cb (GESTimelineLayer * layer, GESClip * clip, App * app)
|
layer_object_added_cb (GESLayer * layer, GESClip * clip, App * app)
|
||||||
{
|
{
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
gchar *description;
|
gchar *description;
|
||||||
|
@ -377,7 +377,7 @@ layer_object_added_cb (GESTimelineLayer * layer, GESClip * clip, App * app)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_object_removed_cb (GESTimelineLayer * layer, GESClip * clip, App * app)
|
layer_object_removed_cb (GESLayer * layer, GESClip * clip, App * app)
|
||||||
{
|
{
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
|
|
||||||
|
@ -742,11 +742,11 @@ get_video_patterns (void)
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
layer_added_cb (GESTimeline * timeline, GESTimelineLayer * layer, App * app)
|
layer_added_cb (GESTimeline * timeline, GESLayer * layer, App * app)
|
||||||
{
|
{
|
||||||
if (!GES_IS_SIMPLE_TIMELINE_LAYER (layer)) {
|
if (!GES_IS_SIMPLE_LAYER (layer)) {
|
||||||
GST_ERROR ("This timeline contains a layer type other than "
|
GST_ERROR ("This timeline contains a layer type other than "
|
||||||
"GESSimpleTimelineLayer. Timeline editing disabled");
|
"GESSimpleLayer. Timeline editing disabled");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1041,7 +1041,7 @@ app_delete_objects (App * app, GList * objects)
|
||||||
GList *cur;
|
GList *cur;
|
||||||
|
|
||||||
for (cur = objects; cur; cur = cur->next) {
|
for (cur = objects; cur; cur = cur->next) {
|
||||||
ges_timeline_layer_remove_clip (app->layer, GES_CLIP (cur->data));
|
ges_layer_remove_clip (app->layer, GES_CLIP (cur->data));
|
||||||
cur->data = NULL;
|
cur->data = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1057,10 +1057,10 @@ app_move_selected_up (App * app)
|
||||||
GList *objects, *tmp;
|
GList *objects, *tmp;
|
||||||
gint pos;
|
gint pos;
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (app->layer);
|
objects = ges_layer_get_clips (app->layer);
|
||||||
pos = g_list_index (objects, app->selected_objects->data);
|
pos = g_list_index (objects, app->selected_objects->data);
|
||||||
|
|
||||||
ges_simple_timeline_layer_move_object (GES_SIMPLE_TIMELINE_LAYER (app->layer),
|
ges_simple_layer_move_object (GES_SIMPLE_LAYER (app->layer),
|
||||||
GES_CLIP (app->selected_objects->data), pos - 1);
|
GES_CLIP (app->selected_objects->data), pos - 1);
|
||||||
|
|
||||||
for (tmp = objects; tmp; tmp = tmp->next) {
|
for (tmp = objects; tmp; tmp = tmp->next) {
|
||||||
|
@ -1076,7 +1076,7 @@ app_add_effect_on_selected_clips (App * app, const gchar * bin_desc)
|
||||||
|
|
||||||
/* No crash if the video is playing */
|
/* No crash if the video is playing */
|
||||||
gst_element_set_state (GST_ELEMENT (app->pipeline), GST_STATE_PAUSED);
|
gst_element_set_state (GST_ELEMENT (app->pipeline), GST_STATE_PAUSED);
|
||||||
objects = ges_timeline_layer_get_clips (app->layer);
|
objects = ges_layer_get_clips (app->layer);
|
||||||
|
|
||||||
for (tmp = objects; tmp; tmp = tmp->next) {
|
for (tmp = objects; tmp; tmp = tmp->next) {
|
||||||
effect = GES_TRACK_ELEMENT (ges_effect_new (bin_desc));
|
effect = GES_TRACK_ELEMENT (ges_effect_new (bin_desc));
|
||||||
|
@ -1126,10 +1126,10 @@ app_move_selected_down (App * app)
|
||||||
GList *objects, *tmp;
|
GList *objects, *tmp;
|
||||||
gint pos;
|
gint pos;
|
||||||
|
|
||||||
objects = ges_timeline_layer_get_clips (app->layer);
|
objects = ges_layer_get_clips (app->layer);
|
||||||
pos = g_list_index (objects, app->selected_objects->data);
|
pos = g_list_index (objects, app->selected_objects->data);
|
||||||
|
|
||||||
ges_simple_timeline_layer_move_object (GES_SIMPLE_TIMELINE_LAYER (app->layer),
|
ges_simple_layer_move_object (GES_SIMPLE_LAYER (app->layer),
|
||||||
GES_CLIP (app->selected_objects->data), pos - 1);
|
GES_CLIP (app->selected_objects->data), pos - 1);
|
||||||
|
|
||||||
for (tmp = objects; tmp; tmp = tmp->next) {
|
for (tmp = objects; tmp; tmp = tmp->next) {
|
||||||
|
@ -1146,8 +1146,7 @@ app_add_file (App * app, gchar * uri)
|
||||||
|
|
||||||
clip = GES_CLIP (ges_uri_clip_new (uri));
|
clip = GES_CLIP (ges_uri_clip_new (uri));
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER (app->layer),
|
ges_simple_layer_add_object (GES_SIMPLE_LAYER (app->layer), clip, -1);
|
||||||
clip, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1187,8 +1186,7 @@ app_add_title (App * app)
|
||||||
clip = GES_CLIP (ges_title_clip_new ());
|
clip = GES_CLIP (ges_title_clip_new ());
|
||||||
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER (app->layer),
|
ges_simple_layer_add_object (GES_SIMPLE_LAYER (app->layer), clip, -1);
|
||||||
clip, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1201,8 +1199,7 @@ app_add_test (App * app)
|
||||||
clip = GES_CLIP (ges_test_clip_new ());
|
clip = GES_CLIP (ges_test_clip_new ());
|
||||||
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER
|
ges_simple_layer_add_object (GES_SIMPLE_LAYER (app->layer), clip, -1);
|
||||||
(app->layer), clip, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1216,8 +1213,7 @@ app_add_transition (App * app)
|
||||||
(GES_VIDEO_STANDARD_TRANSITION_TYPE_CROSSFADE));
|
(GES_VIDEO_STANDARD_TRANSITION_TYPE_CROSSFADE));
|
||||||
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
g_object_set (G_OBJECT (clip), "duration", GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object (GES_SIMPLE_TIMELINE_LAYER
|
ges_simple_layer_add_object (GES_SIMPLE_LAYER (app->layer), clip, -1);
|
||||||
(app->layer), clip, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1338,7 +1334,7 @@ app_new (void)
|
||||||
if (!(ges_timeline_add_track (ret->timeline, v)))
|
if (!(ges_timeline_add_track (ret->timeline, v)))
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if (!(ret->layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ()))
|
if (!(ret->layer = (GESLayer *) ges_simple_layer_new ()))
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if (!(ges_timeline_add_layer (ret->timeline, ret->layer)))
|
if (!(ges_timeline_add_layer (ret->timeline, ret->layer)))
|
||||||
|
|
|
@ -81,7 +81,7 @@ make_timeline (char *path, float duration, char *text, guint32 color,
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *trackv, *tracka;
|
GESTrack *trackv, *tracka;
|
||||||
GESTimelineLayer *layer1;
|
GESLayer *layer1;
|
||||||
GESClip *srca;
|
GESClip *srca;
|
||||||
GESClip *overlay;
|
GESClip *overlay;
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
|
@ -100,7 +100,7 @@ make_timeline (char *path, float duration, char *text, guint32 color,
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
ges_timeline_add_track (timeline, tracka);
|
ges_timeline_add_track (timeline, tracka);
|
||||||
|
|
||||||
layer1 = GES_TIMELINE_LAYER (ges_timeline_layer_new ());
|
layer1 = GES_LAYER (ges_layer_new ());
|
||||||
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
||||||
|
|
||||||
if (!ges_timeline_add_layer (timeline, layer1))
|
if (!ges_timeline_add_layer (timeline, layer1))
|
||||||
|
@ -109,8 +109,8 @@ make_timeline (char *path, float duration, char *text, guint32 color,
|
||||||
aduration = (guint64) (duration * GST_SECOND);
|
aduration = (guint64) (duration * GST_SECOND);
|
||||||
srca = make_source (path, 0, aduration, 1);
|
srca = make_source (path, 0, aduration, 1);
|
||||||
overlay = make_overlay (text, 0, aduration, 0, color, xpos, ypos);
|
overlay = make_overlay (text, 0, aduration, 0, color, xpos, ypos);
|
||||||
ges_timeline_layer_add_clip (layer1, srca);
|
ges_layer_add_clip (layer1, srca);
|
||||||
ges_timeline_layer_add_clip (layer1, overlay);
|
ges_layer_add_clip (layer1, overlay);
|
||||||
|
|
||||||
return pipeline;
|
return pipeline;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ main (int argc, gchar ** argv)
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *tracka, *trackv;
|
GESTrack *tracka, *trackv;
|
||||||
GESTimelineLayer *layer1, *layer2;
|
GESLayer *layer1, *layer2;
|
||||||
GESUriClip *src;
|
GESUriClip *src;
|
||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
|
|
||||||
|
@ -76,8 +76,8 @@ main (int argc, gchar ** argv)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
trackv = ges_track_video_raw_new ();
|
trackv = ges_track_video_raw_new ();
|
||||||
|
|
||||||
layer1 = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer1 = (GESLayer *) ges_simple_layer_new ();
|
||||||
layer2 = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer2 = (GESLayer *) ges_simple_layer_new ();
|
||||||
g_object_set (layer2, "priority", 1, NULL);
|
g_object_set (layer2, "priority", 1, NULL);
|
||||||
|
|
||||||
if (!ges_timeline_add_layer (timeline, layer1) ||
|
if (!ges_timeline_add_layer (timeline, layer1) ||
|
||||||
|
@ -94,7 +94,7 @@ main (int argc, gchar ** argv)
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
g_object_set (src, "in-point", inpoint * GST_SECOND,
|
g_object_set (src, "in-point", inpoint * GST_SECOND,
|
||||||
"duration", duration * GST_SECOND, "mute", mute, NULL);
|
"duration", duration * GST_SECOND, "mute", mute, NULL);
|
||||||
ges_timeline_layer_add_clip (layer1, GES_CLIP (src));
|
ges_layer_add_clip (layer1, GES_CLIP (src));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Play the pipeline */
|
/* Play the pipeline */
|
||||||
|
|
|
@ -27,7 +27,7 @@ main (int argc, gchar ** argv)
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESClip *source;
|
GESClip *source;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
|
|
||||||
/* Initialize GStreamer (this will parse environment variables and commandline
|
/* Initialize GStreamer (this will parse environment variables and commandline
|
||||||
|
@ -43,7 +43,7 @@ main (int argc, gchar ** argv)
|
||||||
timeline = ges_timeline_new_audio_video ();
|
timeline = ges_timeline_new_audio_video ();
|
||||||
|
|
||||||
/* We are only going to be doing one layer of clips */
|
/* We are only going to be doing one layer of clips */
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer))
|
if (!ges_timeline_add_layer (timeline, layer))
|
||||||
|
@ -53,12 +53,12 @@ main (int argc, gchar ** argv)
|
||||||
src_asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
src_asset = ges_asset_request (GES_TYPE_TEST_CLIP, NULL, NULL);
|
||||||
|
|
||||||
/* Add sources to our layer */
|
/* Add sources to our layer */
|
||||||
ges_timeline_layer_add_asset (layer, src_asset, 0, 0, GST_SECOND,
|
ges_layer_add_asset (layer, src_asset, 0, 0, GST_SECOND,
|
||||||
GES_TRACK_TYPE_UNKNOWN);
|
GES_TRACK_TYPE_UNKNOWN);
|
||||||
source = ges_timeline_layer_add_asset (layer, src_asset, GST_SECOND, 0,
|
source = ges_layer_add_asset (layer, src_asset, GST_SECOND, 0,
|
||||||
GST_SECOND, GES_TRACK_TYPE_UNKNOWN);
|
GST_SECOND, GES_TRACK_TYPE_UNKNOWN);
|
||||||
g_object_set (source, "freq", 480.0, "vpattern", 2, NULL);
|
g_object_set (source, "freq", 480.0, "vpattern", 2, NULL);
|
||||||
ges_timeline_layer_add_asset (layer, src_asset, 2 * GST_SECOND, 0,
|
ges_layer_add_asset (layer, src_asset, 2 * GST_SECOND, 0,
|
||||||
GST_SECOND, GES_TRACK_TYPE_UNKNOWN);
|
GST_SECOND, GES_TRACK_TYPE_UNKNOWN);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ main (int argc, gchar ** argv)
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *tracka;
|
GESTrack *tracka;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
GstClockTime offset = 0;
|
GstClockTime offset = 0;
|
||||||
guint i;
|
guint i;
|
||||||
|
@ -50,7 +50,7 @@ main (int argc, gchar ** argv)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
|
|
||||||
/* We are only going to be doing one layer of clips */
|
/* We are only going to be doing one layer of clips */
|
||||||
layer = ges_timeline_layer_new ();
|
layer = ges_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer))
|
if (!ges_timeline_add_layer (timeline, layer))
|
||||||
|
@ -70,7 +70,7 @@ main (int argc, gchar ** argv)
|
||||||
|
|
||||||
g_object_set (src, "start", offset, "duration", GST_SECOND, NULL);
|
g_object_set (src, "start", offset, "duration", GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_timeline_layer_add_clip (layer, (GESClip *) src);
|
ges_layer_add_clip (layer, (GESClip *) src);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In order to listen our timeline, let's grab a convenience pipeline to put
|
/* In order to listen our timeline, let's grab a convenience pipeline to put
|
||||||
|
|
|
@ -25,7 +25,7 @@ main (int argc, gchar ** argv)
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *tracka;
|
GESTrack *tracka;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
guint i;
|
guint i;
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ main (int argc, gchar ** argv)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
|
|
||||||
/* We are only going to be doing one layer of clips */
|
/* We are only going to be doing one layer of clips */
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer))
|
if (!ges_timeline_add_layer (timeline, layer))
|
||||||
|
@ -68,9 +68,9 @@ main (int argc, gchar ** argv)
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
|
|
||||||
g_object_set (src, "duration", GST_SECOND, NULL);
|
g_object_set (src, "duration", GST_SECOND, NULL);
|
||||||
/* Since we're using a GESSimpleTimelineLayer, objects will be automatically
|
/* Since we're using a GESSimpleLayer, objects will be automatically
|
||||||
* appended to the end of the layer */
|
* appended to the end of the layer */
|
||||||
ges_timeline_layer_add_clip (layer, (GESClip *) src);
|
ges_layer_add_clip (layer, (GESClip *) src);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In order to view our timeline, let's grab a convenience pipeline to put
|
/* In order to view our timeline, let's grab a convenience pipeline to put
|
||||||
|
|
|
@ -57,7 +57,7 @@ main (int argc, gchar ** argv)
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *tracka;
|
GESTrack *tracka;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GMainLoop *mainloop;
|
GMainLoop *mainloop;
|
||||||
GstEncodingProfile *profile;
|
GstEncodingProfile *profile;
|
||||||
gchar *container = (gchar *) "application/ogg";
|
gchar *container = (gchar *) "application/ogg";
|
||||||
|
@ -104,7 +104,7 @@ main (int argc, gchar ** argv)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
|
|
||||||
/* We are only going to be doing one layer of clips */
|
/* We are only going to be doing one layer of clips */
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer))
|
if (!ges_timeline_add_layer (timeline, layer))
|
||||||
|
@ -123,9 +123,9 @@ main (int argc, gchar ** argv)
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
|
|
||||||
g_object_set (src, "duration", GST_SECOND, NULL);
|
g_object_set (src, "duration", GST_SECOND, NULL);
|
||||||
/* Since we're using a GESSimpleTimelineLayer, objects will be automatically
|
/* Since we're using a GESSimpleLayer, objects will be automatically
|
||||||
* appended to the end of the layer */
|
* appended to the end of the layer */
|
||||||
ges_timeline_layer_add_clip (layer, (GESClip *) src);
|
ges_layer_add_clip (layer, (GESClip *) src);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In order to view our timeline, let's grab a convenience pipeline to put
|
/* In order to view our timeline, let's grab a convenience pipeline to put
|
||||||
|
|
|
@ -55,7 +55,7 @@ make_timeline (char *path, float duration, char *text)
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *trackv, *tracka;
|
GESTrack *trackv, *tracka;
|
||||||
GESTimelineLayer *layer1;
|
GESLayer *layer1;
|
||||||
GESClip *srca;
|
GESClip *srca;
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
guint64 aduration;
|
guint64 aduration;
|
||||||
|
@ -73,7 +73,7 @@ make_timeline (char *path, float duration, char *text)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
ges_timeline_add_track (timeline, tracka);
|
ges_timeline_add_track (timeline, tracka);
|
||||||
|
|
||||||
layer1 = GES_TIMELINE_LAYER (ges_timeline_layer_new ());
|
layer1 = GES_LAYER (ges_layer_new ());
|
||||||
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
||||||
|
|
||||||
if (!ges_timeline_add_layer (timeline, layer1))
|
if (!ges_timeline_add_layer (timeline, layer1))
|
||||||
|
@ -81,7 +81,7 @@ make_timeline (char *path, float duration, char *text)
|
||||||
|
|
||||||
aduration = (guint64) (duration * GST_SECOND);
|
aduration = (guint64) (duration * GST_SECOND);
|
||||||
srca = make_source (path, 0, aduration, 1, text);
|
srca = make_source (path, 0, aduration, 1, text);
|
||||||
ges_timeline_layer_add_clip (layer1, srca);
|
ges_layer_add_clip (layer1, srca);
|
||||||
|
|
||||||
return pipeline;
|
return pipeline;
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,7 +73,7 @@ static GESTimelinePipeline *
|
||||||
create_timeline (void)
|
create_timeline (void)
|
||||||
{
|
{
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *tracka, *trackv;
|
GESTrack *tracka, *trackv;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESClip *src;
|
GESClip *src;
|
||||||
|
@ -83,7 +83,7 @@ create_timeline (void)
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
trackv = ges_track_video_raw_new ();
|
trackv = ges_track_video_raw_new ();
|
||||||
|
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer) ||
|
if (!ges_timeline_add_layer (timeline, layer) ||
|
||||||
|
@ -97,8 +97,7 @@ create_timeline (void)
|
||||||
"vpattern", GES_VIDEO_TEST_PATTERN_SNOW,
|
"vpattern", GES_VIDEO_TEST_PATTERN_SNOW,
|
||||||
"duration", 10 * GST_SECOND, NULL);
|
"duration", 10 * GST_SECOND, NULL);
|
||||||
|
|
||||||
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) layer,
|
ges_simple_layer_add_object ((GESSimpleLayer *) layer, GES_CLIP (src), 0);
|
||||||
GES_CLIP (src), 0);
|
|
||||||
|
|
||||||
pipeline = ges_timeline_pipeline_new ();
|
pipeline = ges_timeline_pipeline_new ();
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,7 @@ make_timeline (gchar * nick, gdouble tdur, gchar * patha, gfloat adur,
|
||||||
{
|
{
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
GESTrack *trackv, *tracka;
|
GESTrack *trackv, *tracka;
|
||||||
GESTimelineLayer *layer1;
|
GESLayer *layer1;
|
||||||
GESClip *srca, *srcb;
|
GESClip *srca, *srcb;
|
||||||
GESTimelinePipeline *pipeline;
|
GESTimelinePipeline *pipeline;
|
||||||
guint64 aduration, bduration, tduration, tstart, ainpoint, binpoint;
|
guint64 aduration, bduration, tduration, tstart, ainpoint, binpoint;
|
||||||
|
@ -108,7 +108,7 @@ make_timeline (gchar * nick, gdouble tdur, gchar * patha, gfloat adur,
|
||||||
tracka = ges_track_audio_raw_new ();
|
tracka = ges_track_audio_raw_new ();
|
||||||
ges_timeline_add_track (timeline, tracka);
|
ges_timeline_add_track (timeline, tracka);
|
||||||
|
|
||||||
layer1 = GES_TIMELINE_LAYER (ges_timeline_layer_new ());
|
layer1 = GES_LAYER (ges_layer_new ());
|
||||||
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
g_object_set (layer1, "priority", (gint32) 0, NULL);
|
||||||
|
|
||||||
if (!ges_timeline_add_layer (timeline, layer1))
|
if (!ges_timeline_add_layer (timeline, layer1))
|
||||||
|
@ -122,8 +122,8 @@ make_timeline (gchar * nick, gdouble tdur, gchar * patha, gfloat adur,
|
||||||
tstart = aduration - tduration;
|
tstart = aduration - tduration;
|
||||||
srca = make_source (patha, 0, aduration, ainpoint, 1);
|
srca = make_source (patha, 0, aduration, ainpoint, 1);
|
||||||
srcb = make_source (pathb, tstart, bduration, binpoint, 2);
|
srcb = make_source (pathb, tstart, bduration, binpoint, 2);
|
||||||
ges_timeline_layer_add_clip (layer1, srca);
|
ges_layer_add_clip (layer1, srca);
|
||||||
ges_timeline_layer_add_clip (layer1, srcb);
|
ges_layer_add_clip (layer1, srcb);
|
||||||
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, srca);
|
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, srca);
|
||||||
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, srcb);
|
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, srcb);
|
||||||
|
|
||||||
|
@ -137,7 +137,7 @@ make_timeline (gchar * nick, gdouble tdur, gchar * patha, gfloat adur,
|
||||||
g_object_set (tr,
|
g_object_set (tr,
|
||||||
"start", (guint64) tstart,
|
"start", (guint64) tstart,
|
||||||
"duration", (guint64) tduration, "in-point", (guint64) 0, NULL);
|
"duration", (guint64) tduration, "in-point", (guint64) 0, NULL);
|
||||||
ges_timeline_layer_add_clip (layer1, GES_CLIP (tr));
|
ges_layer_add_clip (layer1, GES_CLIP (tr));
|
||||||
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, tr);
|
g_timeout_add_seconds (1, (GSourceFunc) print_transition_data, tr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -128,7 +128,7 @@ make_encoding_profile (gchar * audio, gchar * video, gchar * video_restriction,
|
||||||
static GESTimeline *
|
static GESTimeline *
|
||||||
create_timeline (int nbargs, gchar ** argv, gchar * audio, gchar * video)
|
create_timeline (int nbargs, gchar ** argv, gchar * audio, gchar * video)
|
||||||
{
|
{
|
||||||
GESTimelineLayer *layer;
|
GESLayer *layer;
|
||||||
GESTrack *tracka = NULL, *trackv = NULL;
|
GESTrack *tracka = NULL, *trackv = NULL;
|
||||||
GESTimeline *timeline;
|
GESTimeline *timeline;
|
||||||
guint i;
|
guint i;
|
||||||
|
@ -141,7 +141,7 @@ create_timeline (int nbargs, gchar ** argv, gchar * audio, gchar * video)
|
||||||
trackv = ges_track_video_raw_new ();
|
trackv = ges_track_video_raw_new ();
|
||||||
|
|
||||||
/* We are only going to be doing one layer of clips */
|
/* We are only going to be doing one layer of clips */
|
||||||
layer = (GESTimelineLayer *) ges_simple_timeline_layer_new ();
|
layer = (GESLayer *) ges_simple_layer_new ();
|
||||||
|
|
||||||
/* Add the tracks and the layer to the timeline */
|
/* Add the tracks and the layer to the timeline */
|
||||||
if (!ges_timeline_add_layer (timeline, layer) ||
|
if (!ges_timeline_add_layer (timeline, layer) ||
|
||||||
|
@ -222,9 +222,9 @@ create_timeline (int nbargs, gchar ** argv, gchar * audio, gchar * video)
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Since we're using a GESSimpleTimelineLayer, objects will be automatically
|
/* Since we're using a GESSimpleLayer, objects will be automatically
|
||||||
* appended to the end of the layer */
|
* appended to the end of the layer */
|
||||||
ges_timeline_layer_add_clip (layer, clip);
|
ges_layer_add_clip (layer, clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
return timeline;
|
return timeline;
|
||||||
|
|
Loading…
Reference in a new issue