|  |  |  | Clutter Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | Signals | ||||
                    ClutterTexture;
                    ClutterTextureClass;
enum                ClutterTextureFlags;
enum                ClutterTextureQuality;
ClutterActor *      clutter_texture_new                 (void);
ClutterActor *      clutter_texture_new_from_file       (const gchar *filename,
                                                         GError **error);
ClutterActor *      clutter_texture_new_from_actor      (ClutterActor *actor);
#define             CLUTTER_TEXTURE_ERROR
enum                ClutterTextureError;
gboolean            clutter_texture_set_from_file       (ClutterTexture *texture,
                                                         const gchar *filename,
                                                         GError **error);
gboolean            clutter_texture_set_from_rgb_data   (ClutterTexture *texture,
                                                         const guchar *data,
                                                         gboolean has_alpha,
                                                         gint width,
                                                         gint height,
                                                         gint rowstride,
                                                         gint bpp,
                                                         ClutterTextureFlags flags,
                                                         GError **error);
gboolean            clutter_texture_set_from_yuv_data   (ClutterTexture *texture,
                                                         const guchar *data,
                                                         gint width,
                                                         gint height,
                                                         ClutterTextureFlags flags,
                                                         GError **error);
gboolean            clutter_texture_set_area_from_rgb_data
                                                        (ClutterTexture *texture,
                                                         const guchar *data,
                                                         gboolean has_alpha,
                                                         gint x,
                                                         gint y,
                                                         gint width,
                                                         gint height,
                                                         gint rowstride,
                                                         gint bpp,
                                                         ClutterTextureFlags flags,
                                                         GError **error);
void                clutter_texture_get_base_size       (ClutterTexture *texture,
                                                         gint *width,
                                                         gint *height);
CoglPixelFormat     clutter_texture_get_pixel_format    (ClutterTexture *texture);
gint                clutter_texture_get_max_tile_waste  (ClutterTexture *texture);
ClutterTextureQuality  clutter_texture_get_filter_quality
                                                        (ClutterTexture *texture);
void                clutter_texture_set_filter_quality  (ClutterTexture *texture,
                                                         ClutterTextureQuality filter_quality);
CoglHandle          clutter_texture_get_cogl_texture    (ClutterTexture *texture);
void                clutter_texture_set_cogl_texture    (ClutterTexture *texture,
                                                         CoglHandle cogl_tex);
CoglHandle          clutter_texture_get_cogl_material   (ClutterTexture *texture);
void                clutter_texture_set_cogl_material   (ClutterTexture *texture,
                                                         CoglHandle cogl_material);
gboolean            clutter_texture_get_sync_size       (ClutterTexture *texture);
void                clutter_texture_set_sync_size       (ClutterTexture *texture,
                                                         gboolean sync_size);
void                clutter_texture_get_repeat          (ClutterTexture *texture,
                                                         gboolean *repeat_x,
                                                         gboolean *repeat_y);
void                clutter_texture_set_repeat          (ClutterTexture *texture,
                                                         gboolean repeat_x,
                                                         gboolean repeat_y);
gboolean            clutter_texture_get_keep_aspect_ratio
                                                        (ClutterTexture *texture);
void                clutter_texture_set_keep_aspect_ratio
                                                        (ClutterTexture *texture,
                                                         gboolean keep_aspect);
gboolean            clutter_texture_get_load_async      (ClutterTexture *texture);
void                clutter_texture_set_load_async      (ClutterTexture *texture,
                                                         gboolean load_async);
gboolean            clutter_texture_get_load_data_async (ClutterTexture *texture);
void                clutter_texture_set_load_data_async (ClutterTexture *texture,
                                                         gboolean load_async);
