aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/graphics/direct/Geometry.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
committercrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
commit7f15a1ff9a2007e119798053083a0a87d042990a (patch)
treecb35c01a7eaee867376d959b96c9bbd15df939e5 /include/cru/win/graphics/direct/Geometry.hpp
parent74956951ee663012df0c3fe4ebe29799cb2f7732 (diff)
parent7703063a5816b089483e78ccd74bb9902ccfbea8 (diff)
downloadcru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.gz
cru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.bz2
cru-7f15a1ff9a2007e119798053083a0a87d042990a.zip
Merge branch 'master' of https://github.com/crupest/CruUI
Diffstat (limited to 'include/cru/win/graphics/direct/Geometry.hpp')
-rw-r--r--include/cru/win/graphics/direct/Geometry.hpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/include/cru/win/graphics/direct/Geometry.hpp b/include/cru/win/graphics/direct/Geometry.hpp
new file mode 100644
index 00000000..edfec590
--- /dev/null
+++ b/include/cru/win/graphics/direct/Geometry.hpp
@@ -0,0 +1,57 @@
+#pragma once
+#include "ComResource.hpp"
+#include "Resource.hpp"
+
+#include "cru/platform/graphics/Geometry.hpp"
+
+namespace cru::platform::graphics::win::direct {
+class D2DGeometryBuilder : public DirectGraphResource,
+ public virtual IGeometryBuilder {
+ public:
+ explicit D2DGeometryBuilder(DirectGraphFactory* factory);
+
+ CRU_DELETE_COPY(D2DGeometryBuilder)
+ CRU_DELETE_MOVE(D2DGeometryBuilder)
+
+ ~D2DGeometryBuilder() override = default;
+
+ public:
+ void BeginFigure(const Point& point) override;
+ void LineTo(const Point& point) override;
+ void QuadraticBezierTo(const Point& control_point,
+ const Point& end_point) override;
+ void CloseFigure(bool close) override;
+
+ std::unique_ptr<IGeometry> Build() override;
+
+ private:
+ bool IsValid() { return geometry_ != nullptr; }
+ void CheckValidation();
+
+ private:
+ Microsoft::WRL::ComPtr<ID2D1PathGeometry> geometry_;
+ Microsoft::WRL::ComPtr<ID2D1GeometrySink> geometry_sink_;
+};
+
+class D2DGeometry : public DirectGraphResource,
+ public virtual IGeometry,
+ public IComResource<ID2D1Geometry> {
+ public:
+ D2DGeometry(DirectGraphFactory* factory,
+ Microsoft::WRL::ComPtr<ID2D1PathGeometry> geometry);
+
+ CRU_DELETE_COPY(D2DGeometry)
+ CRU_DELETE_MOVE(D2DGeometry)
+
+ ~D2DGeometry() override = default;
+
+ public:
+ ID2D1Geometry* GetComInterface() const override { return geometry_.Get(); }
+
+ public:
+ bool FillContains(const Point& point) override;
+
+ private:
+ Microsoft::WRL::ComPtr<ID2D1PathGeometry> geometry_;
+};
+} // namespace cru::platform::graphics::win::direct