|  |  |  | GStreamer Editing Services 1.2.0 Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | Signals | ||||
#include <ges/ges.h>
                    GESProject;
gboolean            ges_project_load                    (GESProject *project,
                                                         GESTimeline *timeline,
                                                         GError **error);
gboolean            ges_project_add_asset               (GESProject *project,
                                                         GESAsset *asset);
gboolean            ges_project_remove_asset            (GESProject *project,
                                                         GESAsset *asset);
GList *             ges_project_list_assets             (GESProject *project,
                                                         GType filter);
GESAsset *          ges_project_get_asset               (GESProject *project,
                                                         const gchar *id,
                                                         GType extractable_type);
gboolean            ges_project_save                    (GESProject *project,
                                                         GESTimeline *timeline,
                                                         const gchar *uri,
                                                         GESAsset *formatter_asset,
                                                         gboolean overwrite,
                                                         GError **error);
gboolean            ges_project_create_asset            (GESProject *project,
                                                         const gchar *id,
                                                         GType extractable_type);
GType               ges_project_get_type                (void);
gchar *             ges_project_get_uri                 (GESProject *project);
GESProject *        ges_project_new                     (const gchar *uri);
gboolean            ges_project_add_encoding_profile    (GESProject *project,
                                                         GstEncodingProfile *profile);
const GList *       ges_project_list_encoding_profiles  (GESProject *project);
GList *             ges_project_get_loading_assets      (GESProject *project);
"asset-added" :Run Last"asset-removed" :Run Last"error-loading-asset" :Run Last"loaded" :Run First"missing-uri" :Run Last
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:
| 1 2 3 4 5 6 7 8 9 10 | 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.
gboolean ges_project_load (GESProject *project,GESTimeline *timeline,GError **error);
Loads project into timeline
| 
 | A GESProject that has an uriset already | 
| 
 | A blank timeline to load projectinto | 
| 
 | An error to be set in case something wrong happens or NULL. [out][allow-none] | 
| Returns : | TRUEif the project could be loadedFALSEotherwize. | 
gboolean ges_project_add_asset (GESProject *project,GESAsset *asset);
Adds a Asset to project, the project will keep a reference on
asset.
| 
 | A GESProject | 
| 
 | A GESAsset to add to project. [transfer none] | 
| Returns : | TRUEif the asset could be addedFALSEit was already
in the project | 
gboolean ges_project_remove_asset (GESProject *project,GESAsset *asset);
remove a asset to from project.
| 
 | A GESProject | 
| 
 | A GESAsset to remove from project. [transfer none] | 
| Returns : | TRUEif the asset could be removedFALSEotherwise | 
GList * ges_project_list_assets (GESProject *project,GType filter);
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.
| 
 | A GESProject | 
| 
 | Type of assets to list, GES_TYPE_EXTRACTABLE will list all assets | 
| Returns : | The list of GESAsset the object contains. [transfer full][element-type GESAsset] | 
GESAsset * ges_project_get_asset (GESProject *project,const gchar *id,GType extractable_type);
| 
 | A GESProject | 
| 
 | The id of the asset to retrieve | 
| 
 | The extractable_type of the asset
to retrieve from object | 
| Returns : | The GESAsset with idorNULLif no asset withidas an ID. [transfer full][allow-none] | 
gboolean ges_project_save (GESProject *project,GESTimeline *timeline,const gchar *uri,GESAsset *formatter_asset,gboolean overwrite,GError **error);
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);)
| 
 | A GESProject to save | 
| 
 | The GESTimeline to save, it must have been extracted from project | 
| 
 | The uri where to save projectandtimeline | 
| 
 | The formatter asset to use or NULL. IfNULL,
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. [allow-none] | 
| 
 | TRUEto overwrite file if it exists | 
| 
 | An error to be set in case something wrong happens or NULL. [out][allow-none] | 
| Returns : | TRUEif the project could be save,FALSEotherwize | 
gboolean ges_project_create_asset (GESProject *project,const gchar *id,GType extractable_type);
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
| 
 | A GESProject | 
| 
 | The id of the asset to create and add to project. [allow-none] | 
| 
 | The GType of the asset to create | 
| Returns : | TRUEif the asset started to be addedFALSEit was already
in the project | 
gchar *             ges_project_get_uri                 (GESProject *project);
Retrieve the uri that is currently set on project
| 
 | A GESProject | 
| Returns : | The uri that is set on project | 
GESProject *        ges_project_new                     (const gchar *uri);
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.
| 
 | The uri to be set after creating the project. [allow-none] | 
| Returns : | A newly created GESProject | 
gboolean ges_project_add_encoding_profile (GESProject *project,GstEncodingProfile *profile);
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.
| 
 | A GESProject | 
| 
 | A GstEncodingProfile to add to the project. If a profile with the same name already exists, it will be replaced | 
| Returns : | TRUEifprofilecould be added,FALSEotherwize | 
const GList *       ges_project_list_encoding_profiles  (GESProject *project);
Lists the encoding profile that have been set to project. The first one
is the latest added.
| 
 | A GESProject | 
| Returns : | The
list of GstEncodingProfile used in project. [transfer none][element-type GstPbutils.EncodingProfile][allow-none] | 
GList *             ges_project_get_loading_assets      (GESProject *project);
Get the assets that are being loaded
| 
 | A GESProject | 
| Returns : | 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. [transfer full][element-type GES.Asset] | 
"uri" property"uri" gchar* : Read / Write / Construct Only
uri of the project.
Default value: NULL
"asset-added" signalvoid                user_function                      (GESProject *formatter,
                                                        GESAsset   *asset,
                                                        gpointer    user_data)      : Run Last
| 
 | the GESProject | 
| 
 | The GESAsset that has been added to project | 
| 
 | user data set when the signal handler was connected. | 
"asset-removed" signalvoid                user_function                      (GESProject *formatter,
                                                        GESAsset   *asset,
                                                        gpointer    user_data)      : Run Last
| 
 | the GESProject | 
| 
 | The GESAsset that has been removed from project | 
| 
 | user data set when the signal handler was connected. | 
"error-loading-asset" signalvoid                user_function                      (GESProject *project,
                                                        GError     *error,
                                                        gchar      *id,
                                                        GType      *extractable_type,
                                                        gpointer    user_data)             : Run Last
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 GESProject on which a problem happend when creted a GESAsset | 
| 
 | The GError defining the error that accured, might be NULL | 
| 
 | The idof the asset that failed loading | 
| 
 | The extractable_typeof the asset that
failed loading | 
| 
 | user data set when the signal handler was connected. | 
"loaded" signalvoid                user_function                      (GESProject  *project,
                                                        GESTimeline *timeline,
                                                        gpointer     user_data)      : Run First
| 
 | the GESProject that is done loading a project. | 
| 
 | The GESTimeline that complete loading | 
| 
 | user data set when the signal handler was connected. | 
"missing-uri" signalgchar*              user_function                      (GESProject *project,
                                                        GError     *error,
                                                        GESAsset   *wrong_asset,
                                                        gpointer    user_data)        : Run Last
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | 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 GESProject reporting that a file has moved | 
| 
 | 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. | 
| 
 | user data set when the signal handler was connected. | 
| Returns : | The new URI of wrong_asset. [transfer full][allow-none] |