js-draw 0.18.1 → 0.18.2
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 +3 -0
- package/dist/cjs/src/Color4.d.ts +61 -0
- package/dist/cjs/src/Color4.js +197 -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 +472 -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 +24 -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 +40 -0
- package/dist/cjs/src/components/Stroke.js +191 -0
- package/dist/cjs/src/components/TextComponent.d.ts +53 -0
- package/dist/cjs/src/components/TextComponent.js +258 -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 +12 -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 +34 -0
- package/dist/cjs/src/lib.js +63 -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 +5 -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/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 +187 -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 +16 -0
- package/dist/cjs/src/tools/lib.js +36 -0
- package/dist/cjs/src/tools/localization.d.ts +28 -0
- package/dist/cjs/src/tools/localization.js +30 -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 +61 -0
- package/dist/mjs/src/Color4.mjs +193 -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 +442 -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 +24 -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 +40 -0
- package/dist/mjs/src/components/Stroke.mjs +185 -0
- package/dist/mjs/src/components/TextComponent.d.ts +53 -0
- package/dist/mjs/src/components/TextComponent.mjs +252 -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 +12 -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 +34 -0
- package/dist/mjs/src/lib.mjs +34 -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 +5 -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/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 +158 -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 +16 -0
- package/dist/mjs/src/tools/lib.mjs +16 -0
- package/dist/mjs/src/tools/localization.d.ts +28 -0
- package/dist/mjs/src/tools/localization.mjs +27 -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 +1 -1
- package/src/Color4.test.ts +40 -0
- package/src/Color4.ts +236 -0
- package/src/Editor.css +86 -0
- package/src/Editor.loadFrom.test.ts +24 -0
- package/src/Editor.toSVG.test.ts +111 -0
- package/src/Editor.ts +1122 -0
- package/src/EditorImage.test.ts +120 -0
- package/src/EditorImage.ts +603 -0
- package/src/EventDispatcher.test.ts +123 -0
- package/src/EventDispatcher.ts +71 -0
- package/src/Pointer.ts +127 -0
- package/src/SVGLoader.test.ts +114 -0
- package/src/SVGLoader.ts +511 -0
- package/src/UndoRedoHistory.test.ts +33 -0
- package/src/UndoRedoHistory.ts +102 -0
- package/src/Viewport.ts +319 -0
- package/src/bundle/bundled.ts +7 -0
- package/src/commands/Command.ts +45 -0
- package/src/commands/Duplicate.ts +48 -0
- package/src/commands/Erase.ts +74 -0
- package/src/commands/SerializableCommand.ts +49 -0
- package/src/commands/UnresolvedCommand.ts +37 -0
- package/src/commands/invertCommand.ts +51 -0
- package/src/commands/lib.ts +16 -0
- package/src/commands/localization.ts +47 -0
- package/src/commands/uniteCommands.test.ts +23 -0
- package/src/commands/uniteCommands.ts +135 -0
- package/src/components/AbstractComponent.transformBy.test.ts +22 -0
- package/src/components/AbstractComponent.ts +364 -0
- package/src/components/ImageBackground.test.ts +35 -0
- package/src/components/ImageBackground.ts +176 -0
- package/src/components/ImageComponent.ts +171 -0
- package/src/components/RestylableComponent.ts +142 -0
- package/src/components/SVGGlobalAttributesObject.ts +81 -0
- package/src/components/Stroke.test.ts +139 -0
- package/src/components/Stroke.ts +245 -0
- package/src/components/TextComponent.test.ts +99 -0
- package/src/components/TextComponent.ts +315 -0
- package/src/components/UnknownSVGObject.test.ts +10 -0
- package/src/components/UnknownSVGObject.ts +60 -0
- package/src/components/builders/ArrowBuilder.ts +107 -0
- package/src/components/builders/FreehandLineBuilder.ts +212 -0
- package/src/components/builders/LineBuilder.ts +77 -0
- package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +454 -0
- package/src/components/builders/RectangleBuilder.ts +74 -0
- package/src/components/builders/types.ts +15 -0
- package/src/components/lib.ts +25 -0
- package/src/components/localization.ts +22 -0
- package/src/components/util/StrokeSmoother.ts +293 -0
- package/src/components/util/describeComponentList.ts +18 -0
- package/src/lib.ts +37 -0
- package/src/localization.ts +34 -0
- package/src/localizations/de.ts +98 -0
- package/src/localizations/en.ts +8 -0
- package/src/localizations/es.ts +74 -0
- package/src/localizations/getLocalizationTable.test.ts +27 -0
- package/src/localizations/getLocalizationTable.ts +55 -0
- package/src/math/LineSegment2.test.ts +99 -0
- package/src/math/LineSegment2.ts +160 -0
- package/src/math/Mat33.test.ts +244 -0
- package/src/math/Mat33.ts +437 -0
- package/src/math/Path.fromString.test.ts +223 -0
- package/src/math/Path.test.ts +198 -0
- package/src/math/Path.toString.test.ts +77 -0
- package/src/math/Path.ts +790 -0
- package/src/math/Rect2.test.ts +204 -0
- package/src/math/Rect2.ts +315 -0
- package/src/math/Triangle.ts +29 -0
- package/src/math/Vec2.test.ts +30 -0
- package/src/math/Vec2.ts +18 -0
- package/src/math/Vec3.test.ts +44 -0
- package/src/math/Vec3.ts +218 -0
- package/src/math/lib.ts +15 -0
- package/src/math/rounding.test.ts +65 -0
- package/src/math/rounding.ts +156 -0
- package/src/rendering/Display.ts +249 -0
- package/src/rendering/RenderingStyle.test.ts +68 -0
- package/src/rendering/RenderingStyle.ts +55 -0
- package/src/rendering/TextRenderingStyle.ts +45 -0
- package/src/rendering/caching/CacheRecord.test.ts +49 -0
- package/src/rendering/caching/CacheRecord.ts +77 -0
- package/src/rendering/caching/CacheRecordManager.ts +71 -0
- package/src/rendering/caching/RenderingCache.test.ts +44 -0
- package/src/rendering/caching/RenderingCache.ts +66 -0
- package/src/rendering/caching/RenderingCacheNode.ts +405 -0
- package/src/rendering/caching/testUtils.ts +35 -0
- package/src/rendering/caching/types.ts +34 -0
- package/src/rendering/lib.ts +6 -0
- package/src/rendering/localization.ts +20 -0
- package/src/rendering/renderers/AbstractRenderer.ts +222 -0
- package/src/rendering/renderers/CanvasRenderer.ts +296 -0
- package/src/rendering/renderers/DummyRenderer.test.ts +42 -0
- package/src/rendering/renderers/DummyRenderer.ts +136 -0
- package/src/rendering/renderers/SVGRenderer.ts +354 -0
- package/src/rendering/renderers/TextOnlyRenderer.ts +70 -0
- package/src/styles.js +7 -0
- package/src/testing/beforeEachFile.ts +8 -0
- package/src/testing/createEditor.ts +11 -0
- package/src/testing/global.d.ts +17 -0
- package/src/testing/lib.ts +3 -0
- package/src/testing/loadExpectExtensions.ts +25 -0
- package/src/testing/sendPenEvent.ts +31 -0
- package/src/testing/sendTouchEvent.ts +78 -0
- package/src/toolbar/HTMLToolbar.ts +492 -0
- package/src/toolbar/IconProvider.ts +736 -0
- package/src/toolbar/lib.ts +4 -0
- package/src/toolbar/localization.ts +106 -0
- package/src/toolbar/makeColorInput.ts +145 -0
- package/src/toolbar/toolbar.css +213 -0
- package/src/toolbar/types.ts +5 -0
- package/src/toolbar/widgets/ActionButtonWidget.ts +39 -0
- package/src/toolbar/widgets/BaseToolWidget.ts +56 -0
- package/src/toolbar/widgets/BaseWidget.ts +377 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +167 -0
- package/src/toolbar/widgets/EraserToolWidget.ts +85 -0
- package/src/toolbar/widgets/HandToolWidget.ts +250 -0
- package/src/toolbar/widgets/InsertImageWidget.css +44 -0
- package/src/toolbar/widgets/InsertImageWidget.ts +223 -0
- package/src/toolbar/widgets/OverflowWidget.css +27 -0
- package/src/toolbar/widgets/OverflowWidget.ts +92 -0
- package/src/toolbar/widgets/PenToolWidget.ts +288 -0
- package/src/toolbar/widgets/SelectionToolWidget.ts +190 -0
- package/src/toolbar/widgets/TextToolWidget.ts +145 -0
- package/src/toolbar/widgets/lib.ts +13 -0
- package/src/tools/BaseTool.ts +76 -0
- package/src/tools/Eraser.test.ts +103 -0
- package/src/tools/Eraser.ts +139 -0
- package/src/tools/FindTool.css +7 -0
- package/src/tools/FindTool.ts +152 -0
- package/src/tools/PanZoom.test.ts +310 -0
- package/src/tools/PanZoom.ts +520 -0
- package/src/tools/PasteHandler.ts +95 -0
- package/src/tools/Pen.test.ts +194 -0
- package/src/tools/Pen.ts +226 -0
- package/src/tools/PipetteTool.ts +55 -0
- package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +28 -0
- package/src/tools/SelectionTool/Selection.ts +607 -0
- package/src/tools/SelectionTool/SelectionHandle.ts +108 -0
- package/src/tools/SelectionTool/SelectionTool.css +23 -0
- package/src/tools/SelectionTool/SelectionTool.test.ts +261 -0
- package/src/tools/SelectionTool/SelectionTool.ts +480 -0
- package/src/tools/SelectionTool/TransformMode.ts +114 -0
- package/src/tools/SelectionTool/types.ts +11 -0
- package/src/tools/TextTool.ts +326 -0
- package/src/tools/ToolController.ts +178 -0
- package/src/tools/ToolEnabledGroup.ts +14 -0
- package/src/tools/ToolSwitcherShortcut.ts +39 -0
- package/src/tools/ToolbarShortcutHandler.ts +34 -0
- package/src/tools/UndoRedoShortcut.test.ts +56 -0
- package/src/tools/UndoRedoShortcut.ts +25 -0
- package/src/tools/lib.ts +21 -0
- package/src/tools/localization.ts +66 -0
- package/src/types.ts +234 -0
- package/src/util/assertions.ts +55 -0
- package/src/util/fileToBase64.ts +18 -0
- package/src/util/untilNextAnimationFrame.ts +9 -0
- package/src/util/waitForTimeout.ts +9 -0
@@ -0,0 +1,128 @@
|
|
1
|
+
// @packageDocumentation @internal
|
2
|
+
// Clean up stringified numbers
|
3
|
+
export const cleanUpNumber = (text) => {
|
4
|
+
// Regular expression substitions can be somewhat expensive. Only do them
|
5
|
+
// if necessary.
|
6
|
+
if (text.indexOf('e') > 0) {
|
7
|
+
// Round to zero.
|
8
|
+
if (text.match(/[eE][-]\d{2,}$/)) {
|
9
|
+
return '0';
|
10
|
+
}
|
11
|
+
}
|
12
|
+
const lastChar = text.charAt(text.length - 1);
|
13
|
+
if (lastChar === '0' || lastChar === '.') {
|
14
|
+
// Remove trailing zeroes
|
15
|
+
text = text.replace(/([.]\d*[^0]+)0+$/, '$1');
|
16
|
+
text = text.replace(/[.]0+$/, '.');
|
17
|
+
// Remove trailing period
|
18
|
+
text = text.replace(/[.]$/, '');
|
19
|
+
}
|
20
|
+
const firstChar = text.charAt(0);
|
21
|
+
if (firstChar === '0' || firstChar === '-') {
|
22
|
+
// Remove unnecessary leading zeroes.
|
23
|
+
text = text.replace(/^(0+)[.]/, '.');
|
24
|
+
text = text.replace(/^-(0+)[.]/, '-.');
|
25
|
+
text = text.replace(/^(-?)0+$/, '$10');
|
26
|
+
}
|
27
|
+
if (text === '-0') {
|
28
|
+
return '0';
|
29
|
+
}
|
30
|
+
return text;
|
31
|
+
};
|
32
|
+
export const toRoundedString = (num) => {
|
33
|
+
// Try to remove rounding errors. If the number ends in at least three/four zeroes
|
34
|
+
// (or nines) just one or two digits, it's probably a rounding error.
|
35
|
+
const fixRoundingUpExp = /^([-]?\d*\.\d{3,})0{4,}\d{1,4}$/;
|
36
|
+
const hasRoundingDownExp = /^([-]?)(\d*)\.(\d{3,}9{4,})\d{1,4}$/;
|
37
|
+
let text = num.toString(10);
|
38
|
+
if (text.indexOf('.') === -1) {
|
39
|
+
return text;
|
40
|
+
}
|
41
|
+
const roundingDownMatch = hasRoundingDownExp.exec(text);
|
42
|
+
if (roundingDownMatch) {
|
43
|
+
const negativeSign = roundingDownMatch[1];
|
44
|
+
const postDecimalString = roundingDownMatch[3];
|
45
|
+
const lastDigit = parseInt(postDecimalString.charAt(postDecimalString.length - 1), 10);
|
46
|
+
const postDecimal = parseInt(postDecimalString, 10);
|
47
|
+
const preDecimal = parseInt(roundingDownMatch[2], 10);
|
48
|
+
const origPostDecimalString = roundingDownMatch[3];
|
49
|
+
let newPostDecimal = (postDecimal + 10 - lastDigit).toString();
|
50
|
+
let carry = 0;
|
51
|
+
if (newPostDecimal.length > postDecimal.toString().length) {
|
52
|
+
// Left-shift
|
53
|
+
newPostDecimal = newPostDecimal.substring(1);
|
54
|
+
carry = 1;
|
55
|
+
}
|
56
|
+
// parseInt(...).toString() removes leading zeroes. Add them back.
|
57
|
+
while (newPostDecimal.length < origPostDecimalString.length) {
|
58
|
+
newPostDecimal = carry.toString(10) + newPostDecimal;
|
59
|
+
carry = 0;
|
60
|
+
}
|
61
|
+
text = `${negativeSign + (preDecimal + carry).toString()}.${newPostDecimal}`;
|
62
|
+
}
|
63
|
+
text = text.replace(fixRoundingUpExp, '$1');
|
64
|
+
return cleanUpNumber(text);
|
65
|
+
};
|
66
|
+
const numberExp = /^([-]?)(\d*)[.](\d+)$/;
|
67
|
+
export const getLenAfterDecimal = (numberAsString) => {
|
68
|
+
const numberMatch = numberExp.exec(numberAsString);
|
69
|
+
if (!numberMatch) {
|
70
|
+
// If not a match, either the number is exponential notation (or is something
|
71
|
+
// like NaN or Infinity)
|
72
|
+
if (numberAsString.search(/[eE]/) !== -1 || /^[a-zA-Z]+$/.exec(numberAsString)) {
|
73
|
+
return -1;
|
74
|
+
// Or it has no decimal point
|
75
|
+
}
|
76
|
+
else {
|
77
|
+
return 0;
|
78
|
+
}
|
79
|
+
}
|
80
|
+
const afterDecimalLen = numberMatch[3].length;
|
81
|
+
return afterDecimalLen;
|
82
|
+
};
|
83
|
+
// [reference] should be a string representation of a base-10 number (no exponential (e.g. 10e10))
|
84
|
+
export const toStringOfSamePrecision = (num, ...references) => {
|
85
|
+
const text = num.toString(10);
|
86
|
+
const textMatch = numberExp.exec(text);
|
87
|
+
if (!textMatch) {
|
88
|
+
return text;
|
89
|
+
}
|
90
|
+
let decimalPlaces = -1;
|
91
|
+
for (const reference of references) {
|
92
|
+
decimalPlaces = Math.max(getLenAfterDecimal(reference), decimalPlaces);
|
93
|
+
}
|
94
|
+
if (decimalPlaces === -1) {
|
95
|
+
return toRoundedString(num);
|
96
|
+
}
|
97
|
+
// Make text's after decimal length match [afterDecimalLen].
|
98
|
+
let postDecimal = textMatch[3].substring(0, decimalPlaces);
|
99
|
+
let preDecimal = textMatch[2];
|
100
|
+
const nextDigit = textMatch[3].charAt(decimalPlaces);
|
101
|
+
if (nextDigit !== '') {
|
102
|
+
const asNumber = parseInt(nextDigit, 10);
|
103
|
+
if (asNumber >= 5) {
|
104
|
+
// Don't attempt to parseInt() an empty string.
|
105
|
+
if (postDecimal.length > 0) {
|
106
|
+
const leadingZeroMatch = /^(0+)(\d*)$/.exec(postDecimal);
|
107
|
+
let leadingZeroes = '';
|
108
|
+
let postLeading = postDecimal;
|
109
|
+
if (leadingZeroMatch) {
|
110
|
+
leadingZeroes = leadingZeroMatch[1];
|
111
|
+
postLeading = leadingZeroMatch[2];
|
112
|
+
}
|
113
|
+
postDecimal = (parseInt(postDecimal) + 1).toString();
|
114
|
+
// If postDecimal got longer, remove leading zeroes if possible
|
115
|
+
if (postDecimal.length > postLeading.length && leadingZeroes.length > 0) {
|
116
|
+
leadingZeroes = leadingZeroes.substring(1);
|
117
|
+
}
|
118
|
+
postDecimal = leadingZeroes + postDecimal;
|
119
|
+
}
|
120
|
+
if (postDecimal.length === 0 || postDecimal.length > decimalPlaces) {
|
121
|
+
preDecimal = (parseInt(preDecimal) + 1).toString();
|
122
|
+
postDecimal = postDecimal.substring(1);
|
123
|
+
}
|
124
|
+
}
|
125
|
+
}
|
126
|
+
const negativeSign = textMatch[1];
|
127
|
+
return cleanUpNumber(`${negativeSign}${preDecimal}.${postDecimal}`);
|
128
|
+
};
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import AbstractRenderer from './renderers/AbstractRenderer';
|
2
|
+
import { Editor } from '../Editor';
|
3
|
+
import { Point2 } from '../math/Vec2';
|
4
|
+
import RenderingCache from './caching/RenderingCache';
|
5
|
+
import Color4 from '../Color4';
|
6
|
+
export declare enum RenderingMode {
|
7
|
+
DummyRenderer = 0,
|
8
|
+
CanvasRenderer = 1
|
9
|
+
}
|
10
|
+
/**
|
11
|
+
* Handles `HTMLCanvasElement`s (or other drawing surfaces if being used) used to display the editor's contents.
|
12
|
+
*
|
13
|
+
* @example
|
14
|
+
* ```
|
15
|
+
* const editor = new Editor(document.body);
|
16
|
+
* const w = editor.display.width;
|
17
|
+
* const h = editor.display.height;
|
18
|
+
* const center = Vec2.of(w / 2, h / 2);
|
19
|
+
* const colorAtCenter = editor.display.getColorAt(center);
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
export default class Display {
|
23
|
+
private editor;
|
24
|
+
private parent;
|
25
|
+
private dryInkRenderer;
|
26
|
+
private wetInkRenderer;
|
27
|
+
private textRenderer;
|
28
|
+
private textRerenderOutput;
|
29
|
+
private cache;
|
30
|
+
private resizeSurfacesCallback?;
|
31
|
+
private flattenCallback?;
|
32
|
+
/** @internal */
|
33
|
+
constructor(editor: Editor, mode: RenderingMode, parent: HTMLElement | null);
|
34
|
+
/**
|
35
|
+
* @returns the visible width of the display (e.g. how much
|
36
|
+
* space the display's element takes up in the x direction
|
37
|
+
* in the DOM).
|
38
|
+
*/
|
39
|
+
get width(): number;
|
40
|
+
get height(): number;
|
41
|
+
/** @internal */
|
42
|
+
getCache(): RenderingCache;
|
43
|
+
/**
|
44
|
+
* @returns the color at the given point on the dry ink renderer, or `null` if `screenPos`
|
45
|
+
* is not on the display.
|
46
|
+
*/
|
47
|
+
getColorAt: (_screenPos: Point2) => Color4 | null;
|
48
|
+
private initializeCanvasRendering;
|
49
|
+
private initializeTextRendering;
|
50
|
+
/**
|
51
|
+
* Rerenders the text-based display.
|
52
|
+
* The text-based display is intended for screen readers and can be navigated to by pressing `tab`.
|
53
|
+
*/
|
54
|
+
rerenderAsText(): void;
|
55
|
+
/**
|
56
|
+
* Clears the drawing surfaces and otherwise prepares for a rerender.
|
57
|
+
*
|
58
|
+
* @returns the dry ink renderer.
|
59
|
+
*/
|
60
|
+
startRerender(): AbstractRenderer;
|
61
|
+
/**
|
62
|
+
* If `draftMode`, the dry ink renderer is configured to render
|
63
|
+
* low-quality output.
|
64
|
+
*/
|
65
|
+
setDraftMode(draftMode: boolean): void;
|
66
|
+
/** @internal */
|
67
|
+
getDryInkRenderer(): AbstractRenderer;
|
68
|
+
/**
|
69
|
+
* @returns The renderer used for showing action previews (e.g. an unfinished stroke).
|
70
|
+
* The `wetInkRenderer`'s surface is stacked above the `dryInkRenderer`'s.
|
71
|
+
*/
|
72
|
+
getWetInkRenderer(): AbstractRenderer;
|
73
|
+
/** Re-renders the contents of the wetInkRenderer onto the dryInkRenderer. */
|
74
|
+
flatten(): void;
|
75
|
+
}
|
@@ -0,0 +1,207 @@
|
|
1
|
+
import CanvasRenderer from './renderers/CanvasRenderer.mjs';
|
2
|
+
import { EditorEventType } from '../types.mjs';
|
3
|
+
import DummyRenderer from './renderers/DummyRenderer.mjs';
|
4
|
+
import { Vec2 } from '../math/Vec2.mjs';
|
5
|
+
import RenderingCache from './caching/RenderingCache.mjs';
|
6
|
+
import TextOnlyRenderer from './renderers/TextOnlyRenderer.mjs';
|
7
|
+
import Color4 from '../Color4.mjs';
|
8
|
+
export var RenderingMode;
|
9
|
+
(function (RenderingMode) {
|
10
|
+
RenderingMode[RenderingMode["DummyRenderer"] = 0] = "DummyRenderer";
|
11
|
+
RenderingMode[RenderingMode["CanvasRenderer"] = 1] = "CanvasRenderer";
|
12
|
+
// SVGRenderer is not supported by the main display
|
13
|
+
})(RenderingMode || (RenderingMode = {}));
|
14
|
+
/**
|
15
|
+
* Handles `HTMLCanvasElement`s (or other drawing surfaces if being used) used to display the editor's contents.
|
16
|
+
*
|
17
|
+
* @example
|
18
|
+
* ```
|
19
|
+
* const editor = new Editor(document.body);
|
20
|
+
* const w = editor.display.width;
|
21
|
+
* const h = editor.display.height;
|
22
|
+
* const center = Vec2.of(w / 2, h / 2);
|
23
|
+
* const colorAtCenter = editor.display.getColorAt(center);
|
24
|
+
* ```
|
25
|
+
*/
|
26
|
+
export default class Display {
|
27
|
+
/** @internal */
|
28
|
+
constructor(editor, mode, parent) {
|
29
|
+
this.editor = editor;
|
30
|
+
this.parent = parent;
|
31
|
+
this.textRerenderOutput = null;
|
32
|
+
/**
|
33
|
+
* @returns the color at the given point on the dry ink renderer, or `null` if `screenPos`
|
34
|
+
* is not on the display.
|
35
|
+
*/
|
36
|
+
this.getColorAt = (_screenPos) => {
|
37
|
+
return null;
|
38
|
+
};
|
39
|
+
if (mode === RenderingMode.CanvasRenderer) {
|
40
|
+
this.initializeCanvasRendering();
|
41
|
+
}
|
42
|
+
else if (mode === RenderingMode.DummyRenderer) {
|
43
|
+
this.dryInkRenderer = new DummyRenderer(editor.viewport);
|
44
|
+
this.wetInkRenderer = new DummyRenderer(editor.viewport);
|
45
|
+
}
|
46
|
+
else {
|
47
|
+
throw new Error(`Unknown rendering mode, ${mode}!`);
|
48
|
+
}
|
49
|
+
this.textRenderer = new TextOnlyRenderer(editor.viewport, editor.localization);
|
50
|
+
this.initializeTextRendering();
|
51
|
+
const cacheBlockResolution = Vec2.of(600, 600);
|
52
|
+
this.cache = new RenderingCache({
|
53
|
+
createRenderer: () => {
|
54
|
+
if (mode === RenderingMode.DummyRenderer) {
|
55
|
+
return new DummyRenderer(editor.viewport);
|
56
|
+
}
|
57
|
+
else if (mode !== RenderingMode.CanvasRenderer) {
|
58
|
+
throw new Error('Unspported rendering mode');
|
59
|
+
}
|
60
|
+
// Make the canvas slightly larger than each cache block to prevent
|
61
|
+
// seams.
|
62
|
+
const canvas = document.createElement('canvas');
|
63
|
+
canvas.width = cacheBlockResolution.x + 1;
|
64
|
+
canvas.height = cacheBlockResolution.y + 1;
|
65
|
+
const ctx = canvas.getContext('2d');
|
66
|
+
return new CanvasRenderer(ctx, editor.viewport);
|
67
|
+
},
|
68
|
+
isOfCorrectType: (renderer) => {
|
69
|
+
return this.dryInkRenderer.canRenderFromWithoutDataLoss(renderer);
|
70
|
+
},
|
71
|
+
blockResolution: cacheBlockResolution,
|
72
|
+
cacheSize: 600 * 600 * 4 * 90,
|
73
|
+
maxScale: 1.3,
|
74
|
+
// Require about 20 strokes with 4 parts each to cache an image in one of the
|
75
|
+
// parts of the cache grid.
|
76
|
+
minProportionalRenderTimePerCache: 20 * 4,
|
77
|
+
// Require about 105 strokes with 4 parts each to use the cache at all.
|
78
|
+
minProportionalRenderTimeToUseCache: 105 * 4,
|
79
|
+
});
|
80
|
+
this.editor.notifier.on(EditorEventType.DisplayResized, event => {
|
81
|
+
var _a;
|
82
|
+
if (event.kind !== EditorEventType.DisplayResized) {
|
83
|
+
throw new Error('Mismatched event.kinds!');
|
84
|
+
}
|
85
|
+
(_a = this.resizeSurfacesCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
86
|
+
});
|
87
|
+
}
|
88
|
+
/**
|
89
|
+
* @returns the visible width of the display (e.g. how much
|
90
|
+
* space the display's element takes up in the x direction
|
91
|
+
* in the DOM).
|
92
|
+
*/
|
93
|
+
get width() {
|
94
|
+
return this.dryInkRenderer.displaySize().x;
|
95
|
+
}
|
96
|
+
get height() {
|
97
|
+
return this.dryInkRenderer.displaySize().y;
|
98
|
+
}
|
99
|
+
/** @internal */
|
100
|
+
getCache() {
|
101
|
+
return this.cache;
|
102
|
+
}
|
103
|
+
initializeCanvasRendering() {
|
104
|
+
const dryInkCanvas = document.createElement('canvas');
|
105
|
+
const wetInkCanvas = document.createElement('canvas');
|
106
|
+
const dryInkCtx = dryInkCanvas.getContext('2d');
|
107
|
+
const wetInkCtx = wetInkCanvas.getContext('2d');
|
108
|
+
this.dryInkRenderer = new CanvasRenderer(dryInkCtx, this.editor.viewport);
|
109
|
+
this.wetInkRenderer = new CanvasRenderer(wetInkCtx, this.editor.viewport);
|
110
|
+
dryInkCanvas.className = 'dryInkCanvas';
|
111
|
+
wetInkCanvas.className = 'wetInkCanvas';
|
112
|
+
if (this.parent) {
|
113
|
+
this.parent.appendChild(dryInkCanvas);
|
114
|
+
this.parent.appendChild(wetInkCanvas);
|
115
|
+
}
|
116
|
+
this.resizeSurfacesCallback = () => {
|
117
|
+
const hasSizeMismatch = (canvas) => {
|
118
|
+
return canvas.clientHeight !== canvas.height || canvas.clientWidth !== canvas.width;
|
119
|
+
};
|
120
|
+
// Ensure that the drawing surfaces sizes match the
|
121
|
+
// canvas' sizes to prevent stretching.
|
122
|
+
if (hasSizeMismatch(dryInkCanvas) || hasSizeMismatch(wetInkCanvas)) {
|
123
|
+
dryInkCanvas.width = dryInkCanvas.clientWidth;
|
124
|
+
dryInkCanvas.height = dryInkCanvas.clientHeight;
|
125
|
+
wetInkCanvas.width = wetInkCanvas.clientWidth;
|
126
|
+
wetInkCanvas.height = wetInkCanvas.clientHeight;
|
127
|
+
this.editor.notifier.dispatch(EditorEventType.DisplayResized, {
|
128
|
+
kind: EditorEventType.DisplayResized,
|
129
|
+
newSize: Vec2.of(this.width, this.height),
|
130
|
+
});
|
131
|
+
}
|
132
|
+
};
|
133
|
+
this.resizeSurfacesCallback();
|
134
|
+
this.flattenCallback = () => {
|
135
|
+
dryInkCtx.drawImage(wetInkCanvas, 0, 0);
|
136
|
+
};
|
137
|
+
this.getColorAt = (screenPos) => {
|
138
|
+
const pixel = dryInkCtx.getImageData(screenPos.x, screenPos.y, 1, 1);
|
139
|
+
const data = pixel === null || pixel === void 0 ? void 0 : pixel.data;
|
140
|
+
if (data) {
|
141
|
+
const color = Color4.ofRGBA(data[0] / 255, data[1] / 255, data[2] / 255, data[3] / 255);
|
142
|
+
return color;
|
143
|
+
}
|
144
|
+
return null;
|
145
|
+
};
|
146
|
+
}
|
147
|
+
initializeTextRendering() {
|
148
|
+
const textRendererOutputContainer = document.createElement('div');
|
149
|
+
textRendererOutputContainer.classList.add('textRendererOutputContainer');
|
150
|
+
const rerenderButton = document.createElement('button');
|
151
|
+
rerenderButton.classList.add('rerenderButton');
|
152
|
+
rerenderButton.innerText = this.editor.localization.rerenderAsText;
|
153
|
+
this.textRerenderOutput = document.createElement('div');
|
154
|
+
this.textRerenderOutput.setAttribute('aria-live', 'polite');
|
155
|
+
rerenderButton.onclick = () => {
|
156
|
+
this.rerenderAsText();
|
157
|
+
};
|
158
|
+
textRendererOutputContainer.replaceChildren(rerenderButton, this.textRerenderOutput);
|
159
|
+
this.editor.createHTMLOverlay(textRendererOutputContainer);
|
160
|
+
}
|
161
|
+
/**
|
162
|
+
* Rerenders the text-based display.
|
163
|
+
* The text-based display is intended for screen readers and can be navigated to by pressing `tab`.
|
164
|
+
*/
|
165
|
+
rerenderAsText() {
|
166
|
+
this.textRenderer.clear();
|
167
|
+
this.editor.image.render(this.textRenderer, this.editor.viewport);
|
168
|
+
if (this.textRerenderOutput) {
|
169
|
+
this.textRerenderOutput.innerText = this.textRenderer.getDescription();
|
170
|
+
}
|
171
|
+
}
|
172
|
+
/**
|
173
|
+
* Clears the drawing surfaces and otherwise prepares for a rerender.
|
174
|
+
*
|
175
|
+
* @returns the dry ink renderer.
|
176
|
+
*/
|
177
|
+
startRerender() {
|
178
|
+
var _a;
|
179
|
+
(_a = this.resizeSurfacesCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
180
|
+
this.wetInkRenderer.clear();
|
181
|
+
this.dryInkRenderer.clear();
|
182
|
+
return this.dryInkRenderer;
|
183
|
+
}
|
184
|
+
/**
|
185
|
+
* If `draftMode`, the dry ink renderer is configured to render
|
186
|
+
* low-quality output.
|
187
|
+
*/
|
188
|
+
setDraftMode(draftMode) {
|
189
|
+
this.dryInkRenderer.setDraftMode(draftMode);
|
190
|
+
}
|
191
|
+
/** @internal */
|
192
|
+
getDryInkRenderer() {
|
193
|
+
return this.dryInkRenderer;
|
194
|
+
}
|
195
|
+
/**
|
196
|
+
* @returns The renderer used for showing action previews (e.g. an unfinished stroke).
|
197
|
+
* The `wetInkRenderer`'s surface is stacked above the `dryInkRenderer`'s.
|
198
|
+
*/
|
199
|
+
getWetInkRenderer() {
|
200
|
+
return this.wetInkRenderer;
|
201
|
+
}
|
202
|
+
/** Re-renders the contents of the wetInkRenderer onto the dryInkRenderer. */
|
203
|
+
flatten() {
|
204
|
+
var _a;
|
205
|
+
(_a = this.flattenCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
206
|
+
}
|
207
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import Color4 from '../Color4';
|
2
|
+
interface RenderingStyle {
|
3
|
+
fill: Color4;
|
4
|
+
stroke?: {
|
5
|
+
color: Color4;
|
6
|
+
width: number;
|
7
|
+
};
|
8
|
+
}
|
9
|
+
export default RenderingStyle;
|
10
|
+
export declare const cloneStyle: (style: RenderingStyle) => {
|
11
|
+
fill: Color4;
|
12
|
+
stroke: {
|
13
|
+
color: Color4;
|
14
|
+
width: number;
|
15
|
+
} | undefined;
|
16
|
+
};
|
17
|
+
export declare const stylesEqual: (a: RenderingStyle, b: RenderingStyle) => boolean;
|
18
|
+
export declare const styleToJSON: (style: RenderingStyle) => {
|
19
|
+
fill: string;
|
20
|
+
stroke: {
|
21
|
+
color: string;
|
22
|
+
width: number;
|
23
|
+
} | undefined;
|
24
|
+
};
|
25
|
+
export declare const styleFromJSON: (json: Record<string, any>) => {
|
26
|
+
fill: Color4;
|
27
|
+
stroke: {
|
28
|
+
color: Color4;
|
29
|
+
width: any;
|
30
|
+
} | undefined;
|
31
|
+
};
|
@@ -0,0 +1,38 @@
|
|
1
|
+
import Color4 from '../Color4.mjs';
|
2
|
+
export const cloneStyle = (style) => {
|
3
|
+
return {
|
4
|
+
fill: style.fill,
|
5
|
+
stroke: style.stroke ? Object.assign({}, style.stroke) : undefined,
|
6
|
+
};
|
7
|
+
};
|
8
|
+
export const stylesEqual = (a, b) => {
|
9
|
+
var _a, _b, _c, _d, _e, _f;
|
10
|
+
const result = a === b || (a.fill.eq(b.fill)
|
11
|
+
&& (a.stroke == undefined) === (b.stroke == undefined)
|
12
|
+
&& ((_d = (_b = (_a = a.stroke) === null || _a === void 0 ? void 0 : _a.color) === null || _b === void 0 ? void 0 : _b.eq((_c = b.stroke) === null || _c === void 0 ? void 0 : _c.color)) !== null && _d !== void 0 ? _d : true)
|
13
|
+
&& ((_e = a.stroke) === null || _e === void 0 ? void 0 : _e.width) === ((_f = b.stroke) === null || _f === void 0 ? void 0 : _f.width));
|
14
|
+
// Map undefined/null -> false
|
15
|
+
return result !== null && result !== void 0 ? result : false;
|
16
|
+
};
|
17
|
+
// Returns an object that can be converted to a JSON string with
|
18
|
+
// JSON.stringify.
|
19
|
+
export const styleToJSON = (style) => {
|
20
|
+
const stroke = !style.stroke ? undefined : {
|
21
|
+
color: style.stroke.color.toHexString(),
|
22
|
+
width: style.stroke.width,
|
23
|
+
};
|
24
|
+
return {
|
25
|
+
fill: style.fill.toHexString(),
|
26
|
+
stroke,
|
27
|
+
};
|
28
|
+
};
|
29
|
+
export const styleFromJSON = (json) => {
|
30
|
+
const stroke = json.stroke ? {
|
31
|
+
color: Color4.fromHex(json.stroke.color),
|
32
|
+
width: json.stroke.width,
|
33
|
+
} : undefined;
|
34
|
+
return {
|
35
|
+
fill: Color4.fromHex(json.fill),
|
36
|
+
stroke,
|
37
|
+
};
|
38
|
+
};
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import RenderingStyle from './RenderingStyle';
|
2
|
+
export interface TextStyle {
|
3
|
+
size: number;
|
4
|
+
fontFamily: string;
|
5
|
+
fontWeight?: string;
|
6
|
+
fontVariant?: string;
|
7
|
+
renderingStyle: RenderingStyle;
|
8
|
+
}
|
9
|
+
export default TextStyle;
|
10
|
+
export declare const cloneTextStyle: (style: TextStyle) => {
|
11
|
+
renderingStyle: {
|
12
|
+
fill: import("../Color4").default;
|
13
|
+
stroke: {
|
14
|
+
color: import("../Color4").default;
|
15
|
+
width: number;
|
16
|
+
} | undefined;
|
17
|
+
};
|
18
|
+
size: number;
|
19
|
+
fontFamily: string;
|
20
|
+
fontWeight?: string | undefined;
|
21
|
+
fontVariant?: string | undefined;
|
22
|
+
};
|
23
|
+
export declare const textStyleFromJSON: (json: any) => TextStyle;
|
24
|
+
export declare const textStyleToJSON: (style: TextStyle) => {
|
25
|
+
renderingStyle: {
|
26
|
+
fill: string;
|
27
|
+
stroke: {
|
28
|
+
color: string;
|
29
|
+
width: number;
|
30
|
+
} | undefined;
|
31
|
+
};
|
32
|
+
size: number;
|
33
|
+
fontFamily: string;
|
34
|
+
fontWeight?: string | undefined;
|
35
|
+
fontVariant?: string | undefined;
|
36
|
+
};
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { cloneStyle, styleFromJSON, styleToJSON } from './RenderingStyle.mjs';
|
2
|
+
export const cloneTextStyle = (style) => {
|
3
|
+
return Object.assign(Object.assign({}, style), { renderingStyle: cloneStyle(style.renderingStyle) });
|
4
|
+
};
|
5
|
+
export const textStyleFromJSON = (json) => {
|
6
|
+
if (typeof json === 'string') {
|
7
|
+
json = JSON.parse(json);
|
8
|
+
}
|
9
|
+
if (typeof (json.fontFamily) !== 'string') {
|
10
|
+
throw new Error('Serialized textStyle missing string fontFamily attribute!');
|
11
|
+
}
|
12
|
+
const style = {
|
13
|
+
renderingStyle: styleFromJSON(json.renderingStyle),
|
14
|
+
size: json.size,
|
15
|
+
fontWeight: json.fontWeight,
|
16
|
+
fontVariant: json.fontVariant,
|
17
|
+
fontFamily: json.fontFamily,
|
18
|
+
};
|
19
|
+
return style;
|
20
|
+
};
|
21
|
+
export const textStyleToJSON = (style) => {
|
22
|
+
return Object.assign(Object.assign({}, style), { renderingStyle: styleToJSON(style.renderingStyle) });
|
23
|
+
};
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import Mat33 from '../../math/Mat33';
|
2
|
+
import Rect2 from '../../math/Rect2';
|
3
|
+
import AbstractRenderer from '../renderers/AbstractRenderer';
|
4
|
+
import { BeforeDeallocCallback, CacheState } from './types';
|
5
|
+
export default class CacheRecord {
|
6
|
+
private onBeforeDeallocCallback;
|
7
|
+
private cacheState;
|
8
|
+
private renderer;
|
9
|
+
private lastUsedCycle;
|
10
|
+
private allocd;
|
11
|
+
allocCount: number;
|
12
|
+
constructor(onBeforeDeallocCallback: BeforeDeallocCallback | null, cacheState: CacheState);
|
13
|
+
startRender(): AbstractRenderer;
|
14
|
+
dealloc(): void;
|
15
|
+
isAllocd(): boolean;
|
16
|
+
realloc(newDeallocCallback: BeforeDeallocCallback): void;
|
17
|
+
getLastUsedCycle(): number;
|
18
|
+
getTransform(drawTo: Rect2): Mat33;
|
19
|
+
setRenderingRegion(drawTo: Rect2): void;
|
20
|
+
}
|
@@ -0,0 +1,55 @@
|
|
1
|
+
import Mat33 from '../../math/Mat33.mjs';
|
2
|
+
// Represents a cached renderer/canvas
|
3
|
+
// This is not a [CacheNode] -- it handles cached renderers and does not have sub-renderers.
|
4
|
+
export default class CacheRecord {
|
5
|
+
constructor(onBeforeDeallocCallback, cacheState) {
|
6
|
+
this.onBeforeDeallocCallback = onBeforeDeallocCallback;
|
7
|
+
this.cacheState = cacheState;
|
8
|
+
this.allocd = false;
|
9
|
+
// For debugging
|
10
|
+
this.allocCount = 0;
|
11
|
+
this.renderer = cacheState.props.createRenderer();
|
12
|
+
this.lastUsedCycle = -1;
|
13
|
+
this.allocd = true;
|
14
|
+
}
|
15
|
+
startRender() {
|
16
|
+
this.lastUsedCycle = this.cacheState.currentRenderingCycle;
|
17
|
+
if (!this.allocd) {
|
18
|
+
throw new Error('Only alloc\'d canvases can be rendered to');
|
19
|
+
}
|
20
|
+
return this.renderer;
|
21
|
+
}
|
22
|
+
dealloc() {
|
23
|
+
var _a;
|
24
|
+
(_a = this.onBeforeDeallocCallback) === null || _a === void 0 ? void 0 : _a.call(this);
|
25
|
+
this.allocd = false;
|
26
|
+
this.onBeforeDeallocCallback = null;
|
27
|
+
this.lastUsedCycle = 0;
|
28
|
+
}
|
29
|
+
isAllocd() {
|
30
|
+
return this.allocd;
|
31
|
+
}
|
32
|
+
realloc(newDeallocCallback) {
|
33
|
+
if (this.allocd) {
|
34
|
+
this.dealloc();
|
35
|
+
}
|
36
|
+
this.allocd = true;
|
37
|
+
this.onBeforeDeallocCallback = newDeallocCallback;
|
38
|
+
this.lastUsedCycle = this.cacheState.currentRenderingCycle;
|
39
|
+
this.allocCount++;
|
40
|
+
}
|
41
|
+
getLastUsedCycle() {
|
42
|
+
return this.lastUsedCycle;
|
43
|
+
}
|
44
|
+
// Returns the transformation that maps [drawTo] to this' renderable region
|
45
|
+
// (i.e. a [cacheProps.blockResolution]-sized rectangle with top left at (0, 0))
|
46
|
+
getTransform(drawTo) {
|
47
|
+
const transform = Mat33.scaling2D(this.cacheState.props.blockResolution.x / drawTo.size.x).rightMul(Mat33.translation(drawTo.topLeft.times(-1)));
|
48
|
+
return transform;
|
49
|
+
}
|
50
|
+
setRenderingRegion(drawTo) {
|
51
|
+
this.renderer.setTransform(
|
52
|
+
// Invert to map objects instead of the viewport
|
53
|
+
this.getTransform(drawTo));
|
54
|
+
}
|
55
|
+
}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { BeforeDeallocCallback, CacheProps, CacheState } from './types';
|
2
|
+
import CacheRecord from './CacheRecord';
|
3
|
+
import Rect2 from '../../math/Rect2';
|
4
|
+
export declare class CacheRecordManager {
|
5
|
+
private cacheRecords;
|
6
|
+
private maxCanvases;
|
7
|
+
private cacheState;
|
8
|
+
constructor(cacheProps: CacheProps);
|
9
|
+
setSharedState(state: CacheState): void;
|
10
|
+
allocCanvas(drawTo: Rect2, onDealloc: BeforeDeallocCallback): CacheRecord;
|
11
|
+
private getLeastRecentlyUsedRecord;
|
12
|
+
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import CacheRecord from './CacheRecord.mjs';
|
2
|
+
const debugMode = false;
|
3
|
+
export class CacheRecordManager {
|
4
|
+
constructor(cacheProps) {
|
5
|
+
// Fixed-size array: Cache blocks are assigned indicies into [cachedCanvases].
|
6
|
+
this.cacheRecords = [];
|
7
|
+
this.maxCanvases = Math.ceil(
|
8
|
+
// Assuming four components per pixel:
|
9
|
+
cacheProps.cacheSize / 4 / cacheProps.blockResolution.x / cacheProps.blockResolution.y);
|
10
|
+
}
|
11
|
+
setSharedState(state) {
|
12
|
+
this.cacheState = state;
|
13
|
+
}
|
14
|
+
allocCanvas(drawTo, onDealloc) {
|
15
|
+
if (this.cacheRecords.length < this.maxCanvases) {
|
16
|
+
const record = new CacheRecord(onDealloc, this.cacheState);
|
17
|
+
record.setRenderingRegion(drawTo);
|
18
|
+
this.cacheRecords.push(record);
|
19
|
+
if (debugMode) {
|
20
|
+
console.log('[Cache] Cache spaces used: ', this.cacheRecords.length, ' of ', this.maxCanvases);
|
21
|
+
}
|
22
|
+
return record;
|
23
|
+
}
|
24
|
+
else {
|
25
|
+
const lru = this.getLeastRecentlyUsedRecord();
|
26
|
+
if (debugMode) {
|
27
|
+
console.log('[Cache] Re-alloc. Times allocated: ', lru.allocCount, '\nLast used cycle: ', lru.getLastUsedCycle(), '\nCurrent cycle: ', this.cacheState.currentRenderingCycle);
|
28
|
+
}
|
29
|
+
lru.realloc(onDealloc);
|
30
|
+
lru.setRenderingRegion(drawTo);
|
31
|
+
if (debugMode) {
|
32
|
+
console.log('[Cache] Now re-alloc\'d. Last used cycle: ', lru.getLastUsedCycle());
|
33
|
+
console.assert(lru['cacheState'] === this.cacheState, '[Cache] Unequal cache states! cacheState should be a shared object!');
|
34
|
+
}
|
35
|
+
return lru;
|
36
|
+
}
|
37
|
+
}
|
38
|
+
// Returns null if there are no cache records. Returns an unalloc'd record if one exists.
|
39
|
+
getLeastRecentlyUsedRecord() {
|
40
|
+
this.cacheRecords.sort((a, b) => a.getLastUsedCycle() - b.getLastUsedCycle());
|
41
|
+
return this.cacheRecords[0];
|
42
|
+
}
|
43
|
+
}
|