|  |  |  | Clutter Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | ||||
                    ClutterScript;
                    ClutterScriptClass;
ClutterScript *     clutter_script_new                  (void);
enum                ClutterScriptError;
guint               clutter_script_load_from_data       (ClutterScript *script,
                                                         const gchar *data,
                                                         gssize length,
                                                         GError **error);
guint               clutter_script_load_from_file       (ClutterScript *script,
                                                         const gchar *filename,
                                                         GError **error);
void                clutter_script_add_search_paths     (ClutterScript *script,
                                                         const gchar * const paths[],
                                                         gsize n_paths);
gchar *             clutter_script_lookup_filename      (ClutterScript *script,
                                                         const gchar *filename);
GObject *           clutter_script_get_object           (ClutterScript *script,
                                                         const gchar *name);
gint                clutter_script_get_objects          (ClutterScript *script,
                                                         const gchar *first_name,
                                                         ...);
void                clutter_script_unmerge_objects      (ClutterScript *script,
                                                         guint merge_id);
void                clutter_script_ensure_objects       (ClutterScript *script);
GList *             clutter_script_list_objects         (ClutterScript *script);
void                (*ClutterScriptConnectFunc)         (ClutterScript *script,
                                                         GObject *object,
                                                         const gchar *signal_name,
                                                         const gchar *handler_name,
                                                         GObject *connect_object,
                                                         GConnectFlags flags,
                                                         gpointer user_data);
void                clutter_script_connect_signals      (ClutterScript *script,
                                                         gpointer user_data);
void                clutter_script_connect_signals_full (ClutterScript *script,
                                                         ClutterScriptConnectFunc func,
                                                         gpointer user_data);
GType               clutter_script_get_type_from_name   (ClutterScript *script,
                                                         const gchar *type_name);
const gchar *       clutter_get_script_id               (GObject *gobject);
ClutterScript is an object used for loading and building parts or a complete scenegraph from external definition data in forms of string buffers or files.
The UI definition format is JSON, the JavaScript Object Notation as
described by RFC 4627. ClutterScript can load a JSON data stream,
parse it and build all the objects defined into it. Each object must
have an "id" and a "type" properties defining the name to be used
to retrieve it from ClutterScript with clutter_script_get_object(),
and the class type to be instanciated. Every other attribute will
be mapped to the class properties.
A ClutterScript holds a reference on every object it creates from
the definition data, except for the stage. Every non-actor object
will be finalized when the ClutterScript instance holding it will
be finalized, so they need to be referenced using g_object_ref() in
order for them to survive.
A simple object might be defined as:
{
  "id"     : "red-button",
  "type"   : "ClutterRectangle",
  "width"  : 100,
  "height" : 100,
  "color"  : "#ff0000ff"
}
This will produce a red ClutterRectangle, 100x100 pixels wide, and with a ClutterScript id of "red-button"; it can be retrieved by calling:
ClutterActor *red_button; red_button = CLUTTER_ACTOR (clutter_script_get_object (script, "red-button"));
and then manipulated with the Clutter API. For every object created
using ClutterScript it is possible to check the id by calling
clutter_get_script_id().
Packing can be represented using the "children" member, and passing an array of objects or ids of objects already defined (but not packed: the packing rules of Clutter still apply, and an actor cannot be packed in multiple containers without unparenting it in between).
Behaviours and timelines can also be defined inside a UI definition buffer:
{
  "id"          : "rotate-behaviour",
  "type"        : "ClutterBehaviourRotate",
  "angle-start" : 0.0,
  "angle-end"   : 360.0,
  "axis"        : "z-axis",
  "alpha"       : {
    "timeline" : { "duration" : 4000, "loop" : true },
    "mode"     : "easeInSine"
  }
}
And then to apply a defined behaviour to an actor defined inside the definition of an actor, the "behaviour" member can be used:
{
  "id" : "my-rotating-actor",
  "type" : "ClutterTexture",
  ...
  "behaviours" : [ "rotate-behaviour" ]
}
A ClutterAlpha belonging to a ClutterBehaviour can only be defined implicitly like in the example above, or explicitly by setting the "alpha" property to point to a previously defined ClutterAlpha, e.g.:
{
  "id"          : "rotate-behaviour",
  "type"        : "ClutterBehaviourRotate",
  "angle-start" : 0.0,
  "angle-end"   : 360.0,
  "axis"        : "z-axis",
  "alpha"       : {
    "id"       : "rotate-alpha",
    "type"     : "ClutterAlpha",
    "timeline" : {
      "id"       : "rotate-timeline",
      "type      : "ClutterTimeline",
      "duration" : 4000,
      "loop"     : true
    },
    "function" : "custom_sine_alpha"
  }
}
Implicitely defined ClutterAlphas and ClutterTimelines
can omit the id member, as well as the
type member, but will not be available using
clutter_script_get_object() (they can, however, be extracted using the
ClutterBehaviour and ClutterAlpha API respectively).
Signal handlers can be defined inside a Clutter UI definition file and
then autoconnected to their respective signals using the
clutter_script_connect_signals() function:
  ...
  "signals" : [
    { "name" : "button-press-event", "handler" : "on_button_press" },
    {
      "name" : "foo-signal",
      "handler" : "after_foo",
      "after" : true
    },
  ],
  ...
