The Assets in the GStreamer Editing Services represent the resources
that can be used. You can create assets for any type that implements the #GESExtractable
interface, for example #GESClips, #GESFormatter, and #GESTrackElement do implement it.
This means that assets will represent for example a #GESUriClips, #GESBaseEffect etc,
and then you can extract objects of those types with the appropriate parameters from the asset
using the #ges_asset_extract method:
|[
GESAsset *effect_asset;
GESEffect *effect;
// You create an asset for an effect
effect_asset = ges_asset_request (GES_TYPE_EFFECT, "agingtv", NULL);
// And now you can extract an instance of GESEffect from that asset
effect = GES_EFFECT (ges_asset_extract (effect_asset));
]|
In that example, the advantages of having a #GESAsset are that you can know what effects
you are working with and let your user know about the avalaible ones, you can add metadata
to the #GESAsset through the #GESMetaContainer interface and you have a model for your
custom effects. Note that #GESAsset management is making easier thanks to the #GESProject class.
Each asset is represented by a pair of @extractable_type and @id (string). Actually the @extractable_type
is the type that implements the #GESExtractable interface, that means that for example for a #GESUriClip,
the type that implements the #GESExtractable interface is #GESClip.
The identifier represents different things depending on the @extractable_type and you should check
the documentation of each type to know what the ID of #GESAsset actually represents for that type. By default,
we only have one #GESAsset per type, and the @id is the name of the type, but this behaviour is overriden
to be more useful. For example, for GESTransitionClips, the ID is the vtype of the transition
you will extract from it (ie crossfade, box-wipe-rc etc..) For #GESEffect the ID is the
@bin-description property of the extracted objects (ie the gst-launch style description of the bin that
will be used).
Each and every #GESAsset is cached into GES, and you can query those with the #ges_list_assets function.
Also the system will automatically register #GESAssets for #GESFormatters and #GESTransitionClips
and standard effects (actually not implemented yet) and you can simply query those calling:
|[
GList *formatter_assets, *tmp;
// List all the transitions
formatter_assets = ges_list_assets (GES_TYPE_FORMATTER);
// Print some infos about the formatter GESAsset
for (tmp = formatter_assets; tmp; tmp = tmp->next) {
g_print ("Name of the formatter: %s, file extension it produces: %s",
ges_meta_container_get_string (GES_META_CONTAINER (tmp->data), GES_META_FORMATTER_NAME),
ges_meta_container_get_string (GES_META_CONTAINER (tmp->data), GES_META_FORMATTER_EXTENSION));
}
g_list_free (transition_assets);
]|
You can request the creation of #GESAssets using either #ges_asset_request_async or
#ges_asset_request_async. All the #GESAssets are cached and thus any asset that has already
been created can be requested again without overhead.
Sets an asset from the internal cache as needing reload. An asset needs reload
in the case where, for example, we were missing a GstPlugin to use it and that
plugin has been installed, or, that particular asset content as changed
meanwhile (in the case of the usage of proxies).
Once an asset has been set as "needs reload", requesting that asset again
will lead to it being re discovered, and reloaded as if it was not in the
cache before.
%TRUE if the asset was in the cache and could be set as needing reload,
%FALSE otherwise.
The #GType of the object that can be extracted from the
asset to be reloaded.
The identifier of the asset to mark as needing reload
Create a #GESAsset in the most simple cases, you should look at the @extractable_type
documentation to see if that constructor can be called for this particular type
As it is recommanded not to instanciate assets for GESUriClip synchronously,
it will not work with this method, but you can instead use the specific
#ges_uri_clip_asset_request_sync method if you really want to.
A reference to the wanted #GESAsset or %NULL
The #GType of the object that can be extracted from the new asset.
The Identifier or %NULL
Request a new #GESAsset asyncronously, @callback will be called when the materail is
ready to be used or if an error occured.
Example of request of a GESAsset async:
|[
// The request callback
static void
asset_loaded_cb (GESAsset * source, GAsyncResult * res, gpointer user_data)
{
GESAsset *asset;
GError *error = NULL;
asset = ges_asset_request_finish (res, &error);
if (asset) {
g_print ("The file: %s is usable as a FileSource",
ges_asset_get_id (asset));
} else {
g_print ("The file: %s is *not* usable as a FileSource because: %s",
ges_asset_get_id (source), error->message);
}
gst_object_unref (mfs);
}
// The request:
ges_asset_request_async (GES_TYPE_URI_CLIP, some_uri, NULL,
(GAsyncReadyCallback) asset_loaded_cb, user_data);
]|
The #GType of the object that can be extracted from the
new asset. The class must implement the #GESExtractable interface.
The Identifier of the asset we want to create. This identifier depends of the extractable,
type you want. By default it is the name of the class itself (or %NULL), but for example for a
GESEffect, it will be the pipeline description, for a GESUriClip it
will be the name of the file, etc... You should refer to the documentation of the #GESExtractable
type you want to create a #GESAsset for.
optional %GCancellable object, %NULL to ignore.
a #GAsyncReadyCallback to call when the initialization is finished,
Note that the @source of the callback will be the #GESAsset, but you need to
make sure that the asset is properly loaded using the #ges_asset_request_finish
method. This asset can not be used as is.
The user data to pass when @callback is called
Finalize the request of an async #GESAsset
The #GESAsset previously requested
The #GAsyncResult from which to get the newly created #GESAsset
Extracts a new #GObject from @asset. The type of the object is
defined by the extractable-type of @asset, you can check what
type will be extracted from @asset using
#ges_asset_get_extractable_type
A newly created #GESExtractable
The #GESAsset to get extract an object from
Extracts a new #GObject from @asset. The type of the object is
defined by the extractable-type of @asset, you can check what
type will be extracted from @asset using
#ges_asset_get_extractable_type
A newly created #GESExtractable
The #GESAsset to get extract an object from
The #GError of the asset or %NULL if
the asset was loaded without issue
The asset to retrieve the error from
Gets the type of object that can be extracted from @self
the type of object that can be extracted from @self
The #GESAsset
Gets the ID of a #GESAsset
The ID of @self
The #GESAsset to get ID from
The proxy in use for @asset
The #GESAsset to get currenlty used proxy
The #GESAsset that is proxied by @proxy
The #GESAsset from which to get the the asset it proxies.
The list of proxies @asset has. Note that the default asset to be
used is always the first in that list.
The #GESAsset to get proxies from
A proxying asset is an asset that can substitue the real @asset. For example if you
have a full HD #GESUriClipAsset you might want to set a lower resolution (HD version
of the same file) as proxy. Note that when an asset is proxied, calling
#ges_asset_request will actually return the proxy asset.
%TRUE if @proxy has been set on @asset, %FALSE otherwise.
The #GESAsset to set proxy on
The #GESAsset that should be used as default proxy for @asset or
%NULL if you want to use the currently set proxy. Note that an asset can proxy one and only
one other asset.
Removes @proxy from the list of known proxies for @asset.
If @proxy was the current proxy for @asset, stop using it.
%TRUE if @proxy was a known proxy for @asset, %FALSE otherwise.
The #GESAsset to stop proxying with @proxy
The #GESAsset to stop considering as a proxy for @asset
A newly created #GESExtractable
The #GESAsset to get extract an object from
## Children Properties
You can use the following children properties through the
#ges_track_element_set_child_property and alike set of methods:
<informaltable frame="none">
<tgroup cols="3">
<colspec colname="properties_type" colwidth="150px"/>
<colspec colname="properties_name" colwidth="200px"/>
<colspec colname="properties_flags" colwidth="400px"/>
<tbody>
<row>
<entry role="property_type"><link linkend="gdouble"><type>double</type></link></entry>
<entry role="property_name"><link linkend="GESAudioSource--volume">volume</link></entry>
<entry>volume factor, 1.0=100%.</entry>
</row>
<row>
<entry role="property_type"><link linkend="gboolean"><type>gboolean</type></link></entry>
<entry role="property_name"><link linkend="GESAudioSource--mute">mute</link></entry>
<entry>mute channel.</entry>
</row>
</tbody>
</tgroup>
</informaltable>
Outputs a test audio stream using audiotestsrc. The default property values
output silence. Useful for testing pipelines, or to fill gaps in an audio
track.
Get the current frequency of @self.
The current frequency of @self.
a #GESAudioTestSource
Get the current volume of @self.
The current volume of @self
a #GESAudioTestSource
Lets you set the frequency applied on the track element
a #GESAudioTestSource
The frequency you want to apply on @self
Sets the volume of the test audio signal.
a #GESAudioTestSource
The volume you want to apply on @self
Sane default properties to specify and fixate the output stream are
set as restriction-caps.
It is advised, to modify these properties, to use
#ges_track_update_restriction_caps, setting them directly is
possible through #ges_track_set_restriction_caps, but not specifying
one of them can lead to negotiation issues, only use that function
if you actually know what you're doing :)
The default properties are:
- format: S32LE
- channels: 2
- rate: 44100
- layout: interleaved
Creates a new #GESAudioTrack of type #GES_TRACK_TYPE_AUDIO and with generic
raw audio caps ("audio/x-raw");
A new #GESTrack
Creates a new #GESAudioTransition.
The newly created #GESAudioTransition.
The location of the file/resource to use.
parent class
The effect will be applied on the sources that have lower priorities
(higher number) between the inpoint and the end of it.
A #GESClip is a 'natural' object which controls one or more
#GESTrackElement(s) in one or more #GESTrack(s).
Keeps a reference to the #GESTrackElement(s) it created and
sets/updates their properties.
the #GESTrackElement to be used, or %NULL if it can't provide one
for the given @track.
a #GESClip
a #GESTrackType
%TRUE on success %FALSE on failure.
a #GESClip
a #GESTrackType
Extracts a #GESTrackElement from @asset and adds it to the @clip.
Should only be called in order to add operations to a #GESClip,
ni other cases TrackElement are added automatically when adding the
#GESClip/#GESAsset to a layer.
Takes a reference on @track_element.
Created #GESTrackElement or NULL
if an error happened
a #GESClip
a #GESAsset with #GES_TYPE_TRACK_ELEMENT as extractable_type
Finds the #GESTrackElement controlled by @clip that is used in @track. You
may optionally specify a GType to further narrow search criteria.
Note: If many objects match, then the one with the highest priority will be
returned.
The #GESTrackElement used by @track,
else %NULL. Unref after usage
a #GESClip
a #GESTrack or NULL
a #GType indicating the type of track element you are looking
for or %G_TYPE_NONE if you do not care about the track type.
Finds all the #GESTrackElement controlled by @clip that is used in @track. You
may optionally specify a GType to further narrow search criteria.
a #GList of the
#GESTrackElement contained in @clip.
The refcount of the objects will be increased. The user will have to
unref each #GESTrackElement and free the #GList.
a #GESClip
a #GESTrack or NULL
a #GESTrackType indicating the type of tracks in which elements
should be searched.
a #GType indicating the type of track element you are looking
for or %G_TYPE_NONE if you do not care about the track type.
Get the #GESLayer to which this clip belongs.
The #GESLayer where this @clip is being
used, or %NULL if it is not used on any layer. The caller should unref it
usage.
a #GESClip
Get the formats supported by @clip.
The formats supported by @clip.
the #GESClip
Gets the index position of an effect.
The top index of the effect, -1 if something went wrong.
The origin #GESClip
The #GESBaseEffect we want to get the top index from
Get effects applied on @clip
a #GList of the
#GESBaseEffect that are applied on @clip order by ascendant priorities.
The refcount of the objects will be increased. The user will have to
unref each #GESBaseEffect and free the #GList.
The origin #GESClip
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.
%TRUE if @clip could be moved %FALSE otherwize
a #GESClip
the new #GESLayer
Sets the formats supported by the file.
the #GESClip to set supported formats on
the #GESTrackType defining formats supported by @clip
This is a convenience method that lets you set the index of a top effect.
%TRUE if @effect was successfuly moved, %FALSE otherwise.
The origin #GESClip
The #GESBaseEffect to move
the new index at which to move the @effect inside this
#GESClip
The function modifies @clip, and creates another #GESClip so we have two
clips at the end, splitted at the time specified by @position, as a position
in the timeline (not in the clip to be split). For example, if
ges_clip_split is called on a 4-second clip playing from 0:01.00 until
0:05.00, with a split position of 0:02.00, this will result in one clip of 1
second and one clip of 3 seconds, not in two clips of 2 seconds.
The newly created clip will be added to the same layer as @clip is in. This
implies that @clip must be in a #GESLayer for the operation to be possible.
This method supports clips playing at a different tempo than one second per
second. For example, splitting a clip with a #GESEffect 'pitch tempo=1.5'
four seconds after it starts, will set the inpoint of the new clip to six
seconds after that of the clip to split. For this, the rate-changing
property must be registered using @ges_effect_class_register_rate_property;
for the 'pitch' plugin, this is already done.
The newly created #GESClip resulting
from the splitting or %NULL if the clip can't be split.
the #GESClip to split
a #GstClockTime representing the timeline position at which to split
The GESLayer where this clip is being used. If you want to connect to its
notify signal you should connect to it with g_signal_connect_after as the
signal emission can be stop in the first fase.
The formats supported by the clip.
The #GESUriClipAsset is a special #GESAsset specilized in #GESClip.
it is mostly used to get information about the #GESTrackType-s the objects extracted
from it can potentialy create #GESTrackElement for.
Gets track types for which objects extracted from @self can create #GESTrackElement
The track types on which @self will create TrackElement when added to
a layer
a #GESClipAsset
Sets track types for which objects extracted from @self can create #GESTrackElement
a #GESClipAsset
The track types supported by the GESClipAsset
The formats supported by the asset.
Subclasses can override the @create_track_element.
method to create a single #GESTrackElement for a given #GESTrack.
method to create multiple #GESTrackElements for a
#GESTrack.
The #GESContainer base class.
Groups the #GESContainer-s provided in @containers. It creates a subclass
of #GESContainer, depending on the containers provided in @containers.
Basically, if all the containers in @containers should be contained in a same
clip (all the #GESTrackElement they contain have the exact same
start/inpoint/duration and are in the same layer), it will create a #GESClip
otherwise a #GESGroup will be created
The #GESContainer (subclass) resulting of the
grouping
The
#GESContainer to group, they must all be in a same #GESTimeline
Edit @container in the different exisiting #GESEditMode modes. In the case of
slide, and roll, you need to specify a #GESEdge
%TRUE if the container as been edited properly, %FALSE if an error
occured
the #GESClip to edit
The layers you want the edit to
happen in, %NULL means that the edition is done in all the
#GESLayers contained in the current timeline.
The priority of the layer @container should land in.
If the layer you're trying to move the container to doesn't exist, it will
be created automatically. -1 means no move.
The #GESEditMode in which the editition will happen.
The #GESEdge the edit should happen on.
The position at which to edit @container (in nanosecond)
Ungroups the #GESTimelineElement contained in this GESContainer,
creating new #GESContainer containing those #GESTimelineElement
apropriately.
The list of
#GESContainer resulting from the ungrouping operation
The user is responsible for unreffing the contained objects
and freeing the list.
The #GESContainer to ungroup
Wether to recursively ungroup @container
Add the #GESTimelineElement to the container.
%TRUE on success, %FALSE on failure.
a #GESContainer
the #GESTimelineElement
Edit @container in the different exisiting #GESEditMode modes. In the case of
slide, and roll, you need to specify a #GESEdge
%TRUE if the container as been edited properly, %FALSE if an error
occured
the #GESClip to edit
The layers you want the edit to
happen in, %NULL means that the edition is done in all the
#GESLayers contained in the current timeline.
The priority of the layer @container should land in.
If the layer you're trying to move the container to doesn't exist, it will
be created automatically. -1 means no move.
The #GESEditMode in which the editition will happen.
The #GESEdge the edit should happen on.
The position at which to edit @container (in nanosecond)
Get the list of #GESTimelineElement contained in @container
The user is responsible for unreffing the contained objects
and freeing the list.
The list of
timeline element contained in @container.
a #GESContainer
Whether to recursively get children in @container
Release the @child from the control of @container.
%TRUE if the @child was properly released, else %FALSE.
a #GESContainer
the #GESTimelineElement to release
Ungroups the #GESTimelineElement contained in this GESContainer,
creating new #GESContainer containing those #GESTimelineElement
apropriately.
The list of
#GESContainer resulting from the ungrouping operation
The user is responsible for unreffing the contained objects
and freeing the list.
The #GESContainer to ungroup
Wether to recursively ungroup @container
The span of priorities which this container occupies.
A list of TimelineElement
controlled by this Container. NOTE: Do not modify.
The span of priorities this container occupies
Will be emitted after a child was added to @container.
Usually you should connect with #g_signal_connect_after
as in the first emission stage, the signal emission might
get stopped internally.
the #GESTimelineElement that was added.
Will be emitted after a child was removed from @container.
the #GESTimelineElement that was removed.
The list of
#GESContainer resulting from the ungrouping operation
The user is responsible for unreffing the contained objects
and freeing the list.
The #GESContainer to ungroup
Wether to recursively ungroup @container
%TRUE if the container as been edited properly, %FALSE if an error
occured
the #GESClip to edit
The layers you want the edit to
happen in, %NULL means that the edition is done in all the
#GESLayers contained in the current timeline.
The priority of the layer @container should land in.
If the layer you're trying to move the container to doesn't exist, it will
be created automatically. -1 means no move.
The #GESEditMode in which the editition will happen.
The #GESEdge the edit should happen on.
The position at which to edit @container (in nanosecond)
A function that will be called to create the #GstElement that will be used
as a source to fill the gaps in @track.
A #GstElement (must be a source) that will be used to
fill the gaps (periods of time in @track that containes no source).
the #GESTrack
Creates the 'primary' track element for this @clip.
Subclasses should implement this method if they only provide a
single #GESTrackElement per track.
If the subclass needs to create more than one #GESTrackElement for a
given track, then it should implement the 'create_track_elements'
method instead.
The implementer of this function shall return the proper #GESTrackElement
that should be controlled by @clip for the given @track.
The returned #GESTrackElement will be automatically added to the list
of objects controlled by the #GESClip.
the #GESTrackElement to be used, or %NULL if it can't provide one
for the given @track.
a #GESClip
a #GESTrackType
Create all track elements this clip handles for this type of track.
Subclasses should implement this method if they potentially need to
return more than one #GESTrackElement(s) for a given #GESTrack.
%TRUE on success %FALSE on failure.
a #GESClip
a #GESTrackType
The edges of an object contain in a #GESTimeline or #GESTrack
Represents the start of an object.
Represents the end of an object.
Represent the fact we are not workin with any edge of an
object.
You can also find more explanation about the behaviour of those modes at:
<ulink url="http://pitivi.org/manual/trimming.html"> trim, ripple and roll</ulink>
and <ulink url="http://pitivi.org/manual/usingclips.html">clip management</ulink>.
The object is edited the normal way (default).
The objects are edited in ripple mode.
The Ripple mode allows you to modify the beginning/end of a clip
and move the neighbours accordingly. This will change the overall
timeline duration. In the case of ripple end, the duration of the
clip being rippled can't be superior to its max_duration - inpoint
otherwise the action won't be executed.
The object is edited in roll mode.
The Roll mode allows you to modify the position of an editing point
between two clips without modifying the inpoint of the first clip
nor the out-point of the second clip. This will not change the
overall timeline duration.
The object is edited in trim mode.
The Trim mode allows you to modify the in-point/duration of a clip
without modifying its position in the timeline.
The object is edited in slide mode.
The Slide mode allows you to modify the position of a clip in a
timeline without modifying its duration or its in-point, but will
modify the duration of the previous clip and in-point of the
following clip so does not modify the overall timeline duration.
(not implemented yet)
Creates a new #GESEffect from the description of the bin. It should be
possible to determine the type of the effect through the element
'klass' metadata of the GstElements that will be created.
In that corner case, you should use:
#ges_asset_request (GES_TYPE_EFFECT, "audio your ! bin ! description", NULL);
and extract that asset to be in full control.
a newly created #GESEffect, or %NULL if something went
wrong.
The gst-launch like bin description of the effect
The description of the effect bin with a gst-launch-style
pipeline description.
Example: "videobalance saturation=1.5 hue=+0.5"
parent class
Register an element that can change the rate at which media is playing. The
property type must be float or double, and must be a factor of the rate,
i.e. a value of 2.0 must mean that the media plays twice as fast. For
example, this is true for the properties 'rate' and 'tempo' of the element
'pitch', which is already registered by default. By registering the element,
timeline duration can be correctly converted into media duration, allowing
the right segment seeks to be sent to the sources.
A reference to the GESEffectClass can be obtained as follows:
GES_EFFECT_CLASS (g_type_class_ref (GES_TYPE_EFFECT));
whether the rate property was succesfully registered. When this
method returns false, a warning is emitted with more information.
Instance of the GESEffectClass
Name of the GstElement that changes the rate
Name of the property that changes the rate
The effect will be applied on the sources that have lower priorities
(higher number) between the inpoint and the end of it.
Creates a new #GESEffectClip from the description of the bin.
a newly created #GESEffectClip, or
%NULL if something went wrong.
The gst-launch like bin description of the effect
The gst-launch like bin description of the effect
The description of the audio track of the effect bin with a gst-launch-style
pipeline description. This should be used for test purposes.
Example: "audiopanorama panorama=1.0"
The description of the video track of the effect bin with a gst-launch-style
pipeline description. This should be used for test purposes.
Example: "videobalance saturation=1.5 hue=+0.5"
The ID passed is malformed
An error happened while loading the asset
The formatted files was malformed
FIXME: Long description needed
The #id of the associated #GESAsset, free with #g_free
The #GESExtractable
Method for getting an asset from a #GESExtractable
The #GESAsset or %NULL if none has
been set
The #GESExtractable from which to retrieve a #GESAsset
The #id of the associated #GESAsset, free with #g_free
The #GESExtractable
Method to set the asset which instantiated the specified object
%TRUE if @asset could be set %FALSE otherwize
Target object
The #GESAsset to set
The ID to use for the asset or %NULL if @id is not valid
The #GType to check @id for:
The id to check
The #id of the associated #GESAsset, free with #g_free
The #GESExtractable
A function that will be called when the GNonLin object of a corresponding
track element needs to be filled.
The implementer of this function shall add the proper #GstElement to @nleobj
using gst_bin_add().
TRUE if the implementer succesfully filled the @nleobj, else #FALSE.
the #GESClip controlling the track elements
the #GESTrackElement
the GNonLin object that needs to be filled.
Base class for timeline data serialization and deserialization.
Checks if there is a #GESFormatter available which can load a #GESTimeline
from the given URI.
TRUE if there is a #GESFormatter that can support the given uri
or FALSE if not.
a #gchar * pointing to the URI
Returns TRUE if there is a #GESFormatter available which can save a
#GESTimeline to the given URI.
TRUE if the given @uri is supported, else FALSE.
a #gchar * pointing to a URI
Get the default #GESAsset to use as formatter. It will return
the asset for the #GESFormatter that has the highest @rank
The #GESAsset for the formatter with highest @rank
Load data from the given URI into timeline.
TRUE if the timeline data was successfully loaded from the URI,
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
Save data from timeline to the given URI.
TRUE if the timeline data was successfully saved to the URI
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
%TRUE to overwrite file if it exists
Load data from the given URI into timeline.
TRUE if the timeline data was successfully loaded from the URI,
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
Save data from timeline to the given URI.
TRUE if the timeline data was successfully saved to the URI
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
%TRUE to overwrite file if it exists
GES Formatter class. Override the vmethods to implement the formatter functionnality.
the parent class structure
Whether the URI can be loaded
class method to deserialize data from a URI
class method to serialize data to a URI
Virtual method for loading a timeline from a given URI.
Every #GESFormatter subclass needs to implement this method.
TRUE if the timeline data was successfully loaded from the URI,
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
Virtual method for saving a timeline to a uri.
Every #GESFormatter subclass needs to implement this method.
TRUE if the timeline data was successfully saved to the URI
else FALSE.
a #GESFormatter
a #GESTimeline
a #gchar * pointing to a URI
%TRUE to overwrite file if it exists
A #GESGroup is an object which controls one or more
#GESClips in one or more #GESLayer(s).
To instanciate a group, you should use the ges_container_group method,
this will be responsible for deciding what subclass of #GESContainer
should be instaciated to group the various #GESTimelineElement passed
in parametter.
Created a new empty #GESGroup, if you want to group several container
together, it is recommanded to use the #ges_container_group method so the
proper subclass is selected.
The new empty group.
The duration (in nanoseconds) which will be used in the container
The in-point at which this #GESGroup will start outputting data
from its contents (in nanoseconds).
Ex : an in-point of 5 seconds means that the first outputted buffer will
be the one located 5 seconds in the controlled resource.
The maximum duration (in nanoseconds) of the #GESGroup.
The position of the object in its container (in nanoseconds).
Outputs the video stream from a given file as a still frame. The frame
chosen will be determined by the in-point property on the track element. For
image files, do not set the in-point property.
The location of the file/resource to use.
Responsible for the ordering of the various contained Clip(s). A
timeline layer has a "priority" property, which is used to manage the
priorities of individual Clips. Two layers should not have the
same priority within a given timeline.
Creates a new #GESLayer.
A new #GESLayer
Creates Clip from asset, adds it to layer and
returns a reference to it.
Created #GESClip
a #GESLayer
The asset to add to
The start value to set on the new #GESClip,
if @start == GST_CLOCK_TIME_NONE, it will be set to
the current duration of @layer
The inpoint value to set on the new #GESClip
The duration value to set on the new #GESClip
The #GESTrackType to set on the the new #GESClip
Adds the given clip to the layer. Sets the clip's parent, and thus
takes ownership of the clip.
An clip can only be added to one layer.
Calling this method will construct and properly set all the media related
elements on @clip. If you need to know when those objects (actually #GESTrackElement)
are constructed, you should connect to the container::child-added signal which
is emited right after those elements are ready to be used.
%TRUE if the clip was properly added to the layer, or %FALSE
if the @layer refuses to add the clip.
a #GESLayer
the #GESClip to add.
Gets whether transitions are automatically added when objects
overlap or not.
%TRUE if transitions are automatically added, else %FALSE.
a #GESLayer
Get the clips this layer contains.
a #GList of
clips. The user is responsible for
unreffing the contained objects and freeing the list.
a #GESLayer
Gets the clips which appear between @start and @end on @layer.
a #GList of clips intersecting [@start, @end) interval on @layer.
a #GESLayer
start of the interval
end of the interval
Lets you retrieve the duration of the layer, which means
the end time of the last clip inside it
The duration of a layer
The #GESLayer to get the duration from
Get the priority of @layer within the timeline.
The priority of the @layer within the timeline.
a #GESLayer
Get the #GESTimeline in which #GESLayer currently is.
the #GESTimeline in which #GESLayer
currently is or %NULL if not in any timeline yet.
The #GESLayer to get the parent #GESTimeline from
Convenience method to check if @layer is empty (doesn't contain any clip),
or not.
%TRUE if @layer is empty, %FALSE if it already contains at least
one #GESClip
The #GESLayer to check
Removes the given @clip from the @layer and unparents it.
Unparenting it means the reference owned by @layer on the @clip will be
removed. If you wish to use the @clip after this function, make sure you
call gst_object_ref() before removing it from the @layer.
%TRUE if the clip could be removed, %FALSE if the layer does
not want to remove the clip.
a #GESLayer
the #GESClip to remove
Sets the layer to the given @auto_transition. See the documentation of the
property auto_transition for more information.
a #GESLayer
whether the auto_transition is active
Sets the layer to the given @priority. See the documentation of the
priority property for more information.
a #GESLayer
the priority to set
Sets whether transitions are added automagically when clips overlap.
The priority of the layer in the #GESTimeline. 0 is the highest
priority. Conceptually, a #GESTimeline is a stack of GESLayers,
and the priority of the layer represents its position in the stack. Two
layers should not have the same priority within a given GESTimeline.
Note that the timeline needs to be commited (with #ges_timeline_commit)
for the change to be taken into account.
the #GESTimeline where this layer is being used.
Will be emitted after the clip was added to the layer.
the #GESClip that was added.
Will be emitted after the clip was removed from the layer.
the #GESClip that was removed
Subclasses can override the @get_objects if they can provide a more
efficient way of providing the list of contained #GESClip(s).
The description of an object, can be used in various context (string)
The description
The extension of the files produced by a formatter (string)
Mimetype used for the file produced by a formatter (string)
The mime type
Name of a formatter it is used as ID of Formater assets (string)
The name of the formatter
The rank of a formatter (GstRank)
The rank of a formatter
The version of a formatter (double)
The formatter version
The version of the format in which a project is serialized
The volume, can be used for audio track or layers
The volume for a track or a layer, it is register as a float
The default volume
The default volume for a track or a layer as a float
Interface that allows reading and writing meta
Deserializes a meta container.
TRUE on success, FALSE if there was an error.
Target container
a string created with ges_meta_container_metas_to_string()
Calls the given function for each metadata inside the meta container. Note
that if there is no metadata, the function won't be called at all.
container to iterate over
function to be called for each metadata
user specified data
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns FALSE if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns %FALSE if @meta_item
can not be found.
Gets the value of a given meta item, returns NULL if @key
can not be found.
the #GValue corresponding to the meta with the given @key.
Target container
The key name of the meta to retrieve
Target container
Name of the meta item to get
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Target container
Name of the meta item to get
Destination to which value of meta item will be copied
Gets the value of a given meta item, returns NULL if @meta_item
can not be found.
Serializes a meta container to a string.
a newly-allocated string, or NULL in case of an error.
The string must be freed with g_free() when no longer needed.
a #GESMetaContainer
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the static meta could be added, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets a static meta on @container. This method lets you define static
metadatas, which means that the type of the registered will be the only
type accepted for this meta on that particular @container.
%TRUE if the meta could be register, %FALSE otherwize
Target container
The #GESMetaFlag to be used
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
Sets the value of a given meta item
%TRUE if the meta could be added, %FALSE otherwize
Target container
Name of the meta item to set
Value to set
The metadata is readable
The metadata is writable
The metadata is readable and writable
Outputs the video stream from a given image sequence. The start frame
chosen will be determined by the in-point property on the track element.
Creates a new #GESMultiFileSource for the provided @uri.
A new #GESMultiFileSource.
the URI the source should control
The uri of the file/resource to use. You can set a start index,
a stop index and a sequence pattern.
The format is <multifile://start:stop\@location-pattern>.
The pattern uses printf string formating.
Example uris:
multifile:///home/you/image\%03d.jpg
multifile://20:50@/home/you/sequence/\%04d.png
Base class for overlays, transitions, and effects
Operations are any kind of object that both outputs AND consumes data.
Overlays are objects which modify the underlying layer(s).
Examples of overlays include text, image watermarks, or audio dubbing.
Transitions, which change from one source to another over time, are
not considered overlays.
parent class
#GESPipeline allows developers to view and render #GESTimeline
in a simple fashion.
Its usage is inspired by the 'playbin' element from gst-plugins-base.
Creates a new conveninence #GESPipeline.
the new #GESPipeline.
the #GESPipelineFlags currently in use.
a #GESPipeline
Returns a #GstSample with the currently playing image in the format specified by
caps. The caller should free the sample with #gst_sample_unref when finished. If ANY
caps are specified, the information will be returned in the whatever format
is currently used by the sink. This information can be retrieve from caps
associated with the buffer.
a #GstSample or %NULL
a #GESPipeline in %GST_STATE_PLAYING or %GST_STATE_PAUSED
caps specifying current format. Use %GST_CAPS_ANY
for native size.
A convenience method for @ges_pipeline_get_thumbnail which
returns a buffer in 24-bit RGB, optionally scaled to the specified width
and height. If -1 is specified for either dimension, it will be left at
native size. You can retreive this information from the caps associated
with the buffer.
The caller is responsible for unreffing the returned sample with
#gst_sample_unref.
a #GstSample or %NULL
a #GESPipeline in %GST_STATE_PLAYING or %GST_STATE_PAUSED
the requested width or -1 for native size
the requested height or -1 for native size
Obtains a pointer to playsink's audio sink element that is used for
displaying audio when the #GESPipeline is in %GES_PIPELINE_MODE_PREVIEW
The caller is responsible for unreffing the returned element with
#gst_object_unref.
a pointer to the playsink audio sink #GstElement
a #GESPipeline
Obtains a pointer to playsink's video sink element that is used for
displaying video when the #GESPipeline is in %GES_PIPELINE_MODE_PREVIEW
The caller is responsible for unreffing the returned element with
#gst_object_unref.
a pointer to the playsink video sink #GstElement
a #GESPipeline
Sets playsink's audio sink element that is used for displaying audio when
the #GESPipeline is in %GES_PIPELINE_MODE_PREVIEW
a #GESPipeline in %GST_STATE_NULL
a audio sink #GstElement
Sets playsink's video sink element that is used for displaying video when
the #GESPipeline is in %GES_PIPELINE_MODE_PREVIEW
a #GESPipeline in %GST_STATE_NULL
a video sink #GstElement
Saves the current frame to the specified @location.
%TRUE if the thumbnail was properly save, else %FALSE.
a #GESPipeline in %GST_STATE_PLAYING or %GST_STATE_PAUSED
the requested width or -1 for native size
the requested height or -1 for native size
a string specifying the desired mime type (for example,
image/jpeg)
the path to save the thumbnail
switches the @pipeline to the specified @mode. The default mode when
creating a #GESPipeline is #GES_PIPELINE_MODE_PREVIEW.
Note: The @pipeline will be set to #GST_STATE_NULL during this call due to
the internal changes that happen. The caller will therefore have to
set the @pipeline to the requested state after calling this method.
%TRUE if the mode was properly set, else %FALSE.
a #GESPipeline
the #GESPipelineFlags to use
Specify where the pipeline shall be rendered and with what settings.
A copy of @profile and @output_uri will be done internally, the caller can
safely free those values afterwards.
This method must be called before setting the pipeline mode to
#GES_PIPELINE_MODE_RENDER
%TRUE if the settings were aknowledged properly, else %FALSE
a #GESPipeline
the URI to which the timeline will be rendered
the #GstEncodingProfile to use to render the timeline.
Sets the timeline to use in this pipeline.
The reference to the @timeline will be stolen by the @pipeline.
%TRUE if the @timeline could be successfully set on the @pipeline,
else %FALSE.
a #GESPipeline
the #GESTimeline to set on the @pipeline.
Audio sink for the preview.
Pipeline mode. See ges_pipeline_set_mode() for more
info.
Timeline to use in this pipeline. See also
ges_pipeline_set_timeline() for more info.
Video sink for the preview.
parent class
The various modes the #GESPipeline can be configured to.
output audio to the soundcard
output video to the screen
output audio/video to soundcard/screen (default)
render timeline (forces decoding)
render timeline (tries to avoid decoding/reencoding)
This is a legacy format and you should avoid to use it. The formatter
is really not in good shape and is deprecated.
The #GESProject is used to control a set of #GESAsset and is a
#GESAsset with #GES_TYPE_TIMELINE as @extractable_type itself. That
means that you can extract #GESTimeline from a project as followed:
|[
GESProject *project;
GESTimeline *timeline;
project = ges_project_new ("file:///path/to/a/valid/project/uri");
// Here you can connect to the various signal to get more infos about
// what is happening and recover from errors if possible
...
timeline = ges_asset_extract (GES_ASSET (project));
]|
The #GESProject class offers a higher level API to handle #GESAsset-s.
It lets you request new asset, and it informs you about new assets through
a set of signals. Also it handles problem such as missing files/missing
#GstElement and lets you try to recover from those.
Creates a new #GESProject and sets its uri to @uri if provided. Note that
if @uri is not valid or %NULL, the uri of the project will then be set
the first time you save the project. If you then save the project to
other locations, it will never be updated again and the first valid URI is
the URI it will keep refering to.
A newly created #GESProject
The uri to be set after creating the project.
Adds a #Asset to @project, the project will keep a reference on
@asset.
%TRUE if the asset could be added %FALSE it was already
in the project
A #GESProject
A #GESAsset to add to @project
Adds @profile to the project. It lets you save in what format
the project has been renders and keep a reference to those formats.
Also, those formats will be saves to the project file when possible.
%TRUE if @profile could be added, %FALSE otherwize
A #GESProject
A #GstEncodingProfile to add to the project. If a profile with
the same name already exists, it will be replaced
Create and add a #GESAsset to @project. You should connect to the
"asset-added" signal to get the asset when it finally gets added to
@project
%TRUE if the asset started to be added %FALSE it was already
in the project
A #GESProject
The id of the asset to create and add to @project
The #GType of the asset to create
Create and add a #GESAsset to @project. You should connect to the
"asset-added" signal to get the asset when it finally gets added to
@project
The newly created #GESAsset or %NULL.
A #GESProject
The id of the asset to create and add to @project
The #GType of the asset to create
The #GESAsset with
@id or %NULL if no asset with @id as an ID
A #GESProject
The id of the asset to retrieve
The extractable_type of the asset
to retrieve from @object
Get the assets that are being loaded
A set of loading asset
that will be added to @project. Note that those Asset are *not* loaded yet,
and thus can not be used
A #GESProject
Retrieve the uri that is currently set on @project
a newly allocated string representing uri.
A #GESProject
List all @asset contained in @project filtering per extractable_type
as defined by @filter. It copies the asset and thus will not be updated
in time.
The list of
#GESAsset the object contains
A #GESProject
Type of assets to list, #GES_TYPE_EXTRACTABLE will list
all assets
Lists the encoding profile that have been set to @project. The first one
is the latest added.
The
list of #GstEncodingProfile used in @project
A #GESProject
Loads @project into @timeline
%TRUE if the project could be loaded %FALSE otherwize.
A #GESProject that has an @uri set already
A blank timeline to load @project into
remove a @asset to from @project.
%TRUE if the asset could be removed %FALSE otherwise
A #GESProject
A #GESAsset to remove from @project
Save the timeline of @project to @uri. You should make sure that @timeline
is one of the timelines that have been extracted from @project
(using ges_asset_extract (@project);)
%TRUE if the project could be save, %FALSE otherwize
A #GESProject to save
The #GESTimeline to save, it must have been extracted from @project
The uri where to save @project and @timeline
The formatter asset to use or %NULL. If %NULL,
will try to save in the same format as the one from which the timeline as been loaded
or default to the formatter with highest rank
%TRUE to overwrite file if it exists
The #GESAsset that has been added to @project
The #GESAsset that started loading
The #GESAsset that has been removed from @project
Informs you that a #GESAsset could not be created. In case of
missing GStreamer plugins, the error will be set to #GST_CORE_ERROR
#GST_CORE_ERROR_MISSING_PLUGIN
The #GError defining the error that accured, might be %NULL
The @id of the asset that failed loading
The @extractable_type of the asset that
failed loading
The #GESTimeline that complete loading
|[
static gchar
source_moved_cb (GESProject *project, GError *error, GESAsset *asset_with_error)
{
return g_strdup ("file:///the/new/uri.ogg");
}
static int
main (int argc, gchar ** argv)
{
GESTimeline *timeline;
GESProject *project = ges_project_new ("file:///some/uri.xges");
g_signal_connect (project, "missing-uri", source_moved_cb, NULL);
timeline = ges_asset_extract (GES_ASSET (project));
}
]|
The new URI of @wrong_asset
The error that happened
The asset with the wrong ID, you should us it and its content
only to find out what the new location is.
Base class for single-media sources
Base class for sources of a #GESLayer
Useful for testing purposes.
You can use the ges_asset_request_simple API to create an Asset
capable of extracting GESTestClip-s
Creates a new #GESTestClip.
The newly created #GESTestClip,
or %NULL if there was an error.
Creates a new #GESTestClip for the provided @nick.
The newly created #GESTestClip,
or %NULL if there was an error.
the nickname for which to create the #GESTestClip
Get the frequency @self generates.
The frequency @self generates. See audiotestsrc element.
a #GESTestClip
Get the volume of the test audio signal applied on @self.
The volume of the test audio signal applied on @self.
a #GESTestClip
Get the #GESVideoTestPattern which is applied on @self.
The #GESVideoTestPattern which is applied on @self.
a #GESTestClip
Let you know if the audio track of @self is muted or not.
Whether the audio track of @self is muted or not.
a #GESTestClip
Sets the frequency to generate. See audiotestsrc element.
the #GESTestClip to set the frequency on
the frequency you want to use on @self
Sets whether the audio track of this clip is muted or not.
the #GESTestClip on which to mute or unmute the audio track
%TRUE to mute the audio track, %FALSE to unmute it
Sets the volume of the test audio signal.
the #GESTestClip to set the volume on
the volume of the audio signal you want to use on @self
Sets which video pattern to display on @self.
the #GESTestClip to set the pattern on
the #GESVideoTestPattern to use on @self
The frequency to generate for audio track elements.
Whether the sound will be played or not.
The volume for the audio track elements.
Video pattern to display in video track elements.
Horizontal alignment of the text.
align text left
align text center
align text right
align text on xpos position
Creates a new #GESTextOverlay.
The newly created #GESTextOverlay or
%NULL if something went wrong.
Get the color used by @source.
The color used by @source.
a GESTextOverlay
Get the pango font description currently set on @source.
The pango font description currently set on @source.
a GESTextOverlay
Get the horizontal aligment used by @source.
The horizontal aligment used by @source.
a GESTextOverlay
Get the text currently set on @source.
The text currently set on @source.
a GESTextOverlay
Get the vertical aligment used by @source.
The vertical aligment used by @source.
a GESTextOverlay
Get the horizontal position used by @source.
The horizontal position used by @source.
a GESTextOverlay
Get the vertical position used by @source.
The vertical position used by @source.
a GESTextOverlay
Sets the color of the text.
the #GESTextOverlay* to set
The color @self is being set to
Sets the pango font description of the text this track element
will render.
the #GESTextOverlay
the pango font description
Sets the horizontal aligment of the text.
the #GESTextOverlay* to set text on
The #GESTextHAlign defining the horizontal alignment
of the text render by @self.
Sets the text this track element will render.
the #GESTextOverlay* to set text on
the text to render. an internal copy of this text will be
made.
Sets the vertical aligment of the text.
the #GESTextOverlay* to set text on
The #GESTextVAlign defining the vertical alignment
of the text render by @self.
Sets the horizontal position of the text.
the #GESTextOverlay* to set
The horizontal position @self is being set to
Sets the vertical position of the text.
the #GESTextOverlay* to set
The vertical position @self is being set to
Renders text onto the next lower priority stream using textrender.
Creates a new #GESTextOverlayClip
The newly created
#GESTextOverlayClip, or %NULL if there was an error.
Get the color used by @source.
The color used by @source.
a #GESTextOverlayClip
Get the pango font description used by @self.
The pango font description used by @self.
a #GESTextOverlayClip
Get the horizontal aligment used by @self.
The horizontal aligment used by @self.
a #GESTextOverlayClip
Get the text currently set on @self.
The text currently set on @self.
a #GESTextOverlayClip
Get the vertical aligment used by @self.
The vertical aligment used by @self.
a #GESTextOverlayClip
Get the horizontal position used by @source.
The horizontal position used by @source.
a #GESTextOverlayClip
Get the vertical position used by @source.
The vertical position used by @source.
a #GESTextOverlayClip
Sets the color of the text.
the #GESTextOverlayClip* to set
The color @self is being set to
Sets the pango font description of the text
the #GESTextOverlayClip*
the pango font description
Sets the horizontal aligment of the text.
the #GESTextOverlayClip* to set horizontal alignement of text on
#GESTextHAlign
Sets the text this clip will render.
the #GESTextOverlayClip* to set text on
the text to render. an internal copy of this text will be
made.
Sets the vertical aligment of the text.
the #GESTextOverlayClip* to set vertical alignement of text on
#GESTextVAlign
Sets the horizontal position of the text.
the #GESTextOverlayClip* to set
The horizontal position @self is being set to
Sets the vertical position of the text.
the #GESTextOverlayClip* to set
The vertical position @self is being set to
The color of the text
Pango font description string
Horizontal alignment of the text
The text to diplay
Vertical alignent of the text
The horizontal position of the text
The vertical position of the text
Vertical alignment of the text.
draw text on the baseline
draw text on the bottom
draw text on top
draw text on ypos position
draw text on the center
#GESTimeline is the central object for any multimedia timeline.
Contains a list of #GESLayer which users should use to arrange the
various clips through time.
The output type is determined by the #GESTrack that are set on
the #GESTimeline.
To save/load a timeline, you can use the ges_timeline_load_from_uri() and
ges_timeline_save_to_uri() methods to use the default format. If you wish
Note that any change you make in the timeline will not actually be taken
into account until you call the #ges_timeline_commit method.
Creates a new empty #GESTimeline.
The new timeline.
Creates a new #GESTimeline containing a raw audio and a
raw video track.
The newly created #GESTimeline.
Creates a timeline from the given URI.
A new timeline if the uri was loaded
successfully, or %NULL if the uri could not be loaded.
the URI to load from
Add the layer to the timeline. The reference to the @layer will be stolen
by the @timeline.
%TRUE if the layer was properly added, else %FALSE.
a #GESTimeline
the #GESLayer to add
Add a track to the timeline. The reference to the track will be stolen by the
pipeline.
%TRUE if the track was properly added, else %FALSE.
a #GESTimeline
the #GESTrack to add
Append a newly created #GESLayer to @timeline
Note that you do not own any reference to the returned layer.
The newly created #GESLayer, or the last (empty)
#GESLayer of @timeline.
a #GESTimeline
Commit all the pending changes of the clips contained in the
@timeline.
When changes happen in a timeline, they are not
directly executed in the non-linear engine. Call this method once you are
done with a set of changes and want it to be executed.
The #GESTimeline::commited signal will be emitted when the (possibly updated)
#GstPipeline is ready to output data again, except if the state of the
timeline was #GST_STATE_READY or #GST_STATE_NULL.
Note that all the pending changes will automatically be executed when the
timeline goes from #GST_STATE_READY to #GST_STATE_PAUSED, which usually is
triggered by corresponding state changes in a containing #GESPipeline.
You should not try to change the state of the timeline, seek it or add
tracks to it during a commit operation, that is between a call to this
function and after receiving the #GESTimeline::commited signal.
See #ges_timeline_commit_sync if you don't want to bother with waiting
for the signal.
%TRUE if pending changes were commited or %FALSE if nothing needed
to be commited
a #GESTimeline
Commit all the pending changes of the #GESClips contained in the
@timeline.
Will return once the update is complete, that is when the
(possibly updated) #GstPipeline is ready to output data again, or if the
state of the timeline was #GST_STATE_READY or #GST_STATE_NULL.
This function will wait for any pending state change of the timeline by
calling #gst_element_get_state with a #GST_CLOCK_TIME_NONE timeout, you
should not try to change the state from another thread before this function
has returned.
See #ges_timeline_commit for more information.
%TRUE if pending changes were commited or %FALSE if nothing needed
to be commited
a #GESTimeline
Gets whether transitions are automatically added when objects
overlap or not.
%TRUE if transitions are automatically added, else %FALSE.
a #GESTimeline
Get the current duration of @timeline
The current duration of @timeline
a #GESTimeline
Gets a #GESTimelineElement contained in the timeline
The #GESTimelineElement or %NULL if
not found.
a #GESTimeline
Get the list of #GESGroup present in the Timeline.
the list of
#GESGroup that contain clips present in the timeline's layers.
Must not be changed.
a #GESTimeline
Retrieve the layer with @priority as a priority
A #GESLayer or %NULL if no layer with
@priority was found
Since 1.6
The #GESTimeline to retrive a layer from
The priority of the layer to find
Get the list of #GESLayer present in the Timeline.
the list of
#GESLayer present in the Timeline sorted by priority.
The caller should unref each Layer once he is done with them.
a #GESTimeline
Search the #GstPad corresponding to the given @timeline's @track.
The corresponding #GstPad if it is
found, or %NULL if there is an error.
The #GESTimeline
The #GESTrack
Gets the configured snapping distance of the timeline. See
the documentation of the property snapping_distance for more
information.
The @snapping_distance property of the timeline
a #GESTimeline
Search the #GESTrack corresponding to the given @timeline's @pad.
The corresponding #GESTrack if it is
found, or %NULL if there is an error.
The #GESTimeline
The #GstPad
Returns the list of #GESTrack used by the Timeline.
A list of #GESTrack.
The caller should unref each track once he is done with them.
a #GESTimeline
Check whether a #GESTimeline is empty or not
%TRUE if the timeline is empty %FALSE otherwize
a #GESTimeline
Loads the contents of URI into the given timeline.
%TRUE if the timeline was loaded successfully, or %FALSE if the uri
could not be loaded.
an empty #GESTimeline into which to load the formatter
The URI to load from
Paste @element inside the timeline. @element must have been
created using ges_timeline_element_copy with deep=TRUE set,
i.e. it must be a deep copy, otherwise it will fail.
Shallow copy of the @element pasted
The #GESTimeline onto which the #GESTimelineElement should be pasted
The #GESTimelineElement to paste
The position in the timeline the element should
be pasted to, meaning it will become the start of @element
The #GESLayer to which the element should be pasted to.
-1 means paste to the same layer from which the @element has been copied from.
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
method, you need to take a reference before calling.
%TRUE if the layer was properly removed, else %FALSE.
a #GESTimeline
the #GESLayer to remove
Remove the @track from the @timeline. The reference stolen when adding the
@track will be removed. If you wish to use the @track after calling this
function you must ensure that you have a reference to it.
%TRUE if the @track was properly removed, else %FALSE.
a #GESTimeline
the #GESTrack to remove
Saves the timeline to the given location
%TRUE if the timeline was successfully saved to the given location,
else %FALSE.
a #GESTimeline
The location to save to
The formatter asset to use or %NULL. If %NULL,
will try to save in the same format as the one from which the timeline as been loaded
or default to the formatter with highest rank
%TRUE to overwrite file if it exists
Sets the layer to the given @auto_transition. See the documentation of the
property auto_transition for more information.
a #GESLayer
whether the auto_transition is active
Sets the @snapping_distance of the timeline. See the documentation of the
property snapping_distance for more information.
a #GESLayer
whether the snapping_distance is active
Sets whether transitions are added automagically when clips overlap.
Current duration (in nanoseconds) of the #GESTimeline
Distance (in nanoseconds) from which a moving object will snap
with it neighboors. 0 means no snapping.
A list of #GESLayer sorted by priority NOTE: Do not modify.
A list of #GESTrack sorted by priority NOTE: Do not modify.
This signal will be emitted once the changes initiated by #ges_timeline_commit
have been executed in the backend. Use #ges_timeline_commit_sync if you
don't need to do anything in the meantime.
Will be emitted after a new group is added to to the timeline.
the #GESGroup
Will be emitted after a group has been removed from the timeline.
the #GESGroup
a list of #GESContainer
Will be emitted after a new layer is added to the timeline.
the #GESLayer that was added to the timeline
Will be emitted after the layer was removed from the timeline.
the #GESLayer that was removed from the timeline
a #GPtrArray of #GESTrack-s where that object should be added
The #GESClip on which @track_element will land
The #GESTrackElement for which to choose the tracks it should land into
Will be emitted after the track was added to the timeline.
the #GESTrack that was added to the timeline
Will be emitted after the track was removed from the timeline.
the #GESTrack that was removed from the timeline
parent class
The GESTimelineElement base class implements the notion of timing as well
as priority. A GESTimelineElement can have a parent object which will be
responsible for controlling its timing properties.
Gets all the TrackTypes @self will interact with
A #GESTimelineElement
Looks up which @element and @pspec would be effected by the given @name. If various
contained elements have this property name you will get the first one, unless you
specify the class name in @name.
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
Edits @self in ripple mode. It allows you to modify the
start of @self and move the following neighbours accordingly.
This will change the overall timeline duration.
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new start of @self in ripple mode.
Edits @self in ripple mode. It allows you to modify the
duration of a @self and move the following neighbours accordingly.
This will change the overall timeline duration.
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new end (start + duration) of @self in ripple mode. It will
basically only change the duration of @self.
Edits @self in roll mode. It allows you to modify the
duration of a @self and trim (basicly change the start + inpoint
in this case) the following neighbours accordingly.
This will not change the overall timeline duration.
%TRUE if the self as been rolled properly, %FALSE if an error
occured
The #GESTimelineElement to roll.
The new end (start + duration) of @self in roll mode
Edits @self in roll mode. It allows you to modify the
start and inpoint of a @self and "resize" (basicly change the duration
in this case) of the previous neighbours accordingly.
This will not change the overall timeline duration.
%TRUE if the self as been roll properly, %FALSE if an error
occured
The #GESTimelineElement to roll
The new start of @self in roll mode, it will also adapat
the in-point of @self according
Sets the parent of @self to @parent. The parents needs to already
own a hard reference on @self.
%TRUE if @parent could be set or %FALSE when @self
already had a parent or @self and @parent are the same.
a #GESTimelineElement
new parent of self
Edits @self in trim mode. It allows you to modify the
inpoint and start of @self.
This will not change the overall timeline duration.
Note that to trim the end of an self you can just set its duration. The same way
as this method, it will take into account the snapping-distance property of the
timeline in which @self is.
%TRUE if the self as been trimmed properly, %FALSE if an error
occured
The #GESTimelineElement to trim.
The new start of @self in trim mode, will adapt the inpoint
of @self accordingly
Copies @self
The newly create #GESTimelineElement, copied from @self
The #GESTimelineElement to copy
whether we want to create the elements @self contains or not
Gets properties of a child of @self.
The origin #GESTimelineElement
The name of the first property to get
return location for the first property, followed optionally by more
name/return location pairs, followed by NULL
In general, a copy is made of the property contents and
the caller is responsible for freeing the memory by calling
g_value_unset().
Gets a property of a GstElement contained in @object.
Note that #ges_timeline_element_get_child_property is really
intended for language bindings, #ges_timeline_element_get_child_properties
is much more convenient for C programming.
%TRUE if the property was found, %FALSE otherwize
The origin #GESTimelineElement
The name of the property
return location for the property value, it will
be initialized if it is initialized with 0
Gets a property of a child of @self.
a #GESTrackElement
The #GParamSpec that specifies the property you want to get
return location for the value
Gets a property of a child of @self. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
The #GESTimelineElement parent object
The name of the first property to get
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
The @duration of @self
a #GESTimelineElement
The @inpoint of @self
a #GESTimelineElement
The @maxduration of @self
a #GESTimelineElement
Returns a copy of the name of @self.
Caller should g_free() the return value after usage.
The name of @self
a #GESTimelineElement
Returns the parent of @self. This function increases the refcount
of the parent object so you should gst_object_unref() it after usage.
parent of @self, this can be %NULL if
@self has no parent. unref after usage.
a #GESTimelineElement
The @priority of @self
a #GESTimelineElement
The @start of @self
a #GESTimelineElement
Returns the timeline of @self. This function increases the refcount
of the timeline so you should gst_object_unref() it after usage.
timeline of @self, this can be %NULL if
@self has no timeline. unref after usage.
a #GESTimelineElement
Gets the toplevel #GESTimelineElement controlling @self
The toplevel controlling parent of @self
The #GESTimelineElement to get the toplevel parent from
Gets all the TrackTypes @self will interact with
A #GESTimelineElement
Gets an array of #GParamSpec* for all configurable properties of the
children of @self.
an array of #GParamSpec* which should be freed after use or
%NULL if something went wrong
The #GESTimelineElement to get the list of children properties from
return location for the length of the returned array
Looks up which @element and @pspec would be effected by the given @name. If various
contained elements have this property name you will get the first one, unless you
specify the class name in @name.
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
Paste @self inside the timeline. @self must have been created
using ges_timeline_element_copy with recurse=TRUE set,
otherwise it will fail.
Paste @self copying the element
The #GESTimelineElement to paste
The position in the timeline the element should
be copied to, meaning it will become the start of @self
Edits @self in ripple mode. It allows you to modify the
start of @self and move the following neighbours accordingly.
This will change the overall timeline duration.
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new start of @self in ripple mode.
Edits @self in ripple mode. It allows you to modify the
duration of a @self and move the following neighbours accordingly.
This will change the overall timeline duration.
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new end (start + duration) of @self in ripple mode. It will
basically only change the duration of @self.
Edits @self in roll mode. It allows you to modify the
duration of a @self and trim (basicly change the start + inpoint
in this case) the following neighbours accordingly.
This will not change the overall timeline duration.
%TRUE if the self as been rolled properly, %FALSE if an error
occured
The #GESTimelineElement to roll.
The new end (start + duration) of @self in roll mode
Edits @self in roll mode. It allows you to modify the
start and inpoint of a @self and "resize" (basicly change the duration
in this case) of the previous neighbours accordingly.
This will not change the overall timeline duration.
%TRUE if the self as been roll properly, %FALSE if an error
occured
The #GESTimelineElement to roll
The new start of @self in roll mode, it will also adapat
the in-point of @self according
Sets a property of a child of @self. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
The #GESTimelineElement parent object
The name of the first property to set
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
Sets a property of a child of @self
Note that #ges_timeline_element_set_child_property is really
intended for language bindings, #ges_timeline_element_set_child_properties
is much more convenient for C programming.
%TRUE if the property was set, %FALSE otherwize
The origin #GESTimelineElement
The name of the property
the value
Sets a property of a child of @self.
a #GESTimelineElement
The #GParamSpec that specifies the property you want to set
the value
Sets a property of a child of @self. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
The #GESTimelineElement parent object
The name of the first property to set
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
Set the duration of the object
Note that if the timeline snap-distance property of the timeline containing
@self is set, @self will properly snap to its neighboors.
a #GESTimelineElement
the duration in #GstClockTime
Set the in-point, that is the moment at which the @self will start
outputting data from its contents.
a #GESTimelineElement
the in-point in #GstClockTime
Set the maximun duration of the object
a #GESTimelineElement
the maximum duration in #GstClockTime
Sets the name of object, or gives @self a guaranteed unique name (if name is NULL).
This function makes a copy of the provided name, so the caller retains ownership
of the name it sent.
a #GESTimelineElement
The name @self should take (if avalaible<)
Sets the parent of @self to @parent. The parents needs to already
own a hard reference on @self.
%TRUE if @parent could be set or %FALSE when @self
already had a parent or @self and @parent are the same.
a #GESTimelineElement
new parent of self
Sets the priority of the object within the containing layer
All priority management is done by GES itself now.
To set #GESEffect priorities #ges_clip_set_top_effect_index should
be used.
a #GESTimelineElement
the priority
Set the position of the object in its containing layer.
Note that if the snapping-distance property of the timeline containing
@self is set, @self will properly snap to the edges around @start.
a #GESTimelineElement
the position in #GstClockTime
Sets the timeline of @self to @timeline.
%TRUE if @timeline could be set or %FALSE when @timeline
already had a timeline.
a #GESTimelineElement
The #GESTimeline @self is in
Edits @self in trim mode. It allows you to modify the
inpoint and start of @self.
This will not change the overall timeline duration.
Note that to trim the end of an self you can just set its duration. The same way
as this method, it will take into account the snapping-distance property of the
timeline in which @self is.
%TRUE if the self as been trimmed properly, %FALSE if an error
occured
The #GESTimelineElement to trim.
The new start of @self in trim mode, will adapt the inpoint
of @self accordingly
The duration (in nanoseconds) which will be used in the container
The in-point at which this #GESTimelineElement will start outputting data
from its contents (in nanoseconds).
Ex : an in-point of 5 seconds means that the first outputted buffer will
be the one located 5 seconds in the controlled resource.
The maximum duration (in nanoseconds) of the #GESTimelineElement.
The name of the object
The parent container of the object
The priority of the object.
Setting GESTimelineElement priorities is deprecated
as all priority management is done by GES itself now.
Whether the element should be serialized.
The position of the object in its container (in nanoseconds).
The timeline in which @element is
The #GESTimelineElement that controls the object
The #GESAsset from which the object has been extracted
position (in time) of the object
Position in the media from which the object should be used
duration of the object to be used
The maximum duration the object can have
priority of the object in the layer (0:top priority)
The deep notify signal is used to be notified of property changes of all
the childs of @timeline_element
the object that originated the signal
the property that changed
The GESTimelineElement base class. Subclasses should override at least
@set_start @set_inpoint @set_duration @ripple @ripple_end @roll_start
@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.
%TRUE if @parent could be set or %FALSE when @self
already had a parent or @self and @parent are the same.
a #GESTimelineElement
new parent of self
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new start of @self in ripple mode.
%TRUE if the self as been rippled properly, %FALSE if an error
occured
The #GESTimelineElement to ripple.
The new end (start + duration) of @self in ripple mode. It will
basically only change the duration of @self.
%TRUE if the self as been roll properly, %FALSE if an error
occured
The #GESTimelineElement to roll
The new start of @self in roll mode, it will also adapat
the in-point of @self according
%TRUE if the self as been rolled properly, %FALSE if an error
occured
The #GESTimelineElement to roll.
The new end (start + duration) of @self in roll mode
%TRUE if the self as been trimmed properly, %FALSE if an error
occured
The #GESTimelineElement to trim.
The new start of @self in trim mode, will adapt the inpoint
of @self accordingly
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
A #GESTimelineElement
Renders the given text in the specified font, at specified position, and
with the specified background pattern.
Creates a new #GESTitleClip
The newly created #GESTitleClip,
or %NULL if there was an error.
Get the background used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The color used by @self.
a #GESTitleClip
Get the pango font description used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The pango font description used by @self.
a #GESTitleClip
Get the horizontal aligment used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The horizontal aligment used by @self.
a #GESTitleClip
Get the text currently set on @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The text currently set on @self.
a #GESTitleClip
Get the color used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The color used by @self.
a #GESTitleClip
Get the vertical aligment used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The vertical aligment used by @self.
a #GESTitleClip
Get the horizontal position used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The horizontal position used by @self.
a #GESTitleClip
Get the vertical position used by @self.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The vertical position used by @self.
a #GESTitleClip
Sets the background of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set
The color @self is being set to
Sets the color of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set
The color @self is being set to
Sets the pango font description of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip*
the pango font description
Sets the horizontal aligment of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set horizontal alignement of text on
#GESTextHAlign
Sets the text this clip will render.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set text on
the text to render. an internal copy of this text will be
made.
Sets the vertical aligment of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set vertical alignement of text on
#GESTextVAlign
Sets the horizontal position of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set
The horizontal position @self is being set to
Sets the vertical position of the text.
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
the #GESTitleClip* to set
The vertical position @self is being set to
The background of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The color of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
Pango font description string
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
Horizontal alignment of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The text to diplay
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
Vertical alignent of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The horizontal position of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
The vertical position of the text
use ges_track_element_get/set_children_properties on the
underlying GESTrackElement instead
#GESTitleSource is a GESTimelineElement that implements the notion
of titles in GES.
## Children Properties
You can use the following children properties through the
#ges_track_element_set_child_property and alike set of methods:
<informaltable frame="none">
<tgroup cols="3">
<colspec colname="properties_type" colwidth="150px"/>
<colspec colname="properties_name" colwidth="200px"/>
<colspec colname="properties_flags" colwidth="400px"/>
<tbody>
<row>
<entry role="property_type"><link linkend="guint"><type>guint</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--background">background</link></entry>
<entry>The color of the background</entry>
</row>
<row>
<entry role="property_type"><link linkend="guint"><type>guint</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--color">color</link></entry>
<entry>The color of the text</entry>
</row>
<row>
<entry role="property_type"><link linkend="gchar"><type>gchar</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--font-desc">font-desc</link></entry>
<entry>Pango font description string</entry>
</row>
<row>
<entry role="property_type"><link linkend="GESTextHAlign"><type>GESTextHAlign</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--halignment">halignment</link></entry>
<entry>Horizontal alignment of the text</entry>
</row>
<row>
<entry role="property_type"><link linkend="gchar"><type>gchar</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--text">text</link></entry>
<entry>The text to be rendered</entry>
</row>
<row>
<entry role="property_type"><link linkend="GESTextVAlign"><type>GESTextVAlign</type></link>
</entry><entry role="property_name"><link linkend="GESTileSource--valignment">valignment</link>
</entry><entry>Vertical alignent of the text</entry>
</row>
<row>
<entry role="property_type"><link linkend="gdouble"><type>gdouble</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--xpos">xpos</link></entry>
<entry>The horizontal position of the text</entry>
</row>
<row><entry role="property_type"><link linkend="gdouble"><type>gdouble</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--ypos">ypos</link></entry>
<entry>The vertical position of the text</entry>
</row>
<row><entry role="property_type"><link linkend="gboolean"><type>gboolean</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--shaded-background">shaded-background</link></entry>
<entry>Whether to shade the background under the text area</entry>
</row>
<row><entry role="property_type"><link linkend="guint"><type>guint</type></link></entry>
<entry role="property_name"><link linkend="GESTileSource--outline-color">outline-color</link></entry>
<entry>Color to use for outline the text (big-endian ARGB).</entry>
</row>
</tbody>
</tgroup>
</informaltable>
Get the background used by @source.
The background used by @source.
a #GESTitleSource
Get the pango font description used by @source.
The pango font description used by this
@source.
a #GESTitleSource
Get the horizontal aligment used by @source.
The horizontal aligment used by @source.
a #GESTitleSource
Get the text currently set on the @source.
The text currently set on the @source.
a #GESTitleSource
Get the color used by @source.
The color used by @source.
a #GESTitleSource
Get the vertical aligment used by @source.
The vertical aligment used by @source.
a #GESTitleSource
Get the horizontal position used by @source.
The horizontal position used by @source.
a #GESTitleSource
Get the vertical position used by @source.
The vertical position used by @source.
a #GESTitleSource
Sets the color of the background
the #GESTitleSource* to set
the color @self is being set to
Set the pango font description this source will use to render
the text.
the #GESTitleSource
the pango font description
Sets the vertical aligment of the text.
the #GESTitleSource* to set text on
#GESTextHAlign
Sets the text this track element will render.
use ges_track_element_get/set_children_properties on the
GESTrackElement instead
the #GESTitleSource* to set text on
the text to render. an internal copy of this text will be
made.
Sets the color of the text.
the #GESTitleSource* to set
the color @self is being set to
Sets the vertical aligment of the text.
the #GESTitleSource* to set text on
#GESTextVAlign
Sets the horizontal position of the text.
the #GESTitleSource* to set
the horizontal position @self is being set to
Sets the vertical position of the text.
the #GESTitleSource* to set
the color @self is being set to
parent class
Corresponds to one output format (i.e. audio OR video).
Contains the compatible TrackElement(s).
Creates a new #GESTrack with the given @type and @caps.
The newly created track will steal a reference to the caps. If you wish to
use those caps elsewhere, you will have to take an extra reference.
A new #GESTrack.
The type of track
The caps to restrict the output of the track to.
Adds the given object to the track. Sets the object's controlling track,
and thus takes ownership of the @object.
An object can only be added to one track.
#TRUE if the object was properly added. #FALSE if the track does not
want to accept the object.
a #GESTrack
the #GESTrackElement to add
Commits all the pending changes of the TrackElement contained in the
track.
When timing changes happen in a timeline, the changes are not
directly done inside NLE. This method needs to be called so any changes
on a clip contained in the timeline actually happen at the media
processing level.
%TRUE if something as been commited %FALSE if nothing needed
to be commited
a #GESTrack
Get the #GstCaps this track is configured to output.
The #GstCaps this track is configured to output.
a #GESTrack
Gets the #GESTrackElement contained in @track
the list of
#GESTrackElement present in the Track sorted by priority and start.
a #GESTrack
Gets if the underlying #NleComposition contains an expandable mixer.
#True if there is a mixer, #False otherwise.
a #GESTrack
Get the #GESTimeline this track belongs to. Can be %NULL.
The #GESTimeline this track belongs to. Can be %NULL.
a #GESTrack
Removes the object from the track and unparents it.
Unparenting it means the reference owned by @track on the @object will be
removed. If you wish to use the @object after this function, make sure you
call gst_object_ref() before removing it from the @track.
#TRUE if the object was removed, else #FALSE if the track
could not remove the object (like if it didn't belong to the track).
a #GESTrack
the #GESTrackElement to remove
Sets the function that should be used to create the GstElement used to fill gaps.
To avoid to provide such a function we advice you to use the
#ges_audio_track_new and #ges_video_track_new constructor when possible.
a #GESTrack
The #GESCreateElementForGapFunc that will be used
to create #GstElement to fill gaps
Sets if the #GESTrack should be mixing.
a #GESTrack
TRUE if the track should be mixing, FALSE otherwise.
Sets the given @caps as the caps the track has to output.
a #GESTrack
the #GstCaps to set
Sets @timeline as the timeline controlling @track.
a #GESTrack
a #GESTimeline
Updates the restriction caps by modifying all the fields present in @caps
in the original restriction caps. If for example the current restriction caps
are video/x-raw, format=I420, width=360 and @caps is video/x-raw, format=RGB,
the restriction caps will be updated to video/x-raw, format=RGB, width=360.
Modification happens for each structure in the new caps, and
one can add new fields or structures through that function.
a #GESTrack
the #GstCaps to update with
Caps used to filter/choose the output stream. This is generally set to
a generic set of caps like 'video/x-raw' for raw video.
Default value: #GST_CAPS_ANY.
Current duration of the track
Default value: O
Whether layer mixing is activated or not on the track.
Caps used to filter/choose the output stream.
Default value: #GST_CAPS_ANY.
Type of stream the track outputs. This is used when creating the #GESTrack
to specify in generic terms what type of content will be outputted.
It also serves as a 'fast' way to check what type of data will be outputted
from the #GESTrack without having to actually check the #GESTrack's caps
property.
a #GESTrackType indicting the basic type of the track.
Will be emitted after a track element was added to the track.
the #GESTrackElement that was added.
Will be emitted after a track element was removed from the track.
the #GESTrackElement that was removed.
#GESTrackElement is the Base Class for any object that can be contained in a
#GESTrack.
It contains the basic information as to the location of the object within
its container, like the start position, the inpoint, the duration and the
priority.
Looks up which @element and @pspec would be effected by the given @name. If various
contained elements have this property name you will get the first one, unless you
specify the class name in @name.
Use #ges_timeline_element_lookup_child
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
Looks for the properties defines with the various parametters and add
them to the hashtable of children properties.
To be used by subclasses only
The #GESTrackElement to set chidlren props on
The GstElement to retrieve properties from
An array of categories of GstElement to
take into account (as defined in the factory meta "klass" field)
A
blacklist of elements factory names to not take into account
A list
of propery names to add as children properties
Edit @object in the different exisiting #GESEditMode modes. In the case of
slide, and roll, you need to specify a #GESEdge
%TRUE if the object as been edited properly, %FALSE if an error
occured
the #GESTrackElement to edit
The layers you want the edit to
happen in, %NULL means that the edition is done in all the
#GESLayers contained in the current timeline.
FIXME: This is not implemented yet.
The #GESEditMode in which the edition will happen.
The #GESEdge the edit should happen on.
The position at which to edit @object (in nanosecond)
A
#GHashTable containing all property_name: GstControlBinding
The #TrackElement from which to get all set bindings
Gets properties of a child of @object.
Use #ges_timeline_element_get_child_properties
The origin #GESTrackElement
The name of the first property to get
return location for the first property, followed optionally by more
name/return location pairs, followed by NULL
In general, a copy is made of the property contents and
the caller is responsible for freeing the memory by calling
g_value_unset().
Gets a property of a GstElement contained in @object.
Note that #ges_track_element_get_child_property is really
intended for language bindings, #ges_track_element_get_child_properties
is much more convenient for C programming.
Use #ges_timeline_element_get_child_property
%TRUE if the property was found, %FALSE otherwize
The origin #GESTrackElement
The name of the property
return location for the property value, it will
be initialized if it is initialized with 0
Gets a property of a child of @object.
Use #ges_timeline_element_get_child_property_by_pspec
a #GESTrackElement
The #GParamSpec that specifies the property you want to get
return location for the value
Gets a property of a child of @object. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
Use #ges_timeline_element_get_child_property_valist
The #GESTrackElement parent object
The name of the first property to get
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
Looks up the various controlled properties for that #GESTrackElement,
and returns the #GstControlBinding which controls @property_name.
the #GstControlBinding associated with
@property_name, or %NULL if that property is not controlled.
the #GESTrackElement in which to lookup the bindings.
The property_name to which the binding is associated.
Get the #GstElement this track element is controlling within GNonLin.
the #GstElement this track element is controlling
within GNonLin.
a #GESTrackElement
Get the NleObject object this object is controlling.
use #ges_track_element_get_nleobject instead.
the NleObject object this object is controlling.
a #GESTrackElement
Get the GNonLin object this object is controlling.
the GNonLin object this object is controlling.
a #GESTrackElement
Get the #GESTrack to which this object belongs.
The #GESTrack to which this object
belongs. Can be %NULL if it is not in any track
a #GESTrackElement
Lets you know if @object will be used for playback and rendering,
or not.
%TRUE if @object is active, %FALSE otherwize
a #GESTrackElement
Gets an array of #GParamSpec* for all configurable properties of the
children of @object.
Use #ges_timeline_element_list_children_properties
an array of #GParamSpec* which should be freed after use or
%NULL if something went wrong
The #GESTrackElement to get the list of children properties from
return location for the length of the returned array
Looks up which @element and @pspec would be effected by the given @name. If various
contained elements have this property name you will get the first one, unless you
specify the class name in @name.
Use #ges_timeline_element_lookup_child
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
Removes a #GstControlBinding from @object.
%TRUE if the binding could be removed, %FALSE if an error
occured
the #GESTrackElement on which to set a control binding
The name of the property to control.
Sets the usage of the @object. If @active is %TRUE, the object will be used for
playback and rendering, else it will be ignored.
%TRUE if the property was toggled, else %FALSE
a #GESTrackElement
visibility
Sets a property of a child of @object. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
Use #ges_timeline_element_set_child_properties
The #GESTrackElement parent object
The name of the first property to set
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
Sets a property of a GstElement contained in @object.
Note that #ges_track_element_set_child_property is really
intended for language bindings, #ges_track_element_set_child_properties
is much more convenient for C programming.
use #ges_timeline_element_set_child_property instead
%TRUE if the property was set, %FALSE otherwize
The origin #GESTrackElement
The name of the property
the value
Sets a property of a child of @object.
Use #ges_timeline_element_set_child_property_by_spec
a #GESTrackElement
The #GParamSpec that specifies the property you want to set
the value
Sets a property of a child of @object. If there are various child elements
that have the same property name, you can distinguish them using the following
syntax: 'ClasseName::property_name' as property name. If you don't, the
corresponding property of the first element found will be set.
Use #ges_timeline_element_set_child_property_valist
The #GESTrackElement parent object
The name of the first property to set
value for the first property, followed optionally by more
name/return location pairs, followed by NULL
Creates a #GstControlBinding and adds it to the #GstElement concerned by the
property. Use the same syntax as #ges_track_element_lookup_child for
the property name.
%TRUE if the binding could be created and added, %FALSE if an error
occured
the #GESTrackElement on which to set a control binding
the #GstControlSource to set on the binding.
The name of the property to control.
The type of binding to create. Only "direct" is available for now.
Whether the object should be taken into account in the #GESTrack output.
If #FALSE, then its contents will not be used in the resulting track.
The control-binding-added signal is emitted each time a control binding
is added for a child property of @track_element
the #GstControlBinding that has been added
The control-binding-removed signal is emitted each time a control binding
is removed for a child property of @track_element
the #GstControlBinding that has been removed
Get the GESAssetTrackType the #GESTrackElement extracted from @self
should get into
a #GESTrackType
A #GESAssetObject
Set the #GESAssetTrackType the #GESTrackElement extracted from @self
should get into
A #GESAssetObject
A #GESTrackType
Subclasses can override the @create_gnl_object method to override what type
of GNonLin object will be created.
name of the GNonLin GStElementFactory type to use.
TRUE if @element and @pspec could be found. FALSE otherwise. In that
case the values for @pspec and @element are not modified. Unref @element after
usage.
object to lookup the property in
name of the property to look up. You can specify the name of the
class as such: "ClassName::property-name", to guarantee that you get the
proper GParamSpec in case various GstElement-s contain the same property
name. If you don't do so, you will get the first element found, having
this property and the and the corresponding GParamSpec.
pointer to a #GstElement that
takes the real object to set property on
pointer to take the #GParamSpec
describing the property
Types of content handled by a track. If the content is not one of
@GES_TRACK_TYPE_AUDIO, @GES_TRACK_TYPE_VIDEO or @GES_TRACK_TYPE_TEXT,
the user of the #GESTrack must set the type to @GES_TRACK_TYPE_CUSTOM.
@GES_TRACK_TYPE_UNKNOWN is for internal purposes and should not be used
by users
A track of unknown type (i.e. invalid)
An audio track
A video track
A text (subtitle) track
A custom-content track
Base class for media transitions.
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
B object. At the transition in point, only A will be visible, and by the
end only B will be visible.
The shape of the video transition depends on the value of the "vtype"
property. The default value is "crossfade". For audio, only "crossfade" is
supported.
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
will be updated when needed.
Creates a new #GESTransitionClip.
a newly created #GESTransitionClip,
or %NULL if something went wrong.
the type of transition to create
Creates a new #GESTransitionClip for the provided @nick.
The newly created #GESTransitionClip,
or %NULL if something went wrong
a string representing the type of transition to create
a #GESVideoStandardTransitionType representing the wipe to use
a #GESVideoStandardTransitionType indicating the type of video transition
to apply.
Represents all the output streams from a particular uri. It is assumed that
the URI points to a file of some type.
Creates a new #GESUriClip for the provided @uri.
The newly created #GESUriClip, or
%NULL if there was an error.
the URI the source should control
Get the location of the resource.
The location of the resource.
the #GESUriClip
Lets you know if @self is an image or not.
%TRUE if @self is a still image %FALSE otherwise.
the #GESUriClip
Lets you know if the audio track of @self is muted or not.
%TRUE if the audio track of @self is muted, %FALSE otherwise.
the #GESUriClip
Sets whether the clip is a still image or not.
the #GESUriClip
%TRUE if @self is a still image, %FALSE otherwise
Sets whether the audio track of this clip is muted or not.
the #GESUriClip on which to mute or unmute the audio track
%TRUE to mute @self audio track, %FALSE to unmute it
Whether this uri clip represents a still image or not. This must be set
before create_track_elements is called.
Whether the sound will be played or not.
The location of the file/resource to use.
The #GESUriClipAsset is a special #GESAsset that lets you handle
the media file to use inside the GStreamer Editing Services. It has APIs that
let you get information about the medias. Also, the tags found in the media file are
set as Metadatas of the Asser.
Creates a #GESUriClipAsset for @uri
Example of request of a GESUriClipAsset:
|[
// The request callback
static void
filesource_asset_loaded_cb (GESAsset * source, GAsyncResult * res, gpointer user_data)
{
GError *error = NULL;
GESUriClipAsset *filesource_asset;
filesource_asset = GES_URI_CLIP_ASSET (ges_asset_request_finish (res, &error));
if (filesource_asset) {
g_print ("The file: %s is usable as a FileSource, it is%s an image and lasts %" GST_TIME_FORMAT,
ges_asset_get_id (GES_ASSET (filesource_asset))
ges_uri_clip_asset_is_image (filesource_asset) ? "" : " not",
GST_TIME_ARGS (ges_uri_clip_asset_get_duration (filesource_asset));
} else {
g_print ("The file: %s is *not* usable as a FileSource because: %s",
ges_asset_get_id (source), error->message);
}
gst_object_unref (mfs);
}
// The request:
ges_uri_clip_asset_new (uri, (GAsyncReadyCallback) filesource_asset_loaded_cb, user_data);
]|
The URI of the file for which to create a #GESUriClipAsset
optional %GCancellable object, %NULL to ignore.
a #GAsyncReadyCallback to call when the initialization is finished
The user data to pass when @callback is called
Creates a #GESUriClipAsset for @uri syncronously. You should avoid
to use it in application, and rather create #GESUriClipAsset asynchronously
A reference to the requested asset or
%NULL if an error happened
The URI of the file for which to create a #GESUriClipAsset.
You can also use multi file uris for #GESMultiFileSource.
Gets duration of the file represented by @self
The duration of @self
a #GESUriClipAsset
Gets #GstDiscovererInfo about the file
#GstDiscovererInfo of specified asset
Target asset
Get the GESUriSourceAsset @self containes
a
#GList of #GESUriSourceAsset
A #GESUriClipAsset
Gets Whether the file represented by @self is an image or not
Whether the file represented by @self is an image or not
a #indent: Standard input:311: Error:Unexpected end of file
GESUriClipAsset
The duration (in nanoseconds) of the media file
Sets the timeout of #GESUriClipAsset loading
The #GESUriClipAssetClass on which to set the discoverer timeout
The timeout to set
NOTE: You should never request such a #GESAsset as they will be created automatically
by #GESUriClipAsset-s.
Get the #GESUriClipAsset @self is contained in
a #GESUriClipAsset
A #GESUriClipAsset
Get the #GstDiscovererStreamInfo user by @asset
a #GESUriClipAsset
A #GESUriClipAsset
# Children Properties:
You can use the following children properties through the
#ges_track_element_set_child_property and alike set of methods:
<informaltable frame="none">
<tgroup cols="3">
<colspec colname="properties_type" colwidth="150px"/>
<colspec colname="properties_name" colwidth="200px"/>
<colspec colname="properties_flags" colwidth="400px"/>
<tbody>
<row>
<entry role="property_type"><link linkend="gdouble"><type>double</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--alpha">alpha</link></entry>
<entry>The desired alpha for the stream.</entry>
</row>
<row>
<entry role="property_type"><link linkend="gint"><type>gint</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--posx">posx</link></entry>
<entry>The desired x position for the stream.</entry>
</row>
<row>
<entry role="property_type"><link linkend="gint"><type>gint</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--posy">posy</link></entry>
<entry>The desired y position for the stream</entry>
</row>
<row>
<entry role="property_type"><link linkend="gint"><type>gint</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--width">width</link></entry>
<entry>The desired width for that source. Set to 0 if size is not mandatory, will be set to width of the current track.</entry>
</row>
<row>
<entry role="property_type"><link linkend="gint"><type>gint</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--height">height</link></entry>
<entry>The desired height for that source. Set to 0 if size is not mandatory, will be set to height of the current track.</entry>
</row>
<row>
<entry role="property_type"><link linkend="GstDeinterlaceModes"><type>GstDeinterlaceModes</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--deinterlace-mode">deinterlace-mode</link></entry>
<entry>Deinterlace Mode</entry>
</row>
<row>
<entry role="property_type"><link linkend="GstDeinterlaceFields"><type>GstDeinterlaceFields</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--deinterlace-fields">deinterlace-fields</link></entry>
<entry>Fields to use for deinterlacing</entry>
</row>
<row>
<entry role="property_type"><link linkend="GstDeinterlaceFieldLayout"><type>GstDeinterlaceFieldLayout</type></link></entry>
<entry role="property_name"><link linkend="GESVideoSource--deinterlace-tff">deinterlace-tff</link></entry>
<entry>Deinterlace top field first</entry>
</row>
</tbody>
</tgroup>
</informaltable>
Transition type has not been set,
A bar moves from left to right,
A bar moves from top to bottom,
A box expands from the upper-left corner to the lower-right corner,
A box expands from the upper-right corner to the lower-left corner,
A box expands from the lower-right corner to the upper-left corner,
A box expands from the lower-left corner to the upper-right corner,
A box shape expands from each of the four corners toward the center,
A box shape expands from the center of each quadrant toward the corners of each quadrant,
A central, vertical line splits and expands toward the left and right edges,
A central, horizontal line splits and expands toward the top and bottom edges,
A box expands from the top edge's midpoint to the bottom corners,
A box expands from the right edge's midpoint to the left corners,
A box expands from the bottom edge's midpoint to the top corners,
A box expands from the left edge's midpoint to the right corners,
A diagonal line moves from the upper-left corner to the lower-right corner,
A diagonal line moves from the upper right corner to the lower-left corner,
Two wedge shapes slide in from the top and bottom edges toward the center,
Two wedge shapes slide in from the left and right edges toward the center,
A diagonal line from the lower-left to upper-right corners splits and expands toward the opposite corners,
A diagonal line from upper-left to lower-right corners splits and expands toward the opposite corners,
Four wedge shapes split from the center and retract toward the four edges,
A diamond connecting the four edge midpoints simultaneously contracts toward the center and expands toward the edges,
A wedge shape moves from top to bottom,
A wedge shape moves from right to left,
A wedge shape moves from bottom to top,
A wedge shape moves from left to right,
A 'V' shape extending from the bottom edge's midpoint to the opposite corners contracts toward the center and expands toward the edges,
A 'V' shape extending from the left edge's midpoint to the opposite corners contracts toward the center and expands toward the edges,
A 'V' shape extending from the top edge's midpoint to the opposite corners contracts toward the center and expands toward the edges,
A 'V' shape extending from the right edge's midpoint to the opposite corners contracts toward the center and expands toward the edges,
A rectangle expands from the center.,
A radial hand sweeps clockwise from the twelve o'clock position,
A radial hand sweeps clockwise from the three o'clock position,
A radial hand sweeps clockwise from the six o'clock position,
A radial hand sweeps clockwise from the nine o'clock position,
Two radial hands sweep clockwise from the twelve and six o'clock positions,
Two radial hands sweep clockwise from the nine and three o'clock positions,
Four radial hands sweep clockwise,
A fan unfolds from the top edge, the fan axis at the center,
A fan unfolds from the right edge, the fan axis at the center,
Two fans, their axes at the center, unfold from the top and bottom,
Two fans, their axes at the center, unfold from the left and right,
A radial hand sweeps clockwise from the top edge's midpoint,
A radial hand sweeps clockwise from the right edge's midpoint,
A radial hand sweeps clockwise from the bottom edge's midpoint,
A radial hand sweeps clockwise from the left edge's midpoint,
Two radial hands sweep clockwise and counter-clockwise from the top and bottom edges' midpoints,
Two radial hands sweep clockwise and counter-clockwise from the left and right edges' midpoints,
Two radial hands attached at the top and bottom edges' midpoints sweep from right to left,
Two radial hands attached at the left and right edges' midpoints sweep from top to bottom,
A fan unfolds from the bottom, the fan axis at the top edge's midpoint,
A fan unfolds from the left, the fan axis at the right edge's midpoint,
A fan unfolds from the top, the fan axis at the bottom edge's midpoint,
A fan unfolds from the right, the fan axis at the left edge's midpoint,
Two fans, their axes at the top and bottom, unfold from the center,
Two fans, their axes at the left and right, unfold from the center,
A radial hand sweeps clockwise from the upper-left corner,
A radial hand sweeps counter-clockwise from the lower-left corner.,
A radial hand sweeps clockwise from the lower-right corner,
A radial hand sweeps counter-clockwise from the upper-right corner,
Two radial hands attached at the upper-left and lower-right corners sweep down and up,
Two radial hands attached at the lower-left and upper-right corners sweep down and up,
Two radial hands attached at the upper-left and upper-right corners sweep down,
Two radial hands attached at the upper-left and lower-left corners sweep to the right,
Two radial hands attached at the lower-left and lower-right corners sweep up,
Two radial hands attached at the upper-right and lower-right corners sweep to the left,
Two radial hands attached at the midpoints of the top and bottom halves sweep from right to left,
Two radial hands attached at the midpoints of the left and right halves sweep from top to bottom,
Two sets of radial hands attached at the midpoints of the top and bottom halves sweep from top to bottom and bottom to top,
Two sets of radial hands attached at the midpoints of the left and right halves sweep from left to right and right to left,
Crossfade
The test pattern to produce
A standard SMPTE test pattern
Random noise
A black image
A white image
A red image
A green image
A blue image
Checkers pattern (1px)
Checkers pattern (2px)
Checkers pattern (4px)
Checkers pattern (8px)
Circular pattern
Alternate between black and white
SMPTE test pattern (75% color bars)
Zone plate
Gamut checkers
Chroma zone plate
Solid color
Get the video pattern used by the @source.
The video pattern used by the @source.
a #GESVideoTestPattern
Sets the source to use the given @pattern.
a #GESVideoTestSource
a #GESVideoTestPattern
Creates a new #GESVideoTrack of type #GES_TRACK_TYPE_VIDEO and with generic
raw video caps ("video/x-raw");
A new #GESTrack.
Creates a new #GESVideoTransition.
The newly created
#GESVideoTransition, or %NULL if there was an error.
Get the border property of @self, this value represents
the border width of the transition.
The border values of @self or -1 if not meaningful
(this will happen when not using a smpte transition).
The #GESVideoTransition to get the border from
Get the transition type used by @trans.
The transition type used by @trans.
a #GESVideoTransition
Get the invert property of @self, this value represents
the direction of the transition.
The invert value of @self
The #GESVideoTransition to get the inversion from
Set the border property of @self, this value represents
the border width of the transition. In case this value does
not make sense for the current transition type, it is cached
for later use.
The #GESVideoTransition to set the border to
The value of the border to set on @object
Set the invert property of @self, this value represents
the direction of the transition. In case this value does
not make sense for the current transition type, it is cached
for later use.
The #GESVideoTransition to set invert on
%TRUE if the transition should be inverted %FALSE otherwise
Sets the transition being used to @type.
%TRUE if the transition type was properly changed, else %FALSE.
a #GESVideoTransition
a #GESVideoStandardTransitionType
This value represents the border width of the transition.
This value represents the direction of the transition.
parent class
The location of the file/resource to use.
Clean up any resources created by GES in ges_init().
It is normally not needed to call this function in a normal application as the
resources will automatically be freed when the program terminates.
This function is therefore mostly used by testsuites and other memory profiling tools.
After this call GES (including this method) should not be used anymore.
Initialize the GStreamer Editing Service. Call this before any usage of
GES. You should take care of initilizing GStreamer before calling this
function.
Initializes the GStreamer Editing Services library, setting up internal path lists,
and loading evrything needed.
This function will return %FALSE if GES could not be initialized
for some reason.
%TRUE if GES could be initialized.
pointer to application's argc
pointer to application's argv
Returns a #GOptionGroup with GES's argument specifications. The
group is set up to use standard GOption callbacks, so when using this
group in combination with GOption parsing methods, all argument parsing
and initialization is automated.
This function is useful if you want to integrate GES with other
libraries that use GOption (see g_option_context_add_group() ).
If you use this function, you should make sure you initialise the GStreamer
as one of the very first things in your program. That means you need to
use gst_init_get_option_group() and add it to the option context before
using the ges_init_get_option_group() result.
a pointer to GES's option group.
List all @asset filtering per filter as defined by @filter.
It copies the asset and thus will not be updated in time.
The list of
#GESAsset the object contains
Type of assets to list, #GES_TYPE_EXTRACTABLE will list
all assets
Get the last buffer @playsink showed
A #GstSample containing the last frame from
@playsink in the format defined by the @caps
The playsink to get last frame from
The caps defining the format the return value will have
Gets the version number of the GStreamer Editing Services library.
pointer to a guint to store the major version number
pointer to a guint to store the minor version number
pointer to a guint to store the micro version number
pointer to a guint to store the nano version number