From ae0694c91602fa1cd278394132bc1320c00deba8 Mon Sep 17 00:00:00 2001 From: crupest Date: Sun, 15 May 2022 22:46:05 +0800 Subject: ... --- .../cru/platform/graphics/cairo/CairoGeometry.h | 30 ++++++++++++++++++++++ .../platform/graphics/cairo/CairoGraphicsFactory.h | 8 ++++++ 2 files changed, 38 insertions(+) create mode 100644 include/cru/platform/graphics/cairo/CairoGeometry.h (limited to 'include/cru/platform/graphics') diff --git a/include/cru/platform/graphics/cairo/CairoGeometry.h b/include/cru/platform/graphics/cairo/CairoGeometry.h new file mode 100644 index 00000000..0ddedba4 --- /dev/null +++ b/include/cru/platform/graphics/cairo/CairoGeometry.h @@ -0,0 +1,30 @@ +#pragma once +#include "CairoResource.h" +#include "cru/platform/graphics/Geometry.h" + +#include + +namespace cru::platform::graphics::cairo { +class CRU_PLATFORM_GRAPHICS_CAIRO_API CairoGeometry : public CairoResource, + public virtual IGeometry { + public: + CairoGeometry(CairoGraphicsFactory* factory, cairo_path_t* cairo_path, + bool auto_destroy); + ~CairoGeometry(); + + bool FillContains(const Point& point) override; + Rect GetBounds() override; + std::unique_ptr Transform(const Matrix& matrix) override; + std::unique_ptr CreateStrokeGeometry(float width) override; + + cairo_path_t* GetCairoPath() const { return cairo_path_; } + + private: + cairo_path_t* cairo_path_; + bool auto_destroy_; +}; + +class CRU_PLATFORM_GRAPHICS_CAIRO_API CairoGeometryBuilder + : public CairoResource, + public virtual IGeometryBuilder {}; +} // namespace cru::platform::graphics::cairo diff --git a/include/cru/platform/graphics/cairo/CairoGraphicsFactory.h b/include/cru/platform/graphics/cairo/CairoGraphicsFactory.h index 0c364d5e..130c1c26 100644 --- a/include/cru/platform/graphics/cairo/CairoGraphicsFactory.h +++ b/include/cru/platform/graphics/cairo/CairoGraphicsFactory.h @@ -3,6 +3,8 @@ #include "../Factory.h" #include "CairoResource.h" +#include + namespace cru::platform::graphics::cairo { class CRU_PLATFORM_GRAPHICS_CAIRO_API CairoGraphicsFactory : public CairoResource, @@ -12,5 +14,11 @@ class CRU_PLATFORM_GRAPHICS_CAIRO_API CairoGraphicsFactory ~CairoGraphicsFactory() override; public: + cairo_surface_t* GetDefaultCairoSurface() { return default_cairo_surface_; } + cairo_t* GetDefaultCairo() { return default_cairo_; } + + private: + cairo_surface_t* default_cairo_surface_; + cairo_t* default_cairo_; }; } // namespace cru::platform::graphics::cairo -- cgit v1.2.3