Signal handler definitions must have a "name" and a "handler" members;
they can also have the "after" and "swapped" boolean members (for the
signal connection flags G_CONNECT_AFTER and G_CONNECT_SWAPPED
respectively) and the "object" string member for calling
g_signal_connect_object() instead of g_signal_connect().
Clutter reserves the following names, so classes defining properties through the usual GObject registration process should avoid using these names to avoid collisions:
  "id"         := the unique name of a ClutterScript object
  "type"       := the class literal name, also used to infer the type
                  function
  "type_func"  := the GType function name, for non-standard classes
  "children"   := an array of names or objects to add as children
  "behaviours" := an array of names or objects to apply to an actor
  "signals"    := an array of signal definitions to connect to an object
  "is-default" := a boolean flag used when defining the #ClutterStage;
                  if set to "true" the default stage will be used instead
                  of creating a new #ClutterStage instance
ClutterScript is available since Clutter 0.6
typedef struct _ClutterScript ClutterScript;
The ClutterScript structure contains only private data and should be accessed using the provided API
Since 0.6
typedef struct {
  GType (* get_type_from_name) (ClutterScript *script,
                                const gchar   *type_name);
} ClutterScriptClass;
The ClutterScriptClass structure contains only private data
| 
 | virtual function used to map a type name
  to a GType. This function should only be overridden by
  language bindings in order to map native types to GType.
  The default implementation is equivalent to g_type_from_name() | 
Since 0.6
ClutterScript * clutter_script_new (void);
Creates a new ClutterScript instance. ClutterScript can be used to load objects definitions for scenegraph elements, like actors, or behavioural elements, like behaviours and timelines. The definitions must be encoded using the JavaScript Object Notation (JSON) language.
| Returns : | the newly created ClutterScript instance. Use g_object_unref()when done. | 
Since 0.6
typedef enum {
  CLUTTER_SCRIPT_ERROR_INVALID_TYPE_FUNCTION,
  CLUTTER_SCRIPT_ERROR_INVALID_PROPERTY,
  CLUTTER_SCRIPT_ERROR_INVALID_VALUE
} ClutterScriptError;
ClutterScript error enumeration.
| Type function not found or invalid | |
| Property not found or invalid | |
| Invalid value | 
Since 0.6
guint clutter_script_load_from_data (ClutterScript *script, const gchar *data, gssize length, GError **error);
Loads the definitions from data into script and merges with
the currently loaded ones, if any.
| 
 | a ClutterScript | 
| 
 | a buffer containing the definitions | 
| 
 | the length of the buffer, or -1 if datais a NUL-terminated
  buffer | 
| 
 | return location for a GError, or NULL | 
| Returns : | on error, zero is returned and erroris set
  accordingly. On success, the merge id for the UI definitions is
  returned. You can use the merge id withclutter_script_unmerge(). | 
Since 0.6
guint clutter_script_load_from_file (ClutterScript *script, const gchar *filename, GError **error);
Loads the definitions from filename into script and merges with
the currently loaded ones, if any.
| 
 | a ClutterScript | 
| 
 | the full path to the definition file | 
| 
 | return location for a GError, or NULL | 
| Returns : | on error, zero is returned and erroris set
  accordingly. On success, the merge id for the UI definitions is
  returned. You can use the merge id withclutter_script_unmerge(). | 
Since 0.6
void clutter_script_add_search_paths (ClutterScript *script, const gchar * const paths[], gsize n_paths);
Adds paths to the list of search paths held by script.
The search paths are used by clutter_script_lookup_filename(), which
can be used to define search paths for the textures source file name
or other custom, file-based properties.
| 
 | a ClutterScript | 
| 
 | an array of strings containing different search paths | 
