@reffy/infinite-canvas 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.txt +21 -0
- package/README.md +94 -0
- package/esm/API.d.ts +21 -0
- package/esm/API.d.ts.map +1 -0
- package/esm/API.js +74 -0
- package/esm/API.js.map +1 -0
- package/esm/Canvas.d.ts +69 -0
- package/esm/Canvas.d.ts.map +1 -0
- package/esm/Canvas.js +383 -0
- package/esm/Canvas.js.map +1 -0
- package/esm/Component.d.ts +126 -0
- package/esm/Component.d.ts.map +1 -0
- package/esm/Component.js +612 -0
- package/esm/Component.js.map +1 -0
- package/esm/bounding/AABB.d.ts +10 -0
- package/esm/bounding/AABB.d.ts.map +1 -0
- package/esm/bounding/AABB.js +19 -0
- package/esm/bounding/AABB.js.map +1 -0
- package/esm/bounding/BoundingBox.d.ts +53 -0
- package/esm/bounding/BoundingBox.d.ts.map +1 -0
- package/esm/bounding/BoundingBox.js +300 -0
- package/esm/bounding/BoundingBox.js.map +1 -0
- package/esm/bounding/Marquee.d.ts +28 -0
- package/esm/bounding/Marquee.d.ts.map +1 -0
- package/esm/bounding/Marquee.js +111 -0
- package/esm/bounding/Marquee.js.map +1 -0
- package/esm/bounding/MultiBoundingBox.d.ts +33 -0
- package/esm/bounding/MultiBoundingBox.d.ts.map +1 -0
- package/esm/bounding/MultiBoundingBox.js +373 -0
- package/esm/bounding/MultiBoundingBox.js.map +1 -0
- package/esm/bounding/index.d.ts +6 -0
- package/esm/bounding/index.d.ts.map +1 -0
- package/esm/bounding/index.js +6 -0
- package/esm/bounding/index.js.map +1 -0
- package/esm/bounding/type.d.ts +13 -0
- package/esm/bounding/type.d.ts.map +1 -0
- package/esm/bounding/type.js +6 -0
- package/esm/bounding/type.js.map +1 -0
- package/esm/camera/Camera.d.ts +27 -0
- package/esm/camera/Camera.d.ts.map +1 -0
- package/esm/camera/Camera.js +68 -0
- package/esm/camera/Camera.js.map +1 -0
- package/esm/camera/index.d.ts +2 -0
- package/esm/camera/index.d.ts.map +1 -0
- package/esm/camera/index.js +2 -0
- package/esm/camera/index.js.map +1 -0
- package/esm/contextMenu/ContextMenu.d.ts +57 -0
- package/esm/contextMenu/ContextMenu.d.ts.map +1 -0
- package/esm/contextMenu/ContextMenu.js +118 -0
- package/esm/contextMenu/ContextMenu.js.map +1 -0
- package/esm/contextMenu/Interaction.d.ts +22 -0
- package/esm/contextMenu/Interaction.d.ts.map +1 -0
- package/esm/contextMenu/Interaction.js +256 -0
- package/esm/contextMenu/Interaction.js.map +1 -0
- package/esm/contextMenu/index.d.ts +3 -0
- package/esm/contextMenu/index.d.ts.map +1 -0
- package/esm/contextMenu/index.js +3 -0
- package/esm/contextMenu/index.js.map +1 -0
- package/esm/history/history.d.ts +29 -0
- package/esm/history/history.d.ts.map +1 -0
- package/esm/history/history.js +120 -0
- package/esm/history/history.js.map +1 -0
- package/esm/history/index.d.ts +2 -0
- package/esm/history/index.d.ts.map +1 -0
- package/esm/history/index.js +2 -0
- package/esm/history/index.js.map +1 -0
- package/esm/index.d.ts +5 -0
- package/esm/index.d.ts.map +1 -0
- package/esm/index.js +5 -0
- package/esm/index.js.map +1 -0
- package/esm/loader/Interaction.d.ts +4 -0
- package/esm/loader/Interaction.d.ts.map +1 -0
- package/esm/loader/Interaction.js +17 -0
- package/esm/loader/Interaction.js.map +1 -0
- package/esm/loader/Loader.d.ts +19 -0
- package/esm/loader/Loader.d.ts.map +1 -0
- package/esm/loader/Loader.js +49 -0
- package/esm/loader/Loader.js.map +1 -0
- package/esm/loader/index.d.ts +3 -0
- package/esm/loader/index.d.ts.map +1 -0
- package/esm/loader/index.js +3 -0
- package/esm/loader/index.js.map +1 -0
- package/esm/manager/ContextMenu.d.ts +11 -0
- package/esm/manager/ContextMenu.d.ts.map +1 -0
- package/esm/manager/ContextMenu.js +46 -0
- package/esm/manager/ContextMenu.js.map +1 -0
- package/esm/manager/FlipCommand.d.ts +18 -0
- package/esm/manager/FlipCommand.d.ts.map +1 -0
- package/esm/manager/FlipCommand.js +35 -0
- package/esm/manager/FlipCommand.js.map +1 -0
- package/esm/manager/KeyEvent.d.ts +16 -0
- package/esm/manager/KeyEvent.d.ts.map +1 -0
- package/esm/manager/KeyEvent.js +51 -0
- package/esm/manager/KeyEvent.js.map +1 -0
- package/esm/manager/OrderCommand.d.ts +17 -0
- package/esm/manager/OrderCommand.d.ts.map +1 -0
- package/esm/manager/OrderCommand.js +28 -0
- package/esm/manager/OrderCommand.js.map +1 -0
- package/esm/manager/PointerEvent.d.ts +70 -0
- package/esm/manager/PointerEvent.d.ts.map +1 -0
- package/esm/manager/PointerEvent.js +171 -0
- package/esm/manager/PointerEvent.js.map +1 -0
- package/esm/manager/SceneCommand.d.ts +18 -0
- package/esm/manager/SceneCommand.d.ts.map +1 -0
- package/esm/manager/SceneCommand.js +85 -0
- package/esm/manager/SceneCommand.js.map +1 -0
- package/esm/manager/Selection.d.ts +61 -0
- package/esm/manager/Selection.d.ts.map +1 -0
- package/esm/manager/Selection.js +305 -0
- package/esm/manager/Selection.js.map +1 -0
- package/esm/manager/TransformCommand.d.ts +20 -0
- package/esm/manager/TransformCommand.d.ts.map +1 -0
- package/esm/manager/TransformCommand.js +29 -0
- package/esm/manager/TransformCommand.js.map +1 -0
- package/esm/manager/index.d.ts +9 -0
- package/esm/manager/index.d.ts.map +1 -0
- package/esm/manager/index.js +9 -0
- package/esm/manager/index.js.map +1 -0
- package/esm/serializer/index.d.ts +2 -0
- package/esm/serializer/index.d.ts.map +1 -0
- package/esm/serializer/index.js +2 -0
- package/esm/serializer/index.js.map +1 -0
- package/esm/serializer/serializer.d.ts +54 -0
- package/esm/serializer/serializer.d.ts.map +1 -0
- package/esm/serializer/serializer.js +226 -0
- package/esm/serializer/serializer.js.map +1 -0
- package/esm/shaders/grid.d.ts +3 -0
- package/esm/shaders/grid.d.ts.map +1 -0
- package/esm/shaders/grid.js +89 -0
- package/esm/shaders/grid.js.map +1 -0
- package/esm/shaders/img.d.ts +4 -0
- package/esm/shaders/img.d.ts.map +1 -0
- package/esm/shaders/img.js +39 -0
- package/esm/shaders/img.js.map +1 -0
- package/esm/shaders/index.d.ts +4 -0
- package/esm/shaders/index.d.ts.map +1 -0
- package/esm/shaders/index.js +4 -0
- package/esm/shaders/index.js.map +1 -0
- package/esm/shaders/shape.d.ts +4 -0
- package/esm/shaders/shape.d.ts.map +1 -0
- package/esm/shaders/shape.js +29 -0
- package/esm/shaders/shape.js.map +1 -0
- package/esm/shapes/Grid.d.ts +21 -0
- package/esm/shapes/Grid.d.ts.map +1 -0
- package/esm/shapes/Grid.js +86 -0
- package/esm/shapes/Grid.js.map +1 -0
- package/esm/shapes/Img.d.ts +47 -0
- package/esm/shapes/Img.d.ts.map +1 -0
- package/esm/shapes/Img.js +310 -0
- package/esm/shapes/Img.js.map +1 -0
- package/esm/shapes/Rect.d.ts +34 -0
- package/esm/shapes/Rect.d.ts.map +1 -0
- package/esm/shapes/Rect.js +92 -0
- package/esm/shapes/Rect.js.map +1 -0
- package/esm/shapes/Renderable.d.ts +54 -0
- package/esm/shapes/Renderable.d.ts.map +1 -0
- package/esm/shapes/Renderable.js +141 -0
- package/esm/shapes/Renderable.js.map +1 -0
- package/esm/shapes/Shape.d.ts +27 -0
- package/esm/shapes/Shape.d.ts.map +1 -0
- package/esm/shapes/Shape.js +69 -0
- package/esm/shapes/Shape.js.map +1 -0
- package/esm/shapes/Triangle.d.ts +20 -0
- package/esm/shapes/Triangle.d.ts.map +1 -0
- package/esm/shapes/Triangle.js +82 -0
- package/esm/shapes/Triangle.js.map +1 -0
- package/esm/shapes/index.d.ts +6 -0
- package/esm/shapes/index.d.ts.map +1 -0
- package/esm/shapes/index.js +7 -0
- package/esm/shapes/index.js.map +1 -0
- package/esm/state/camera.d.ts +36 -0
- package/esm/state/camera.d.ts.map +1 -0
- package/esm/state/camera.js +88 -0
- package/esm/state/camera.js.map +1 -0
- package/esm/state/index.d.ts +4 -0
- package/esm/state/index.d.ts.map +1 -0
- package/esm/state/index.js +4 -0
- package/esm/state/index.js.map +1 -0
- package/esm/state/pointerEvent.d.ts +23 -0
- package/esm/state/pointerEvent.d.ts.map +1 -0
- package/esm/state/pointerEvent.js +49 -0
- package/esm/state/pointerEvent.js.map +1 -0
- package/esm/state/renderable.d.ts +36 -0
- package/esm/state/renderable.d.ts.map +1 -0
- package/esm/state/renderable.js +176 -0
- package/esm/state/renderable.js.map +1 -0
- package/esm/storage/defaultStorage.d.ts +34 -0
- package/esm/storage/defaultStorage.d.ts.map +1 -0
- package/esm/storage/defaultStorage.js +237 -0
- package/esm/storage/defaultStorage.js.map +1 -0
- package/esm/storage/index.d.ts +3 -0
- package/esm/storage/index.d.ts.map +1 -0
- package/esm/storage/index.js +3 -0
- package/esm/storage/index.js.map +1 -0
- package/esm/storage/storage.d.ts +36 -0
- package/esm/storage/storage.d.ts.map +1 -0
- package/esm/storage/storage.js +44 -0
- package/esm/storage/storage.js.map +1 -0
- package/esm/util/camera/camera.d.ts +19 -0
- package/esm/util/camera/camera.d.ts.map +1 -0
- package/esm/util/camera/camera.js +75 -0
- package/esm/util/camera/camera.js.map +1 -0
- package/esm/util/camera/index.d.ts +2 -0
- package/esm/util/camera/index.d.ts.map +1 -0
- package/esm/util/camera/index.js +2 -0
- package/esm/util/camera/index.js.map +1 -0
- package/esm/util/checks.d.ts +11 -0
- package/esm/util/checks.d.ts.map +1 -0
- package/esm/util/checks.js +36 -0
- package/esm/util/checks.js.map +1 -0
- package/esm/util/clipboard.d.ts +7 -0
- package/esm/util/clipboard.d.ts.map +1 -0
- package/esm/util/clipboard.js +146 -0
- package/esm/util/clipboard.js.map +1 -0
- package/esm/util/color.d.ts +4 -0
- package/esm/util/color.d.ts.map +1 -0
- package/esm/util/color.js +8 -0
- package/esm/util/color.js.map +1 -0
- package/esm/util/customEventType.d.ts +35 -0
- package/esm/util/customEventType.d.ts.map +1 -0
- package/esm/util/customEventType.js +35 -0
- package/esm/util/customEventType.js.map +1 -0
- package/esm/util/files.d.ts +19 -0
- package/esm/util/files.d.ts.map +1 -0
- package/esm/util/files.js +182 -0
- package/esm/util/files.js.map +1 -0
- package/esm/util/handles.d.ts +10 -0
- package/esm/util/handles.d.ts.map +1 -0
- package/esm/util/handles.js +16 -0
- package/esm/util/handles.js.map +1 -0
- package/esm/util/index.d.ts +11 -0
- package/esm/util/index.d.ts.map +1 -0
- package/esm/util/index.js +11 -0
- package/esm/util/index.js.map +1 -0
- package/esm/util/performance.d.ts +2 -0
- package/esm/util/performance.d.ts.map +1 -0
- package/esm/util/performance.js +7 -0
- package/esm/util/performance.js.map +1 -0
- package/esm/util/shaders.d.ts +2 -0
- package/esm/util/shaders.d.ts.map +1 -0
- package/esm/util/shaders.js +30 -0
- package/esm/util/shaders.js.map +1 -0
- package/esm/util/webgl/index.d.ts +3 -0
- package/esm/util/webgl/index.d.ts.map +1 -0
- package/esm/util/webgl/index.js +3 -0
- package/esm/util/webgl/index.js.map +1 -0
- package/esm/util/webgl/m3.d.ts +11 -0
- package/esm/util/webgl/m3.d.ts.map +1 -0
- package/esm/util/webgl/m3.js +98 -0
- package/esm/util/webgl/m3.js.map +1 -0
- package/esm/util/webgl/uniform.d.ts +5 -0
- package/esm/util/webgl/uniform.d.ts.map +1 -0
- package/esm/util/webgl/uniform.js +18 -0
- package/esm/util/webgl/uniform.js.map +1 -0
- package/lib/API.d.ts +21 -0
- package/lib/API.d.ts.map +1 -0
- package/lib/API.js +78 -0
- package/lib/API.js.map +1 -0
- package/lib/Canvas.d.ts +69 -0
- package/lib/Canvas.d.ts.map +1 -0
- package/lib/Canvas.js +387 -0
- package/lib/Canvas.js.map +1 -0
- package/lib/Component.d.ts +126 -0
- package/lib/Component.d.ts.map +1 -0
- package/lib/Component.js +618 -0
- package/lib/Component.js.map +1 -0
- package/lib/bounding/AABB.d.ts +10 -0
- package/lib/bounding/AABB.d.ts.map +1 -0
- package/lib/bounding/AABB.js +23 -0
- package/lib/bounding/AABB.js.map +1 -0
- package/lib/bounding/BoundingBox.d.ts +53 -0
- package/lib/bounding/BoundingBox.d.ts.map +1 -0
- package/lib/bounding/BoundingBox.js +304 -0
- package/lib/bounding/BoundingBox.js.map +1 -0
- package/lib/bounding/Marquee.d.ts +28 -0
- package/lib/bounding/Marquee.d.ts.map +1 -0
- package/lib/bounding/Marquee.js +115 -0
- package/lib/bounding/Marquee.js.map +1 -0
- package/lib/bounding/MultiBoundingBox.d.ts +33 -0
- package/lib/bounding/MultiBoundingBox.d.ts.map +1 -0
- package/lib/bounding/MultiBoundingBox.js +377 -0
- package/lib/bounding/MultiBoundingBox.js.map +1 -0
- package/lib/bounding/index.d.ts +6 -0
- package/lib/bounding/index.d.ts.map +1 -0
- package/lib/bounding/index.js +22 -0
- package/lib/bounding/index.js.map +1 -0
- package/lib/bounding/type.d.ts +13 -0
- package/lib/bounding/type.d.ts.map +1 -0
- package/lib/bounding/type.js +9 -0
- package/lib/bounding/type.js.map +1 -0
- package/lib/camera/Camera.d.ts +27 -0
- package/lib/camera/Camera.d.ts.map +1 -0
- package/lib/camera/Camera.js +72 -0
- package/lib/camera/Camera.js.map +1 -0
- package/lib/camera/index.d.ts +2 -0
- package/lib/camera/index.d.ts.map +1 -0
- package/lib/camera/index.js +18 -0
- package/lib/camera/index.js.map +1 -0
- package/lib/contextMenu/ContextMenu.d.ts +57 -0
- package/lib/contextMenu/ContextMenu.d.ts.map +1 -0
- package/lib/contextMenu/ContextMenu.js +124 -0
- package/lib/contextMenu/ContextMenu.js.map +1 -0
- package/lib/contextMenu/Interaction.d.ts +22 -0
- package/lib/contextMenu/Interaction.d.ts.map +1 -0
- package/lib/contextMenu/Interaction.js +265 -0
- package/lib/contextMenu/Interaction.js.map +1 -0
- package/lib/contextMenu/index.d.ts +3 -0
- package/lib/contextMenu/index.d.ts.map +1 -0
- package/lib/contextMenu/index.js +19 -0
- package/lib/contextMenu/index.js.map +1 -0
- package/lib/history/history.d.ts +29 -0
- package/lib/history/history.d.ts.map +1 -0
- package/lib/history/history.js +127 -0
- package/lib/history/history.js.map +1 -0
- package/lib/history/index.d.ts +2 -0
- package/lib/history/index.d.ts.map +1 -0
- package/lib/history/index.js +18 -0
- package/lib/history/index.js.map +1 -0
- package/lib/index.d.ts +5 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +21 -0
- package/lib/index.js.map +1 -0
- package/lib/loader/Interaction.d.ts +4 -0
- package/lib/loader/Interaction.d.ts.map +1 -0
- package/lib/loader/Interaction.js +21 -0
- package/lib/loader/Interaction.js.map +1 -0
- package/lib/loader/Loader.d.ts +19 -0
- package/lib/loader/Loader.d.ts.map +1 -0
- package/lib/loader/Loader.js +53 -0
- package/lib/loader/Loader.js.map +1 -0
- package/lib/loader/index.d.ts +3 -0
- package/lib/loader/index.d.ts.map +1 -0
- package/lib/loader/index.js +19 -0
- package/lib/loader/index.js.map +1 -0
- package/lib/manager/ContextMenu.d.ts +11 -0
- package/lib/manager/ContextMenu.d.ts.map +1 -0
- package/lib/manager/ContextMenu.js +50 -0
- package/lib/manager/ContextMenu.js.map +1 -0
- package/lib/manager/FlipCommand.d.ts +18 -0
- package/lib/manager/FlipCommand.d.ts.map +1 -0
- package/lib/manager/FlipCommand.js +39 -0
- package/lib/manager/FlipCommand.js.map +1 -0
- package/lib/manager/KeyEvent.d.ts +16 -0
- package/lib/manager/KeyEvent.d.ts.map +1 -0
- package/lib/manager/KeyEvent.js +55 -0
- package/lib/manager/KeyEvent.js.map +1 -0
- package/lib/manager/OrderCommand.d.ts +17 -0
- package/lib/manager/OrderCommand.d.ts.map +1 -0
- package/lib/manager/OrderCommand.js +32 -0
- package/lib/manager/OrderCommand.js.map +1 -0
- package/lib/manager/PointerEvent.d.ts +70 -0
- package/lib/manager/PointerEvent.d.ts.map +1 -0
- package/lib/manager/PointerEvent.js +175 -0
- package/lib/manager/PointerEvent.js.map +1 -0
- package/lib/manager/SceneCommand.d.ts +18 -0
- package/lib/manager/SceneCommand.d.ts.map +1 -0
- package/lib/manager/SceneCommand.js +91 -0
- package/lib/manager/SceneCommand.js.map +1 -0
- package/lib/manager/Selection.d.ts +61 -0
- package/lib/manager/Selection.d.ts.map +1 -0
- package/lib/manager/Selection.js +309 -0
- package/lib/manager/Selection.js.map +1 -0
- package/lib/manager/TransformCommand.d.ts +20 -0
- package/lib/manager/TransformCommand.d.ts.map +1 -0
- package/lib/manager/TransformCommand.js +33 -0
- package/lib/manager/TransformCommand.js.map +1 -0
- package/lib/manager/index.d.ts +9 -0
- package/lib/manager/index.d.ts.map +1 -0
- package/lib/manager/index.js +25 -0
- package/lib/manager/index.js.map +1 -0
- package/lib/serializer/index.d.ts +2 -0
- package/lib/serializer/index.d.ts.map +1 -0
- package/lib/serializer/index.js +18 -0
- package/lib/serializer/index.js.map +1 -0
- package/lib/serializer/serializer.d.ts +54 -0
- package/lib/serializer/serializer.d.ts.map +1 -0
- package/lib/serializer/serializer.js +231 -0
- package/lib/serializer/serializer.js.map +1 -0
- package/lib/shaders/grid.d.ts +3 -0
- package/lib/shaders/grid.d.ts.map +1 -0
- package/lib/shaders/grid.js +92 -0
- package/lib/shaders/grid.js.map +1 -0
- package/lib/shaders/img.d.ts +4 -0
- package/lib/shaders/img.d.ts.map +1 -0
- package/lib/shaders/img.js +43 -0
- package/lib/shaders/img.js.map +1 -0
- package/lib/shaders/index.d.ts +4 -0
- package/lib/shaders/index.d.ts.map +1 -0
- package/lib/shaders/index.js +20 -0
- package/lib/shaders/index.js.map +1 -0
- package/lib/shaders/shape.d.ts +4 -0
- package/lib/shaders/shape.d.ts.map +1 -0
- package/lib/shaders/shape.js +33 -0
- package/lib/shaders/shape.js.map +1 -0
- package/lib/shapes/Grid.d.ts +21 -0
- package/lib/shapes/Grid.d.ts.map +1 -0
- package/lib/shapes/Grid.js +90 -0
- package/lib/shapes/Grid.js.map +1 -0
- package/lib/shapes/Img.d.ts +47 -0
- package/lib/shapes/Img.d.ts.map +1 -0
- package/lib/shapes/Img.js +314 -0
- package/lib/shapes/Img.js.map +1 -0
- package/lib/shapes/Rect.d.ts +34 -0
- package/lib/shapes/Rect.d.ts.map +1 -0
- package/lib/shapes/Rect.js +96 -0
- package/lib/shapes/Rect.js.map +1 -0
- package/lib/shapes/Renderable.d.ts +54 -0
- package/lib/shapes/Renderable.d.ts.map +1 -0
- package/lib/shapes/Renderable.js +146 -0
- package/lib/shapes/Renderable.js.map +1 -0
- package/lib/shapes/Shape.d.ts +27 -0
- package/lib/shapes/Shape.d.ts.map +1 -0
- package/lib/shapes/Shape.js +73 -0
- package/lib/shapes/Shape.js.map +1 -0
- package/lib/shapes/Triangle.d.ts +20 -0
- package/lib/shapes/Triangle.d.ts.map +1 -0
- package/lib/shapes/Triangle.js +86 -0
- package/lib/shapes/Triangle.js.map +1 -0
- package/lib/shapes/index.d.ts +6 -0
- package/lib/shapes/index.d.ts.map +1 -0
- package/lib/shapes/index.js +23 -0
- package/lib/shapes/index.js.map +1 -0
- package/lib/state/camera.d.ts +36 -0
- package/lib/state/camera.d.ts.map +1 -0
- package/lib/state/camera.js +92 -0
- package/lib/state/camera.js.map +1 -0
- package/lib/state/index.d.ts +4 -0
- package/lib/state/index.d.ts.map +1 -0
- package/lib/state/index.js +20 -0
- package/lib/state/index.js.map +1 -0
- package/lib/state/pointerEvent.d.ts +23 -0
- package/lib/state/pointerEvent.d.ts.map +1 -0
- package/lib/state/pointerEvent.js +53 -0
- package/lib/state/pointerEvent.js.map +1 -0
- package/lib/state/renderable.d.ts +36 -0
- package/lib/state/renderable.d.ts.map +1 -0
- package/lib/state/renderable.js +180 -0
- package/lib/state/renderable.js.map +1 -0
- package/lib/storage/defaultStorage.d.ts +34 -0
- package/lib/storage/defaultStorage.d.ts.map +1 -0
- package/lib/storage/defaultStorage.js +246 -0
- package/lib/storage/defaultStorage.js.map +1 -0
- package/lib/storage/index.d.ts +3 -0
- package/lib/storage/index.d.ts.map +1 -0
- package/lib/storage/index.js +19 -0
- package/lib/storage/index.js.map +1 -0
- package/lib/storage/storage.d.ts +36 -0
- package/lib/storage/storage.d.ts.map +1 -0
- package/lib/storage/storage.js +50 -0
- package/lib/storage/storage.js.map +1 -0
- package/lib/util/camera/camera.d.ts +19 -0
- package/lib/util/camera/camera.d.ts.map +1 -0
- package/lib/util/camera/camera.js +87 -0
- package/lib/util/camera/camera.js.map +1 -0
- package/lib/util/camera/index.d.ts +2 -0
- package/lib/util/camera/index.d.ts.map +1 -0
- package/lib/util/camera/index.js +18 -0
- package/lib/util/camera/index.js.map +1 -0
- package/lib/util/checks.d.ts +11 -0
- package/lib/util/checks.d.ts.map +1 -0
- package/lib/util/checks.js +49 -0
- package/lib/util/checks.js.map +1 -0
- package/lib/util/clipboard.d.ts +7 -0
- package/lib/util/clipboard.d.ts.map +1 -0
- package/lib/util/clipboard.js +152 -0
- package/lib/util/clipboard.js.map +1 -0
- package/lib/util/color.d.ts +4 -0
- package/lib/util/color.d.ts.map +1 -0
- package/lib/util/color.js +11 -0
- package/lib/util/color.js.map +1 -0
- package/lib/util/customEventType.d.ts +35 -0
- package/lib/util/customEventType.d.ts.map +1 -0
- package/lib/util/customEventType.js +38 -0
- package/lib/util/customEventType.js.map +1 -0
- package/lib/util/files.d.ts +19 -0
- package/lib/util/files.d.ts.map +1 -0
- package/lib/util/files.js +193 -0
- package/lib/util/files.js.map +1 -0
- package/lib/util/handles.d.ts +10 -0
- package/lib/util/handles.d.ts.map +1 -0
- package/lib/util/handles.js +20 -0
- package/lib/util/handles.js.map +1 -0
- package/lib/util/index.d.ts +11 -0
- package/lib/util/index.d.ts.map +1 -0
- package/lib/util/index.js +27 -0
- package/lib/util/index.js.map +1 -0
- package/lib/util/performance.d.ts +2 -0
- package/lib/util/performance.d.ts.map +1 -0
- package/lib/util/performance.js +10 -0
- package/lib/util/performance.js.map +1 -0
- package/lib/util/shaders.d.ts +2 -0
- package/lib/util/shaders.d.ts.map +1 -0
- package/lib/util/shaders.js +33 -0
- package/lib/util/shaders.js.map +1 -0
- package/lib/util/webgl/index.d.ts +3 -0
- package/lib/util/webgl/index.d.ts.map +1 -0
- package/lib/util/webgl/index.js +19 -0
- package/lib/util/webgl/index.js.map +1 -0
- package/lib/util/webgl/m3.d.ts +11 -0
- package/lib/util/webgl/m3.d.ts.map +1 -0
- package/lib/util/webgl/m3.js +101 -0
- package/lib/util/webgl/m3.js.map +1 -0
- package/lib/util/webgl/uniform.d.ts +5 -0
- package/lib/util/webgl/uniform.d.ts.map +1 -0
- package/lib/util/webgl/uniform.js +21 -0
- package/lib/util/webgl/uniform.js.map +1 -0
- package/package.json +95 -0
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WebGLRenderable = exports.Renderable = void 0;
|
|
4
|
+
const state_1 = require("../state");
|
|
5
|
+
class Renderable {
|
|
6
|
+
get x() {
|
|
7
|
+
return this.state.x;
|
|
8
|
+
}
|
|
9
|
+
get y() {
|
|
10
|
+
return this.state.y;
|
|
11
|
+
}
|
|
12
|
+
get sx() {
|
|
13
|
+
return this.state.scaleX;
|
|
14
|
+
}
|
|
15
|
+
get sy() {
|
|
16
|
+
return this.state.scaleY;
|
|
17
|
+
}
|
|
18
|
+
get dirty() {
|
|
19
|
+
return this.state.dirty;
|
|
20
|
+
}
|
|
21
|
+
get localMatrix() {
|
|
22
|
+
return this.state.localMatrix;
|
|
23
|
+
}
|
|
24
|
+
get worldMatrix() {
|
|
25
|
+
return this.state.worldMatrix;
|
|
26
|
+
}
|
|
27
|
+
get children() {
|
|
28
|
+
return this.state.children;
|
|
29
|
+
}
|
|
30
|
+
get parent() {
|
|
31
|
+
return this.state.parent;
|
|
32
|
+
}
|
|
33
|
+
get angleRadians() {
|
|
34
|
+
return this.state.angleRadians;
|
|
35
|
+
}
|
|
36
|
+
updateTranslation(x, y) {
|
|
37
|
+
this.state.updateTranslation(x, y);
|
|
38
|
+
}
|
|
39
|
+
setTranslation(x, y) {
|
|
40
|
+
this.state.setTranslation(x, y);
|
|
41
|
+
}
|
|
42
|
+
updateScale(x, y) {
|
|
43
|
+
this.state.updateScale(x, y);
|
|
44
|
+
}
|
|
45
|
+
setScale(x, y) {
|
|
46
|
+
this.state.setScale(x, y);
|
|
47
|
+
}
|
|
48
|
+
setAngle(rotationDegree) {
|
|
49
|
+
return this.state.setAngle(rotationDegree);
|
|
50
|
+
}
|
|
51
|
+
flipVertical(height) {
|
|
52
|
+
this.state.flipVertical(height);
|
|
53
|
+
}
|
|
54
|
+
flipHorizontal(width) {
|
|
55
|
+
this.state.flipHorizontal(width);
|
|
56
|
+
}
|
|
57
|
+
markDirty() {
|
|
58
|
+
this.state.markDirty();
|
|
59
|
+
}
|
|
60
|
+
clearDirty() {
|
|
61
|
+
this.state.clearDirty();
|
|
62
|
+
}
|
|
63
|
+
updateLocalMatrix() {
|
|
64
|
+
this.state.updateLocalMatrix();
|
|
65
|
+
}
|
|
66
|
+
setWorldMatrix(matrix) {
|
|
67
|
+
this.state.setWorldMatrix(matrix);
|
|
68
|
+
}
|
|
69
|
+
addChild(child) {
|
|
70
|
+
this.state.appendChild(child);
|
|
71
|
+
}
|
|
72
|
+
addParent(parent) {
|
|
73
|
+
return this.state.setParent(parent);
|
|
74
|
+
}
|
|
75
|
+
clearChildren() {
|
|
76
|
+
return this.state.clearChildren();
|
|
77
|
+
}
|
|
78
|
+
constructor() {
|
|
79
|
+
this.state = new state_1.RenderableState();
|
|
80
|
+
this.setWorldMatrix = this.setWorldMatrix.bind(this);
|
|
81
|
+
this.updateWorldMatrix = this.updateWorldMatrix.bind(this);
|
|
82
|
+
}
|
|
83
|
+
appendChild(child) {
|
|
84
|
+
child.setParent(this);
|
|
85
|
+
if (!child._emitter && this._emitter)
|
|
86
|
+
child._emitter = this._emitter;
|
|
87
|
+
return child;
|
|
88
|
+
}
|
|
89
|
+
setParent(parent) {
|
|
90
|
+
if (this.parent) {
|
|
91
|
+
const i = this.parent.children.indexOf(this);
|
|
92
|
+
if (i >= 0)
|
|
93
|
+
this.parent.children.splice(i, 1);
|
|
94
|
+
}
|
|
95
|
+
if (parent)
|
|
96
|
+
parent.addChild(this);
|
|
97
|
+
this.addParent(parent);
|
|
98
|
+
}
|
|
99
|
+
updateWorldMatrix(parentWorldMatrix) {
|
|
100
|
+
this.updateLocalMatrix();
|
|
101
|
+
this.state.updateWorldMatrix(parentWorldMatrix);
|
|
102
|
+
}
|
|
103
|
+
addEventListener(type, listener, options) {
|
|
104
|
+
const fn = typeof listener === "function"
|
|
105
|
+
? listener
|
|
106
|
+
: listener.handleEvent.bind(listener);
|
|
107
|
+
this._emitter.on(type, fn);
|
|
108
|
+
}
|
|
109
|
+
removeEventListener(type, listener, options) { }
|
|
110
|
+
dispatchEvent(e) {
|
|
111
|
+
this._emitter.emit(e.type, e);
|
|
112
|
+
return !e.defaultPrevented;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
exports.Renderable = Renderable;
|
|
116
|
+
class WebGLRenderable extends Renderable {
|
|
117
|
+
constructor() {
|
|
118
|
+
super(...arguments);
|
|
119
|
+
this.initialized = false;
|
|
120
|
+
}
|
|
121
|
+
updateVertexData(gl) {
|
|
122
|
+
const positions = this.getPositions();
|
|
123
|
+
if (!this.vertexArray || this.vertexArray.length !== positions.length) {
|
|
124
|
+
this.vertexArray = new Float32Array(positions.length);
|
|
125
|
+
}
|
|
126
|
+
this.vertexArray.set(positions);
|
|
127
|
+
gl.bindBuffer(gl.ARRAY_BUFFER, this.positionBuffer);
|
|
128
|
+
gl.bufferData(gl.ARRAY_BUFFER, this.vertexArray, gl.STATIC_DRAW);
|
|
129
|
+
}
|
|
130
|
+
setUpVertexData(gl, program) {
|
|
131
|
+
if (!this.positionBuffer) {
|
|
132
|
+
this.positionBuffer = gl.createBuffer();
|
|
133
|
+
}
|
|
134
|
+
this.attributeLocation = gl.getAttribLocation(program, "a_position");
|
|
135
|
+
}
|
|
136
|
+
setUpUniforms(gl, program) {
|
|
137
|
+
this.resolutionLocation = gl.getUniformLocation(program, "u_resolution");
|
|
138
|
+
this.matrixLocation = gl.getUniformLocation(program, "u_matrix");
|
|
139
|
+
}
|
|
140
|
+
updateUniforms(gl) {
|
|
141
|
+
gl.uniform2f(this.resolutionLocation, gl.canvas.width, gl.canvas.height);
|
|
142
|
+
gl.uniformMatrix3fv(this.matrixLocation, false, this.worldMatrix);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
exports.WebGLRenderable = WebGLRenderable;
|
|
146
|
+
//# sourceMappingURL=Renderable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Renderable.js","sourceRoot":"src/","sources":["shapes/Renderable.ts"],"names":[],"mappings":";;;AACA,oCAA2C;AAE3C,MAAsB,UAAU;IAG9B,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IACtB,CAAC;IACD,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IACtB,CAAC;IACD,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IACD,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IAC1B,CAAC;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IAChC,CAAC;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IAChC,CAAC;IACD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;IACD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IACD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC;IACjC,CAAC;IAED,iBAAiB,CAAC,CAAS,EAAE,CAAS;QACpC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC;IACD,cAAc,CAAC,CAAS,EAAE,CAAS;QACjC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAClC,CAAC;IACD,WAAW,CAAC,CAAS,EAAE,CAAS;QAC9B,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/B,CAAC;IACD,QAAQ,CAAC,CAAS,EAAE,CAAS;QAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,QAAQ,CAAC,cAAsB;QAC7B,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IAC7C,CAAC;IACD,YAAY,CAAC,MAAc;QACzB,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IACD,cAAc,CAAC,KAAa;QAC1B,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;IACzB,CAAC;IACD,UAAU;QACR,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;IAC1B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC;IACjC,CAAC;IACD,cAAc,CAAC,MAAgB;QAC7B,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ,CAAC,KAAiB;QACxB,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IACD,SAAS,CAAC,MAAyB;QACjC,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IACD,aAAa;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IACpC,CAAC;IAID;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,uBAAe,EAAE,CAAC;QAEnC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7D,CAAC;IAED,WAAW,CAAuB,KAAQ;QACxC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;YAAE,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QACrE,OAAO,KAAK,CAAC;IACf,CAAC;IAED,SAAS,CAAC,MAAyB;QACjC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC;gBAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAChD,CAAC;QACD,IAAI,MAAM;YAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IAED,iBAAiB,CAAC,iBAA4B;QAC5C,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,CAAC;IAClD,CAAC;IAMD,gBAAgB,CACd,IAAY,EACZ,QAA4C,EAC5C,OAA2C;QAE3C,MAAM,EAAE,GACN,OAAO,QAAQ,KAAK,UAAU;YAC5B,CAAC,CAAE,QAA0B;YAC7B,CAAC,CAAE,QAAgC,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnE,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,mBAAmB,CACjB,IAAY,EACZ,QAA6C,EAC7C,OAAwC,IACvC,CAAC;IAEJ,aAAa,CAAC,CAAQ;QACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC9B,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;IAC7B,CAAC;CACF;AAvID,gCAuIC;AAED,MAAsB,eAAgB,SAAQ,UAAU;IAAxD;;QAGY,gBAAW,GAAG,KAAK,CAAC;IAqChC,CAAC;IA7BC,gBAAgB,CAAC,EAAyB;QACxC,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAEtC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE,CAAC;YACtE,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACxD,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAEhC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,cAAe,CAAC,CAAC;QACrD,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC;IACnE,CAAC;IAES,eAAe,CAAC,EAAyB,EAAE,OAAqB;QACxE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC,YAAY,EAAE,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IACvE,CAAC;IAES,aAAa,CAAC,EAAyB,EAAE,OAAqB;QACtE,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;QACzE,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IACnE,CAAC;IAES,cAAc,CAAC,EAAyB;QAChD,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACzE,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IACpE,CAAC;CACF;AAxCD,0CAwCC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { AABB } from "../bounding/AABB";
|
|
2
|
+
import { WebGLRenderable } from "./Renderable";
|
|
3
|
+
export interface BoundingVal {
|
|
4
|
+
minX: number;
|
|
5
|
+
minY: number;
|
|
6
|
+
maxX: number;
|
|
7
|
+
maxY: number;
|
|
8
|
+
}
|
|
9
|
+
export declare abstract class Shape extends WebGLRenderable {
|
|
10
|
+
private static _seqCounter;
|
|
11
|
+
private readonly _seq;
|
|
12
|
+
culled: boolean;
|
|
13
|
+
private _renderOrder;
|
|
14
|
+
abstract getVertexCount(): number;
|
|
15
|
+
constructor(x: number, y: number, sx?: number, sy?: number);
|
|
16
|
+
get renderOrder(): number;
|
|
17
|
+
set renderOrder(v: number);
|
|
18
|
+
get seq(): number;
|
|
19
|
+
abstract getEdge(): BoundingVal;
|
|
20
|
+
abstract getBoundingBox(): AABB;
|
|
21
|
+
getZ(): number;
|
|
22
|
+
color: [number, number, number, number];
|
|
23
|
+
render(gl: WebGLRenderingContext, program: WebGLProgram): void;
|
|
24
|
+
protected draw(gl: WebGLRenderingContext): void;
|
|
25
|
+
destroy(): void;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=Shape.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Shape.d.ts","sourceRoot":"src/","sources":["shapes/Shape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,8BAAsB,KAAM,SAAQ,eAAe;IACjD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAK;IAC/B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAuB;IAE5C,MAAM,UAAS;IAEf,OAAO,CAAC,YAAY,CAAa;IACjC,QAAQ,CAAC,cAAc,IAAI,MAAM;gBAErB,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,GAAE,MAAU,EAAE,EAAE,GAAE,MAAU;IAMhE,IAAI,WAAW,IAGI,MAAM,CADxB;IACD,IAAI,WAAW,CAAC,CAAC,EAAE,MAAM,EAKxB;IAED,IAAI,GAAG,WAEN;IAED,QAAQ,CAAC,OAAO,IAAI,WAAW;IAC/B,QAAQ,CAAC,cAAc,IAAI,IAAI;IAE/B,IAAI,IAAI,MAAM;IAMd,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAkB;IAEzD,MAAM,CAAC,EAAE,EAAE,qBAAqB,EAAE,OAAO,EAAE,YAAY,GAAG,IAAI;IAqB9D,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,qBAAqB;IAuBxC,OAAO;CAMR"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Shape = void 0;
|
|
4
|
+
const Renderable_1 = require("./Renderable");
|
|
5
|
+
class Shape extends Renderable_1.WebGLRenderable {
|
|
6
|
+
constructor(x, y, sx = 1, sy = 1) {
|
|
7
|
+
super();
|
|
8
|
+
this._seq = Shape._seqCounter++;
|
|
9
|
+
this.culled = false;
|
|
10
|
+
this._renderOrder = 0;
|
|
11
|
+
this.color = [1, 0, 0.5, 1];
|
|
12
|
+
this.setTranslation(x, y);
|
|
13
|
+
this.setScale(sx, sy);
|
|
14
|
+
}
|
|
15
|
+
get renderOrder() {
|
|
16
|
+
return this._renderOrder;
|
|
17
|
+
}
|
|
18
|
+
set renderOrder(v) {
|
|
19
|
+
if (this._renderOrder !== v) {
|
|
20
|
+
this._renderOrder = v;
|
|
21
|
+
this.markDirty();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
get seq() {
|
|
25
|
+
return this._seq;
|
|
26
|
+
}
|
|
27
|
+
getZ() {
|
|
28
|
+
const step = 0.0001;
|
|
29
|
+
const z = this.renderOrder * step + 0.5;
|
|
30
|
+
return Math.max(0.0, Math.min(1.0, z));
|
|
31
|
+
}
|
|
32
|
+
render(gl, program) {
|
|
33
|
+
this.updateWorldMatrix(this.parent ? this.parent.worldMatrix : undefined);
|
|
34
|
+
gl.useProgram(program);
|
|
35
|
+
if (this.dirty && !this.culled) {
|
|
36
|
+
if (!this.initialized) {
|
|
37
|
+
this.setUpVertexData(gl, program);
|
|
38
|
+
this.setUpUniforms(gl, program);
|
|
39
|
+
this.initialized = true;
|
|
40
|
+
}
|
|
41
|
+
this.updateVertexData(gl);
|
|
42
|
+
this.clearDirty();
|
|
43
|
+
}
|
|
44
|
+
this.updateUniforms(gl);
|
|
45
|
+
const uColor = gl.getUniformLocation(program, "u_color");
|
|
46
|
+
if (uColor) {
|
|
47
|
+
gl.uniform4fv(uColor, this.color);
|
|
48
|
+
}
|
|
49
|
+
if (!this.culled)
|
|
50
|
+
this.draw(gl);
|
|
51
|
+
}
|
|
52
|
+
draw(gl) {
|
|
53
|
+
gl.bindBuffer(gl.ARRAY_BUFFER, this.positionBuffer);
|
|
54
|
+
// Tell the attribute how to get data out of positionBuffer (ARRAY_BUFFER)
|
|
55
|
+
const size = 2; // 2 components per iteration since it's a vec2D
|
|
56
|
+
const type = gl.FLOAT; // the data is 32bit floats
|
|
57
|
+
const normalize = false; // don't normalize the data
|
|
58
|
+
const stride = 0; // 0 = move forward size * sizeof(type) each iteration to get the next position
|
|
59
|
+
const offset = 0; // start at the beginning of the buffer
|
|
60
|
+
gl.vertexAttribPointer(this.attributeLocation, size, type, normalize, stride, offset);
|
|
61
|
+
gl.enableVertexAttribArray(this.attributeLocation);
|
|
62
|
+
gl.drawArrays(gl.TRIANGLES, 0, this.getVertexCount());
|
|
63
|
+
}
|
|
64
|
+
destroy() {
|
|
65
|
+
if (this.positionBuffer) {
|
|
66
|
+
this.positionBuffer = undefined;
|
|
67
|
+
}
|
|
68
|
+
this.initialized = false;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.Shape = Shape;
|
|
72
|
+
Shape._seqCounter = 0;
|
|
73
|
+
//# sourceMappingURL=Shape.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Shape.js","sourceRoot":"src/","sources":["shapes/Shape.ts"],"names":[],"mappings":";;;AACA,6CAA+C;AAS/C,MAAsB,KAAM,SAAQ,4BAAe;IASjD,YAAY,CAAS,EAAE,CAAS,EAAE,KAAa,CAAC,EAAE,KAAa,CAAC;QAC9D,KAAK,EAAE,CAAC;QARO,SAAI,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;QAE5C,WAAM,GAAG,KAAK,CAAC;QAEP,iBAAY,GAAW,CAAC,CAAC;QAgCjC,UAAK,GAAqC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QA3BvD,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,WAAW,CAAC,CAAS;QACvB,IAAI,IAAI,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAED,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAKD,IAAI;QACF,MAAM,IAAI,GAAG,MAAM,CAAC;QACpB,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,GAAG,GAAG,CAAC;QACxC,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC;IAID,MAAM,CAAC,EAAyB,EAAE,OAAqB;QACrD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAC1E,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEvB,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YAC/B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACtB,IAAI,CAAC,eAAe,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBAClC,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1B,CAAC;YACD,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;YAC1B,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,MAAM,GAAG,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QACzD,IAAI,MAAM,EAAE,CAAC;YACX,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;IAES,IAAI,CAAC,EAAyB;QACtC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAEpD,0EAA0E;QAC1E,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,gDAAgD;QAChE,MAAM,IAAI,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,2BAA2B;QAClD,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,2BAA2B;QACpD,MAAM,MAAM,GAAG,CAAC,CAAC,CAAC,+EAA+E;QACjG,MAAM,MAAM,GAAG,CAAC,CAAC,CAAC,uCAAuC;QACzD,EAAE,CAAC,mBAAmB,CACpB,IAAI,CAAC,iBAAiB,EACtB,IAAI,EACJ,IAAI,EACJ,SAAS,EACT,MAAM,EACN,MAAM,CACP,CAAC;QAEF,EAAE,CAAC,uBAAuB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAEnD,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;;AAzFH,sBA0FC;AAzFgB,iBAAW,GAAG,CAAC,AAAJ,CAAK"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AABB } from "bounding";
|
|
2
|
+
import { Shape } from "./Shape";
|
|
3
|
+
export declare class Triangle extends Shape {
|
|
4
|
+
private _base;
|
|
5
|
+
width: number;
|
|
6
|
+
height: number;
|
|
7
|
+
constructor(positions: number[]);
|
|
8
|
+
getPositions(): number[];
|
|
9
|
+
getVertexCount(): number;
|
|
10
|
+
getEdge(): {
|
|
11
|
+
minX: number;
|
|
12
|
+
maxX: number;
|
|
13
|
+
minY: number;
|
|
14
|
+
maxY: number;
|
|
15
|
+
};
|
|
16
|
+
getBoundingBox(): AABB;
|
|
17
|
+
hitTest(x: number, y: number): boolean;
|
|
18
|
+
private edge;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=Triangle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Triangle.d.ts","sourceRoot":"src/","sources":["shapes/Triangle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAChC,OAAO,EAAe,KAAK,EAAE,MAAM,SAAS,CAAC;AAE7C,qBAAa,QAAS,SAAQ,KAAK;IACjC,OAAO,CAAC,KAAK,CAAW;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;gBAEH,SAAS,EAAE,MAAM,EAAE;IAK/B,YAAY,IAAI,MAAM,EAAE;IAaxB,cAAc,IAAI,MAAM;IAIxB,OAAO;;;;;;IAsBP,cAAc,IAAI,IAAI;IAetB,OAAO,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAsC5B,OAAO,CAAC,IAAI,CAOuC;CACpD"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Triangle = void 0;
|
|
4
|
+
const bounding_1 = require("bounding");
|
|
5
|
+
const Shape_1 = require("./Shape");
|
|
6
|
+
class Triangle extends Shape_1.Shape {
|
|
7
|
+
constructor(positions) {
|
|
8
|
+
super(positions[0], positions[1]);
|
|
9
|
+
this.edge = (px, py, qx, qy, rx, ry) => (px - rx) * (qy - ry) - (qx - rx) * (py - ry);
|
|
10
|
+
this._base = positions.slice(0, 6);
|
|
11
|
+
}
|
|
12
|
+
getPositions() {
|
|
13
|
+
const x = this.x, y = this.y;
|
|
14
|
+
return [
|
|
15
|
+
this._base[0] + x,
|
|
16
|
+
this._base[1] + y,
|
|
17
|
+
this._base[2] + x,
|
|
18
|
+
this._base[3] + y,
|
|
19
|
+
this._base[4] + x,
|
|
20
|
+
this._base[5] + y,
|
|
21
|
+
];
|
|
22
|
+
}
|
|
23
|
+
getVertexCount() {
|
|
24
|
+
return 3;
|
|
25
|
+
}
|
|
26
|
+
getEdge() {
|
|
27
|
+
const p = this.getPositions();
|
|
28
|
+
if (!p || p.length < 6) {
|
|
29
|
+
console.error("Triangle is missing positions");
|
|
30
|
+
throw new Error();
|
|
31
|
+
}
|
|
32
|
+
const ax = p[0], ay = p[1];
|
|
33
|
+
const bx = p[2], by = p[3];
|
|
34
|
+
const cx = p[4], cy = p[5];
|
|
35
|
+
return {
|
|
36
|
+
minX: Math.min(ax, bx, cx),
|
|
37
|
+
maxX: Math.max(ax, bx, cx),
|
|
38
|
+
minY: Math.min(ay, by, cy),
|
|
39
|
+
maxY: Math.max(ay, by, cy),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
getBoundingBox() {
|
|
43
|
+
const x0 = this.state.translation[0];
|
|
44
|
+
const x1 = x0 + this.width * this.state.scaleX;
|
|
45
|
+
const y0 = this.state.translation[1];
|
|
46
|
+
const y1 = y0 + this.height * this.state.scaleY;
|
|
47
|
+
const minX = Math.min(x0, x1);
|
|
48
|
+
const maxX = Math.max(x0, x1);
|
|
49
|
+
const minY = Math.min(y0, y1);
|
|
50
|
+
const maxY = Math.max(y0, y1);
|
|
51
|
+
const aabb = new bounding_1.AABB(minX, minY, maxX, maxY);
|
|
52
|
+
return aabb;
|
|
53
|
+
}
|
|
54
|
+
hitTest(x, y) {
|
|
55
|
+
const p = this.getPositions();
|
|
56
|
+
if (!p || p.length < 6)
|
|
57
|
+
return false;
|
|
58
|
+
const ax = p[0], ay = p[1];
|
|
59
|
+
const bx = p[2], by = p[3];
|
|
60
|
+
const cx = p[4], cy = p[5];
|
|
61
|
+
// Fast reject via AABB (optional)
|
|
62
|
+
const minX = Math.min(ax, bx, cx);
|
|
63
|
+
const maxX = Math.max(ax, bx, cx);
|
|
64
|
+
const minY = Math.min(ay, by, cy);
|
|
65
|
+
const maxY = Math.max(ay, by, cy);
|
|
66
|
+
if (x < minX || x > maxX || y < minY || y > maxY)
|
|
67
|
+
return false;
|
|
68
|
+
const eps = 1e-8;
|
|
69
|
+
const e1 = this.edge(x, y, ax, ay, bx, by);
|
|
70
|
+
const e2 = this.edge(x, y, bx, by, cx, cy);
|
|
71
|
+
const e3 = this.edge(x, y, cx, cy, ax, ay);
|
|
72
|
+
// Allow points on edges (>= -eps) and require consistent winding
|
|
73
|
+
const hasNeg = e1 < -eps || e2 < -eps || e3 < -eps;
|
|
74
|
+
const hasPos = e1 > eps || e2 > eps || e3 > eps;
|
|
75
|
+
// If both signs present, point is outside
|
|
76
|
+
if (hasNeg && hasPos)
|
|
77
|
+
return false;
|
|
78
|
+
// Degenerate triangle guard (area ~ 0)
|
|
79
|
+
const area2 = Math.abs(this.edge(ax, ay, bx, by, cx, cy));
|
|
80
|
+
if (area2 <= eps)
|
|
81
|
+
return false;
|
|
82
|
+
return true;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.Triangle = Triangle;
|
|
86
|
+
//# sourceMappingURL=Triangle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Triangle.js","sourceRoot":"src/","sources":["shapes/Triangle.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"src/","sources":["shapes/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AAExB,cAAc,OAAO,CAAC;AACtB,cAAc,cAAc,CAAC;AAC7B,cAAc,QAAQ,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./Rect"), exports);
|
|
18
|
+
__exportStar(require("./Shape"), exports);
|
|
19
|
+
// export * from './Triangle';
|
|
20
|
+
__exportStar(require("./Img"), exports);
|
|
21
|
+
__exportStar(require("./Renderable"), exports);
|
|
22
|
+
__exportStar(require("./Grid"), exports);
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"src/","sources":["shapes/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB;AACxB,8BAA8B;AAC9B,wCAAsB;AACtB,+CAA6B;AAC7B,yCAAuB"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
interface CameraStateOption {
|
|
2
|
+
x: number;
|
|
3
|
+
y: number;
|
|
4
|
+
width: number;
|
|
5
|
+
height: number;
|
|
6
|
+
rotation: number;
|
|
7
|
+
zoom: number;
|
|
8
|
+
}
|
|
9
|
+
export declare class CameraState {
|
|
10
|
+
x: number;
|
|
11
|
+
y: number;
|
|
12
|
+
width: number;
|
|
13
|
+
height: number;
|
|
14
|
+
rotation: number;
|
|
15
|
+
zoom: number;
|
|
16
|
+
constructor(option?: Partial<CameraStateOption>);
|
|
17
|
+
setX(x: number): void;
|
|
18
|
+
setY(y: number): void;
|
|
19
|
+
setPosition(x: number, y: number): void;
|
|
20
|
+
incrementPosition(dx: number, dy: number): void;
|
|
21
|
+
setWidth(width: number): void;
|
|
22
|
+
setHeight(height: number): void;
|
|
23
|
+
setSize(width: number, height: number): void;
|
|
24
|
+
setZoom(zoom: number): void;
|
|
25
|
+
setRotation(rotation: number): void;
|
|
26
|
+
get dimension(): number[];
|
|
27
|
+
get position(): number[];
|
|
28
|
+
get stateVector(): number[];
|
|
29
|
+
get translationMatrix(): number[];
|
|
30
|
+
get rotationMatrix(): number[];
|
|
31
|
+
get scaleMatrix(): number[];
|
|
32
|
+
get cameraMatrix(): number[];
|
|
33
|
+
get canvasMatrix(): number[];
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=camera.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"camera.d.ts","sourceRoot":"src/","sources":["state/camera.ts"],"names":[],"mappings":"AAGA,UAAU,iBAAiB;IACzB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,WAAW;IACtB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;gBAED,MAAM,GAAE,OAAO,CAAC,iBAAiB,CAAM;IAsCnD,IAAI,CAAC,CAAC,EAAE,MAAM;IAId,IAAI,CAAC,CAAC,EAAE,MAAM;IAId,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAKhC,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;IAKxC,QAAQ,CAAC,KAAK,EAAE,MAAM;IAItB,SAAS,CAAC,MAAM,EAAE,MAAM;IAIxB,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAKrC,OAAO,CAAC,IAAI,EAAE,MAAM;IAIpB,WAAW,CAAC,QAAQ,EAAE,MAAM;IAI5B,IAAI,SAAS,aAEZ;IAED,IAAI,QAAQ,aAEX;IAED,IAAI,WAAW,aAEd;IAED,IAAI,iBAAiB,aAEpB;IAED,IAAI,cAAc,aAEjB;IAED,IAAI,WAAW,aAEd;IAED,IAAI,YAAY,aAGf;IAED,IAAI,YAAY,aAEf;CACF"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CameraState = void 0;
|
|
4
|
+
const mobx_1 = require("mobx");
|
|
5
|
+
const util_1 = require("../util");
|
|
6
|
+
class CameraState {
|
|
7
|
+
constructor(option = {}) {
|
|
8
|
+
const { x = 0, y = 0, width = 0, height = 0, rotation = 0, zoom = 1, } = option;
|
|
9
|
+
this.x = x;
|
|
10
|
+
this.y = y;
|
|
11
|
+
this.width = width;
|
|
12
|
+
this.height = height;
|
|
13
|
+
this.rotation = rotation;
|
|
14
|
+
this.zoom = zoom;
|
|
15
|
+
(0, mobx_1.makeObservable)(this, {
|
|
16
|
+
x: mobx_1.observable,
|
|
17
|
+
y: mobx_1.observable,
|
|
18
|
+
width: mobx_1.observable,
|
|
19
|
+
height: mobx_1.observable,
|
|
20
|
+
rotation: mobx_1.observable,
|
|
21
|
+
zoom: mobx_1.observable,
|
|
22
|
+
setX: mobx_1.action,
|
|
23
|
+
setY: mobx_1.action,
|
|
24
|
+
setPosition: mobx_1.action,
|
|
25
|
+
incrementPosition: mobx_1.action,
|
|
26
|
+
setWidth: mobx_1.action,
|
|
27
|
+
setHeight: mobx_1.action,
|
|
28
|
+
setSize: mobx_1.action,
|
|
29
|
+
setZoom: mobx_1.action,
|
|
30
|
+
setRotation: mobx_1.action,
|
|
31
|
+
stateVector: mobx_1.computed,
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
// Actions
|
|
35
|
+
setX(x) {
|
|
36
|
+
this.x = x;
|
|
37
|
+
}
|
|
38
|
+
setY(y) {
|
|
39
|
+
this.y = y;
|
|
40
|
+
}
|
|
41
|
+
setPosition(x, y) {
|
|
42
|
+
this.x = x;
|
|
43
|
+
this.y = y;
|
|
44
|
+
}
|
|
45
|
+
incrementPosition(dx, dy) {
|
|
46
|
+
this.x += dx;
|
|
47
|
+
this.y += dy;
|
|
48
|
+
}
|
|
49
|
+
setWidth(width) {
|
|
50
|
+
this.width = width;
|
|
51
|
+
}
|
|
52
|
+
setHeight(height) {
|
|
53
|
+
this.height = height;
|
|
54
|
+
}
|
|
55
|
+
setSize(width, height) {
|
|
56
|
+
this.width = width;
|
|
57
|
+
this.height = height;
|
|
58
|
+
}
|
|
59
|
+
setZoom(zoom) {
|
|
60
|
+
this.zoom = zoom;
|
|
61
|
+
}
|
|
62
|
+
setRotation(rotation) {
|
|
63
|
+
this.rotation = rotation;
|
|
64
|
+
}
|
|
65
|
+
get dimension() {
|
|
66
|
+
return [this.width, this.height];
|
|
67
|
+
}
|
|
68
|
+
get position() {
|
|
69
|
+
return [this.x, this.y];
|
|
70
|
+
}
|
|
71
|
+
get stateVector() {
|
|
72
|
+
return [this.x, this.y, this.width, this.height, this.rotation, this.zoom];
|
|
73
|
+
}
|
|
74
|
+
get translationMatrix() {
|
|
75
|
+
return util_1.m3.translation(this.x, this.y);
|
|
76
|
+
}
|
|
77
|
+
get rotationMatrix() {
|
|
78
|
+
return util_1.m3.rotation(this.rotation);
|
|
79
|
+
}
|
|
80
|
+
get scaleMatrix() {
|
|
81
|
+
return util_1.m3.scaling(this.zoom, this.zoom);
|
|
82
|
+
}
|
|
83
|
+
get cameraMatrix() {
|
|
84
|
+
const matrix = util_1.m3.multiply(this.translationMatrix, this.rotationMatrix);
|
|
85
|
+
return util_1.m3.multiply(matrix, this.scaleMatrix);
|
|
86
|
+
}
|
|
87
|
+
get canvasMatrix() {
|
|
88
|
+
return util_1.m3.inverse(this.cameraMatrix);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
exports.CameraState = CameraState;
|
|
92
|
+
//# sourceMappingURL=camera.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"camera.js","sourceRoot":"src/","sources":["state/camera.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"src/","sources":["state/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./camera"), exports);
|
|
18
|
+
__exportStar(require("./pointerEvent"), exports);
|
|
19
|
+
__exportStar(require("./renderable"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"src/","sources":["state/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,iDAA+B;AAC/B,+CAA6B"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { BoundingBoxCollisionType } from "../util";
|
|
2
|
+
import { PointerMode } from "../manager";
|
|
3
|
+
import { Point } from "../bounding";
|
|
4
|
+
export declare class PointerEventState {
|
|
5
|
+
lastPointerPos: Point;
|
|
6
|
+
startWorldX: number;
|
|
7
|
+
startWorldY: number;
|
|
8
|
+
lastWorldX: number;
|
|
9
|
+
lastWorldY: number;
|
|
10
|
+
mode: PointerMode;
|
|
11
|
+
resizingDirection: BoundingBoxCollisionType | null;
|
|
12
|
+
constructor(mode?: PointerMode);
|
|
13
|
+
get isResizing(): boolean;
|
|
14
|
+
get dragDXFromStart(): number;
|
|
15
|
+
get dragDYFromStart(): number;
|
|
16
|
+
setMode(mode: PointerMode): void;
|
|
17
|
+
toggleMode(): void;
|
|
18
|
+
setResizingDirection(dir: BoundingBoxCollisionType | null): void;
|
|
19
|
+
clearResizingDirection(): void;
|
|
20
|
+
initialize(worldX: number, worldY: number): void;
|
|
21
|
+
updateLastWorldCoord(x: number, y: number): void;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=pointerEvent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pointerEvent.d.ts","sourceRoot":"src/","sources":["state/pointerEvent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,qBAAa,iBAAiB;IAC5B,cAAc,EAAE,KAAK,CAAkB;IACvC,WAAW,EAAE,MAAM,CAAK;IACxB,WAAW,EAAE,MAAM,CAAK;IACxB,UAAU,EAAE,MAAM,CAAK;IACvB,UAAU,EAAE,MAAM,CAAK;IAEvB,IAAI,EAAE,WAAW,CAAC;IAElB,iBAAiB,EAAE,wBAAwB,GAAG,IAAI,CAAQ;gBAE9C,IAAI,GAAE,WAAgC;IAKlD,IAAI,UAAU,YAEb;IAED,IAAI,eAAe,WAElB;IAED,IAAI,eAAe,WAElB;IAGD,OAAO,CAAC,IAAI,EAAE,WAAW;IAIzB,UAAU;IAKV,oBAAoB,CAAC,GAAG,EAAE,wBAAwB,GAAG,IAAI;IAIzD,sBAAsB;IAKtB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAQzC,oBAAoB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;CAI1C"}
|