| Top | Description |  |  |  |  | 
#include <gdk/gdk.h> cairo_surface_t * gdk_window_create_similar_surface (GdkWindow *window,cairo_content_t content,int width,int height); cairo_surface_t * gdk_window_create_similar_image_surface (GdkWindow *window,cairo_format_t format,int width,int height,int scale); cairo_t * gdk_cairo_create (GdkWindow *window); gboolean gdk_cairo_get_clip_rectangle (cairo_t *cr,GdkRectangle *rect); void gdk_cairo_set_source_color (cairo_t *cr,const GdkColor *color); void gdk_cairo_set_source_rgba (cairo_t *cr,const GdkRGBA *rgba); void gdk_cairo_set_source_pixbuf (cairo_t *cr,const GdkPixbuf *pixbuf,gdouble pixbuf_x,gdouble pixbuf_y); void gdk_cairo_set_source_window (cairo_t *cr,GdkWindow *window,gdouble x,gdouble y); void gdk_cairo_rectangle (cairo_t *cr,const GdkRectangle *rectangle); void gdk_cairo_region (cairo_t *cr,const cairo_region_t *region); cairo_region_t * gdk_cairo_region_create_from_surface (cairo_surface_t *surface); cairo_surface_t * gdk_cairo_surface_create_from_pixbuf (const GdkPixbuf *pixbuf,int scale,GdkWindow *for_window);
Cairo is a graphics library that supports vector graphics and image compositing that can be used with GDK. GTK+ does all of its drawing using cairo.
GDK does not wrap the cairo API, instead it allows to create cairo contexts which can be used to draw on GdkWindows. Additional functions allow use GdkRectangles with cairo and to use GdkColors, GdkRGBAs, GdkPixbufs and GdkWindows as sources for drawing operations.
cairo_surface_t * gdk_window_create_similar_surface (GdkWindow *window,cairo_content_t content,int width,int height);
Create a new surface that is as compatible as possible with the
given window. For example the new surface will have the same
fallback resolution and font options as window. Generally, the new
surface will also use the same backend as window, unless that is
not possible for some reason. The type of the returned surface may
be examined with cairo_surface_get_type().
Initially the surface contents are all 0 (transparent if contents have transparency, black otherwise.)
| 
 | window to make new surface similar to | 
| 
 | the content for the new surface | 
| 
 | width of the new surface | 
| 
 | height of the new surface | 
| Returns : | a pointer to the newly allocated surface. The caller
owns the surface and should call cairo_surface_destroy()when done
with it.
This function always returns a valid pointer, but it will return a
pointer to a "nil" surface ifotheris already in an error state
or any other error occurs. | 
Since 2.22
cairo_surface_t * gdk_window_create_similar_image_surface (GdkWindow *window,cairo_format_t format,int width,int height,int scale);
Create a new image surface that is efficient to draw on the
given window.
Initially the surface contents are all 0 (transparent if contents have transparency, black otherwise.)
| 
 | window to make new surface similar to, or NULLif none | 
| 
 | the format for the new surface. [type int] | 
| 
 | width of the new surface | 
| 
 | height of the new surface | 
| 
 | the scale of the new surface, or 0 to use same as window | 
| Returns : | a pointer to the newly allocated surface. The caller
owns the surface and should call cairo_surface_destroy()when done
with it.
This function always returns a valid pointer, but it will return a
pointer to a "nil" surface ifotheris already in an error state
or any other error occurs. | 
Since 3.10
cairo_t *           gdk_cairo_create                    (GdkWindow *window);
Creates a Cairo context for drawing to window.
cairo_reset_clip() on the resulting cairo_t will
produce undefined results, so avoid it at all costs.
| 
 | a GdkWindow | 
| Returns : | A newly created Cairo context. Free with cairo_destroy()when you are done drawing. | 
Since 2.8
gboolean gdk_cairo_get_clip_rectangle (cairo_t *cr,GdkRectangle *rect);
This is a convenience function around cairo_clip_extents().
It rounds the clip extents to integer coordinates and returns
a boolean indicating if a clip area exists.
void gdk_cairo_set_source_color (cairo_t *cr,const GdkColor *color);
gdk_cairo_set_source_color has been deprecated since version 3.4 and should not be used in newly-written code. Use gdk_cairo_set_source_rgba() instead
Sets the specified GdkColor as the source color of cr.
| 
 | a cairo context | 
| 
 | a GdkColor | 
Since 2.8
void gdk_cairo_set_source_rgba (cairo_t *cr,const GdkRGBA *rgba);
Sets the specified GdkRGBA as the source color of cr.
| 
 | a cairo context | 
| 
 | a GdkRGBA | 
Since 3.0
void gdk_cairo_set_source_pixbuf (cairo_t *cr,const GdkPixbuf *pixbuf,gdouble pixbuf_x,gdouble pixbuf_y);
Sets the given pixbuf as the source pattern for cr.
The pattern has an extend mode of CAIRO_EXTEND_NONE and is aligned
so that the origin of pixbuf is pixbuf_x, pixbuf_y.
| 
 | a cairo context | 
| 
 | a GdkPixbuf | 
| 
 | X coordinate of location to place upper left corner of pixbuf | 
| 
 | Y coordinate of location to place upper left corner of pixbuf | 
Since 2.8
void gdk_cairo_set_source_window (cairo_t *cr,GdkWindow *window,gdouble x,gdouble y);
Sets the given window as the source pattern for cr.
The pattern has an extend mode of CAIRO_EXTEND_NONE and is aligned
so that the origin of window is x, y. The window contains all its
subwindows when rendering.
Note that the contents of window are undefined outside of the
visible part of window, so use this function with care.
| 
 | a cairo context | 
| 
 | a GdkWindow | 
| 
 | X coordinate of location to place upper left corner of window | 
| 
 | Y coordinate of location to place upper left corner of window | 
Since 2.24
void gdk_cairo_rectangle (cairo_t *cr,const GdkRectangle *rectangle);
Adds the given rectangle to the current path of cr.
| 
 | a cairo context | 
| 
 | a GdkRectangle | 
Since 2.8
void gdk_cairo_region (cairo_t *cr,const cairo_region_t *region);
Adds the given region to the current path of cr.
| 
 | a cairo context | 
| 
 | a cairo_region_t | 
Since 2.8
cairo_region_t *    gdk_cairo_region_create_from_surface
                                                        (cairo_surface_t *surface);
Creates region that describes covers the area where the given
surface is more than 50% opaque.
This function takes into account device offsets that might be
set with cairo_surface_set_device_offset().
| 
 | a cairo surface | 
| Returns : | A cairo_region_t; must be freed with cairo_region_destroy() | 
cairo_surface_t * gdk_cairo_surface_create_from_pixbuf (const GdkPixbuf *pixbuf,int scale,GdkWindow *for_window);
Creates an image surface with the same contents as the pixbuf.
| 
 | a GdkPixbuf | 
| 
 | the scale of the new surface, or 0 to use same as window | 
| 
 | The window this will be drawn to, on NULL. | 
| Returns : | a new cairo surface, must be freed with cairo_surface_destroy() | 
Since 3.10