96 lines
2.5 KiB
C
96 lines
2.5 KiB
C
|
/* GDK - The GIMP Drawing Kit
|
||
|
*
|
||
|
* gdkcairocontext.c: Cairo wrappers
|
||
|
*
|
||
|
* Copyright © 2018 Benjamin Otte
|
||
|
*
|
||
|
* This library is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU Library General Public
|
||
|
* License as published by the Free Software Foundation; either
|
||
|
* version 2 of the License, or (at your option) any later version.
|
||
|
*
|
||
|
* This library is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
* Library General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Library General Public
|
||
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
#include "config.h"
|
||
|
|
||
|
#include "gdkcairocontext.h"
|
||
|
|
||
|
#include "gdkcairocontextprivate.h"
|
||
|
|
||
|
#include "gdkcairo.h"
|
||
|
|
||
|
/**
|
||
|
* GdkCairoContext:
|
||
|
*
|
||
|
* `GdkCairoContext` is an object representing the platform-specific
|
||
|
* draw context.
|
||
|
*
|
||
|
* `GdkCairoContext`s are created for a surface using
|
||
|
* [method@Gdk.Surface.create_cairo_context], and the context
|
||
|
* can then be used to draw on that surface.
|
||
|
*/
|
||
|
|
||
|
typedef struct _GdkCairoContextPrivate GdkCairoContextPrivate;
|
||
|
|
||
|
struct _GdkCairoContextPrivate {
|
||
|
gpointer unused;
|
||
|
};
|
||
|
|
||
|
G_DEFINE_ABSTRACT_TYPE_WITH_CODE (GdkCairoContext, gdk_cairo_context, GDK_TYPE_DRAW_CONTEXT,
|
||
|
G_ADD_PRIVATE (GdkCairoContext))
|
||
|
|
||
|
static void
|
||
|
gdk_cairo_context_class_init (GdkCairoContextClass *klass)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
gdk_cairo_context_init (GdkCairoContext *self)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* gdk_cairo_context_cairo_create:
|
||
|
* @self: a `GdkCairoContext` that is currently drawing
|
||
|
*
|
||
|
* Retrieves a Cairo context to be used to draw on the `GdkSurface`
|
||
|
* of @context.
|
||
|
*
|
||
|
* A call to [method@Gdk.DrawContext.begin_frame] with this
|
||
|
* @context must have been done or this function will return %NULL.
|
||
|
*
|
||
|
* The returned context is guaranteed to be valid until
|
||
|
* [method@Gdk.DrawContext.end_frame] is called.
|
||
|
*
|
||
|
* Returns: (transfer full) (nullable): a Cairo context
|
||
|
* to draw on `GdkSurface
|
||
|
*/
|
||
|
cairo_t *
|
||
|
gdk_cairo_context_cairo_create (GdkCairoContext *self)
|
||
|
{
|
||
|
GdkDrawContext *draw_context;
|
||
|
cairo_t *cr;
|
||
|
|
||
|
g_return_val_if_fail (GDK_IS_CAIRO_CONTEXT (self), NULL);
|
||
|
|
||
|
draw_context = GDK_DRAW_CONTEXT (self);
|
||
|
|
||
|
if (!gdk_draw_context_is_in_frame (draw_context))
|
||
|
return NULL;
|
||
|
|
||
|
cr = GDK_CAIRO_CONTEXT_GET_CLASS (self)->cairo_create (self);
|
||
|
|
||
|
gdk_cairo_region (cr, gdk_draw_context_get_frame_region (draw_context));
|
||
|
cairo_clip (cr);
|
||
|
|
||
|
return cr;
|
||
|
}
|
||
|
|