GObject +----GInitiallyUnowned +----ClutterActor +----ClutterTexture +----ClutterCairoTexture
"cogl-material" CoglHandle* : Read / Write "cogl-texture" CoglHandle* : Read / Write "disable-slicing" gboolean : Read / Write / Construct Only "filename" gchar* : Write "filter-quality" ClutterTextureQuality : Read / Write / Construct "keep-aspect-ratio" gboolean : Read / Write "load-async" gboolean : Write "load-data-async" gboolean : Write "pixel-format" CoglPixelFormat : Read "repeat-x" gboolean : Read / Write "repeat-y" gboolean : Read / Write "sync-size" gboolean : Read / Write "tile-waste" gint : Read
ClutterTexture is a base class for displaying and manipulating pixel buffer type data.
The clutter_texture_set_from_rgb_data() and
clutter_texture_set_from_file() functions are used to copy image
data into texture memory and subsequently realize the texture.
If texture reads are supported by underlying GL implementation, unrealizing frees image data from texture memory moving to main system memory. Re-realizing then performs the opposite operation. This process allows basic management of commonly limited available texture memory.
Note: a ClutterTexture will scale its contents to fit the bounding
box requested using clutter_actor_set_size(). To display an area of
a texture without scaling, you should set the clip area using
clutter_actor_set_clip().
typedef struct _ClutterTexture ClutterTexture;
The ClutterTexture structure contains only private data and should be accessed using the provided API
Since 0.1
typedef struct {
  void (* size_change)   (ClutterTexture *texture,
                          gint            width,
                          gint            height);
  void (* pixbuf_change) (ClutterTexture *texture);
  void (* load_finished) (ClutterTexture *texture,
                          const GError   *error);
} ClutterTextureClass;
The ClutterTextureClass structure contains only private data
| 
 | handler for the "size-change" signal | 
| 
 | handler for the "pixbuf-change" signal | 
| 
 | handler for the "load-finished" signal | 
Since 0.1
typedef enum { /*< prefix=CLUTTER_TEXTURE >*/
  CLUTTER_TEXTURE_NONE             = 0,
  CLUTTER_TEXTURE_RGB_FLAG_BGR     = 1 << 1,
  CLUTTER_TEXTURE_RGB_FLAG_PREMULT = 1 << 2, /* FIXME: not handled */
  CLUTTER_TEXTURE_YUV_FLAG_YUV2    = 1 << 3
  /* FIXME: add compressed types ? */
} ClutterTextureFlags;
Flags for clutter_texture_set_from_rgb_data() and
clutter_texture_set_from_yuv_data().
| No flags | |
| FIXME | |
| FIXME | |
| FIXME | 
Since 0.4
typedef enum { /*< prefix=CLUTTER_TEXTURE_QUALITY >*/
  CLUTTER_TEXTURE_QUALITY_LOW,
  CLUTTER_TEXTURE_QUALITY_MEDIUM,
  CLUTTER_TEXTURE_QUALITY_HIGH
} ClutterTextureQuality;
Enumaration controlling the texture quality.
| fastest rendering will use nearest neighbour interpolation when rendering. good setting. | |
| higher quality rendering without using extra resources. | |
| render the texture with the best quality available using extra memory. | 
Since 0.8
ClutterActor * clutter_texture_new (void);
Creates a new empty ClutterTexture object.
| Returns : | A newly created ClutterTexture object. | 
ClutterActor * clutter_texture_new_from_file (const gchar *filename, GError **error);
Creates a new ClutterTexture actor to display the image contained a
file. If the image failed to load then NULL is returned and error
is set.
| 
 | The name of an image file to load. | 
| 
 | Return locatoin for an error. | 
| Returns : | A newly created ClutterTexture object or NULL on error. | 
Since 0.8
ClutterActor * clutter_texture_new_from_actor (ClutterActor *actor);
Creates a new ClutterTexture object with its source a prexisting actor (and associated children). The textures content will contain 'live' redirected output of the actors scene.
Note this function is intented as a utility call for uniformly applying
shaders to groups and other potential visual effects. It requires that
the CLUTTER_FEATURE_OFFSCREEN feature is supported by the current backend
and the target system.
Some tips on usage:
The source actor must be made visible (i.e by calling clutter_actor_show).
The source actor must have a parent in order for it to be
    allocated a size from the layouting mechanism. If the source
    actor does not have a parent when this function is called then
    the ClutterTexture will adopt it and allocate it at its
    preferred size. Using this you can clone an actor that is
    otherwise not displayed. Because of this feature if you do
    intend to display the source actor then you must make sure that
    the actor is parented before calling
    clutter_texture_new_from_actor() or that you unparent it before
    adding it to a container.
