|  |  |  | Cogl 2.0 Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
CoglBitmap; CoglBool cogl_is_bitmap (void *object); CoglBitmap * cogl_bitmap_new_from_file (const char *filename,CoglError **error); CoglBitmap * cogl_bitmap_new_from_buffer (CoglBuffer *buffer,CoglPixelFormat format,int width,int height,int rowstride,int offset); CoglBitmap * cogl_bitmap_new_with_size (CoglContext *context,unsigned int width,unsigned int height,CoglPixelFormat format); CoglBitmap * cogl_bitmap_new_for_data (CoglContext *context,int width,int height,CoglPixelFormat format,int rowstride,uint8_t *data); CoglPixelFormat cogl_bitmap_get_format (CoglBitmap *bitmap); int cogl_bitmap_get_width (CoglBitmap *bitmap); int cogl_bitmap_get_height (CoglBitmap *bitmap); int cogl_bitmap_get_rowstride (CoglBitmap *bitmap); CoglPixelBuffer * cogl_bitmap_get_buffer (CoglBitmap *bitmap); CoglBool cogl_bitmap_get_size_from_file (const char *filename,int *width,int *height); CoglTexture * cogl_texture_new_from_bitmap (CoglBitmap *bitmap,CoglTextureFlags flags,CoglPixelFormat internal_format); #define COGL_BITMAP_ERROR enum CoglBitmapError;
Cogl allows loading image data into memory as CoglBitmaps without loading them immediately into GPU textures.
CoglBitmap is available since Cogl 1.0
CoglBool            cogl_is_bitmap                      (void *object);
Checks whether object is a CoglBitmap
| 
 | a CoglObject pointer | 
| Returns : | TRUEif the passedobjectrepresents a bitmap,
andFALSEotherwise | 
Since 1.0
CoglBitmap * cogl_bitmap_new_from_file (const char *filename,CoglError **error);
Loads an image file from disk. This function can be safely called from within a thread.
| 
 | the file to load. | 
| 
 | a CoglError or NULL. | 
| Returns : | a CoglBitmap to the new loaded
image data, or NULLif loading the image failed. [transfer full] | 
Since 1.0
CoglBitmap * cogl_bitmap_new_from_buffer (CoglBuffer *buffer,CoglPixelFormat format,int width,int height,int rowstride,int offset);
Wraps some image data that has been uploaded into a CoglBuffer as a CoglBitmap. The data is not copied in this process.
| 
 | A CoglBuffer containing image data | 
| 
 | The CoglPixelFormat defining the format of the image data
in the given buffer. | 
| 
 | The width of the image data in the given buffer. | 
| 
 | The height of the image data in the given buffer. | 
| 
 | The rowstride in bytes of the image data in the given buffer. | 
| 
 | The offset into the given bufferto the first pixel that
should be considered part of the CoglBitmap. | 
| Returns : | a CoglBitmap encapsulating the given buffer. [transfer full] | 
Since 1.8
Stability Level: Unstable
CoglBitmap * cogl_bitmap_new_with_size (CoglContext *context,unsigned int width,unsigned int height,CoglPixelFormat format);
Creates a new CoglBitmap with the given width, height and format. The initial contents of the bitmap are undefined.
The data for the bitmap will be stored in a newly created
CoglPixelBuffer. You can get a pointer to the pixel buffer using
cogl_bitmap_get_buffer(). The CoglBuffer API can then be
used to fill the bitmap with data.
cogl_texture_new_from_bitmap(). For various
reasons, such arrays are likely to have a stride larger than width
* bytes_per_pixel. The user must take the stride into account when
writing into it. The stride can be retrieved with
cogl_bitmap_get_rowstride().
| 
 | A CoglContext | 
| 
 | width of the bitmap in pixels | 
| 
 | height of the bitmap in pixels | 
| 
 | the format of the pixels the array will store | 
