aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2023-10-12 21:44:26 +0800
committercrupest <crupest@outlook.com>2023-10-12 21:44:26 +0800
commit2025756fab9103a3baa8999445e61628cfb9b392 (patch)
treef076e51fb4580e77c50579743128176ba4c0e86c /include
parent3c5aa6583d7ab2533ff721282d1efd52d07281c7 (diff)
downloadcru-2025756fab9103a3baa8999445e61628cfb9b392.tar.gz
cru-2025756fab9103a3baa8999445e61628cfb9b392.tar.bz2
cru-2025756fab9103a3baa8999445e61628cfb9b392.zip
...
Diffstat (limited to 'include')
-rw-r--r--include/cru/platform/graphics/Geometry.h27
-rw-r--r--include/cru/platform/graphics/web_canvas/WebCanvasGeometry.h20
-rw-r--r--include/cru/platform/graphics/web_canvas/WebCanvasMatrix.h9
-rw-r--r--include/cru/platform/graphics/web_canvas/WebCanvasRef.h3
4 files changed, 33 insertions, 26 deletions
diff --git a/include/cru/platform/graphics/Geometry.h b/include/cru/platform/graphics/Geometry.h
index 71d003f6..b4b05194 100644
--- a/include/cru/platform/graphics/Geometry.h
+++ b/include/cru/platform/graphics/Geometry.h
@@ -7,18 +7,11 @@ namespace cru::platform::graphics {
/**
* \remarks Geometry implementation is a disaster zone of platform problems.
* Here are some notes. For geometry object:
- * 1. Some platforms just lack the concept of geometry, like web canvas. Even if
- * there is one, it usually has limited capabilities. They only allow you to
- * create path right on the context and use it directly. The geometry itself
- * can't be separated from context and stored independently, not to mention run
- * some functions. You can't even create a geometry from current state of
- * context. In one word, context -x-> geometry, geometry is weak.
- * 2. Doing hit test right on the geometry is not supported on some platform.
- * The geometry needs to be put on the context first.
- * 3. Transform a geometry to create a new geometry is not supported on some
- * platforms. You can transform the context, but no for geometry itself
- * independently.
- * 4. Create a geometry of a stroke of another geometry is not suppored more
+ * 1. Some platforms just lack the concept of geometry. Even if there is one, it
+ * usually has limited capabilities.
+ * 2. Doing hit test right on the geometry out of context is not supported on
+ * some platform. The geometry needs to be put on the context first.
+ * 3. Create a geometry of a stroke of another geometry is not suppored more
* widely.
*
* Workarounds:
@@ -26,15 +19,7 @@ namespace cru::platform::graphics {
* so far, record the commands and replay it on context when it is used.
* 2. If the geometry can't do hit test itself, always attach a canvas with it,
* and when do hit test, put it on context first.
- * 3. If transform a geometry to create a new geometry is not supported, zip the
- * original geometry and a transform matrix. When it is used on context, restore
- * geometry and matrix the same time.
- * 4. There is no good workaround for 4, so don't use it, maybe.
- *
- * Also note for 3, even we can workaround like that, but there are cases it
- * does not work. Like if we add the support for adding an existing path to a
- * new path, transform can only be performed on context and we can't construct a
- * geometry from context, then it fails.
+ * 3. There is no good workaround for 4, so don't use it, maybe.
*
* For geometry builder:
* It is hard to conclude the common commands of all platforms. Some have this,
diff --git a/include/cru/platform/graphics/web_canvas/WebCanvasGeometry.h b/include/cru/platform/graphics/web_canvas/WebCanvasGeometry.h
index dfb5bbe7..5aca42d1 100644
--- a/include/cru/platform/graphics/web_canvas/WebCanvasGeometry.h
+++ b/include/cru/platform/graphics/web_canvas/WebCanvasGeometry.h
@@ -10,14 +10,20 @@
namespace cru::platform::graphics::web_canvas {
class WebCanvasGeometry : public WebCanvasResource, public virtual IGeometry {
public:
- WebCanvasGeometry(WebCanvasGraphicsFactory* factory, emscripten::val path2d);
+ WebCanvasGeometry(WebCanvasGraphicsFactory* factory, emscripten::val canvas,
+ emscripten::val path2d);
~WebCanvasGeometry() override;
bool StrokeContains(float width, const Point& point) override;
- virtual bool FillContains(const Point& point) = 0;
- virtual Rect GetBounds() = 0;
- virtual std::unique_ptr<IGeometry> Transform(const Matrix& matrix) = 0;
+
+ bool FillContains(const Point& point) override;
+
+ Rect GetBounds() override;
+
+ std::unique_ptr<IGeometry> Transform(const Matrix& matrix) override;
+
private:
+ emscripten::val canvas_;
emscripten::val path2d_;
};
@@ -27,10 +33,14 @@ class WebCanvasGeometry : public WebCanvasResource, public virtual IGeometry {
class WebCanvasGeometryBuilder : public WebCanvasResource,
public SvgGeometryBuilderMixin {
public:
- WebCanvasGeometryBuilder(WebCanvasGraphicsFactory* factory);
+ WebCanvasGeometryBuilder(WebCanvasGraphicsFactory* factory,
+ emscripten::val canvas);
~WebCanvasGeometryBuilder() override;
std::unique_ptr<IGeometry> Build() override;
+
+ private:
+ emscripten::val canvas_;
};
} // namespace cru::platform::graphics::web_canvas
diff --git a/include/cru/platform/graphics/web_canvas/WebCanvasMatrix.h b/include/cru/platform/graphics/web_canvas/WebCanvasMatrix.h
new file mode 100644
index 00000000..428e0ae5
--- /dev/null
+++ b/include/cru/platform/graphics/web_canvas/WebCanvasMatrix.h
@@ -0,0 +1,9 @@
+#pragma once
+
+#include "../../Matrix.h"
+
+#include <emscripten/val.h>
+
+namespace cru::platform::graphics::web_canvas {
+emscripten::val CreateDomMatrix(const Matrix& matrix);
+}
diff --git a/include/cru/platform/graphics/web_canvas/WebCanvasRef.h b/include/cru/platform/graphics/web_canvas/WebCanvasRef.h
index 4cb960bd..a5d4f395 100644
--- a/include/cru/platform/graphics/web_canvas/WebCanvasRef.h
+++ b/include/cru/platform/graphics/web_canvas/WebCanvasRef.h
@@ -18,6 +18,9 @@ namespace cru::platform::graphics::web_canvas {
int GetWidth() const;
int GetHeight() const;
+ void Save() const;
+ void Restore() const;
+
private:
emscripten::val val_;
};