When getting the image for the clone texture, Clutter will attempt to render the source actor exactly as it would appear if it was rendered on screen. The source actor's parent transformations are taken into account. Therefore if your source actor is rotated along the X or Y axes so that it has some depth, the texture will appear differently depending on the on-screen location of the source actor. While painting the source actor, Clutter will set up a temporary asymmetric perspective matrix as the projection matrix so that the source actor will be projected as if a small section of the screen was being viewed. Before version 0.8.2, an orthogonal identity projection was used which meant that the source actor would be clipped if any part of it was not on the zero Z-plane.
Avoid reparenting the source with the created texture.
A group can be padded with a transparent rectangle as to provide a border to contents for shader output (blurring text for example).
The texture will automatically resize to contain a further transformed source. However, this involves overhead and can be avoided by placing the source actor in a bounding group sized large enough to contain any child tranformations.
Uploading pixel data to the texture (e.g by using
    clutter_actor_set_from_file()) will destroy the offscreen texture data
    and end redirection.
cogl_texture_get_data() with the handle returned by
    clutter_texture_get_cogl_texture() can be used to read the
    offscreen texture pixels into a pixbuf.
| 
 | A source ClutterActor | 
| Returns : | A newly created ClutterTexture object, or NULLon failure. | 
Since 0.6
#define CLUTTER_TEXTURE_ERROR (clutter_texture_error_quark ())
Error domain for ClutterTexture errors
Since 0.4
typedef enum {
  CLUTTER_TEXTURE_ERROR_OUT_OF_MEMORY,
  CLUTTER_TEXTURE_ERROR_NO_YUV,
  CLUTTER_TEXTURE_ERROR_BAD_FORMAT
} ClutterTextureError;
Error enumeration for ClutterTexture
| OOM condition | |
| YUV operation attempted but no YUV support found | |
| The requested format for clutter_texture_set_from_rgb_data or clutter_texture_set_from_yuv_data is unsupported. | 
Since 0.4
gboolean clutter_texture_set_from_file (ClutterTexture *texture, const gchar *filename, GError **error);
Sets the ClutterTexture image data from an image file. In case of
failure, FALSE is returned and error is set.
If "load-async" is set to TRUE, this function
will return as soon as possible, and the actual image loading
from disk will be performed asynchronously. "size-change"
will be emitten when the size of the texture is available and
"load-finished" will be emitted when the image has been
loaded or if an error occurred.
| 
 | A ClutterTexture | 
| 
 | The filename of the image in GLib file name encoding | 
| 
 | Return location for a GError, or NULL | 
| Returns : | TRUEif the image was successfully loaded and set | 
Since 0.8
gboolean clutter_texture_set_from_rgb_data (ClutterTexture *texture, const guchar *data, gboolean has_alpha, gint width, gint height, gint rowstride, gint bpp, ClutterTextureFlags flags, GError **error);
Sets ClutterTexture image data.
| 
 | A ClutterTexture | 
| 
 | Image data in RGBA type colorspace. | 
| 
 | Set to TRUE if image data has an alpha channel. | 
| 
 | Width in pixels of image data. | 
| 
 | Height in pixels of image data | 
| 
 | Distance in bytes between row starts. | 
| 
 | bytes per pixel (Currently only 3 and 4 supported,
                       depending on has_alpha) | 
| 
 | ClutterTextureFlags | 
| 
 | return location for a GError, or NULL. | 
| Returns : | TRUEon success,FALSEon failure. | 
Since 0.4.
gboolean clutter_texture_set_from_yuv_data (ClutterTexture *texture, const guchar *data, gint width, gint height, ClutterTextureFlags flags, GError **error);
Sets a ClutterTexture from YUV image data. If an error occurred,
FALSE is returned and error is set.
| 
 | A ClutterTexture | 