| Returns : | a CoglPixelBuffer representing the
newly created array or NULLon failure. [transfer full] | 
Since 1.10
Stability Level: Unstable
CoglBitmap * cogl_bitmap_new_for_data (CoglContext *context,int width,int height,CoglPixelFormat format,int rowstride,uint8_t *data);
Creates a bitmap using some existing data. The data is not copied
so the application must keep the buffer alive for the lifetime of
the CoglBitmap. This can be used for example with
cogl_framebuffer_read_pixels_into_bitmap() to read data directly
into an application buffer with the specified rowstride.
| 
 | A CoglContext | 
| 
 | The width of the bitmap. | 
| 
 | The height of the bitmap. | 
| 
 | The format of the pixel data. | 
| 
 | The rowstride of the bitmap (the number of bytes from the start of one row of the bitmap to the next). | 
| 
 | A pointer to the data. The bitmap will take ownership of this data. | 
| Returns : | A new CoglBitmap. [transfer full] | 
Since 1.10
Stability Level: Unstable
CoglPixelFormat     cogl_bitmap_get_format              (CoglBitmap *bitmap);
| 
 | A CoglBitmap | 
| Returns : | the CoglPixelFormat that the data for the bitmap is in. | 
Since 1.10
Stability Level: Unstable
int                 cogl_bitmap_get_width               (CoglBitmap *bitmap);
| 
 | A CoglBitmap | 
| Returns : | the width of the bitmap | 
Since 1.10
Stability Level: Unstable
int                 cogl_bitmap_get_height              (CoglBitmap *bitmap);
| 
 | A CoglBitmap | 
| Returns : | the height of the bitmap | 
Since 1.10
Stability Level: Unstable
int                 cogl_bitmap_get_rowstride           (CoglBitmap *bitmap);
| 
 | A CoglBitmap | 
| Returns : | the rowstride of the bitmap. This is the number of bytes between the address of start of one row to the address of the next row in the image. | 
Since 1.10
Stability Level: Unstable
CoglPixelBuffer *   cogl_bitmap_get_buffer              (CoglBitmap *bitmap);
| 
 | A CoglBitmap | 
| Returns : | the CoglPixelBuffer that this
buffer uses for storage. Note that if the bitmap was created with cogl_bitmap_new_from_file()then it will not actually be using a
pixel buffer and this function will returnNULL. [transfer none] | 
Since 1.10
Stability Level: Unstable
CoglBool cogl_bitmap_get_size_from_file (const char *filename,int *width,int *height);
Parses an image file enough to extract the width and height of the bitmap.
| 
 | the file to check | 
| 
 | return location for the bitmap width, or NULL. [out] | 
| 
 | return location for the bitmap height, or NULL. [out] | 
| Returns : | TRUEif the image was successfully parsed | 
Since 1.0
CoglTexture * cogl_texture_new_from_bitmap (CoglBitmap *bitmap,CoglTextureFlags flags,CoglPixelFormat internal_format);
cogl_texture_new_from_bitmap has been deprecated since version 1.18 and should not be used in newly-written code. Use specific constructors such as
                  cogl_texture_2d_new_from_bitmap()
Creates a CoglTexture from a CoglBitmap.
| 
 | A CoglBitmap pointer | 
| 
 | Optional flags for the texture, or COGL_TEXTURE_NONE | 
| 
 | the CoglPixelFormat to use for the GPU storage of the texture | 
| Returns : | A newly created CoglTexture or NULLon failure. [transfer full] | 
Since 1.0
#define COGL_BITMAP_ERROR (cogl_bitmap_error_quark ())
CoglError domain for bitmap errors.
Since 1.4
typedef enum {
  COGL_BITMAP_ERROR_FAILED,
  COGL_BITMAP_ERROR_UNKNOWN_TYPE,
  COGL_BITMAP_ERROR_CORRUPT_IMAGE
} CoglBitmapError;
Error codes that can be thrown when performing bitmap
operations. Note that gdk_pixbuf_new_from_file() can also throw
errors directly from the underlying image loading library. For
example, if GdkPixbuf is used then errors GdkPixbufErrors
will be used directly.
| Generic failure code, something went wrong. | |
| Unknown image type. | |
| An image file was broken somehow. | 
Since 1.4