2013-01-15 13:52:17 +00:00
|
|
|
/*
|
|
|
|
* gst-editing-services
|
|
|
|
* Copyright (C) <2013> Thibault Saunier <thibault.saunier@collabora.com>
|
|
|
|
* <2013> Collabora Ltd.
|
|
|
|
*
|
|
|
|
* gst-editing-services is free software: you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* gst-editing-services 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 General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _GES_TIMELINE_ELEMENT_H_
|
|
|
|
#define _GES_TIMELINE_ELEMENT_H_
|
|
|
|
|
|
|
|
#include <glib-object.h>
|
|
|
|
#include <gst/gst.h>
|
|
|
|
#include "ges-enums.h"
|
|
|
|
#include "ges-types.h"
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
#define GES_TYPE_TIMELINE_ELEMENT (ges_timeline_element_get_type ())
|
|
|
|
#define GES_TIMELINE_ELEMENT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_TIMELINE_ELEMENT, GESTimelineElement))
|
|
|
|
#define GES_TIMELINE_ELEMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_TIMELINE_ELEMENT, GESTimelineElementClass))
|
|
|
|
#define GES_IS_TIMELINE_ELEMENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_TIMELINE_ELEMENT))
|
|
|
|
#define GES_IS_TIMELINE_ELEMENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_TIMELINE_ELEMENT))
|
|
|
|
#define GES_TIMELINE_ELEMENT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_TIMELINE_ELEMENT, GESTimelineElementClass))
|
|
|
|
|
|
|
|
typedef struct _GESTimelineElementPrivate GESTimelineElementPrivate;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_START:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The start position of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_START(obj) (((GESTimelineElement*)obj)->start)
|
|
|
|
|
2013-03-23 04:31:23 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_END:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The end position of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_END(obj) ((((GESTimelineElement*)obj)->start) + (((GESTimelineElement*)obj)->duration))
|
|
|
|
|
2013-01-15 13:52:17 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_INPOINT:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The in-point of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_INPOINT(obj) (((GESTimelineElement*)obj)->inpoint)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_DURATION:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The duration of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_DURATION(obj) (((GESTimelineElement*)obj)->duration)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_MAX_DURATION:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The maximun duration of the object (in nanoseconds).
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_MAX_DURATION(obj) (((GESTimelineElement*)obj)->maxduration)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_PRIORITY:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The priority of the object.
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_PRIORITY(obj) (((GESTimelineElement*)obj)->priority)
|
|
|
|
|
2013-01-20 15:58:05 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_PARENT:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The parent of the object.
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_PARENT(obj) (((GESTimelineElement*)obj)->parent)
|
2013-01-15 13:52:17 +00:00
|
|
|
|
2013-02-28 18:12:15 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_TIMELINE:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The timeline in which the object is.
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_TIMELINE(obj) (((GESTimelineElement*)obj)->timeline)
|
|
|
|
|
2014-02-18 14:14:40 +00:00
|
|
|
/**
|
|
|
|
* GES_TIMELINE_ELEMENT_NAME:
|
|
|
|
* @obj: a #GESTimelineElement
|
|
|
|
*
|
|
|
|
* The name of the object.
|
|
|
|
*/
|
|
|
|
#define GES_TIMELINE_ELEMENT_NAME(obj) (((GESTimelineElement*)obj)->name)
|
|
|
|
|
2013-03-01 22:18:10 +00:00
|
|
|
/**
|
|
|
|
* GESTimelineElement:
|
|
|
|
* @parent: The #GESTimelineElement that controls the object
|
|
|
|
* @asset: The #GESAsset from which the object has been extracted
|
|
|
|
* @start: position (in time) of the object
|
|
|
|
* @inpoint: Position in the media from which the object should be used
|
|
|
|
* @duration: duration of the object to be used
|
|
|
|
* @maxduration: The maximum duration the object can have
|
|
|
|
* @priority: priority of the object in the layer (0:top priority)
|
|
|
|
*
|
|
|
|
* Those filed can be accessed from outside but in no case should
|
|
|
|
* be changed from there. Subclasses can write them but should make
|
|
|
|
* sure to properly call g_object_notify.
|
|
|
|
*/
|
|
|
|
struct _GESTimelineElement
|
|
|
|
{
|
|
|
|
GInitiallyUnowned parent_instance;
|
|
|
|
|
|
|
|
/*< public > */
|
|
|
|
/*< read only >*/
|
|
|
|
GESTimelineElement *parent;
|
|
|
|
GESAsset *asset;
|
|
|
|
GstClockTime start;
|
|
|
|
GstClockTime inpoint;
|
|
|
|
GstClockTime duration;
|
|
|
|
GstClockTime maxduration;
|
|
|
|
guint32 priority;
|
|
|
|
GESTimeline *timeline;
|
2014-02-18 14:14:40 +00:00
|
|
|
gchar *name;
|
2013-03-01 22:18:10 +00:00
|
|
|
|
|
|
|
/*< private >*/
|
|
|
|
GESTimelineElementPrivate *priv;
|
|
|
|
|
|
|
|
/* Padding for API extension */
|
|
|
|
gpointer _ges_reserved[GES_PADDING_LARGE];
|
|
|
|
};
|
|
|
|
|
2013-01-15 13:52:17 +00:00
|
|
|
/**
|
|
|
|
* GESTimelineElementClass:
|
2013-09-01 16:18:53 +00:00
|
|
|
* @set_parent: method to set the parent of a #GESTimelineElement.
|
2013-01-15 13:52:17 +00:00
|
|
|
* @set_start: method to set the start of a #GESTimelineElement
|
|
|
|
* @set_duration: method to set the duration of a #GESTimelineElement
|
|
|
|
* @set_inpoint: method to set the inpoint of a #GESTimelineElement
|
|
|
|
* @set_max_duration: method to set the maximun duration of a #GESTimelineElement
|
|
|
|
* @set_priority: method to set the priority of a #GESTimelineElement
|
|
|
|
* @ripple: method to ripple an object
|
|
|
|
* @ripple_end: method to ripple an object on its #GES_EDGE_END edge
|
|
|
|
* @roll_start: method to roll an object on its #GES_EDGE_START edge
|
|
|
|
* @roll_end: method to roll an object on its #GES_EDGE_END edge
|
|
|
|
* @trim: method to trim an object
|
|
|
|
* @deep_copy: Copy the children properties of @self into @copy
|
|
|
|
*
|
|
|
|
* The GESTimelineElement base class. Subclasses should override at least
|
|
|
|
* @set_start @set_inpoint @set_duration @ripple @ripple_end @roll_start
|
2013-09-01 16:18:53 +00:00
|
|
|
* @roll_end and @trim.
|
|
|
|
*
|
|
|
|
* Vmethods in subclasses should apply all the operation they need to but
|
|
|
|
* the real method implementation is in charge of setting the proper field,
|
|
|
|
* and emit the notify signal.
|
2013-01-15 13:52:17 +00:00
|
|
|
*/
|
|
|
|
struct _GESTimelineElementClass
|
|
|
|
{
|
|
|
|
GInitiallyUnownedClass parent_class;
|
|
|
|
|
2013-03-01 22:18:10 +00:00
|
|
|
/*< public > */
|
2013-09-01 16:18:53 +00:00
|
|
|
gboolean (*set_parent) (GESTimelineElement * self, GESTimelineElement *parent);
|
2013-01-15 13:52:17 +00:00
|
|
|
gboolean (*set_start) (GESTimelineElement * self, GstClockTime start);
|
|
|
|
gboolean (*set_inpoint) (GESTimelineElement * self, GstClockTime inpoint);
|
|
|
|
gboolean (*set_duration) (GESTimelineElement * self, GstClockTime duration);
|
|
|
|
gboolean (*set_max_duration) (GESTimelineElement * self, GstClockTime maxduration);
|
2016-08-11 14:54:08 +00:00
|
|
|
gboolean (*set_priority) (GESTimelineElement * self, guint32 priority); /* set_priority is now protected */
|
2013-01-15 13:52:17 +00:00
|
|
|
|
|
|
|
gboolean (*ripple) (GESTimelineElement *self, guint64 start);
|
|
|
|
gboolean (*ripple_end) (GESTimelineElement *self, guint64 end);
|
|
|
|
gboolean (*roll_start) (GESTimelineElement *self, guint64 start);
|
|
|
|
gboolean (*roll_end) (GESTimelineElement *self, guint64 end);
|
|
|
|
gboolean (*trim) (GESTimelineElement *self, guint64 start);
|
2015-02-19 15:30:18 +00:00
|
|
|
void (*deep_copy) (GESTimelineElement *self, GESTimelineElement *copy);
|
2016-01-01 10:56:27 +00:00
|
|
|
|
|
|
|
GESTimelineElement * (*paste) (GESTimelineElement *self,
|
|
|
|
GESTimelineElement *ref_element,
|
|
|
|
GstClockTime paste_position);
|
2015-02-19 15:30:18 +00:00
|
|
|
|
|
|
|
GParamSpec** (*list_children_properties) (GESTimelineElement * self, guint *n_properties);
|
|
|
|
gboolean (*lookup_child) (GESTimelineElement *self, const gchar *prop_name,
|
|
|
|
GObject **child, GParamSpec **pspec);
|
2015-06-23 11:27:00 +00:00
|
|
|
GESTrackType (*get_track_types) (GESTimelineElement * self);
|
2013-01-15 13:52:17 +00:00
|
|
|
|
2013-03-01 22:18:10 +00:00
|
|
|
/*< private > */
|
2013-01-15 13:52:17 +00:00
|
|
|
/* Padding for API extension */
|
2015-02-19 15:30:18 +00:00
|
|
|
gpointer _ges_reserved[GES_PADDING_LARGE - 2];
|
2013-01-15 13:52:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
GType ges_timeline_element_get_type (void) G_GNUC_CONST;
|
|
|
|
|
2013-07-03 22:33:05 +00:00
|
|
|
GESTimelineElement *
|
|
|
|
ges_timeline_element_get_toplevel_parent (GESTimelineElement *self);
|
2013-01-20 15:58:05 +00:00
|
|
|
GESTimelineElement * ges_timeline_element_get_parent (GESTimelineElement * self);
|
|
|
|
gboolean ges_timeline_element_set_parent (GESTimelineElement *self, GESTimelineElement *parent);
|
2013-02-28 18:12:15 +00:00
|
|
|
gboolean ges_timeline_element_set_timeline (GESTimelineElement *self, GESTimeline *timeline);
|
2013-01-20 15:58:05 +00:00
|
|
|
void ges_timeline_element_set_start (GESTimelineElement *self, GstClockTime start);
|
|
|
|
void ges_timeline_element_set_inpoint (GESTimelineElement *self, GstClockTime inpoint);
|
|
|
|
void ges_timeline_element_set_duration (GESTimelineElement *self, GstClockTime duration);
|
2013-03-01 22:18:10 +00:00
|
|
|
void ges_timeline_element_set_max_duration (GESTimelineElement *self, GstClockTime maxduration);
|
2013-01-20 15:58:05 +00:00
|
|
|
void ges_timeline_element_set_priority (GESTimelineElement *self, guint32 priority);
|
2013-02-01 20:51:02 +00:00
|
|
|
|
|
|
|
GstClockTime ges_timeline_element_get_start (GESTimelineElement *self);
|
|
|
|
GstClockTime ges_timeline_element_get_inpoint (GESTimelineElement *self);
|
|
|
|
GstClockTime ges_timeline_element_get_duration (GESTimelineElement *self);
|
|
|
|
GstClockTime ges_timeline_element_get_max_duration (GESTimelineElement *self);
|
2013-02-28 18:12:15 +00:00
|
|
|
GESTimeline * ges_timeline_element_get_timeline (GESTimelineElement *self);
|
2013-02-01 20:51:02 +00:00
|
|
|
guint32 ges_timeline_element_get_priority (GESTimelineElement *self);
|
|
|
|
|
2013-01-20 15:58:05 +00:00
|
|
|
gboolean ges_timeline_element_ripple (GESTimelineElement *self, GstClockTime start);
|
|
|
|
gboolean ges_timeline_element_ripple_end (GESTimelineElement *self, GstClockTime end);
|
|
|
|
gboolean ges_timeline_element_roll_start (GESTimelineElement *self, GstClockTime start);
|
|
|
|
gboolean ges_timeline_element_roll_end (GESTimelineElement *self, GstClockTime end);
|
|
|
|
gboolean ges_timeline_element_trim (GESTimelineElement *self, GstClockTime start);
|
|
|
|
GESTimelineElement * ges_timeline_element_copy (GESTimelineElement *self, gboolean deep);
|
2014-02-18 14:14:40 +00:00
|
|
|
gchar * ges_timeline_element_get_name (GESTimelineElement *self);
|
|
|
|
gboolean ges_timeline_element_set_name (GESTimelineElement *self, const gchar *name);
|
2015-02-19 15:30:18 +00:00
|
|
|
GParamSpec **
|
|
|
|
ges_timeline_element_list_children_properties (GESTimelineElement *self,
|
|
|
|
guint *n_properties);
|
|
|
|
|
|
|
|
gboolean ges_timeline_element_lookup_child (GESTimelineElement *self,
|
|
|
|
const gchar *prop_name,
|
|
|
|
GObject **child,
|
|
|
|
GParamSpec **pspec);
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_element_get_child_property_by_pspec (GESTimelineElement * self,
|
|
|
|
GParamSpec * pspec,
|
|
|
|
GValue * value);
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_element_get_child_property_valist (GESTimelineElement * self,
|
|
|
|
const gchar * first_property_name,
|
|
|
|
va_list var_args);
|
|
|
|
|
|
|
|
void ges_timeline_element_get_child_properties (GESTimelineElement *self,
|
|
|
|
const gchar * first_property_name,
|
|
|
|
...) G_GNUC_NULL_TERMINATED;
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_element_set_child_property_valist (GESTimelineElement * self,
|
|
|
|
const gchar * first_property_name,
|
|
|
|
va_list var_args);
|
|
|
|
|
|
|
|
void
|
|
|
|
ges_timeline_element_set_child_property_by_pspec (GESTimelineElement * self,
|
|
|
|
GParamSpec * pspec,
|
|
|
|
GValue * value);
|
|
|
|
|
|
|
|
void ges_timeline_element_set_child_properties (GESTimelineElement * self,
|
|
|
|
const gchar * first_property_name,
|
|
|
|
...) G_GNUC_NULL_TERMINATED;
|
|
|
|
|
|
|
|
gboolean ges_timeline_element_set_child_property (GESTimelineElement *self,
|
|
|
|
const gchar *property_name,
|
|
|
|
GValue * value);
|
|
|
|
|
|
|
|
gboolean ges_timeline_element_get_child_property (GESTimelineElement *self,
|
|
|
|
const gchar *property_name,
|
|
|
|
GValue * value);
|
|
|
|
|
|
|
|
gboolean ges_timeline_element_add_child_property (GESTimelineElement * self,
|
|
|
|
GParamSpec *pspec,
|
|
|
|
GObject *child);
|
|
|
|
|
|
|
|
gboolean ges_timeline_element_remove_child_property(GESTimelineElement * self,
|
|
|
|
GParamSpec *pspec);
|
2013-01-15 13:52:17 +00:00
|
|
|
|
2016-01-01 10:56:27 +00:00
|
|
|
GESTimelineElement * ges_timeline_element_paste (GESTimelineElement * self,
|
2015-06-29 16:04:32 +00:00
|
|
|
GstClockTime paste_position);
|
|
|
|
|
2015-06-23 11:27:00 +00:00
|
|
|
GESTrackType ges_timeline_element_get_track_types (GESTimelineElement * self);
|
|
|
|
|
2013-01-15 13:52:17 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* _GES_TIMELINE_ELEMENT_H_ */
|