| 
 | Image data in YUV type colorspace. | 
| 
 | Width in pixels of image data. | 
| 
 | Height in pixels of image data | 
| 
 | ClutterTextureFlags | 
| 
 | Return location for a GError, or NULL. | 
| Returns : | TRUEif the texture was successfully updated | 
Since 0.4
gboolean clutter_texture_set_area_from_rgb_data (ClutterTexture *texture, const guchar *data, gboolean has_alpha, gint x, gint y, gint width, gint height, gint rowstride, gint bpp, ClutterTextureFlags flags, GError **error);
Updates a sub-region of the pixel data in a ClutterTexture.
| 
 | A ClutterTexture | 
| 
 | Image data in RGB type colorspace. | 
| 
 | Set to TRUE if image data has an alpha channel. | 
| 
 | X coordinate of upper left corner of region to update. | 
| 
 | Y coordinate of upper left corner of region to update. | 
| 
 | Width in pixels of region to update. | 
| 
 | Height in pixels of region to update. | 
| 
 | Distance in bytes between row starts on source buffer. | 
| 
 | bytes per pixel (Currently only 3 and 4 supported,
                       depending on has_alpha) | 
| 
 | ClutterTextureFlags | 
| 
 | return location for a GError, or NULL | 
| Returns : | TRUEon success,FALSEon failure. | 
Since 0.6
void clutter_texture_get_base_size (ClutterTexture *texture, gint *width, gint *height);
Gets the size in pixels of the untransformed underlying image
| 
 | a ClutterTexture | 
| 
 | return location for the width, or NULL. out. | 
| 
 | return location for the height, or NULL. out. | 
CoglPixelFormat clutter_texture_get_pixel_format (ClutterTexture *texture);
Retrieves the pixel format used by texture. This is
equivalent to:
  handle = clutter_texture_get_pixel_format (texture);
  if (handle != COGL_INVALID_HANDLE)
    format = cogl_texture_get_format (handle);
| 
 | a ClutterTexture | 
| Returns : | a CoglPixelFormat value | 
Since 1.0
gint clutter_texture_get_max_tile_waste (ClutterTexture *texture);
Gets the maximum waste that will be used when creating a texture or -1 if slicing is disabled.
| 
 | A ClutterTexture | 
| Returns : | The maximum waste or -1 if the texture waste is unlimited. | 
Since 0.8
ClutterTextureQuality clutter_texture_get_filter_quality (ClutterTexture *texture);
Gets the filter quality used when scaling a texture.
| 
 | A ClutterTexture | 
| Returns : | The filter quality value. | 
Since 0.8
void clutter_texture_set_filter_quality (ClutterTexture *texture, ClutterTextureQuality filter_quality);
Sets the filter quality when scaling a texture. The quality is an
enumeration currently the following values are supported:
CLUTTER_TEXTURE_QUALITY_LOW which is fast but only uses nearest neighbour
interpolation. CLUTTER_TEXTURE_QUALITY_MEDIUM which is computationally a
bit more expensive (bilinear interpolation), and
CLUTTER_TEXTURE_QUALITY_HIGH which uses extra texture memory resources to
improve scaled down rendering as well (by using mipmaps). The default value
is CLUTTER_TEXTURE_QUALITY_MEDIUM.
| 
 | a ClutterTexture | 
| 
 | new filter quality value | 
Since 0.8
CoglHandle clutter_texture_get_cogl_texture (ClutterTexture *texture);
Retrieves the handle to the underlying COGL texture used for drawing
the actor. No extra reference is taken so if you need to keep the
handle then you should call cogl_handle_ref() on it.
The texture handle returned is the first layer of the material
handle used by the ClutterTexture. If you need to access the other
layers you should use clutter_texture_get_cogl_material() instead
and use the CoglMaterial API.
| 
 | A ClutterTexture | 
