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
|
|
|
*/
|
|
|
|
|
2020-03-17 21:13:51 +00:00
|
|
|
#pragma once
|
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()
|
2020-03-17 18:51:39 +00:00
|
|
|
GES_DECLARE_TYPE(Clip, clip, CLIP);
|
2010-11-28 12:24:07 +00:00
|
|
|
|
2020-03-02 12:56:03 +00:00
|
|
|
/**
|
|
|
|
* GES_CLIP_CLASS_CAN_ADD_EFFECTS:
|
|
|
|
* @klass: A #GESClipClass
|
|
|
|
*
|
|
|
|
* Whether the class allows for the user to add additional non-core
|
|
|
|
* #GESBaseEffect-s to clips from this class.
|
|
|
|
*/
|
|
|
|
#define GES_CLIP_CLASS_CAN_ADD_EFFECTS(klass) ((GES_CLIP_CLASS (klass))->ABI.abi.can_add_effects)
|
|
|
|
|
2009-09-16 10:37:45 +00:00
|
|
|
/**
|
2013-01-26 15:31:33 +00:00
|
|
|
* GESFillTrackElementFunc:
|
2020-01-09 12:11:35 +00:00
|
|
|
* @clip: The #GESClip controlling the track elements
|
|
|
|
* @track_element: The #GESTrackElement
|
|
|
|
* @nleobj: The nleobject that needs to be filled
|
2009-09-16 10:37:45 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* A function that will be called when the nleobject 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
|
|
|
*
|
2014-08-15 13:48:14 +00:00
|
|
|
* The implementer of this function shall add the proper #GstElement to @nleobj
|
2009-09-16 10:37:45 +00:00
|
|
|
* using gst_bin_add().
|
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* Deprecated: 1.18: This method type is no longer used.
|
|
|
|
*
|
|
|
|
* Returns: %TRUE if the implementer successfully filled the @nleobj.
|
2009-09-16 10:37:45 +00:00
|
|
|
*/
|
2013-03-15 14:58:59 +00:00
|
|
|
typedef gboolean (*GESFillTrackElementFunc) (GESClip *clip, GESTrackElement *track_element,
|
2014-08-15 13:48:14 +00:00
|
|
|
GstElement *nleobj);
|
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:
|
2020-01-09 12:11:35 +00:00
|
|
|
* @clip: A #GESClip
|
|
|
|
* @type: A #GESTrackType to create a #GESTrackElement for
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* A method for creating the core #GESTrackElement of a clip, to be added
|
|
|
|
* to a #GESTrack of the given track type.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* If a clip may produce several track elements per track type,
|
|
|
|
* #GESCreateTrackElementsFunc is more appropriate.
|
2010-05-18 10:56:24 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* Returns: (transfer floating) (nullable): The #GESTrackElement created
|
|
|
|
* by @clip, or %NULL if @clip can not provide a track element for the
|
|
|
|
* given @type or an error occurred.
|
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:
|
2020-01-09 12:11:35 +00:00
|
|
|
* @clip: A #GESClip
|
|
|
|
* @type: A #GESTrackType to create #GESTrackElement-s for
|
2010-11-28 12:24:07 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* A method for creating the core #GESTrackElement-s of a clip, to be
|
|
|
|
* added to #GESTrack-s of the given track type.
|
2010-07-07 14:51:39 +00:00
|
|
|
*
|
2020-01-09 12:11:35 +00:00
|
|
|
* Returns: (transfer container) (element-type GESTrackElement): A list of
|
|
|
|
* the #GESTrackElement-s created by @clip for the given @type, or %NULL
|
|
|
|
* if no track elements are created or an error occurred.
|
2010-07-07 14:51:39 +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:
|
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:
|
2020-01-09 12:11:35 +00:00
|
|
|
* @create_track_element: Method to create the core #GESTrackElement of
|
|
|
|
* a clip of this class. If a clip of this class may create several track
|
|
|
|
* elements per track type, this should be left as %NULL, and
|
|
|
|
* create_track_elements() should be used instead. Otherwise, you should
|
|
|
|
* implement this class method and leave create_track_elements() as the
|
|
|
|
* default implementation
|
|
|
|
* @create_track_elements: Method to create the (multiple) core
|
|
|
|
* #GESTrackElement-s of a clip of this class. If create_track_element()
|
|
|
|
* is implemented, this should be kept as the default implementation
|
2020-03-02 12:56:03 +00:00
|
|
|
* @can_add_effects: Whether the user can add additional non-core
|
|
|
|
* #GESBaseEffect-s to clips from this class, to be applied to the output
|
|
|
|
* data of the core elements.
|
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;
|
2011-04-26 23:39:56 +00:00
|
|
|
|
2010-11-29 12:24:13 +00:00
|
|
|
/*< private >*/
|
|
|
|
/* Padding for API extension */
|
2020-03-02 12:56:03 +00:00
|
|
|
union {
|
|
|
|
gpointer _ges_reserved[GES_PADDING_LARGE];
|
|
|
|
struct {
|
|
|
|
gboolean can_add_effects;
|
|
|
|
} abi;
|
|
|
|
} ABI;
|
2009-08-04 15:16:31 +00:00
|
|
|
};
|
2009-08-04 15:13:11 +00:00
|
|
|
|
2013-03-15 14:58:59 +00:00
|
|
|
/****************************************************
|
|
|
|
* TrackElement handling *
|
|
|
|
****************************************************/
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
GESTrackType ges_clip_get_supported_formats (GESClip *clip);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
void ges_clip_set_supported_formats (GESClip *clip, GESTrackType supportedformats);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-09-28 16:09:49 +00:00
|
|
|
GESTrackElement* ges_clip_add_asset (GESClip *clip, GESAsset *asset);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
GESTrackElement* ges_clip_find_track_element (GESClip *clip, GESTrack *track,
|
|
|
|
GType type);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2014-05-19 10:21:52 +00:00
|
|
|
GList * ges_clip_find_track_elements (GESClip * clip, GESTrack * track,
|
|
|
|
GESTrackType track_type, GType type);
|
2013-03-15 14:58:59 +00:00
|
|
|
|
timeline: re-handle clip children track selection
The way a clip's track elements are added to tracks was re-handled. This
doesn't affect the normal usage of a simple audio-video timeline, where
the tracks are added before any clips, but usage for multi-track
timelines has improved. The main changes are:
+ We can now handle a track being selected for more than one track,
including a full copy of their children properties and bindings.
(Previously broken.)
+ When a clip is split, we copy the new elements directly into the same
track, avoiding select-tracks-for-object.
+ When a clip is grouped or ungrouped, we avoid moving the elements to
or from tracks.
+ Added API to allow users to copy the core elements of a clip directly
into a track, complementing select-tracks-for-object.
+ Enforced the rule that a clip can only contain one core child in a
track, and all the non-core children must be added to tracks that
already contains a core child. This extends the previous condition
that two sources from the same clip should not be added to the same
track.
+ Made ges_track_add_element check that the newly added track element
does not break the configuration rules of the timeline.
+ When adding a track to a timeline, we only use
select-tracks-for-object to check whether track elements should be
added to the new track, not existing ones.
+ When removing a track from a timeline, we empty it of all the track
elements that are controlled by a clip. Thus, we ensure that a clip
only contains elements that are in the tracks of the same timeline, or
no track. Similarly, when removing a clip from a timeline.
+ We can now avoid unsupported timeline configurations when a layer is
added to a timeline, and already contains clips.
+ We can now avoid unsupported timeline configurations when a track is
added to a timeline, and the timeline already contains clips.
Fixes https://gitlab.freedesktop.org/gstreamer/gst-editing-services/-/issues/84
2020-04-06 11:09:54 +00:00
|
|
|
GES_API
|
|
|
|
GESTrackElement * ges_clip_add_child_to_track (GESClip * clip, GESTrackElement * child, GESTrack * track, GError **err);
|
|
|
|
|
2013-03-15 14:58:59 +00:00
|
|
|
/****************************************************
|
|
|
|
* Layer *
|
|
|
|
****************************************************/
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-04-23 23:04:04 +00:00
|
|
|
GESLayer* ges_clip_get_layer (GESClip *clip);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2019-02-08 19:44:39 +00:00
|
|
|
gboolean ges_clip_move_to_layer (GESClip *clip, GESLayer *layer);
|
2013-03-15 14:58:59 +00:00
|
|
|
|
|
|
|
/****************************************************
|
|
|
|
* Effects *
|
|
|
|
****************************************************/
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
GList* ges_clip_get_top_effects (GESClip *clip);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
gint ges_clip_get_top_effect_position (GESClip *clip, GESBaseEffect *effect);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2014-06-05 02:05:06 +00:00
|
|
|
gint ges_clip_get_top_effect_index (GESClip *clip, GESBaseEffect *effect);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
gboolean ges_clip_set_top_effect_priority (GESClip *clip, GESBaseEffect *effect,
|
|
|
|
guint newpriority);
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2014-06-05 02:05:06 +00:00
|
|
|
gboolean ges_clip_set_top_effect_index (GESClip *clip, GESBaseEffect *effect,
|
|
|
|
guint newindex);
|
2013-03-15 14:58:59 +00:00
|
|
|
|
|
|
|
/****************************************************
|
|
|
|
* Editing *
|
|
|
|
****************************************************/
|
2018-03-13 14:14:57 +00:00
|
|
|
GES_API
|
2013-03-15 14:58:59 +00:00
|
|
|
GESClip* ges_clip_split (GESClip *clip, guint64 position);
|
2013-01-15 13:52:17 +00:00
|
|
|
|
2020-02-21 12:17:11 +00:00
|
|
|
GES_API
|
|
|
|
GstClockTime ges_clip_get_timeline_time_from_source_frame (GESClip * clip,
|
|
|
|
GESFrameNumber frame_number,
|
|
|
|
GError ** err);
|
|
|
|
|
2020-04-13 16:42:22 +00:00
|
|
|
GES_API
|
|
|
|
GstClockTime ges_clip_get_duration_limit (GESClip * clip);
|
|
|
|
|
2020-02-21 12:17:11 +00:00
|
|
|
G_END_DECLS
|