aboutsummaryrefslogtreecommitdiff
path: root/include/cru/platform/graphics
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-05-15 22:46:05 +0800
committercrupest <crupest@outlook.com>2022-05-15 22:46:05 +0800
commitae0694c91602fa1cd278394132bc1320c00deba8 (patch)
tree5c0cec4d15d4299839237fcf135cc45e29ac90e4 /include/cru/platform/graphics
parent576b19c2aee9314371f2f905a66eeac9cab800c0 (diff)
downloadcru-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.h30
-rw-r--r--include/cru/platform/graphics/cairo/CairoGraphicsFactory.h8
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