| Returns : | COGL texture handle | 
Since 0.8
void clutter_texture_set_cogl_texture (ClutterTexture *texture, CoglHandle cogl_tex);
Replaces the underlying COGL texture drawn by this actor with
cogl_tex. A reference to the texture is taken so if the handle is
no longer needed it should be deref'd with cogl_handle_unref.
This should not be called on an unrealizable texture (one that isn't inside a stage). (Currently the ClutterTexture implementation relies on being able to have a GL texture while unrealized, which means you can get away with it, but it's not correct and may change in the future.)
| 
 | A ClutterTexture | 
| 
 | A CoglHandle for a texture | 
Since 0.8
CoglHandle clutter_texture_get_cogl_material (ClutterTexture *texture);
Returns a handle to the underlying COGL material used for drawing
the actor. No extra reference is taken so if you need to keep the
handle then you should call cogl_handle_ref() on it.
| 
 | A ClutterTexture | 
| Returns : | COGL material handle | 
Since 1.0
void clutter_texture_set_cogl_material (ClutterTexture *texture, CoglHandle cogl_material);
Replaces the underlying COGL texture drawn by this actor with
cogl_tex. A reference to the texture is taken so if the handle is
no longer needed it should be deref'd with cogl_handle_unref.
| 
 | A ClutterTexture | 
| 
 | A CoglHandle for a material | 
Since 0.8
gboolean clutter_texture_get_sync_size (ClutterTexture *texture);
Retrieves the value set with clutter_texture_get_sync_size()
| 
 | a ClutterTexture | 
| Returns : | TRUEif the ClutterTexture should have the same
  preferred size of the underlying image data | 
Since 1.0
void clutter_texture_set_sync_size (ClutterTexture *texture, gboolean sync_size);
Sets whether texture should have the same preferred size as the
underlying image data.
| 
 | a ClutterTexture | 
| 
 | TRUEif the texture should have the same size of the
   underlying image data | 
Since 1.0
void clutter_texture_get_repeat (ClutterTexture *texture, gboolean *repeat_x, gboolean *repeat_y);
Retrieves the horizontal and vertical repeat values set
using clutter_texture_set_repeat()
| 
 | a ClutterTexture | 
| 
 | return location for the horizontal repeat. out. | 
| 
 | return location for the vertical repeat. out. | 
Since 1.0
void clutter_texture_set_repeat (ClutterTexture *texture, gboolean repeat_x, gboolean repeat_y);
Sets whether the texture should repeat horizontally or
vertically when the actor size is bigger than the image size
| 
 | a ClutterTexture | 
| 
 | TRUEif the texture should repeat horizontally | 
| 
 | TRUEif the texture should repeat vertically | 
Since 1.0
gboolean clutter_texture_get_keep_aspect_ratio (ClutterTexture *texture);
Retrieves the value set using clutter_texture_get_keep_aspect_ratio()
| 
 | a ClutterTexture | 
| Returns : | TRUEif the ClutterTexture should maintain the
  aspect ratio of the underlying image | 
Since 1.0
void                clutter_texture_set_keep_aspect_ratio
                                                        (ClutterTexture *texture,
                                                         gboolean keep_aspect);
Sets whether texture should have a preferred size maintaining
the aspect ratio of the underlying image
| 
 | a ClutterTexture | 
| 
 | TRUEto maintain aspect ratio | 
Since 1.0
gboolean clutter_texture_get_load_async (ClutterTexture *texture);
Retrieves the value set using clutter_texture_get_load_async()
| 
 | a ClutterTexture | 
| Returns : | TRUEif the ClutterTexture should load the data from
  disk asynchronously | 
Since 1.0
void clutter_texture_set_load_async (ClutterTexture *texture, gboolean load_async);
Sets whether texture should use a worker thread to load the data
from disk asynchronously. Setting load_async to TRUE will make
clutter_texture_set_from_file() return immediately.
See the "load-async" property documentation, and
clutter_texture_set_load_data_async().
| 
 | a ClutterTexture | 
| 
 | TRUEif the texture should asynchronously load data
  from a filename | 
Since 1.0
gboolean clutter_texture_get_load_data_async (ClutterTexture *texture);
Retrieves the value set by clutter_texture_set_load_data_async()
| 
 | a ClutterTexture | 