| 
 | the length of the passed array | 
Since 0.8
gchar * clutter_script_lookup_filename (ClutterScript *script, const gchar *filename);
Looks up filename inside the search paths of script. If filename
is found, its full path will be returned .
| 
 | a ClutterScript | 
| 
 | the name of the file to lookup | 
| Returns : | the full path of filenameorNULLif no path was
  found. | 
Since 0.8
GObject * clutter_script_get_object (ClutterScript *script, const gchar *name);
Retrieves the object bound to name. This function does not increment
the reference count of the returned object.
| 
 | a ClutterScript | 
| 
 | the name of the object to retrieve | 
| Returns : | transfer none. transfer none. | 
Since 0.6
gint clutter_script_get_objects (ClutterScript *script, const gchar *first_name, ...);
Retrieves a list of objects for the given names. After script, object
names/return location pairs should be listed, with a NULL pointer
ending the list, like:
  GObject *my_label, *a_button, *main_timeline;
  clutter_script_get_objects (script,
                              "my-label", &my_label,
                              "a-button", &a_button,
                              "main-timeline", &main_timeline,
                              NULL);
Note: This function does not increment the reference count of the returned objects.
| 
 | a ClutterScript | 
| 
 | the name of the first object to retrieve | 
| 
 | return location for a GObject, then additional names, ending
  with NULL | 
| Returns : | the number of objects returned. | 
Since 0.6
void clutter_script_unmerge_objects (ClutterScript *script, guint merge_id);
Unmerges the objects identified by merge_id.
| 
 | a ClutterScript | 
| 
 | merge id returned when loading a UI definition | 
Since 0.6
void clutter_script_ensure_objects (ClutterScript *script);
Ensure that every object defined inside script is correctly
constructed. You should rarely need to use this function.
| 
 | a ClutterScript | 
Since 0.6
GList * clutter_script_list_objects (ClutterScript *script);
Retrieves all the objects created by script.
Note: this function does not increment the reference count of the objects it returns.
| 
 | a ClutterScript | 
| Returns : | transfer container) (element-type GObject. transfer container. element-type GObject. | 
Since 0.8.2
void (*ClutterScriptConnectFunc) (ClutterScript *script, GObject *object, const gchar *signal_name, const gchar *handler_name, GObject *connect_object, GConnectFlags flags, gpointer user_data);
This is the signature of a function used to connect signals.  It is used
by the clutter_script_connect_signals_full() function.  It is mainly
intended for interpreted language bindings, but could be useful where the
programmer wants more control over the signal connection process.
| 
 | a ClutterScript | 
| 
 | the object to connect | 
| 
 | the name of the signal | 
| 
 | the name of the signal handler | 
| 
 | the object to connect the signal to, or NULL | 
| 
 | signal connection flags | 
| 
 | user data to pass to the signal handler | 
Since 0.6
void clutter_script_connect_signals (ClutterScript *script, gpointer user_data);
Connects all the signals defined into a UI definition file to their handlers.
This method invokes clutter_script_connect_signals_full() internally
and uses  GModule's introspective features (by opening the current
module's scope) to look at the application's symbol table.
Note that this function will not work if GModule is not supported by the platform Clutter is running on.
| 
 | a ClutterScript | 
| 
 | data to be passed to the signal handlers, or NULL | 
Since 0.6
void clutter_script_connect_signals_full (ClutterScript *script, ClutterScriptConnectFunc func, gpointer user_data);
Connects all the signals defined into a UI definition file to their handlers.
This function allows to control how the signal handlers are going to be connected to their respective signals. It is meant primarily for language bindings to allow resolving the function names using the native API.
Applications should use clutter_script_connect_signals().
| 
 | a ClutterScript | 
| 
 | signal connection function | 
| 
 | data to be passed to the signal handlers, or NULL | 
Since 0.6
GType clutter_script_get_type_from_name (ClutterScript *script, const gchar *type_name);
Looks up a type by name, using the virtual function that ClutterScript has for that purpose. This function should rarely be used.
| 
 | a ClutterScript | 
| 
 | name of the type to look up | 
| Returns : | the type for the requested type name, or G_TYPE_INVALIDif not corresponding type was found. | 
Since 0.6
const gchar * clutter_get_script_id (GObject *gobject);
Retrieves the Clutter script id, if any.
| 
 | a GObject | 
| Returns : | the script id, or NULLifobjectwas not defined inside
  a UI definition file. The returned string is owned by the object and
  should never be modified or freed. | 
Since 0.6