diff options
author | crupest <crupest@outlook.com> | 2022-05-15 22:46:05 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2022-05-15 22:46:05 +0800 |
commit | ae0694c91602fa1cd278394132bc1320c00deba8 (patch) | |
tree | 5c0cec4d15d4299839237fcf135cc45e29ac90e4 /include/cru/platform/graphics | |
parent | 576b19c2aee9314371f2f905a66eeac9cab800c0 (diff) | |
download | cru-ae0694c91602fa1cd278394132bc1320c00deba8.tar.gz cru-ae0694c91602fa1cd278394132bc1320c00deba8.tar.bz2 cru-ae0694c91602fa1cd278394132bc1320c00deba8.zip |
...
Diffstat (limited to 'include/cru/platform/graphics')
-rw-r--r-- | include/cru/platform/graphics/cairo/CairoGeometry.h | 30 | ||||
-rw-r--r-- | include/cru/platform/graphics/cairo/CairoGraphicsFactory.h | 8 |
2 files changed, 38 insertions, 0 deletions
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 <cairo/cairo.h> + +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<IGeometry> Transform(const Matrix& matrix) override; + std::unique_ptr<IGeometry> 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 <cairo/cairo.h> + 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 |