| Returns : | TRUEif the ClutterTexture should load the image
  data from a file asynchronously | 
Since 1.0
void clutter_texture_set_load_data_async (ClutterTexture *texture, gboolean load_async);
Sets whether texture should use a worker thread to load the data
from disk asynchronously. Setting load_async to TRUE will make
clutter_texture_set_from_file() block until the ClutterTexture has
determined the width and height of the image data.
See the "load-async" property documentation, and
clutter_texture_set_load_async().
| 
 | a ClutterTexture | 
| 
 | TRUEif the texture should asynchronously load data
  from a filename | 
Since 1.0
"cogl-material" property"cogl-material" CoglHandle* : Read / Write
The underlying COGL material handle used to draw this actor.
"cogl-texture" property"cogl-texture" CoglHandle* : Read / Write
The underlying COGL texture handle used to draw this actor.
"disable-slicing" property"disable-slicing" gboolean : Read / Write / Construct Only
Force the underlying texture to be singlularand not made of of smaller space saving inidivual textures.
Default value: FALSE
"filename" property"filename" gchar* : Write
The full path of the file containing the texture.
Default value: NULL
"filter-quality" property"filter-quality" ClutterTextureQuality : Read / Write / Construct
Rendering quality used when drawing the texture.
Default value: CLUTTER_TEXTURE_QUALITY_MEDIUM
"keep-aspect-ratio" property"keep-aspect-ratio" gboolean : Read / Write
Keep the aspect ratio of the texture when requesting the preferred width or height.
Default value: FALSE
"load-async" property"load-async" gboolean : Write
Tries to load a texture from a filename by using a local thread to perform the read operations. The initially created texture has dimensions 0x0 when the true size becomes available the "size-change" signal is emitted and when the image has completed loading the "load-finished" signal is emitted.
Threading is only enabled if g_thread_init() has been called prior to
clutter_init(), otherwise ClutterTexture will use the main loop to load
the image.
The upload of the texture data on the GL pipeline is not asynchronous, as
it must be performed from within the same thread that called
clutter_main().
Default value: FALSE
Since 1.0
"load-data-async" property"load-data-async" gboolean : Write
Like "load-async" but loads the width and height synchronously causing some blocking.
Default value: FALSE
Since 1.0
"pixel-format" property"pixel-format" CoglPixelFormat : Read
CoglPixelFormat to use.
Default value: COGL_PIXEL_FORMAT_RGBA_8888
"repeat-x" property"repeat-x" gboolean : Read / Write
Repeat underlying pixbuf rather than scale in x direction.
Default value: FALSE
"repeat-y" property"repeat-y" gboolean : Read / Write
Repeat underlying pixbuf rather than scale in y direction.
Default value: FALSE
"sync-size" property"sync-size" gboolean : Read / Write
Auto sync size of actor to underlying pixbuf dimensions.
Default value: TRUE
"tile-waste" property"tile-waste" gint : Read
Maximum waste area of a sliced texture.
Allowed values: >= -1
Default value: 127
"load-finished" signalvoid user_function (ClutterTexture *texture, gpointer error, gpointer user_data) : Run Last
The ::load-finished signal is emitted when a texture load has
completed. If there was an error during loading, error will
be set, otherwise it will be NULL
| 
 | the texture which received the signal | 
| 
 | A set error, or NULL | 
| 
 | user data set when the signal handler was connected. | 
Since 1.0
"pixbuf-change" signalvoid user_function (ClutterTexture *texture, gpointer user_data) : Run Last
The ::pixbuf-change signal is emitted each time the pixbuf
used by texture changes.
| 
 | the texture which received the signal | 
| 
 | user data set when the signal handler was connected. | 
"size-change" signalvoid user_function (ClutterTexture *texture, gint width, gint height, gpointer user_data) : Run Last
The ::size-change signal is emitted each time the size of the
pixbuf used by texture changes.  The new size is given as
argument to the callback.
| 
 | the texture which received the signal | 
| 
 | the width of the new texture | 
| 
 | the height of the new texture | 
| 
 | user data set when the signal handler was connected. |