Image surfaces provide the ability to render to memory buffers either allocated by cairo or by the calling code.  
 More...
|  | 
|  | ImageSurface (cairo_surface_t*cobject, bool has_reference=false) | 
|  | Create a C++ wrapper for the C instance.  More... 
 | 
|  | 
| virtual | ~ImageSurface () | 
|  | 
| int | get_width () const | 
|  | Gets the width of the ImageSurface in pixels.  More... 
 | 
|  | 
| int | get_height () const | 
|  | Gets the height of the ImageSurface in pixels.  More... 
 | 
|  | 
| Format | get_format () const | 
|  | Gets the format of the surface.  More... 
 | 
|  | 
| int | get_stride () const | 
|  | Returns the stride of the image surface in bytes (or 0 if surface is not an image surface).  More... 
 | 
|  | 
|  | 
| unsigned char* | get_data () | 
|  | Get a pointer to the data of the image surface, for direct inspection or modification.  More... 
 | 
|  | 
| const unsigned char* | get_data () const | 
|  | 
|  | Surface (cairo_surface_t*cobject, bool has_reference=false) | 
|  | Create a C++ wrapper for the C instance.  More... 
 | 
|  | 
|  | Surface (const Surface&)=delete | 
|  | 
| Surface& | operator= (const Surface&)=delete | 
|  | 
| virtual | ~Surface () | 
|  | 
| const unsigned char* | get_mime_data (const std::string& mime_type, unsigned long& length) | 
|  | Return mime data previously attached to surface using the specified mime type.  More... 
 | 
|  | 
| void | set_mime_data (const std::string& mime_type, unsigned char* data, unsigned long length, const SlotDestroy& slot_destroy) | 
|  | Attach an image in the format mime_type to surface.  More... 
 | 
|  | 
| void | unset_mime_data (const std::string& mime_type) | 
|  | Remove the data from a surface.  More... 
 | 
|  | 
| void | get_font_options (FontOptions& options) const | 
|  | Retrieves the default font rendering options for the surface.  More... 
 | 
|  | 
| void | finish () | 
|  | This function finishes the surface and drops all references to external resources.  More... 
 | 
|  | 
| void | flush () | 
|  | Do any pending drawing for the surface and also restore any temporary modifications cairo has made to the surface's state.  More... 
 | 
|  | 
| void | mark_dirty () | 
|  | Tells cairo to consider the data buffer dirty.  More... 
 | 
|  | 
| void | mark_dirty (int x, int y, int width, int height) | 
|  | Marks a rectangular area of the given surface dirty.  More... 
 | 
|  | 
| void | set_device_offset (double x_offset, double y_offset) | 
|  | Sets an offset that is added to the device coordinates determined by the CTM when drawing to surface.  More... 
 | 
|  | 
| void | get_device_offset (double& x_offset, double& y_offset) const | 
|  | Returns a previous device offset set by set_device_offset().  More... 
 | 
|  | 
| void | set_fallback_resolution (double x_pixels_per_inch, double y_pixels_per_inch) | 
|  | Set the horizontal and vertical resolution for image fallbacks.  More... 
 | 
|  | 
| void | get_fallback_resolution (double& x_pixels_per_inch, double& y_pixels_per_inch) const | 
|  | This function returns the previous fallback resolution set by set_fallback_resolution(), or default fallback resolution if never set.  More... 
 | 
|  | 
| SurfaceType | get_type () const | 
|  | 
| Content | get_content () const | 
|  | This function returns the content type of surface which indicates whether the surface contains color and/or alpha information.  More... 
 | 
|  | 
| void | copy_page () | 
|  | Emits the current page for backends that support multiple pages, but doesn't clear it, so that the contents of the current page will be retained for the next page.  More... 
 | 
|  | 
| void | show_page () | 
|  | Emits and clears the current page for backends that support multiple pages.  More... 
 | 
|  | 
| bool | has_show_text_glyphs () const | 
|  | Returns whether the surface supports sophisticated Context::show_text_glyphs() operations.  More... 
 | 
|  | 
| void | write_to_png (const std::string& filename) | 
|  | Writes the contents of surface to a new file filename as a PNG image.  More... 
 | 
