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
|
2012-11-04 00:25:20 +00:00
|
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
2009-08-04 15:13:11 +00:00
|
|
|
*/
|
|
|
|
|
2013-01-20 15:42:29 +00:00
|
|
|
#ifndef _GES_CLIP
|
|
|
|
#define _GES_CLIP
|
2009-08-04 15:13:11 +00:00
|
|
|
|
|
|
|
#include <glib-object.h>
|
2009-08-06 15:38:43 +00:00
|
|
|
#include <gst/gst.h>
|
2013-01-15 13:52:17 +00:00
|
|
|
#include <ges/ges-timeline-element.h>
|
2013-03-01 01:27:50 +00:00
|
|
|
#include <ges/ges-container.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
|
|
|
|
|
2013-01-20 15:42:29 +00:00
|
|
|
#define GES_TYPE_CLIP ges_clip_get_type()
|
|
|
|
#define GES_CLIP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_CLIP, GESClip))
|
|
|
|
#define GES_CLIP_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_CLIP, GESClipClass))
|
|
|
|
#define GES_IS_CLIP(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_CLIP))
|
|
|
|
#define GES_IS_CLIP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_CLIP))
|
|
|
|
#define GES_CLIP_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_CLIP, GESClipClass))
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2013-01-20 15:42:29 +00:00
|
|
|
typedef struct _GESClipPrivate GESClipPrivate;
|
2010-11-28 12:24:07 +00:00
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
2013-01-26 15:31:33 +00:00
|
|
|
* GESFillTrackElementFunc:
|
2013-02-15 02:34:48 +00:00
|
|
|
* @clip: the #GESClip controlling the track elements
|
|
|
|
* @track_element: the #GESTrackElement
|
2009-09-16 10:37:45 +00:00
|
|
|
* @gnlobj: the GNonLin object that needs to be filled.
|
|
|
|
*
|
|
|
|
* A function that will be called when the GNonLin object of a corresponding
|
2013-02-08 19:39:18 +00:00
|
|
|
* track element needs to be filled.
|
2009-09-16 10:37:45 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2013-03-15 14:58:59 +00:00
|
|
|
typedef gboolean (*GESFillTrackElementFunc) (GESClip *clip, GESTrackElement *track_element,
|
|
|
|
GstElement *gnlobj);
|
2009-08-07 14:39:45 +00:00
|
|
|
|
2010-05-18 10:56:24 +00:00
|
|
|
/**
|
2013-01-26 15:31:33 +00:00
|
|
|
* GESCreateTrackElementFunc:
|
2013-02-15 02:34:48 +00:00
|
|
|
* @clip: a #GESClip
|
2012-12-20 23:23:54 +00:00
|
|
|
* @type: a #GESTrackType
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2013-02-15 02:34:48 +00:00
|
|
|
* Creates the 'primary' track element for this @clip.
|
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
|
2013-01-26 15:31:33 +00:00
|
|
|
* single #GESTrackElement per track.
|
2010-12-09 11:53:07 +00:00
|
|
|
*
|
2013-01-26 15:31:33 +00:00
|
|
|
* If the subclass needs to create more than one #GESTrackElement for a
|
|
|
|
* given track, then it should implement the 'create_track_elements'
|
2010-12-09 11:53:07 +00:00
|
|
|
* method instead.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2013-01-26 15:31:33 +00:00
|
|
|
* The implementer of this function shall return the proper #GESTrackElement
|
2013-02-15 02:34:48 +00:00
|
|
|
* that should be controlled by @clip for the given @track.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2013-01-26 15:31:33 +00:00
|
|
|
* The returned #GESTrackElement will be automatically added to the list
|
2013-01-20 15:42:29 +00:00
|
|
|
* of objects controlled by the #GESClip.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2013-01-26 15:31:33 +00:00
|
|
|
* Returns: the #GESTrackElement to be used, or %NULL if it can't provide one
|
2010-12-09 11:53:07 +00:00
|
|
|
* for the given @track.
|
2010-05-18 10:56:24 +00:00
|
|
|
*/
|
2013-03-15 14:58:59 +00:00
|
|
|
typedef GESTrackElement *(*GESCreateTrackElementFunc) (GESClip * clip, GESTrackType type);
|
2009-09-29 13:25:54 +00:00
|
|
|
|
2010-07-07 14:51:39 +00:00
|
|
|
/**
|
2013-01-26 15:31:33 +00:00
|
|
|
* GESCreateTrackElementsFunc:
|
2013-02-15 02:34:48 +00:00
|
|
|
* @clip: a #GESClip
|
2012-12-20 23:23:54 +00:00
|
|
|
* @type: a #GESTrackType
|
2010-11-28 12:24:07 +00:00
|
|
|
*
|
2013-02-15 02:34:48 +00:00
|
|
|
* Create all track elements this clip handles for this type of track.
|
2010-07-07 14:51:39 +00:00
|
|
|
*
|
2010-12-09 11:53:07 +00:00
|
|
|
* Subclasses should implement this method if they potentially need to
|
2013-01-26 15:31:33 +00:00
|
|
|
* return more than one #GESTrackElement(s) for a given #GESTrack.
|
2010-12-09 11:53:07 +00:00
|
|
|
*
|
2010-07-07 14:51:39 +00:00
|
|
|
* Returns: %TRUE on success %FALSE on failure.
|
|
|
|
*/
|
2012-12-20 23:23:54 +00:00
|
|
|
|
2013-02-15 02:34:48 +00:00
|
|
|
typedef GList * (*GESCreateTrackElementsFunc) (GESClip * clip, GESTrackType type);
|
2010-07-07 14:51:39 +00:00
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
2013-01-20 15:42:29 +00:00
|
|
|
* GESClip:
|
2013-01-12 13:50:24 +00:00
|
|
|
*
|
2013-01-20 15:42:29 +00:00
|
|
|
* The #GESClip base class.
|
2009-09-16 10:37:45 +00:00
|
|
|
*/
|
2013-01-20 15:42:29 +00:00
|
|
|
struct _GESClip
|
2012-11-27 16:54:54 +00:00
|
|
|
{
|
2013-03-15 14:58:59 +00:00
|
|
|
GESContainer parent;
|
2009-08-06 09:23:01 +00:00
|
|
|
|
2012-12-17 16:51:49 +00:00
|
|
|
/*< private >*/
|
2013-01-20 15:42:29 +00:00
|
|
|
GESClipPrivate *priv;
|
2012-12-17 16:51:49 +00:00
|
|
|
|
2010-11-29 12:24:13 +00:00
|
|
|
/* Padding for API extension */
|
2013-03-15 14:58:59 +00:00
|
|
|
gpointer _ges_reserved[GES_PADDING_LARGE];
|
2009-08-04 15:16:31 +00:00
|
|
|
};
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
2013-01-20 15:42:29 +00:00
|
|
|
* GESClipClass:
|
2013-01-26 15:31:33 +00:00
|
|
|
* @create_track_element: method to create a single #GESTrackElement for a given #GESTrack.
|
|
|
|
* @create_track_elements: method to create multiple #GESTrackElements for a
|
2010-07-07 13:47:51 +00:00
|
|
|
* #GESTrack.
|
2013-01-26 15:31:33 +00:00
|
|
|
* @fill_track_element: method to fill an associated #GESTrackElement.
|
|
|
|
* @need_fill_track: Set to TRUE if @fill_track_element needs to be called.
|
2009-09-16 10:37:45 +00:00
|
|
|
*
|
2013-01-26 15:31:33 +00:00
|
|
|
* Subclasses can override the @create_track_element and @fill_track_element methods.
|
2009-09-16 10:37:45 +00:00
|
|
|
*/
|
2013-01-20 15:42:29 +00:00
|
|
|
struct _GESClipClass
|
2012-11-27 16:54:54 +00:00
|
|
|
{
|
|
|
|
/*< private > */
|
2013-03-15 14:58:59 +00:00
|
|
|
GESContainerClass parent_class;
|
2009-08-06 15:38:43 +00:00
|
|
|
|
2012-11-27 16:54:54 +00:00
|
|
|
/*< public > */
|
2013-03-15 14:58:59 +00:00
|
|
|
GESCreateTrackElementFunc create_track_element;
|
2013-01-26 15:31:33 +00:00
|
|
|
GESCreateTrackElementsFunc create_track_elements;
|
2013-03-15 14:58:59 +00:00
|
|
|
GESFillTrackElementFunc fill_track_element;
|
|
|
|
gboolean need_fill_track;
|
2011-04-26 23:39:56 +00:00
|
|
|
|
2010-11-29 12:24:13 +00:00
|
|
|
/*< private >*/
|
|
|
|
/* Padding for API extension */
|
2012-09-22 16:51:46 +00:00
|
|
|
gpointer _ges_reserved[GES_PADDING_LARGE];
|
2009-08-04 15:16:31 +00:00
|
|
|
};
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2013-03-15 14:58:59 +00:00
|
|
|
/****************************************************
|
|
|
|
* Standard *
|
|
|
|
****************************************************/
|
2013-01-20 15:42:29 +00:00
|
|
|
GType ges_clip_get_type (void);
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2013-03-15 14:58:59 +00:00
|
|
|
/****************************************************
|
|
|
|
* TrackElement handling *
|
|
|
|
****************************************************/
|
|
|
|
GESTrackType ges_clip_get_supported_formats (GESClip *clip);
|
|
|
|
void ges_clip_set_supported_formats (GESClip *clip, GESTrackType supportedformats);
|
|
|
|
gboolean ges_clip_add_asset (GESClip *clip, GESAsset *asset);
|
|
|
|
gboolean ges_clip_fill_track_element (GESClip *clip, GESTrackElement *trackelement,
|
|
|
|
GstElement *gnlobj);
|
|
|
|
GESTrackElement* ges_clip_find_track_element (GESClip *clip, GESTrack *track,
|
|
|
|
GType type);
|
|
|
|
|
|
|
|
/****************************************************
|
|
|
|
* Layer *
|
|
|
|
****************************************************/
|
2013-04-23 23:04:04 +00:00
|
|
|
GESLayer* ges_clip_get_layer (GESClip *clip);
|
|
|
|
gboolean ges_clip_move_to_layer (GESClip *clip, GESLayer *layer);
|
2013-03-15 14:58:59 +00:00
|
|
|
|
|
|
|
/****************************************************
|
|
|
|
* Effects *
|
|
|
|
****************************************************/
|
|
|
|
GList* ges_clip_get_top_effects (GESClip *clip);
|
|
|
|
gint ges_clip_get_top_effect_position (GESClip *clip, GESBaseEffect *effect);
|
|
|
|
gboolean ges_clip_set_top_effect_priority (GESClip *clip, GESBaseEffect *effect,
|
|
|
|
guint newpriority);
|
|
|
|
|
|
|
|
/****************************************************
|
|
|
|
* Editing *
|
|
|
|
****************************************************/
|
|
|
|
GESClip* ges_clip_split (GESClip *clip, guint64 position);
|
|
|
|
gboolean ges_clip_edit (GESClip *clip, GList *layers,
|
|
|
|
gint new_layer_priority, GESEditMode mode,
|
|
|
|
GESEdge edge, guint64 position);
|
2013-01-15 13:52:17 +00:00
|
|
|
|
2009-08-04 15:13:11 +00:00
|
|
|
G_END_DECLS
|
2013-01-20 15:42:29 +00:00
|
|
|
#endif /* _GES_CLIP */
|