2009-08-04 15:13:11 +00:00
|
|
|
/* GStreamer Editing Services
|
2009-11-30 14:14:25 +00:00
|
|
|
* Copyright (C) 2009 Edward Hervey <edward.hervey@collabora.co.uk>
|
|
|
|
* 2009 Nokia Corporation
|
2009-08-04 15:13:11 +00:00
|
|
|
*
|
|
|
|
* 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., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _GES_TIMELINE_OBJECT
|
|
|
|
#define _GES_TIMELINE_OBJECT
|
|
|
|
|
|
|
|
#include <glib-object.h>
|
2009-08-06 15:38:43 +00:00
|
|
|
#include <gst/gst.h>
|
2009-08-06 10:14:37 +00:00
|
|
|
#include <ges/ges-types.h>
|
2011-12-01 03:18:30 +00:00
|
|
|
#include <ges/ges-track.h>
|
2009-08-04 15:13:11 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
#define GES_TYPE_TIMELINE_OBJECT ges_timeline_object_get_type()
|
|
|
|
|
|
|
|
#define GES_TIMELINE_OBJECT(obj) \
|
|
|
|
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_TIMELINE_OBJECT, GESTimelineObject))
|
|
|
|
|
|
|
|
#define GES_TIMELINE_OBJECT_CLASS(klass) \
|
|
|
|
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_TIMELINE_OBJECT, GESTimelineObjectClass))
|
|
|
|
|
|
|
|
#define GES_IS_TIMELINE_OBJECT(obj) \
|
|
|
|
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_TIMELINE_OBJECT))
|
|
|
|
|
|
|
|
#define GES_IS_TIMELINE_OBJECT_CLASS(klass) \
|
|
|
|
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_TIMELINE_OBJECT))
|
|
|
|
|
|
|
|
#define GES_TIMELINE_OBJECT_GET_CLASS(obj) \
|
|
|
|
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_TIMELINE_OBJECT, GESTimelineObjectClass))
|
|
|
|
|
2010-11-28 12:24:07 +00:00
|
|
|
typedef struct _GESTimelineObjectPrivate GESTimelineObjectPrivate;
|
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
2010-12-15 12:27:39 +00:00
|
|
|
* GESFillTrackObjectFunc:
|
2009-09-16 10:37:45 +00:00
|
|
|
* @object: the #GESTimelineObject controlling the track object
|
|
|
|
* @trobject: the #GESTrackObject
|
|
|
|
* @gnlobj: the GNonLin object that needs to be filled.
|
|
|
|
*
|
|
|
|
* A function that will be called when the GNonLin object of a corresponding
|
|
|
|
* track object needs to be filled.
|
|
|
|
*
|
|
|
|
* The implementer of this function shall add the proper #GstElement to @gnlobj
|
|
|
|
* using gst_bin_add().
|
|
|
|
*
|
|
|
|
* Returns: TRUE if the implementer succesfully filled the @gnlobj, else #FALSE.
|
|
|
|
*/
|
2010-12-15 12:27:39 +00:00
|
|
|
typedef gboolean (*GESFillTrackObjectFunc) (GESTimelineObject * object,
|
2010-11-28 12:24:07 +00:00
|
|
|
GESTrackObject * trobject,
|
|
|
|
GstElement * gnlobj);
|
2009-08-07 14:39:45 +00:00
|
|
|
|
2010-05-18 10:56:24 +00:00
|
|
|
/**
|
2010-12-15 18:18:42 +00:00
|
|
|
* GESCreateTrackObjectFunc:
|
2010-05-18 10:56:24 +00:00
|
|
|
* @object: a #GESTimelineObject
|
|
|
|
* @track: a #GESTrack
|
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* Creates the 'primary' track object for this @object.
|
2010-11-28 12:24:07 +00:00
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* Subclasses should implement this method if they only provide a
|
|
|
|
* single #GESTrackObject per track.
|
|
|
|
*
|
|
|
|
* If the subclass needs to create more than one #GESTrackObject for a
|
|
|
|
* given track, then it should implement the 'create_track_objects'
|
|
|
|
* method instead.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
|
|
|
* The implementer of this function shall return the proper #GESTrackObject
|
|
|
|
* that should be controlled by @object for the given @track.
|
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* The returned #GESTrackObject will be automatically added to the list
|
|
|
|
* of objects controlled by the #GESTimelineObject.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* Returns: the #GESTrackObject to be used, or %NULL if it can't provide one
|
|
|
|
* for the given @track.
|
2010-05-18 10:56:24 +00:00
|
|
|
*/
|
2010-12-15 18:18:42 +00:00
|
|
|
typedef GESTrackObject* (*GESCreateTrackObjectFunc) (GESTimelineObject * object,
|
2010-11-28 12:24:07 +00:00
|
|
|
GESTrack * track);
|
2009-09-29 13:25:54 +00:00
|
|
|
|
2010-07-07 14:51:39 +00:00
|
|
|
/**
|
2010-12-15 18:18:42 +00:00
|
|
|
* GESCreateTrackObjectsFunc:
|
2010-07-07 14:51:39 +00:00
|
|
|
* @object: a #GESTimelineObject
|
2010-07-07 15:07:33 +00:00
|
|
|
* @track: a #GESTrack
|
2010-11-28 12:24:07 +00:00
|
|
|
*
|
2010-07-07 14:51:39 +00:00
|
|
|
* Create all track objects this object handles for this type of track.
|
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* Subclasses should implement this method if they potentially need to
|
|
|
|
* return more than one #GESTrackObject(s) for a given #GESTrack.
|
|
|
|
*
|
|
|
|
* For each object created, the subclass must call
|
|
|
|
* ges_timeline_object_add_track_object() with the newly created object
|
|
|
|
* and provided @track.
|
|
|
|
*
|
2010-07-07 14:51:39 +00:00
|
|
|
* Returns: %TRUE on success %FALSE on failure.
|
|
|
|
*/
|
2010-12-15 18:18:42 +00:00
|
|
|
typedef gboolean (*GESCreateTrackObjectsFunc) (GESTimelineObject * object,
|
2010-07-07 14:51:39 +00:00
|
|
|
GESTrack *track);
|
|
|
|
|
2009-09-29 13:25:54 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_OBJECT_START:
|
|
|
|
* @obj: a #GESTimelineObject
|
|
|
|
*
|
|
|
|
* The start position of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_OBJECT_START(obj) (((GESTimelineObject*)obj)->start)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_OBJECT_INPOINT:
|
|
|
|
* @obj: a #GESTimelineObject
|
|
|
|
*
|
|
|
|
* The in-point of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_OBJECT_INPOINT(obj) (((GESTimelineObject*)obj)->inpoint)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_OBJECT_DURATION:
|
|
|
|
* @obj: a #GESTimelineObject
|
|
|
|
*
|
|
|
|
* The duration position of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_OBJECT_DURATION(obj) (((GESTimelineObject*)obj)->duration)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_OBJECT_PRIORITY:
|
|
|
|
* @obj: a #GESTimelineObject
|
|
|
|
*
|
2010-03-13 14:53:16 +00:00
|
|
|
* The priority of the object.
|
2009-09-29 13:25:54 +00:00
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_OBJECT_PRIORITY(obj) (((GESTimelineObject*)obj)->priority)
|
|
|
|
|
2010-07-09 10:09:08 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_OBJECT_HEIGHT:
|
|
|
|
* @obj: a #GESTimelineObject
|
|
|
|
*
|
|
|
|
* The span of priorities this object occupies.
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_OBJECT_HEIGHT(obj) (((GESTimelineObject*)obj)->height)
|
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
|
|
|
* GESTimelineObject:
|
|
|
|
*
|
2010-12-09 16:09:11 +00:00
|
|
|
* The #GESTimelineObject base class.
|
2009-09-16 10:37:45 +00:00
|
|
|
*/
|
2009-08-04 15:16:31 +00:00
|
|
|
struct _GESTimelineObject {
|
2009-09-16 10:37:45 +00:00
|
|
|
/*< private >*/
|
2010-12-20 11:01:04 +00:00
|
|
|
GInitiallyUnowned parent;
|
2009-08-07 14:39:45 +00:00
|
|
|
|
2010-11-28 12:24:07 +00:00
|
|
|
GESTimelineObjectPrivate *priv;
|
|
|
|
|
|
|
|
/* We don't add those properties to the priv struct for optimization purposes
|
|
|
|
* start, inpoint, duration and fullduration are in nanoseconds */
|
|
|
|
guint64 start; /* position (in time) of the object in the layer */
|
|
|
|
guint64 inpoint; /* in-point */
|
|
|
|
guint64 duration; /* duration of the object used in the layer */
|
|
|
|
guint32 priority; /* priority of the object in the layer (0:top priority) */
|
2010-07-09 09:51:21 +00:00
|
|
|
guint32 height; /* the span of priorities this object needs */
|
2009-08-06 09:23:01 +00:00
|
|
|
|
|
|
|
guint64 fullduration; /* Full usable duration of the object (-1: no duration) */
|
2010-11-29 12:24:13 +00:00
|
|
|
|
|
|
|
/* Padding for API extension */
|
|
|
|
gpointer _ges_reserved[GES_PADDING];
|
2009-08-04 15:16:31 +00:00
|
|
|
};
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
|
|
|
* GESTimelineObjectClass:
|
2010-07-07 13:47:51 +00:00
|
|
|
* @create_track_object: method to create a single #GESTrackObject for a given #GESTrack.
|
2010-12-09 16:09:11 +00:00
|
|
|
* @create_track_objects: method to create multiple #GESTrackObjects for a
|
2010-07-07 13:47:51 +00:00
|
|
|
* #GESTrack.
|
2009-09-16 10:37:45 +00:00
|
|
|
* @fill_track_object: method to fill an associated #GESTrackObject.
|
2009-09-21 10:51:16 +00:00
|
|
|
* @need_fill_track: Set to TRUE if @fill_track_object needs to be called.
|
2011-04-26 23:39:56 +00:00
|
|
|
* @track_object_added: Should be overridden by subclasses if they need to perform an
|
2011-05-20 14:02:58 +00:00
|
|
|
* operation when a #GESTrackObject is added. Since: 0.10.2
|
2011-04-26 23:39:56 +00:00
|
|
|
* @track_object_released: Should be overridden by subclassed if they need to perform
|
2011-05-20 14:02:58 +00:00
|
|
|
* action when a #GESTrackObject is released. Since: 0.10.2
|
2009-09-16 10:37:45 +00:00
|
|
|
*
|
|
|
|
* Subclasses can override the @create_track_object and @fill_track_object methods.
|
|
|
|
*/
|
2009-08-04 15:16:31 +00:00
|
|
|
struct _GESTimelineObjectClass {
|
2010-12-08 14:36:55 +00:00
|
|
|
/*< private >*/
|
2010-12-20 11:01:04 +00:00
|
|
|
GInitiallyUnownedClass parent_class;
|
2009-08-06 15:38:43 +00:00
|
|
|
|
2010-11-29 12:24:13 +00:00
|
|
|
/*< public >*/
|
2010-12-15 18:18:42 +00:00
|
|
|
GESCreateTrackObjectFunc create_track_object;
|
|
|
|
GESCreateTrackObjectsFunc create_track_objects;
|
2010-07-07 13:47:51 +00:00
|
|
|
|
2011-05-20 14:03:30 +00:00
|
|
|
/* FIXME : might need a release_track_object */
|
|
|
|
GESFillTrackObjectFunc fill_track_object;
|
|
|
|
gboolean need_fill_track;
|
|
|
|
|
2011-04-26 23:39:56 +00:00
|
|
|
void (*track_object_added) (GESTimelineObject *object,
|
|
|
|
GESTrackObject *tck_object);
|
|
|
|
void (*track_object_released) (GESTimelineObject *object,
|
|
|
|
GESTrackObject *tck_object);
|
|
|
|
|
2010-11-29 12:24:13 +00:00
|
|
|
/*< private >*/
|
|
|
|
/* Padding for API extension */
|
2011-05-20 14:03:30 +00:00
|
|
|
gpointer _ges_reserved[GES_PADDING - 2];
|
2009-08-04 15:16:31 +00:00
|
|
|
};
|
2009-08-04 15:13:11 +00:00
|
|
|
|
|
|
|
GType ges_timeline_object_get_type (void);
|
|
|
|
|
2011-05-06 17:36:35 +00:00
|
|
|
/* Setters */
|
|
|
|
void ges_timeline_object_set_start (GESTimelineObject * object,
|
|
|
|
guint64 start);
|
|
|
|
void ges_timeline_object_set_inpoint (GESTimelineObject * object,
|
|
|
|
guint64 inpoint);
|
|
|
|
void ges_timeline_object_set_duration (GESTimelineObject * object,
|
|
|
|
guint64 duration);
|
|
|
|
void ges_timeline_object_set_priority (GESTimelineObject * object,
|
|
|
|
guint priority);
|
|
|
|
|
|
|
|
void ges_timeline_object_set_layer (GESTimelineObject * object,
|
|
|
|
GESTimelineLayer * layer);
|
|
|
|
|
|
|
|
/* TrackObject handling */
|
2009-08-06 10:14:37 +00:00
|
|
|
GESTrackObject *
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_create_track_object (GESTimelineObject * object,
|
|
|
|
GESTrack * track);
|
2009-08-06 09:23:01 +00:00
|
|
|
|
2011-05-06 17:36:35 +00:00
|
|
|
gboolean
|
|
|
|
ges_timeline_object_create_track_objects (GESTimelineObject * object,
|
|
|
|
GESTrack * track);
|
2010-07-07 13:47:51 +00:00
|
|
|
|
2009-08-07 14:39:45 +00:00
|
|
|
gboolean
|
|
|
|
ges_timeline_object_release_track_object (GESTimelineObject * object,
|
2011-05-06 17:36:35 +00:00
|
|
|
GESTrackObject * trackobject);
|
2009-08-07 14:39:45 +00:00
|
|
|
|
2009-08-06 15:38:43 +00:00
|
|
|
gboolean
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_fill_track_object (GESTimelineObject * object,
|
|
|
|
GESTrackObject * trackobj,
|
|
|
|
GstElement * gnlobj);
|
2009-08-06 15:38:43 +00:00
|
|
|
|
2010-03-12 16:17:30 +00:00
|
|
|
GESTrackObject *
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_find_track_object (GESTimelineObject * object,
|
|
|
|
GESTrack * track, GType type);
|
2010-11-28 12:24:07 +00:00
|
|
|
|
|
|
|
GList *
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_get_track_objects (GESTimelineObject *object);
|
2010-03-12 16:17:30 +00:00
|
|
|
|
2010-07-07 15:07:33 +00:00
|
|
|
gboolean
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_add_track_object (GESTimelineObject *object,
|
|
|
|
GESTrackObject *trobj);
|
|
|
|
|
|
|
|
/* Layer */
|
|
|
|
GESTimelineLayer *
|
|
|
|
ges_timeline_object_get_layer (GESTimelineObject *object);
|
2010-07-07 15:07:33 +00:00
|
|
|
|
2011-06-06 19:55:47 +00:00
|
|
|
gboolean
|
|
|
|
ges_timeline_object_move_to_layer (GESTimelineObject *object,
|
|
|
|
GESTimelineLayer *layer);
|
|
|
|
|
|
|
|
gboolean
|
|
|
|
ges_timeline_object_is_moving_from_layer (GESTimelineObject *object);
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_object_set_moving_from_layer (GESTimelineObject * object,
|
|
|
|
gboolean is_moving);
|
|
|
|
|
2011-05-06 17:36:35 +00:00
|
|
|
/* Effects */
|
2011-01-31 10:32:14 +00:00
|
|
|
GList *
|
2011-05-06 17:36:35 +00:00
|
|
|
ges_timeline_object_get_top_effects (GESTimelineObject *object);
|
2011-01-31 10:32:14 +00:00
|
|
|
|
2011-01-31 10:41:37 +00:00
|
|
|
gint
|
|
|
|
ges_timeline_object_get_top_effect_position (GESTimelineObject *object,
|
2011-05-06 17:36:35 +00:00
|
|
|
GESTrackEffect *effect);
|
2011-01-31 10:41:37 +00:00
|
|
|
|
2011-02-04 10:44:19 +00:00
|
|
|
gboolean
|
|
|
|
ges_timeline_object_set_top_effect_priority (GESTimelineObject *object,
|
2011-05-06 17:36:35 +00:00
|
|
|
GESTrackEffect *effect,
|
|
|
|
guint newpriority);
|
2011-02-04 10:44:19 +00:00
|
|
|
|
2011-12-01 03:18:30 +00:00
|
|
|
GESTrackType
|
|
|
|
ges_timeline_object_get_supported_formats (GESTimelineObject * self);
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_object_set_supported_formats (GESTimelineObject * self,
|
|
|
|
GESTrackType supportedformats);
|
|
|
|
|
2011-08-24 09:48:14 +00:00
|
|
|
GESTimelineObject *
|
|
|
|
ges_timeline_object_split(GESTimelineObject * ref_object, gint64 position);
|
|
|
|
|
2009-08-04 15:13:11 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* _GES_TIMELINE_OBJECT */
|
|
|
|
|