|  |  |  | Cogl 2.0 Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
CoglTexture3D; CoglTexture3D * cogl_texture_3d_new_with_size (CoglContext *context,int width,int height,int depth,CoglPixelFormat internal_format,GError **error); CoglTexture3D * cogl_texture_3d_new_from_bitmap (CoglBitmap *bitmap,unsigned int height,unsigned int depth,CoglPixelFormat internal_format,GError **error); CoglTexture3D * cogl_texture_3d_new_from_data (CoglContext *context,int width,int height,int depth,CoglPixelFormat format,CoglPixelFormat internal_format,int rowstride,int image_stride,const uint8_t *data,GError **error); CoglBool cogl_is_texture_3d (void *object);
These functions allow 3D textures to be used. 3D textures can be thought of as layers of 2D images arranged into a cuboid shape. When choosing a texel from the texture, Cogl will take into account the 'r' texture coordinate to select one of the images.
CoglTexture3D * cogl_texture_3d_new_with_size (CoglContext *context,int width,int height,int depth,CoglPixelFormat internal_format,GError **error);
Creates a new Cogl 3D texture with the specified dimensions and pixel format.
Note that this function will throw a GError if
COGL_FEATURE_TEXTURE_3D is not advertised. It can also fail if the
requested dimensions are not supported by the GPU.
| 
 | a CoglContext | 
| 
 | width of the texture in pixels. | 
| 
 | height of the texture in pixels. | 
| 
 | depth of the texture in pixels. | 
| 
 | the CoglPixelFormat to use for the GPU storage of the texture. | 
| 
 | A GError return location. | 
| Returns : | a new CoglTexture3D object or NULLon failure and an exception will be returned
inerror. | 
Since 1.10
Stability Level: Unstable
CoglTexture3D * cogl_texture_3d_new_from_bitmap (CoglBitmap *bitmap,unsigned int height,unsigned int depth,CoglPixelFormat internal_format,GError **error);
Creates a new 3D texture and initializes it with the images in
bitmap. The images are assumed to be packed together after one
another in the increasing y axis. The height of individual image is
given as height and the number of images is given in depth. The
actual height of the bitmap can be larger than height × depth. In
this case it assumes there is padding between the images.
| 
 | A CoglBitmap object. | 
| 
 | height of the texture in pixels. | 
| 
 | depth of the texture in pixels. | 
| 
 | the CoglPixelFormat that will be used for storing
the buffer on the GPU. If COGL_PIXEL_FORMAT_ANYis given then a
premultiplied format similar to the format of the source data will
be used. The default blending equations of Cogl expect premultiplied
color data; the main use of passing a non-premultiplied format here
is if you have non-premultiplied source data and are going to adjust
the blend mode (seecogl_pipeline_set_blend()) or use the data for
something other than straight blending. | 
| 
 | A GError return location. | 
| Returns : | the newly created texture or NULLif
there was an error. | 
Since 2.0
Stability Level: Unstable
CoglTexture3D * cogl_texture_3d_new_from_data (CoglContext *context,int width,int height,int depth,CoglPixelFormat format,CoglPixelFormat internal_format,int rowstride,int image_stride,const uint8_t *data,GError **error);
Creates a new 3D texture and initializes it with data. The data is
assumed to be packed array of depth images. There can be padding
between the images using image_stride.
Note that this function will throw a GError if
COGL_FEATURE_TEXTURE_3D is not advertised. It can also fail if the
requested dimensions are not supported by the GPU.
| 
 | a CoglContext | 
| 
 | width of the texture in pixels. | 
| 
 | height of the texture in pixels. | 
| 
 | depth of the texture in pixels. | 
| 
 | the CoglPixelFormat the buffer is stored in in RAM | 
| 
 | the CoglPixelFormat that will be used for storing
the buffer on the GPU. If COGL_PIXEL_FORMAT_ANYis given then a
premultiplied format similar to the format of the source data will
be used. The default blending equations of Cogl expect premultiplied
color data; the main use of passing a non-premultiplied format here
is if you have non-premultiplied source data and are going to adjust
the blend mode (seecogl_pipeline_set_blend()) or use the data for
something other than straight blending. | 
| 
 | the memory offset in bytes between the starts of
scanlines in dataor 0 to infer it from the width and format | 
| 
 | the number of bytes from one image to the next. This
can be used to add padding between the images in a similar way
that the rowstride can be used to add padding between
rows. Alternatively 0 can be passed to infer the image_stridefrom theheight. | 
| 
 | pointer the memory region where the source buffer resides | 
| 
 | A GError return location. | 
| Returns : | the newly created CoglTexture3D or NULLif
there was an error an an exception will be returned
througherror. | 
Since 1.10
Stability Level: Unstable
CoglBool            cogl_is_texture_3d                  (void *object);
Checks whether the given object references a CoglTexture3D
| 
 | a CoglObject | 
| Returns : | TRUEif the passed object represents a 3D texture
andFALSEotherwise | 
Since 1.4
Stability Level: Unstable