js-draw 0.18.1 → 0.19.0
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/CHANGELOG.md +10 -0
- package/dist/bundle.js +2 -2
- package/dist/bundledStyles.js +1 -0
- package/dist/cjs/src/Color4.d.ts +69 -0
- package/dist/cjs/src/Color4.js +264 -0
- package/dist/cjs/src/Editor.d.ts +308 -0
- package/dist/cjs/src/Editor.js +904 -0
- package/dist/cjs/src/EditorImage.d.ts +97 -0
- package/dist/cjs/src/EditorImage.js +486 -0
- package/dist/cjs/src/EventDispatcher.d.ts +30 -0
- package/dist/cjs/src/EventDispatcher.js +57 -0
- package/dist/cjs/src/Pointer.d.ts +24 -0
- package/dist/cjs/src/Pointer.js +84 -0
- package/dist/cjs/src/SVGLoader.d.ts +48 -0
- package/dist/cjs/src/SVGLoader.js +475 -0
- package/dist/cjs/src/UndoRedoHistory.d.ts +19 -0
- package/dist/cjs/src/UndoRedoHistory.js +93 -0
- package/dist/cjs/src/Viewport.d.ts +71 -0
- package/dist/cjs/src/Viewport.js +264 -0
- package/dist/cjs/src/bundle/bundled.d.ts +4 -0
- package/dist/cjs/src/bundle/bundled.js +24 -0
- package/dist/cjs/src/commands/Command.d.ts +16 -0
- package/dist/cjs/src/commands/Command.js +34 -0
- package/dist/cjs/src/commands/Duplicate.d.ts +14 -0
- package/dist/cjs/src/commands/Duplicate.js +39 -0
- package/dist/cjs/src/commands/Erase.d.ts +14 -0
- package/dist/cjs/src/commands/Erase.js +63 -0
- package/dist/cjs/src/commands/SerializableCommand.d.ts +12 -0
- package/dist/cjs/src/commands/SerializableCommand.js +42 -0
- package/dist/cjs/src/commands/UnresolvedCommand.d.ts +14 -0
- package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
- package/dist/cjs/src/commands/invertCommand.d.ts +4 -0
- package/dist/cjs/src/commands/invertCommand.js +49 -0
- package/dist/cjs/src/commands/lib.d.ts +7 -0
- package/dist/cjs/src/commands/lib.js +18 -0
- package/dist/cjs/src/commands/localization.d.ts +23 -0
- package/dist/cjs/src/commands/localization.js +24 -0
- package/dist/cjs/src/commands/uniteCommands.d.ts +4 -0
- package/dist/cjs/src/commands/uniteCommands.js +121 -0
- package/dist/cjs/src/components/AbstractComponent.d.ts +73 -0
- package/dist/cjs/src/components/AbstractComponent.js +258 -0
- package/dist/cjs/src/components/ImageBackground.d.ts +42 -0
- package/dist/cjs/src/components/ImageBackground.js +146 -0
- package/dist/cjs/src/components/ImageComponent.d.ts +31 -0
- package/dist/cjs/src/components/ImageComponent.js +152 -0
- package/dist/cjs/src/components/RestylableComponent.d.ts +43 -0
- package/dist/cjs/src/components/RestylableComponent.js +88 -0
- package/dist/cjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
- package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
- package/dist/cjs/src/components/Stroke.d.ts +75 -0
- package/dist/cjs/src/components/Stroke.js +225 -0
- package/dist/cjs/src/components/TextComponent.d.ts +75 -0
- package/dist/cjs/src/components/TextComponent.js +280 -0
- package/dist/cjs/src/components/UnknownSVGObject.d.ts +18 -0
- package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
- package/dist/cjs/src/components/builders/ArrowBuilder.d.ts +19 -0
- package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
- package/dist/cjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
- package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
- package/dist/cjs/src/components/builders/LineBuilder.d.ts +18 -0
- package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
- package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
- package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
- package/dist/cjs/src/components/builders/RectangleBuilder.d.ts +20 -0
- package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
- package/dist/cjs/src/components/builders/types.d.ts +12 -0
- package/dist/cjs/src/components/builders/types.js +2 -0
- package/dist/cjs/src/components/lib.d.ts +13 -0
- package/dist/cjs/src/components/lib.js +43 -0
- package/dist/cjs/src/components/localization.d.ts +11 -0
- package/dist/cjs/src/components/localization.js +13 -0
- package/dist/cjs/src/components/util/StrokeSmoother.d.ts +35 -0
- package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
- package/dist/cjs/src/components/util/describeComponentList.d.ts +4 -0
- package/dist/cjs/src/components/util/describeComponentList.js +16 -0
- package/dist/cjs/src/lib.d.ts +64 -0
- package/dist/cjs/src/lib.js +93 -0
- package/dist/cjs/src/localization.d.ts +14 -0
- package/dist/cjs/src/localization.js +13 -0
- package/dist/cjs/src/localizations/de.d.ts +3 -0
- package/dist/cjs/src/localizations/de.js +6 -0
- package/dist/cjs/src/localizations/en.d.ts +3 -0
- package/dist/cjs/src/localizations/en.js +6 -0
- package/dist/cjs/src/localizations/es.d.ts +3 -0
- package/dist/cjs/src/localizations/es.js +20 -0
- package/dist/cjs/src/localizations/getLocalizationTable.d.ts +3 -0
- package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
- package/dist/cjs/src/math/LineSegment2.d.ts +24 -0
- package/dist/cjs/src/math/LineSegment2.js +131 -0
- package/dist/cjs/src/math/Mat33.d.ts +118 -0
- package/dist/cjs/src/math/Mat33.js +332 -0
- package/dist/cjs/src/math/Path.d.ts +71 -0
- package/dist/cjs/src/math/Path.js +655 -0
- package/dist/cjs/src/math/Rect2.d.ts +52 -0
- package/dist/cjs/src/math/Rect2.js +234 -0
- package/dist/cjs/src/math/Triangle.d.ts +11 -0
- package/dist/cjs/src/math/Triangle.js +22 -0
- package/dist/cjs/src/math/Vec2.d.ts +13 -0
- package/dist/cjs/src/math/Vec2.js +19 -0
- package/dist/cjs/src/math/Vec3.d.ts +106 -0
- package/dist/cjs/src/math/Vec3.js +177 -0
- package/dist/cjs/src/math/lib.d.ts +7 -0
- package/dist/cjs/src/math/lib.js +18 -0
- package/dist/cjs/src/math/rounding.d.ts +4 -0
- package/dist/cjs/src/math/rounding.js +135 -0
- package/dist/cjs/src/rendering/Display.d.ts +75 -0
- package/dist/cjs/src/rendering/Display.js +214 -0
- package/dist/cjs/src/rendering/RenderingStyle.d.ts +31 -0
- package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
- package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +36 -0
- package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
- package/dist/cjs/src/rendering/caching/CacheRecord.d.ts +20 -0
- package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
- package/dist/cjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
- package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
- package/dist/cjs/src/rendering/caching/RenderingCache.d.ts +11 -0
- package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
- package/dist/cjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
- package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
- package/dist/cjs/src/rendering/caching/testUtils.d.ts +9 -0
- package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
- package/dist/cjs/src/rendering/caching/types.d.ts +19 -0
- package/dist/cjs/src/rendering/caching/types.js +2 -0
- package/dist/cjs/src/rendering/lib.d.ts +7 -0
- package/dist/cjs/src/rendering/lib.js +17 -0
- package/dist/cjs/src/rendering/localization.d.ts +10 -0
- package/dist/cjs/src/rendering/localization.js +12 -0
- package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
- package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
- package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
- package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
- package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
- package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
- package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
- package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
- package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
- package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
- package/dist/cjs/src/testing/beforeEachFile.d.ts +1 -0
- package/dist/cjs/src/testing/beforeEachFile.js +12 -0
- package/dist/cjs/src/testing/createEditor.d.ts +4 -0
- package/dist/cjs/src/testing/createEditor.js +14 -0
- package/dist/cjs/src/testing/lib.d.ts +2 -0
- package/dist/cjs/src/testing/lib.js +10 -0
- package/dist/cjs/src/testing/loadExpectExtensions.d.ts +2 -0
- package/dist/cjs/src/testing/loadExpectExtensions.js +28 -0
- package/dist/cjs/src/testing/sendPenEvent.d.ts +12 -0
- package/dist/cjs/src/testing/sendPenEvent.js +24 -0
- package/dist/cjs/src/testing/sendTouchEvent.d.ts +42 -0
- package/dist/cjs/src/testing/sendTouchEvent.js +87 -0
- package/dist/cjs/src/toolbar/HTMLToolbar.d.ts +103 -0
- package/dist/cjs/src/toolbar/HTMLToolbar.js +383 -0
- package/dist/cjs/src/toolbar/IconProvider.d.ts +62 -0
- package/dist/cjs/src/toolbar/IconProvider.js +660 -0
- package/dist/cjs/src/toolbar/lib.d.ts +3 -0
- package/dist/cjs/src/toolbar/lib.js +24 -0
- package/dist/cjs/src/toolbar/localization.d.ts +49 -0
- package/dist/cjs/src/toolbar/localization.js +51 -0
- package/dist/cjs/src/toolbar/makeColorInput.d.ts +6 -0
- package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
- package/dist/cjs/src/toolbar/types.d.ts +4 -0
- package/dist/cjs/src/toolbar/types.js +2 -0
- package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
- package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
- package/dist/cjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
- package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
- package/dist/cjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
- package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
- package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
- package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
- package/dist/cjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
- package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
- package/dist/cjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
- package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
- package/dist/cjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
- package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
- package/dist/cjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
- package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
- package/dist/cjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
- package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
- package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
- package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
- package/dist/cjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
- package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
- package/dist/cjs/src/toolbar/widgets/lib.d.ts +10 -0
- package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
- package/dist/cjs/src/tools/BaseTool.d.ts +22 -0
- package/dist/cjs/src/tools/BaseTool.js +66 -0
- package/dist/cjs/src/tools/Eraser.d.ts +23 -0
- package/dist/cjs/src/tools/Eraser.js +112 -0
- package/dist/cjs/src/tools/FindTool.d.ts +21 -0
- package/dist/cjs/src/tools/FindTool.js +121 -0
- package/dist/cjs/src/tools/PanZoom.d.ts +52 -0
- package/dist/cjs/src/tools/PanZoom.js +421 -0
- package/dist/cjs/src/tools/PasteHandler.d.ts +23 -0
- package/dist/cjs/src/tools/PasteHandler.js +99 -0
- package/dist/cjs/src/tools/Pen.d.ts +39 -0
- package/dist/cjs/src/tools/Pen.js +179 -0
- package/dist/cjs/src/tools/PipetteTool.d.ts +18 -0
- package/dist/cjs/src/tools/PipetteTool.js +45 -0
- package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
- package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
- package/dist/cjs/src/tools/SelectionTool/Selection.d.ts +64 -0
- package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
- package/dist/cjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
- package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
- package/dist/cjs/src/tools/SelectionTool/types.d.ts +9 -0
- package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
- package/dist/cjs/src/tools/SoundUITool.d.ts +24 -0
- package/dist/cjs/src/tools/SoundUITool.js +164 -0
- package/dist/cjs/src/tools/TextTool.d.ts +33 -0
- package/dist/cjs/src/tools/TextTool.js +262 -0
- package/dist/cjs/src/tools/ToolController.d.ts +18 -0
- package/dist/cjs/src/tools/ToolController.js +192 -0
- package/dist/cjs/src/tools/ToolEnabledGroup.d.ts +6 -0
- package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
- package/dist/cjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
- package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
- package/dist/cjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
- package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
- package/dist/cjs/src/tools/UndoRedoShortcut.d.ts +8 -0
- package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
- package/dist/cjs/src/tools/lib.d.ts +17 -0
- package/dist/cjs/src/tools/lib.js +38 -0
- package/dist/cjs/src/tools/localization.d.ts +31 -0
- package/dist/cjs/src/tools/localization.js +33 -0
- package/dist/cjs/src/types.d.ts +151 -0
- package/dist/cjs/src/types.js +38 -0
- package/dist/cjs/src/util/assertions.d.ts +23 -0
- package/dist/cjs/src/util/assertions.js +51 -0
- package/dist/cjs/src/util/fileToBase64.d.ts +3 -0
- package/dist/cjs/src/util/fileToBase64.js +15 -0
- package/dist/cjs/src/util/untilNextAnimationFrame.d.ts +3 -0
- package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
- package/dist/cjs/src/util/waitForTimeout.d.ts +2 -0
- package/dist/cjs/src/util/waitForTimeout.js +9 -0
- package/dist/mjs/src/Color4.d.ts +69 -0
- package/dist/mjs/src/Color4.mjs +257 -0
- package/dist/mjs/src/Editor.d.ts +308 -0
- package/dist/mjs/src/Editor.mjs +874 -0
- package/dist/mjs/src/EditorImage.d.ts +97 -0
- package/dist/mjs/src/EditorImage.mjs +477 -0
- package/dist/mjs/src/EventDispatcher.d.ts +30 -0
- package/dist/mjs/src/EventDispatcher.mjs +54 -0
- package/dist/mjs/src/Pointer.d.ts +24 -0
- package/dist/mjs/src/Pointer.mjs +80 -0
- package/dist/mjs/src/SVGLoader.d.ts +48 -0
- package/dist/mjs/src/SVGLoader.mjs +445 -0
- package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
- package/dist/mjs/src/UndoRedoHistory.mjs +91 -0
- package/dist/mjs/src/Viewport.d.ts +71 -0
- package/dist/mjs/src/Viewport.mjs +256 -0
- package/dist/mjs/src/bundle/bundled.d.ts +4 -0
- package/dist/mjs/src/bundle/bundled.mjs +5 -0
- package/dist/mjs/src/commands/Command.d.ts +16 -0
- package/dist/mjs/src/commands/Command.mjs +30 -0
- package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
- package/dist/mjs/src/commands/Duplicate.mjs +33 -0
- package/dist/mjs/src/commands/Erase.d.ts +14 -0
- package/dist/mjs/src/commands/Erase.mjs +57 -0
- package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
- package/dist/mjs/src/commands/SerializableCommand.mjs +36 -0
- package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
- package/dist/mjs/src/commands/UnresolvedCommand.mjs +22 -0
- package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
- package/dist/mjs/src/commands/invertCommand.mjs +44 -0
- package/dist/mjs/src/commands/lib.d.ts +7 -0
- package/dist/mjs/src/commands/lib.mjs +7 -0
- package/dist/mjs/src/commands/localization.d.ts +23 -0
- package/dist/mjs/src/commands/localization.mjs +21 -0
- package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
- package/dist/mjs/src/commands/uniteCommands.mjs +116 -0
- package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
- package/dist/mjs/src/components/AbstractComponent.mjs +252 -0
- package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
- package/dist/mjs/src/components/ImageBackground.mjs +139 -0
- package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
- package/dist/mjs/src/components/ImageComponent.mjs +146 -0
- package/dist/mjs/src/components/RestylableComponent.d.ts +43 -0
- package/dist/mjs/src/components/RestylableComponent.mjs +80 -0
- package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
- package/dist/mjs/src/components/SVGGlobalAttributesObject.mjs +59 -0
- package/dist/mjs/src/components/Stroke.d.ts +75 -0
- package/dist/mjs/src/components/Stroke.mjs +219 -0
- package/dist/mjs/src/components/TextComponent.d.ts +75 -0
- package/dist/mjs/src/components/TextComponent.mjs +274 -0
- package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
- package/dist/mjs/src/components/UnknownSVGObject.mjs +44 -0
- package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
- package/dist/mjs/src/components/builders/ArrowBuilder.mjs +86 -0
- package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
- package/dist/mjs/src/components/builders/FreehandLineBuilder.mjs +165 -0
- package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
- package/dist/mjs/src/components/builders/LineBuilder.mjs +58 -0
- package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
- package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs +339 -0
- package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
- package/dist/mjs/src/components/builders/RectangleBuilder.mjs +50 -0
- package/dist/mjs/src/components/builders/types.d.ts +12 -0
- package/dist/mjs/src/components/builders/types.mjs +1 -0
- package/dist/mjs/src/components/lib.d.ts +13 -0
- package/dist/mjs/src/components/lib.mjs +12 -0
- package/dist/mjs/src/components/localization.d.ts +11 -0
- package/dist/mjs/src/components/localization.mjs +10 -0
- package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
- package/dist/mjs/src/components/util/StrokeSmoother.mjs +210 -0
- package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
- package/dist/mjs/src/components/util/describeComponentList.mjs +14 -0
- package/dist/mjs/src/lib.d.ts +64 -0
- package/dist/mjs/src/lib.mjs +64 -0
- package/dist/mjs/src/localization.d.ts +14 -0
- package/dist/mjs/src/localization.mjs +10 -0
- package/dist/mjs/src/localizations/de.d.ts +3 -0
- package/dist/mjs/src/localizations/de.mjs +4 -0
- package/dist/mjs/src/localizations/en.d.ts +3 -0
- package/dist/mjs/src/localizations/en.mjs +4 -0
- package/dist/mjs/src/localizations/es.d.ts +3 -0
- package/dist/mjs/src/localizations/es.mjs +18 -0
- package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
- package/dist/mjs/src/localizations/getLocalizationTable.mjs +45 -0
- package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
- package/dist/mjs/src/math/LineSegment2.mjs +125 -0
- package/dist/mjs/src/math/Mat33.d.ts +118 -0
- package/dist/mjs/src/math/Mat33.mjs +326 -0
- package/dist/mjs/src/math/Path.d.ts +71 -0
- package/dist/mjs/src/math/Path.mjs +648 -0
- package/dist/mjs/src/math/Rect2.d.ts +52 -0
- package/dist/mjs/src/math/Rect2.mjs +228 -0
- package/dist/mjs/src/math/Triangle.d.ts +11 -0
- package/dist/mjs/src/math/Triangle.mjs +19 -0
- package/dist/mjs/src/math/Vec2.d.ts +13 -0
- package/dist/mjs/src/math/Vec2.mjs +13 -0
- package/dist/mjs/src/math/Vec3.d.ts +106 -0
- package/dist/mjs/src/math/Vec3.mjs +174 -0
- package/dist/mjs/src/math/lib.d.ts +7 -0
- package/dist/mjs/src/math/lib.mjs +7 -0
- package/dist/mjs/src/math/rounding.d.ts +4 -0
- package/dist/mjs/src/math/rounding.mjs +128 -0
- package/dist/mjs/src/rendering/Display.d.ts +75 -0
- package/dist/mjs/src/rendering/Display.mjs +207 -0
- package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
- package/dist/mjs/src/rendering/RenderingStyle.mjs +38 -0
- package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
- package/dist/mjs/src/rendering/TextRenderingStyle.mjs +23 -0
- package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
- package/dist/mjs/src/rendering/caching/CacheRecord.mjs +55 -0
- package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
- package/dist/mjs/src/rendering/caching/CacheRecordManager.mjs +43 -0
- package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
- package/dist/mjs/src/rendering/caching/RenderingCache.mjs +45 -0
- package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
- package/dist/mjs/src/rendering/caching/RenderingCacheNode.mjs +320 -0
- package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
- package/dist/mjs/src/rendering/caching/testUtils.mjs +20 -0
- package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
- package/dist/mjs/src/rendering/caching/types.mjs +1 -0
- package/dist/mjs/src/rendering/lib.d.ts +7 -0
- package/dist/mjs/src/rendering/lib.mjs +5 -0
- package/dist/mjs/src/rendering/localization.d.ts +10 -0
- package/dist/mjs/src/rendering/localization.mjs +9 -0
- package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
- package/dist/mjs/src/rendering/renderers/AbstractRenderer.mjs +144 -0
- package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
- package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +230 -0
- package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
- package/dist/mjs/src/rendering/renderers/DummyRenderer.mjs +106 -0
- package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
- package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +304 -0
- package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
- package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.mjs +57 -0
- package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
- package/dist/mjs/src/testing/beforeEachFile.mjs +7 -0
- package/dist/mjs/src/testing/createEditor.d.ts +4 -0
- package/dist/mjs/src/testing/createEditor.mjs +9 -0
- package/dist/mjs/src/testing/lib.d.ts +2 -0
- package/dist/mjs/src/testing/lib.mjs +2 -0
- package/dist/mjs/src/testing/loadExpectExtensions.d.ts +2 -0
- package/dist/mjs/src/testing/loadExpectExtensions.mjs +24 -0
- package/dist/mjs/src/testing/sendPenEvent.d.ts +12 -0
- package/dist/mjs/src/testing/sendPenEvent.mjs +19 -0
- package/dist/mjs/src/testing/sendTouchEvent.d.ts +42 -0
- package/dist/mjs/src/testing/sendTouchEvent.mjs +62 -0
- package/dist/mjs/src/toolbar/HTMLToolbar.d.ts +103 -0
- package/dist/mjs/src/toolbar/HTMLToolbar.mjs +376 -0
- package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
- package/dist/mjs/src/toolbar/IconProvider.mjs +654 -0
- package/dist/mjs/src/toolbar/lib.d.ts +3 -0
- package/dist/mjs/src/toolbar/lib.mjs +3 -0
- package/dist/mjs/src/toolbar/localization.d.ts +49 -0
- package/dist/mjs/src/toolbar/localization.mjs +48 -0
- package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
- package/dist/mjs/src/toolbar/makeColorInput.mjs +113 -0
- package/dist/mjs/src/toolbar/types.d.ts +4 -0
- package/dist/mjs/src/toolbar/types.mjs +1 -0
- package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
- package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.mjs +25 -0
- package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
- package/dist/mjs/src/toolbar/widgets/BaseToolWidget.mjs +44 -0
- package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
- package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +307 -0
- package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
- package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +120 -0
- package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
- package/dist/mjs/src/toolbar/widgets/EraserToolWidget.mjs +57 -0
- package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
- package/dist/mjs/src/toolbar/widgets/HandToolWidget.mjs +172 -0
- package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
- package/dist/mjs/src/toolbar/widgets/InsertImageWidget.mjs +170 -0
- package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
- package/dist/mjs/src/toolbar/widgets/OverflowWidget.mjs +71 -0
- package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
- package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +220 -0
- package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
- package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.mjs +147 -0
- package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
- package/dist/mjs/src/toolbar/widgets/TextToolWidget.mjs +109 -0
- package/dist/mjs/src/toolbar/widgets/lib.d.ts +10 -0
- package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
- package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
- package/dist/mjs/src/tools/BaseTool.mjs +63 -0
- package/dist/mjs/src/tools/Eraser.d.ts +23 -0
- package/dist/mjs/src/tools/Eraser.mjs +106 -0
- package/dist/mjs/src/tools/FindTool.d.ts +21 -0
- package/dist/mjs/src/tools/FindTool.mjs +114 -0
- package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
- package/dist/mjs/src/tools/PanZoom.mjs +414 -0
- package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
- package/dist/mjs/src/tools/PasteHandler.mjs +93 -0
- package/dist/mjs/src/tools/Pen.d.ts +39 -0
- package/dist/mjs/src/tools/Pen.mjs +173 -0
- package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
- package/dist/mjs/src/tools/PipetteTool.mjs +39 -0
- package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
- package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs +22 -0
- package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
- package/dist/mjs/src/tools/SelectionTool/Selection.mjs +459 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionHandle.mjs +81 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
- package/dist/mjs/src/tools/SelectionTool/SelectionTool.mjs +398 -0
- package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
- package/dist/mjs/src/tools/SelectionTool/TransformMode.mjs +98 -0
- package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
- package/dist/mjs/src/tools/SelectionTool/types.mjs +11 -0
- package/dist/mjs/src/tools/SoundUITool.d.ts +24 -0
- package/dist/mjs/src/tools/SoundUITool.mjs +158 -0
- package/dist/mjs/src/tools/TextTool.d.ts +33 -0
- package/dist/mjs/src/tools/TextTool.mjs +256 -0
- package/dist/mjs/src/tools/ToolController.d.ts +18 -0
- package/dist/mjs/src/tools/ToolController.mjs +163 -0
- package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
- package/dist/mjs/src/tools/ToolEnabledGroup.mjs +11 -0
- package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
- package/dist/mjs/src/tools/ToolSwitcherShortcut.mjs +32 -0
- package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
- package/dist/mjs/src/tools/ToolbarShortcutHandler.mjs +23 -0
- package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
- package/dist/mjs/src/tools/UndoRedoShortcut.mjs +22 -0
- package/dist/mjs/src/tools/lib.d.ts +17 -0
- package/dist/mjs/src/tools/lib.mjs +17 -0
- package/dist/mjs/src/tools/localization.d.ts +31 -0
- package/dist/mjs/src/tools/localization.mjs +30 -0
- package/dist/mjs/src/types.d.ts +151 -0
- package/dist/mjs/src/types.mjs +35 -0
- package/dist/mjs/src/util/assertions.d.ts +23 -0
- package/dist/mjs/src/util/assertions.mjs +45 -0
- package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
- package/dist/mjs/src/util/fileToBase64.mjs +13 -0
- package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
- package/dist/mjs/src/util/untilNextAnimationFrame.mjs +7 -0
- package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
- package/dist/mjs/src/util/waitForTimeout.mjs +7 -0
- package/package.json +6 -4
- package/src/Editor.css +86 -0
- package/src/styles.js +7 -0
- package/src/toolbar/toolbar.css +213 -0
- package/src/toolbar/widgets/InsertImageWidget.css +44 -0
- package/src/toolbar/widgets/OverflowWidget.css +27 -0
- package/src/tools/FindTool.css +7 -0
- package/src/tools/SelectionTool/SelectionTool.css +23 -0
- package/src/tools/SoundUITool.css +15 -0
- package/src/tools/tools.css +4 -0
@@ -0,0 +1,332 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
const Vec2_1 = require("./Vec2");
|
7
|
+
const Vec3_1 = __importDefault(require("./Vec3"));
|
8
|
+
/**
|
9
|
+
* Represents a three dimensional linear transformation or
|
10
|
+
* a two-dimensional affine transformation. (An affine transformation scales/rotates/shears
|
11
|
+
* **and** translates while a linear transformation just scales/rotates/shears).
|
12
|
+
*/
|
13
|
+
class Mat33 {
|
14
|
+
/**
|
15
|
+
* Creates a matrix from inputs in the form,
|
16
|
+
* ```
|
17
|
+
* ⎡ a1 a2 a3 ⎤
|
18
|
+
* ⎢ b1 b2 b3 ⎥
|
19
|
+
* ⎣ c1 c2 c3 ⎦
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
constructor(a1, a2, a3, b1, b2, b3, c1, c2, c3) {
|
23
|
+
this.a1 = a1;
|
24
|
+
this.a2 = a2;
|
25
|
+
this.a3 = a3;
|
26
|
+
this.b1 = b1;
|
27
|
+
this.b2 = b2;
|
28
|
+
this.b3 = b3;
|
29
|
+
this.c1 = c1;
|
30
|
+
this.c2 = c2;
|
31
|
+
this.c3 = c3;
|
32
|
+
this.cachedInverse = undefined;
|
33
|
+
this.rows = [
|
34
|
+
Vec3_1.default.of(a1, a2, a3),
|
35
|
+
Vec3_1.default.of(b1, b2, b3),
|
36
|
+
Vec3_1.default.of(c1, c2, c3),
|
37
|
+
];
|
38
|
+
}
|
39
|
+
/**
|
40
|
+
* Creates a matrix from the given rows:
|
41
|
+
* ```
|
42
|
+
* ⎡ r1.x r1.y r1.z ⎤
|
43
|
+
* ⎢ r2.x r2.y r2.z ⎥
|
44
|
+
* ⎣ r3.x r3.y r3.z ⎦
|
45
|
+
* ```
|
46
|
+
*/
|
47
|
+
static ofRows(r1, r2, r3) {
|
48
|
+
return new Mat33(r1.x, r1.y, r1.z, r2.x, r2.y, r2.z, r3.x, r3.y, r3.z);
|
49
|
+
}
|
50
|
+
/**
|
51
|
+
* Either returns the inverse of this, or, if this matrix is singular/uninvertable,
|
52
|
+
* returns Mat33.identity.
|
53
|
+
*
|
54
|
+
* This may cache the computed inverse and return the cached version instead of recomputing
|
55
|
+
* it.
|
56
|
+
*/
|
57
|
+
inverse() {
|
58
|
+
var _a;
|
59
|
+
return (_a = this.computeInverse()) !== null && _a !== void 0 ? _a : Mat33.identity;
|
60
|
+
}
|
61
|
+
invertable() {
|
62
|
+
return this.computeInverse() !== null;
|
63
|
+
}
|
64
|
+
computeInverse() {
|
65
|
+
if (this.cachedInverse !== undefined) {
|
66
|
+
return this.cachedInverse;
|
67
|
+
}
|
68
|
+
const toIdentity = [
|
69
|
+
this.rows[0],
|
70
|
+
this.rows[1],
|
71
|
+
this.rows[2],
|
72
|
+
];
|
73
|
+
const toResult = [
|
74
|
+
Vec3_1.default.unitX,
|
75
|
+
Vec3_1.default.unitY,
|
76
|
+
Vec3_1.default.unitZ,
|
77
|
+
];
|
78
|
+
// Convert toIdentity to the identity matrix and
|
79
|
+
// toResult to the inverse through elementary row operations
|
80
|
+
for (let cursor = 0; cursor < 3; cursor++) {
|
81
|
+
// Select the [cursor]th diagonal entry
|
82
|
+
let pivot = toIdentity[cursor].at(cursor);
|
83
|
+
// Don't divide by zero (treat very small numbers as zero).
|
84
|
+
const minDivideBy = 1e-10;
|
85
|
+
if (Math.abs(pivot) < minDivideBy) {
|
86
|
+
let swapIndex = -1;
|
87
|
+
// For all other rows,
|
88
|
+
for (let i = 1; i <= 2; i++) {
|
89
|
+
const otherRowIdx = (cursor + i) % 3;
|
90
|
+
if (Math.abs(toIdentity[otherRowIdx].at(cursor)) >= minDivideBy) {
|
91
|
+
swapIndex = otherRowIdx;
|
92
|
+
break;
|
93
|
+
}
|
94
|
+
}
|
95
|
+
// Can't swap with another row?
|
96
|
+
if (swapIndex === -1) {
|
97
|
+
this.cachedInverse = null;
|
98
|
+
return null;
|
99
|
+
}
|
100
|
+
const tmpIdentityRow = toIdentity[cursor];
|
101
|
+
const tmpResultRow = toResult[cursor];
|
102
|
+
// Swap!
|
103
|
+
toIdentity[cursor] = toIdentity[swapIndex];
|
104
|
+
toResult[cursor] = toResult[swapIndex];
|
105
|
+
toIdentity[swapIndex] = tmpIdentityRow;
|
106
|
+
toResult[swapIndex] = tmpResultRow;
|
107
|
+
pivot = toIdentity[cursor].at(cursor);
|
108
|
+
}
|
109
|
+
// Make toIdentity[k = cursor] = 1
|
110
|
+
let scale = 1.0 / pivot;
|
111
|
+
toIdentity[cursor] = toIdentity[cursor].times(scale);
|
112
|
+
toResult[cursor] = toResult[cursor].times(scale);
|
113
|
+
const cursorToIdentityRow = toIdentity[cursor];
|
114
|
+
const cursorToResultRow = toResult[cursor];
|
115
|
+
// Make toIdentity[k ≠ cursor] = 0
|
116
|
+
for (let i = 1; i <= 2; i++) {
|
117
|
+
const otherRowIdx = (cursor + i) % 3;
|
118
|
+
scale = -toIdentity[otherRowIdx].at(cursor);
|
119
|
+
toIdentity[otherRowIdx] = toIdentity[otherRowIdx].plus(cursorToIdentityRow.times(scale));
|
120
|
+
toResult[otherRowIdx] = toResult[otherRowIdx].plus(cursorToResultRow.times(scale));
|
121
|
+
}
|
122
|
+
}
|
123
|
+
const inverse = Mat33.ofRows(toResult[0], toResult[1], toResult[2]);
|
124
|
+
this.cachedInverse = inverse;
|
125
|
+
return inverse;
|
126
|
+
}
|
127
|
+
transposed() {
|
128
|
+
return new Mat33(this.a1, this.b1, this.c1, this.a2, this.b2, this.c2, this.a3, this.b3, this.c3);
|
129
|
+
}
|
130
|
+
rightMul(other) {
|
131
|
+
other = other.transposed();
|
132
|
+
const at = (row, col) => {
|
133
|
+
return this.rows[row].dot(other.rows[col]);
|
134
|
+
};
|
135
|
+
return new Mat33(at(0, 0), at(0, 1), at(0, 2), at(1, 0), at(1, 1), at(1, 2), at(2, 0), at(2, 1), at(2, 2));
|
136
|
+
}
|
137
|
+
/**
|
138
|
+
* Applies this as an affine transformation to the given vector.
|
139
|
+
* Returns a transformed version of `other`.
|
140
|
+
*/
|
141
|
+
transformVec2(other) {
|
142
|
+
// When transforming a Vec2, we want to use the z transformation
|
143
|
+
// components of this for translation:
|
144
|
+
// ⎡ . . tX ⎤
|
145
|
+
// ⎢ . . tY ⎥
|
146
|
+
// ⎣ 0 0 1 ⎦
|
147
|
+
// For this, we need other's z component to be 1 (so that tX and tY
|
148
|
+
// are scaled by 1):
|
149
|
+
let intermediate = Vec3_1.default.of(other.x, other.y, 1);
|
150
|
+
intermediate = this.transformVec3(intermediate);
|
151
|
+
// Drop the z=1 to allow magnitude to work as expected
|
152
|
+
return Vec2_1.Vec2.of(intermediate.x, intermediate.y);
|
153
|
+
}
|
154
|
+
/**
|
155
|
+
* Applies this as a linear transformation to the given vector (doesn't translate).
|
156
|
+
* This is the standard way of transforming vectors in ℝ³.
|
157
|
+
*/
|
158
|
+
transformVec3(other) {
|
159
|
+
return Vec3_1.default.of(this.rows[0].dot(other), this.rows[1].dot(other), this.rows[2].dot(other));
|
160
|
+
}
|
161
|
+
/** @returns true iff this is the identity matrix. */
|
162
|
+
isIdentity() {
|
163
|
+
if (this === Mat33.identity) {
|
164
|
+
return true;
|
165
|
+
}
|
166
|
+
return this.eq(Mat33.identity);
|
167
|
+
}
|
168
|
+
/** Returns true iff this = other ± fuzz */
|
169
|
+
eq(other, fuzz = 0) {
|
170
|
+
for (let i = 0; i < 3; i++) {
|
171
|
+
if (!this.rows[i].eq(other.rows[i], fuzz)) {
|
172
|
+
return false;
|
173
|
+
}
|
174
|
+
}
|
175
|
+
return true;
|
176
|
+
}
|
177
|
+
toString() {
|
178
|
+
let result = '';
|
179
|
+
const maxColumnLens = [0, 0, 0];
|
180
|
+
// Determine the longest item in each column so we can pad the others to that
|
181
|
+
// length.
|
182
|
+
for (const row of this.rows) {
|
183
|
+
for (let i = 0; i < 3; i++) {
|
184
|
+
maxColumnLens[i] = Math.max(maxColumnLens[0], `${row.at(i)}`.length);
|
185
|
+
}
|
186
|
+
}
|
187
|
+
for (let i = 0; i < 3; i++) {
|
188
|
+
if (i === 0) {
|
189
|
+
result += '⎡ ';
|
190
|
+
}
|
191
|
+
else if (i === 1) {
|
192
|
+
result += '⎢ ';
|
193
|
+
}
|
194
|
+
else {
|
195
|
+
result += '⎣ ';
|
196
|
+
}
|
197
|
+
// Add each component of the ith row (after padding it)
|
198
|
+
for (let j = 0; j < 3; j++) {
|
199
|
+
const val = this.rows[i].at(j).toString();
|
200
|
+
let padding = '';
|
201
|
+
for (let i = val.length; i < maxColumnLens[j]; i++) {
|
202
|
+
padding += ' ';
|
203
|
+
}
|
204
|
+
result += val + ', ' + padding;
|
205
|
+
}
|
206
|
+
if (i === 0) {
|
207
|
+
result += ' ⎤';
|
208
|
+
}
|
209
|
+
else if (i === 1) {
|
210
|
+
result += ' ⎥';
|
211
|
+
}
|
212
|
+
else {
|
213
|
+
result += ' ⎦';
|
214
|
+
}
|
215
|
+
result += '\n';
|
216
|
+
}
|
217
|
+
return result.trimEnd();
|
218
|
+
}
|
219
|
+
/**
|
220
|
+
* ```
|
221
|
+
* result[0] = top left element
|
222
|
+
* result[1] = element at row zero, column 1
|
223
|
+
* ...
|
224
|
+
* ```
|
225
|
+
*/
|
226
|
+
toArray() {
|
227
|
+
return [
|
228
|
+
this.a1, this.a2, this.a3,
|
229
|
+
this.b1, this.b2, this.b3,
|
230
|
+
this.c1, this.c2, this.c3,
|
231
|
+
];
|
232
|
+
}
|
233
|
+
/**
|
234
|
+
* @example
|
235
|
+
* ```
|
236
|
+
* new Mat33(
|
237
|
+
* 1, 2, 3,
|
238
|
+
* 4, 5, 6,
|
239
|
+
* 7, 8, 9,
|
240
|
+
* ).mapEntries(component => component - 1);
|
241
|
+
* // → ⎡ 0, 1, 2 ⎤
|
242
|
+
* // ⎢ 3, 4, 5 ⎥
|
243
|
+
* // ⎣ 6, 7, 8 ⎦
|
244
|
+
* ```
|
245
|
+
*/
|
246
|
+
mapEntries(mapping) {
|
247
|
+
return new Mat33(mapping(this.a1), mapping(this.a2), mapping(this.a3), mapping(this.b1), mapping(this.b2), mapping(this.b3), mapping(this.c1), mapping(this.c2), mapping(this.c3));
|
248
|
+
}
|
249
|
+
/** Estimate the scale factor of this matrix (based on the first row). */
|
250
|
+
getScaleFactor() {
|
251
|
+
return Math.hypot(this.a1, this.a2);
|
252
|
+
}
|
253
|
+
/** Constructs a 3x3 translation matrix (for translating `Vec2`s) */
|
254
|
+
static translation(amount) {
|
255
|
+
// When transforming Vec2s by a 3x3 matrix, we give the input
|
256
|
+
// Vec2s z = 1. As such,
|
257
|
+
// outVec2.x = inVec2.x * 1 + inVec2.y * 0 + 1 * amount.x
|
258
|
+
// ...
|
259
|
+
return new Mat33(1, 0, amount.x, 0, 1, amount.y, 0, 0, 1);
|
260
|
+
}
|
261
|
+
static zRotation(radians, center = Vec2_1.Vec2.zero) {
|
262
|
+
if (radians === 0) {
|
263
|
+
return Mat33.identity;
|
264
|
+
}
|
265
|
+
const cos = Math.cos(radians);
|
266
|
+
const sin = Math.sin(radians);
|
267
|
+
// Translate everything so that rotation is about the origin
|
268
|
+
let result = Mat33.translation(center);
|
269
|
+
result = result.rightMul(new Mat33(cos, -sin, 0, sin, cos, 0, 0, 0, 1));
|
270
|
+
return result.rightMul(Mat33.translation(center.times(-1)));
|
271
|
+
}
|
272
|
+
static scaling2D(amount, center = Vec2_1.Vec2.zero) {
|
273
|
+
let result = Mat33.translation(center);
|
274
|
+
let xAmount, yAmount;
|
275
|
+
if (typeof amount === 'number') {
|
276
|
+
xAmount = amount;
|
277
|
+
yAmount = amount;
|
278
|
+
}
|
279
|
+
else {
|
280
|
+
xAmount = amount.x;
|
281
|
+
yAmount = amount.y;
|
282
|
+
}
|
283
|
+
result = result.rightMul(new Mat33(xAmount, 0, 0, 0, yAmount, 0, 0, 0, 1));
|
284
|
+
// Translate such that [center] goes to (0, 0)
|
285
|
+
return result.rightMul(Mat33.translation(center.times(-1)));
|
286
|
+
}
|
287
|
+
/** @see {@link fromCSSMatrix} */
|
288
|
+
toCSSMatrix() {
|
289
|
+
return `matrix(${this.a1},${this.b1},${this.a2},${this.b2},${this.a3},${this.b3})`;
|
290
|
+
}
|
291
|
+
/**
|
292
|
+
* Converts a CSS-form `matrix(a, b, c, d, e, f)` to a Mat33.
|
293
|
+
*
|
294
|
+
* Note that such a matrix has the form,
|
295
|
+
* ```
|
296
|
+
* ⎡ a c e ⎤
|
297
|
+
* ⎢ b d f ⎥
|
298
|
+
* ⎣ 0 0 1 ⎦
|
299
|
+
* ```
|
300
|
+
*/
|
301
|
+
static fromCSSMatrix(cssString) {
|
302
|
+
if (cssString === '' || cssString === 'none') {
|
303
|
+
return Mat33.identity;
|
304
|
+
}
|
305
|
+
const numberExp = '([-]?\\d*(?:\\.\\d*)?(?:[eE][-]?\\d+)?)';
|
306
|
+
const numberSepExp = '[, \\t\\n]';
|
307
|
+
const regExpSource = `^\\s*matrix\\s*\\(${[
|
308
|
+
// According to MDN, matrix(a,b,c,d,e,f) has form:
|
309
|
+
// ⎡ a c e ⎤
|
310
|
+
// ⎢ b d f ⎥
|
311
|
+
// ⎣ 0 0 1 ⎦
|
312
|
+
numberExp, numberExp, numberExp,
|
313
|
+
numberExp, numberExp, numberExp, // b, d, f
|
314
|
+
].join(`${numberSepExp}+`)}${numberSepExp}*\\)\\s*$`;
|
315
|
+
const matrixExp = new RegExp(regExpSource, 'i');
|
316
|
+
const match = matrixExp.exec(cssString);
|
317
|
+
if (!match) {
|
318
|
+
throw new Error(`Unsupported transformation: ${cssString}`);
|
319
|
+
}
|
320
|
+
const matrixData = match.slice(1).map(entry => parseFloat(entry));
|
321
|
+
const a = matrixData[0];
|
322
|
+
const b = matrixData[1];
|
323
|
+
const c = matrixData[2];
|
324
|
+
const d = matrixData[3];
|
325
|
+
const e = matrixData[4];
|
326
|
+
const f = matrixData[5];
|
327
|
+
const transform = new Mat33(a, c, e, b, d, f, 0, 0, 1);
|
328
|
+
return transform;
|
329
|
+
}
|
330
|
+
}
|
331
|
+
exports.default = Mat33;
|
332
|
+
Mat33.identity = new Mat33(1, 0, 0, 0, 1, 0, 0, 0, 1);
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import { Bezier } from 'bezier-js';
|
2
|
+
import { RenderablePathSpec } from '../rendering/renderers/AbstractRenderer';
|
3
|
+
import RenderingStyle from '../rendering/RenderingStyle';
|
4
|
+
import LineSegment2 from './LineSegment2';
|
5
|
+
import Mat33 from './Mat33';
|
6
|
+
import Rect2 from './Rect2';
|
7
|
+
import { Point2 } from './Vec2';
|
8
|
+
export declare enum PathCommandType {
|
9
|
+
LineTo = 0,
|
10
|
+
MoveTo = 1,
|
11
|
+
CubicBezierTo = 2,
|
12
|
+
QuadraticBezierTo = 3
|
13
|
+
}
|
14
|
+
export interface CubicBezierPathCommand {
|
15
|
+
kind: PathCommandType.CubicBezierTo;
|
16
|
+
controlPoint1: Point2;
|
17
|
+
controlPoint2: Point2;
|
18
|
+
endPoint: Point2;
|
19
|
+
}
|
20
|
+
export interface QuadraticBezierPathCommand {
|
21
|
+
kind: PathCommandType.QuadraticBezierTo;
|
22
|
+
controlPoint: Point2;
|
23
|
+
endPoint: Point2;
|
24
|
+
}
|
25
|
+
export interface LinePathCommand {
|
26
|
+
kind: PathCommandType.LineTo;
|
27
|
+
point: Point2;
|
28
|
+
}
|
29
|
+
export interface MoveToPathCommand {
|
30
|
+
kind: PathCommandType.MoveTo;
|
31
|
+
point: Point2;
|
32
|
+
}
|
33
|
+
export type PathCommand = CubicBezierPathCommand | LinePathCommand | QuadraticBezierPathCommand | MoveToPathCommand;
|
34
|
+
interface IntersectionResult {
|
35
|
+
curve: LineSegment2 | Bezier;
|
36
|
+
parameterValue: number;
|
37
|
+
point: Point2;
|
38
|
+
}
|
39
|
+
export default class Path {
|
40
|
+
readonly startPoint: Point2;
|
41
|
+
readonly parts: PathCommand[];
|
42
|
+
readonly bbox: Rect2;
|
43
|
+
constructor(startPoint: Point2, parts: PathCommand[]);
|
44
|
+
private cachedGeometry;
|
45
|
+
get geometry(): Array<LineSegment2 | Bezier>;
|
46
|
+
private cachedPolylineApproximation;
|
47
|
+
polylineApproximation(): LineSegment2[];
|
48
|
+
static computeBBoxForSegment(startPoint: Point2, part: PathCommand): Rect2;
|
49
|
+
intersection(line: LineSegment2): IntersectionResult[];
|
50
|
+
private static mapPathCommand;
|
51
|
+
mapPoints(mapping: (point: Point2) => Point2): Path;
|
52
|
+
transformedBy(affineTransfm: Mat33): Path;
|
53
|
+
union(other: Path | null): Path;
|
54
|
+
private getEndPoint;
|
55
|
+
roughlyIntersects(rect: Rect2, strokeWidth?: number): boolean;
|
56
|
+
closedRoughlyIntersects(rect: Rect2): boolean;
|
57
|
+
static fromRect(rect: Rect2, lineWidth?: number | null): Path;
|
58
|
+
static fromRenderable(renderable: RenderablePathSpec): Path;
|
59
|
+
toRenderable(fill: RenderingStyle): RenderablePathSpec;
|
60
|
+
/**
|
61
|
+
* @returns a Path that, when rendered, looks roughly equivalent to the given path.
|
62
|
+
*/
|
63
|
+
static visualEquivalent(renderablePath: RenderablePathSpec, visibleRect: Rect2): RenderablePathSpec;
|
64
|
+
private cachedStringVersion;
|
65
|
+
toString(useNonAbsCommands?: boolean): string;
|
66
|
+
serialize(): string;
|
67
|
+
static toString(startPoint: Point2, parts: PathCommand[], onlyAbsCommands?: boolean): string;
|
68
|
+
static fromString(pathString: string): Path;
|
69
|
+
static empty: Path;
|
70
|
+
}
|
71
|
+
export {};
|