|  | 
| void | write_to_png_stream (const SlotWriteFunc& write_func) | 
|  | Writes the Surface to the write function.  More... 
 | 
|  | 
| void | write_to_png (cairo_write_func_t write_func, void* closure) | 
|  | 
| RefPtr< Device > | get_device () | 
|  | This function returns the device for a surface.  More... 
 | 
|  | 
| cobject* | cobj () | 
|  | Provides acces to the underlying C cairo surface.  More... 
 | 
|  | 
| const cobject* | cobj () const | 
|  | Provides acces to the underlying C cairo surface.  More... 
 | 
|  | 
|  | 
| static int | format_stride_for_width (Cairo::Format format, int width) | 
|  | This function provides a stride value that will respect all alignment requirements of the accelerated image-rendering code within cairo.  More... 
 | 
|  | 
| static RefPtr< ImageSurface > | create (Format format, int width, int height) | 
|  | Creates an image surface of the specified format and dimensions.  More... 
 | 
|  | 
| static RefPtr< ImageSurface > | create (unsigned char* data, Format format, int width, int height, int stride) | 
|  | Creates an image surface for the provided pixel data.  More... 
 | 
|  | 
| static RefPtr< ImageSurface > | create_from_png (std::string filename) | 
|  | Creates a new image surface and initializes the contents to the given PNG file.  More... 
 | 
|  | 
| static RefPtr< ImageSurface > | create_from_png_stream (const SlotReadFunc& read_func) | 
|  | Creates a new image surface from PNG data read incrementally via the read_func function.  More... 
 | 
|  | 
| static RefPtr< ImageSurface > | create_from_png (cairo_read_func_t read_func, void* closure) | 
|  | 
| static RefPtr< Surface > | create (const RefPtr< Surface > other, Content content, int width, int height) | 
|  | Create a new surface that is as compatible as possible with an existing surface.  More... 
 | 
|  | 
| static RefPtr< Surface > | create (const RefPtr< Surface >& target, double x, double y, double width, double height) | 
|  | Create a new surface that is a rectangle within the target surface.  More... 
 | 
|  | 
Image surfaces provide the ability to render to memory buffers either allocated by cairo or by the calling code. 
The supported image formats are those defined in Cairo::Format
An ImageSurface is the most generic type of Surface and the only one that is available by default. You can either create an ImageSurface whose data is managed by Cairo, or you can create an ImageSurface with a data buffer that you allocated yourself so that you can have full access to the data.
When you create an ImageSurface with your own data buffer, you are free to examine the results at any point and do whatever you want with it. Note that if you modify anything and later want to continue to draw to the surface with cairo, you must let cairo know via Cairo::Surface::mark_dirty()
Note that like all surfaces, an ImageSurface is a reference-counted object that should be used via Cairo::RefPtr. 
  
  | 
        
          | static RefPtr<ImageSurface> Cairo::ImageSurface::create | ( | unsigned char * | data, |  
          |  |  | Format | format, |  
          |  |  | int | width, |  
          |  |  | int | height, |  
          |  |  | int | stride |  
          |  | ) |  |  |  | static | 
 
Creates an image surface for the provided pixel data. 
The output buffer must be kept around until the surface is destroyed or finish() is called on the surface. The initial contents of buffer will be used as the initial image contents; you must explicitly clear the buffer, using, for example, Context::rectangle() and Context::fill() if you want it cleared.
Note that the stride may be larger than width* bytes_per_pixel to provide proper alignment for each pixel and row. This alignment is required to allow high-performance rendering within cairo. The correct way to obtain a legal stride value is to call format_stride_for_width() with the desired format and maximum image width value, and the use the resulting stride value to allocate the data and to create the image surface. See format_stride_for_width() for example code.
- Parameters
- 
  
    | data | a pointer to a buffer supplied by the application in which to write contents. This pointer must be suitably aligned for any kind of variable, (for example, a pointer returned by malloc). |  | format | the format of pixels in the buffer |  | width | the width of the image to be stored in the buffer |  | height | the height of the image to be stored in the buffer |  | stride | the number of bytes between the start of rows in the buffer as allocated. This value should always be computed by cairo_format_stride_for_width() before allocating the data buffer. |  
 
- Returns
- a RefPtr to the newly created surface.