js-draw 0.17.3 → 0.18.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/.github/workflows/firebase-hosting-merge.yml +2 -0
- package/.github/workflows/firebase-hosting-pull-request.yml +2 -0
- package/.github/workflows/github-pages.yml +2 -0
- package/CHANGELOG.md +10 -1
- package/README.md +17 -8
- package/build_tools/postDist.ts +71 -0
- package/dist/bundle.js +9 -1
- package/dist/cjs/build_tools/BundledFile.js +163 -0
- package/dist/cjs/build_tools/buildTranslationTemplate.js +119 -0
- package/dist/cjs/build_tools/bundle.js +10 -0
- package/dist/cjs/build_tools/postDist.js +72 -0
- package/dist/{src → cjs/src}/Color4.d.ts +1 -0
- package/dist/cjs/src/Color4.js +197 -0
- package/dist/{src → cjs/src}/Editor.d.ts +57 -1
- package/dist/cjs/src/Editor.js +904 -0
- package/dist/{src → cjs/src}/EditorImage.d.ts +4 -2
- package/dist/cjs/src/EditorImage.js +486 -0
- package/dist/cjs/src/EventDispatcher.js +57 -0
- package/dist/cjs/src/Pointer.js +84 -0
- package/dist/{src → cjs/src}/SVGLoader.d.ts +4 -0
- package/dist/cjs/src/SVGLoader.js +472 -0
- package/dist/cjs/src/UndoRedoHistory.js +93 -0
- package/dist/cjs/src/Viewport.js +264 -0
- package/dist/cjs/src/bundle/bundled.js +24 -0
- package/dist/cjs/src/commands/Command.js +34 -0
- package/dist/cjs/src/commands/Duplicate.js +39 -0
- package/dist/cjs/src/commands/Erase.js +63 -0
- package/dist/cjs/src/commands/SerializableCommand.js +42 -0
- package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
- package/dist/cjs/src/commands/invertCommand.js +49 -0
- package/dist/cjs/src/commands/lib.js +18 -0
- package/dist/cjs/src/commands/localization.js +24 -0
- package/dist/cjs/src/commands/uniteCommands.js +121 -0
- package/dist/cjs/src/components/AbstractComponent.js +258 -0
- package/dist/cjs/src/components/ImageBackground.js +146 -0
- package/dist/cjs/src/components/ImageComponent.js +152 -0
- package/dist/cjs/src/components/RestylableComponent.js +88 -0
- package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
- package/dist/cjs/src/components/Stroke.js +191 -0
- package/dist/cjs/src/components/TextComponent.js +258 -0
- package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
- package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
- package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
- package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
- package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
- package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
- package/dist/cjs/src/components/builders/types.js +2 -0
- package/dist/cjs/src/components/lib.js +43 -0
- package/dist/cjs/src/components/localization.js +13 -0
- package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
- package/dist/cjs/src/components/util/describeComponentList.js +16 -0
- package/dist/{src → cjs/src}/lib.d.ts +2 -1
- package/dist/cjs/src/lib.js +63 -0
- package/dist/cjs/src/localization.js +13 -0
- package/dist/cjs/src/localizations/de.js +6 -0
- package/dist/cjs/src/localizations/en.js +6 -0
- package/dist/cjs/src/localizations/es.js +20 -0
- package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
- package/dist/cjs/src/math/LineSegment2.js +131 -0
- package/dist/cjs/src/math/Mat33.js +332 -0
- package/dist/cjs/src/math/Path.js +655 -0
- package/dist/cjs/src/math/Rect2.js +234 -0
- package/dist/cjs/src/math/Triangle.js +22 -0
- package/dist/cjs/src/math/Vec2.js +19 -0
- package/dist/cjs/src/math/Vec3.js +177 -0
- package/dist/cjs/src/math/lib.js +18 -0
- package/dist/cjs/src/math/rounding.js +135 -0
- package/dist/cjs/src/rendering/Display.js +214 -0
- package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
- package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
- package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
- package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
- package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
- package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
- package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
- package/dist/cjs/src/rendering/caching/types.js +2 -0
- package/dist/{src → cjs/src}/rendering/lib.d.ts +2 -0
- package/dist/cjs/src/rendering/lib.js +16 -0
- package/dist/cjs/src/rendering/localization.js +12 -0
- package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
- package/dist/{src → cjs/src}/rendering/renderers/CanvasRenderer.d.ts +25 -0
- package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
- package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
- package/dist/{src → cjs/src}/rendering/renderers/SVGRenderer.d.ts +15 -0
- package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
- package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
- package/dist/cjs/src/testing/beforeEachFile.js +12 -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.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.js +383 -0
- package/dist/cjs/src/toolbar/IconProvider.js +660 -0
- package/dist/cjs/src/toolbar/lib.js +24 -0
- package/dist/cjs/src/toolbar/localization.js +51 -0
- package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
- package/dist/cjs/src/toolbar/types.js +2 -0
- package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
- package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
- package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
- package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
- package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
- package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
- package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
- package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
- package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
- package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
- package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
- package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
- package/dist/cjs/src/tools/BaseTool.js +66 -0
- package/dist/cjs/src/tools/Eraser.js +112 -0
- package/dist/cjs/src/tools/FindTool.js +121 -0
- package/dist/cjs/src/tools/PanZoom.js +421 -0
- package/dist/cjs/src/tools/PasteHandler.js +99 -0
- package/dist/cjs/src/tools/Pen.js +179 -0
- package/dist/cjs/src/tools/PipetteTool.js +45 -0
- package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
- package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
- package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
- package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
- package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
- package/dist/cjs/src/tools/TextTool.js +262 -0
- package/dist/cjs/src/tools/ToolController.js +187 -0
- package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
- package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
- package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
- package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
- package/dist/cjs/src/tools/lib.js +36 -0
- package/dist/cjs/src/tools/localization.js +30 -0
- package/dist/cjs/src/types.js +38 -0
- package/dist/cjs/src/util/assertions.js +51 -0
- package/dist/cjs/src/util/fileToBase64.js +15 -0
- package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
- package/dist/cjs/src/util/waitForTimeout.js +9 -0
- package/dist/mjs/build_tools/BundledFile.d.ts +13 -0
- package/dist/{build_tools/buildTranslationTemplate.js → mjs/build_tools/buildTranslationTemplate.mjs} +1 -1
- package/dist/{build_tools/bundle.js → mjs/build_tools/bundle.mjs} +1 -1
- package/dist/mjs/build_tools/postDist.d.ts +1 -0
- package/dist/mjs/build_tools/postDist.mjs +67 -0
- package/dist/mjs/src/Color4.d.ts +61 -0
- package/dist/{src/Color4.js → mjs/src/Color4.mjs} +1 -0
- package/dist/mjs/src/Editor.d.ts +308 -0
- package/dist/{src/Editor.js → mjs/src/Editor.mjs} +86 -49
- package/dist/mjs/src/EditorImage.d.ts +97 -0
- package/dist/{src/EditorImage.js → mjs/src/EditorImage.mjs} +12 -10
- package/dist/mjs/src/EventDispatcher.d.ts +30 -0
- package/dist/mjs/src/Pointer.d.ts +24 -0
- package/dist/{src/Pointer.js → mjs/src/Pointer.mjs} +1 -1
- package/dist/mjs/src/SVGLoader.d.ts +48 -0
- package/dist/{src/SVGLoader.js → mjs/src/SVGLoader.mjs} +15 -11
- package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
- package/dist/{src/UndoRedoHistory.js → mjs/src/UndoRedoHistory.mjs} +1 -1
- package/dist/mjs/src/Viewport.d.ts +71 -0
- package/dist/{src/Viewport.js → mjs/src/Viewport.mjs} +5 -5
- package/dist/mjs/src/bundle/bundled.d.ts +4 -0
- package/dist/{src/bundle/bundled.js → mjs/src/bundle/bundled.mjs} +2 -2
- package/dist/mjs/src/commands/Command.d.ts +16 -0
- package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
- package/dist/{src/commands/Duplicate.js → mjs/src/commands/Duplicate.mjs} +3 -3
- package/dist/mjs/src/commands/Erase.d.ts +14 -0
- package/dist/{src/commands/Erase.js → mjs/src/commands/Erase.mjs} +3 -3
- package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
- package/dist/{src/commands/SerializableCommand.js → mjs/src/commands/SerializableCommand.mjs} +1 -1
- package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
- package/dist/{src/commands/UnresolvedCommand.js → mjs/src/commands/UnresolvedCommand.mjs} +1 -1
- package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
- package/dist/{src/commands/invertCommand.js → mjs/src/commands/invertCommand.mjs} +2 -2
- package/dist/mjs/src/commands/lib.mjs +7 -0
- package/dist/mjs/src/commands/localization.d.ts +23 -0
- package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
- package/dist/{src/commands/uniteCommands.js → mjs/src/commands/uniteCommands.mjs} +2 -2
- package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
- package/dist/{src/components/AbstractComponent.js → mjs/src/components/AbstractComponent.mjs} +4 -4
- package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
- package/dist/{src/components/ImageBackground.js → mjs/src/components/ImageBackground.mjs} +5 -5
- package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
- package/dist/{src/components/ImageComponent.js → mjs/src/components/ImageComponent.mjs} +3 -3
- package/dist/mjs/src/components/RestylableComponent.d.ts +24 -0
- package/dist/{src/components/RestylableComponent.js → mjs/src/components/RestylableComponent.mjs} +4 -4
- package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
- package/dist/{src/components/SVGGlobalAttributesObject.js → mjs/src/components/SVGGlobalAttributesObject.mjs} +3 -3
- package/dist/mjs/src/components/Stroke.d.ts +40 -0
- package/dist/{src/components/Stroke.js → mjs/src/components/Stroke.mjs} +5 -5
- package/dist/mjs/src/components/TextComponent.d.ts +53 -0
- package/dist/{src/components/TextComponent.js → mjs/src/components/TextComponent.mjs} +7 -7
- package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
- package/dist/{src/components/UnknownSVGObject.js → mjs/src/components/UnknownSVGObject.mjs} +3 -3
- package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
- package/dist/{src/components/builders/ArrowBuilder.js → mjs/src/components/builders/ArrowBuilder.mjs} +2 -2
- package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
- package/dist/{src/components/builders/FreehandLineBuilder.js → mjs/src/components/builders/FreehandLineBuilder.mjs} +7 -7
- package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
- package/dist/{src/components/builders/LineBuilder.js → mjs/src/components/builders/LineBuilder.mjs} +2 -2
- package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
- package/dist/{src/components/builders/PressureSensitiveFreehandLineBuilder.js → mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs} +6 -6
- package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
- package/dist/{src/components/builders/RectangleBuilder.js → mjs/src/components/builders/RectangleBuilder.mjs} +4 -4
- package/dist/mjs/src/components/builders/types.d.ts +12 -0
- package/dist/mjs/src/components/builders/types.mjs +1 -0
- package/dist/{src/components/lib.js → mjs/src/components/lib.d.ts} +3 -3
- package/dist/mjs/src/components/lib.mjs +12 -0
- package/dist/mjs/src/components/localization.d.ts +11 -0
- package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
- package/dist/{src/components/util/StrokeSmoother.js → mjs/src/components/util/StrokeSmoother.mjs} +3 -3
- package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
- package/dist/{src/lib.js → mjs/src/lib.d.ts} +4 -3
- package/dist/mjs/src/lib.mjs +34 -0
- package/dist/mjs/src/localization.d.ts +14 -0
- package/dist/{src/localization.js → mjs/src/localization.mjs} +5 -5
- package/dist/mjs/src/localizations/de.d.ts +3 -0
- package/dist/{src/localizations/de.js → mjs/src/localizations/de.mjs} +1 -1
- package/dist/mjs/src/localizations/en.d.ts +3 -0
- package/dist/{src/localizations/en.js → mjs/src/localizations/en.mjs} +1 -1
- package/dist/mjs/src/localizations/es.d.ts +3 -0
- package/dist/{src/localizations/es.js → mjs/src/localizations/es.mjs} +1 -1
- package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
- package/dist/{src/localizations/getLocalizationTable.js → mjs/src/localizations/getLocalizationTable.mjs} +4 -4
- package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
- package/dist/{src/math/LineSegment2.js → mjs/src/math/LineSegment2.mjs} +2 -2
- package/dist/mjs/src/math/Mat33.d.ts +118 -0
- package/dist/{src/math/Mat33.js → mjs/src/math/Mat33.mjs} +2 -2
- package/dist/mjs/src/math/Path.d.ts +71 -0
- package/dist/{src/math/Path.js → mjs/src/math/Path.mjs} +5 -5
- package/dist/mjs/src/math/Rect2.d.ts +52 -0
- package/dist/{src/math/Rect2.js → mjs/src/math/Rect2.mjs} +2 -2
- package/dist/mjs/src/math/Triangle.d.ts +11 -0
- package/dist/mjs/src/math/Vec2.d.ts +13 -0
- package/dist/{src/math/Vec2.js → mjs/src/math/Vec2.mjs} +1 -1
- package/dist/mjs/src/math/Vec3.d.ts +106 -0
- package/dist/mjs/src/math/lib.mjs +7 -0
- package/dist/mjs/src/math/rounding.d.ts +4 -0
- package/dist/mjs/src/rendering/Display.d.ts +75 -0
- package/dist/{src/rendering/Display.js → mjs/src/rendering/Display.mjs} +7 -7
- package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
- package/dist/{src/rendering/RenderingStyle.js → mjs/src/rendering/RenderingStyle.mjs} +1 -1
- package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
- package/dist/{src/rendering/TextRenderingStyle.js → mjs/src/rendering/TextRenderingStyle.mjs} +1 -1
- package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
- package/dist/{src/rendering/caching/CacheRecord.js → mjs/src/rendering/caching/CacheRecord.mjs} +1 -1
- package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
- package/dist/{src/rendering/caching/CacheRecordManager.js → mjs/src/rendering/caching/CacheRecordManager.mjs} +1 -1
- package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
- package/dist/{src/rendering/caching/RenderingCache.js → mjs/src/rendering/caching/RenderingCache.mjs} +3 -3
- package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
- package/dist/{src/rendering/caching/RenderingCacheNode.js → mjs/src/rendering/caching/RenderingCacheNode.mjs} +3 -3
- package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
- package/dist/{src/rendering/caching/testUtils.js → mjs/src/rendering/caching/testUtils.mjs} +4 -4
- package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
- package/dist/mjs/src/rendering/caching/types.mjs +1 -0
- package/dist/{src/rendering/lib.js → mjs/src/rendering/lib.d.ts} +2 -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/renderers/AbstractRenderer.d.ts +68 -0
- package/dist/{src/rendering/renderers/AbstractRenderer.js → mjs/src/rendering/renderers/AbstractRenderer.mjs} +3 -3
- package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
- package/dist/{src/rendering/renderers/CanvasRenderer.js → mjs/src/rendering/renderers/CanvasRenderer.mjs} +32 -5
- package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
- package/dist/{src/rendering/renderers/DummyRenderer.js → mjs/src/rendering/renderers/DummyRenderer.mjs} +2 -2
- package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
- package/dist/{src/rendering/renderers/SVGRenderer.js → mjs/src/rendering/renderers/SVGRenderer.mjs} +33 -7
- package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
- package/dist/{src/rendering/renderers/TextOnlyRenderer.js → mjs/src/rendering/renderers/TextOnlyRenderer.mjs} +2 -2
- package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
- package/dist/{src/testing/beforeEachFile.js → mjs/src/testing/beforeEachFile.mjs} +1 -1
- package/dist/mjs/src/testing/createEditor.d.ts +4 -0
- package/dist/{src/testing/createEditor.js → mjs/src/testing/createEditor.mjs} +2 -2
- 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/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/{src/toolbar/HTMLToolbar.js → mjs/src/toolbar/HTMLToolbar.mjs} +17 -17
- package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
- package/dist/{src/toolbar/IconProvider.js → mjs/src/toolbar/IconProvider.mjs} +4 -4
- package/dist/mjs/src/toolbar/lib.mjs +3 -0
- package/dist/mjs/src/toolbar/localization.d.ts +49 -0
- package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
- package/dist/{src/toolbar/makeColorInput.js → mjs/src/toolbar/makeColorInput.mjs} +3 -3
- 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/{src/toolbar/widgets/ActionButtonWidget.js → mjs/src/toolbar/widgets/ActionButtonWidget.mjs} +1 -1
- package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
- package/dist/{src/toolbar/widgets/BaseToolWidget.js → mjs/src/toolbar/widgets/BaseToolWidget.mjs} +2 -2
- package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
- package/dist/{src/toolbar/widgets/BaseWidget.js → mjs/src/toolbar/widgets/BaseWidget.mjs} +3 -3
- package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
- package/dist/{src/toolbar/widgets/DocumentPropertiesWidget.js → mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs} +9 -7
- package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
- package/dist/{src/toolbar/widgets/EraserToolWidget.js → mjs/src/toolbar/widgets/EraserToolWidget.mjs} +3 -3
- package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
- package/dist/{src/toolbar/widgets/HandToolWidget.js → mjs/src/toolbar/widgets/HandToolWidget.mjs} +7 -7
- package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
- package/dist/{src/toolbar/widgets/InsertImageWidget.js → mjs/src/toolbar/widgets/InsertImageWidget.mjs} +8 -8
- package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
- package/dist/{src/toolbar/widgets/OverflowWidget.js → mjs/src/toolbar/widgets/OverflowWidget.mjs} +1 -1
- package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
- package/dist/{src/toolbar/widgets/PenToolWidget.js → mjs/src/toolbar/widgets/PenToolWidget.mjs} +11 -10
- package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
- package/dist/{src/toolbar/widgets/SelectionToolWidget.js → mjs/src/toolbar/widgets/SelectionToolWidget.mjs} +8 -8
- package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
- package/dist/{src/toolbar/widgets/TextToolWidget.js → mjs/src/toolbar/widgets/TextToolWidget.mjs} +9 -6
- package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
- package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
- package/dist/{src/tools/BaseTool.js → mjs/src/tools/BaseTool.mjs} +1 -1
- package/dist/mjs/src/tools/Eraser.d.ts +23 -0
- package/dist/{src/tools/Eraser.js → mjs/src/tools/Eraser.mjs} +8 -8
- package/dist/mjs/src/tools/FindTool.d.ts +21 -0
- package/dist/{src/tools/FindTool.js → mjs/src/tools/FindTool.mjs} +2 -2
- package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
- package/dist/{src/tools/PanZoom.js → mjs/src/tools/PanZoom.mjs} +8 -8
- package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
- package/dist/{src/tools/PasteHandler.js → mjs/src/tools/PasteHandler.mjs} +7 -7
- package/dist/mjs/src/tools/Pen.d.ts +39 -0
- package/dist/{src/tools/Pen.js → mjs/src/tools/Pen.mjs} +5 -5
- package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
- package/dist/{src/tools/PipetteTool.js → mjs/src/tools/PipetteTool.mjs} +1 -1
- package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
- package/dist/{src/tools/SelectionTool/SelectAllShortcutHandler.js → mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs} +2 -2
- package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
- package/dist/{src/tools/SelectionTool/Selection.js → mjs/src/tools/SelectionTool/Selection.mjs} +12 -12
- package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
- package/dist/{src/tools/SelectionTool/SelectionHandle.js → mjs/src/tools/SelectionTool/SelectionHandle.mjs} +3 -3
- package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
- package/dist/{src/tools/SelectionTool/SelectionTool.js → mjs/src/tools/SelectionTool/SelectionTool.mjs} +13 -14
- package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
- package/dist/{src/tools/SelectionTool/TransformMode.js → mjs/src/tools/SelectionTool/TransformMode.mjs} +4 -4
- package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
- package/dist/mjs/src/tools/TextTool.d.ts +33 -0
- package/dist/{src/tools/TextTool.js → mjs/src/tools/TextTool.mjs} +11 -11
- package/dist/mjs/src/tools/ToolController.d.ts +18 -0
- package/dist/{src/tools/ToolController.js → mjs/src/tools/ToolController.mjs} +16 -16
- package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
- package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
- package/dist/{src/tools/ToolSwitcherShortcut.js → mjs/src/tools/ToolSwitcherShortcut.mjs} +1 -1
- package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
- package/dist/{src/tools/ToolbarShortcutHandler.js → mjs/src/tools/ToolbarShortcutHandler.mjs} +1 -1
- package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
- package/dist/{src/tools/UndoRedoShortcut.js → mjs/src/tools/UndoRedoShortcut.mjs} +1 -1
- package/dist/{src/tools/lib.js → mjs/src/tools/lib.d.ts} +1 -1
- package/dist/mjs/src/tools/lib.mjs +16 -0
- package/dist/mjs/src/tools/localization.d.ts +28 -0
- package/dist/mjs/src/types.d.ts +151 -0
- package/dist/mjs/src/util/assertions.d.ts +23 -0
- package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
- package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
- package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
- package/package.json +34 -33
- package/src/Color4.ts +2 -0
- package/src/Editor.ts +62 -28
- package/src/EditorImage.ts +4 -2
- package/src/SVGLoader.ts +4 -0
- package/src/lib.ts +2 -1
- package/src/rendering/lib.ts +2 -0
- package/src/rendering/renderers/CanvasRenderer.ts +27 -0
- package/src/rendering/renderers/SVGRenderer.ts +32 -1
- package/src/testing/lib.ts +3 -0
- package/src/testing/sendPenEvent.ts +31 -0
- package/src/testing/sendTouchEvent.ts +36 -1
- package/src/toolbar/toolbar.css +5 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +4 -2
- package/src/toolbar/widgets/PenToolWidget.ts +1 -0
- package/src/toolbar/widgets/TextToolWidget.ts +4 -1
- package/src/tools/Eraser.test.ts +11 -10
- package/src/tools/PanZoom.test.ts +1 -1
- package/src/tools/Pen.test.ts +63 -62
- package/src/tools/SelectionTool/SelectionTool.test.ts +15 -14
- package/src/tools/SelectionTool/SelectionTool.ts +5 -7
- package/tsconfig.json +3 -2
- package/tsconfig.mjs.json +9 -0
- package/dist/src/testing/sendTouchEvent.d.ts +0 -6
- package/dist/src/testing/sendTouchEvent.js +0 -26
- /package/dist/{build_tools → cjs/build_tools}/BundledFile.d.ts +0 -0
- /package/dist/{build_tools → cjs/build_tools}/buildTranslationTemplate.d.ts +0 -0
- /package/dist/{build_tools → cjs/build_tools}/bundle.d.ts +0 -0
- /package/dist/{src/components/builders/types.js → cjs/build_tools/postDist.d.ts} +0 -0
- /package/dist/{src → cjs/src}/EventDispatcher.d.ts +0 -0
- /package/dist/{src → cjs/src}/Pointer.d.ts +0 -0
- /package/dist/{src → cjs/src}/UndoRedoHistory.d.ts +0 -0
- /package/dist/{src → cjs/src}/Viewport.d.ts +0 -0
- /package/dist/{src → cjs/src}/bundle/bundled.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/Command.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/Duplicate.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/Erase.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/SerializableCommand.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/UnresolvedCommand.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/invertCommand.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/commands/uniteCommands.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/AbstractComponent.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/ImageBackground.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/ImageComponent.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/RestylableComponent.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/SVGGlobalAttributesObject.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/Stroke.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/TextComponent.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/UnknownSVGObject.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/ArrowBuilder.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/FreehandLineBuilder.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/LineBuilder.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/RectangleBuilder.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/builders/types.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/util/StrokeSmoother.d.ts +0 -0
- /package/dist/{src → cjs/src}/components/util/describeComponentList.d.ts +0 -0
- /package/dist/{src → cjs/src}/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/localizations/de.d.ts +0 -0
- /package/dist/{src → cjs/src}/localizations/en.d.ts +0 -0
- /package/dist/{src → cjs/src}/localizations/es.d.ts +0 -0
- /package/dist/{src → cjs/src}/localizations/getLocalizationTable.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/LineSegment2.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Mat33.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Path.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Rect2.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Triangle.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Vec2.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/Vec3.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/math/rounding.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/Display.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/RenderingStyle.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/TextRenderingStyle.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/CacheRecord.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/CacheRecordManager.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/RenderingCache.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/RenderingCacheNode.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/testUtils.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/caching/types.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/renderers/AbstractRenderer.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/renderers/DummyRenderer.d.ts +0 -0
- /package/dist/{src → cjs/src}/rendering/renderers/TextOnlyRenderer.d.ts +0 -0
- /package/dist/{src → cjs/src}/testing/beforeEachFile.d.ts +0 -0
- /package/dist/{src → cjs/src}/testing/createEditor.d.ts +0 -0
- /package/dist/{src → cjs/src}/testing/loadExpectExtensions.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/HTMLToolbar.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/IconProvider.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/makeColorInput.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/types.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/ActionButtonWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/BaseToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/BaseWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/DocumentPropertiesWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/EraserToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/HandToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/InsertImageWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/OverflowWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/PenToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/SelectionToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/TextToolWidget.d.ts +0 -0
- /package/dist/{src → cjs/src}/toolbar/widgets/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/BaseTool.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/Eraser.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/FindTool.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/PanZoom.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/PasteHandler.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/Pen.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/PipetteTool.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/SelectAllShortcutHandler.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/Selection.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/SelectionHandle.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/SelectionTool.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/TransformMode.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/SelectionTool/types.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/TextTool.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/ToolController.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/ToolEnabledGroup.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/ToolSwitcherShortcut.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/ToolbarShortcutHandler.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/UndoRedoShortcut.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/lib.d.ts +0 -0
- /package/dist/{src → cjs/src}/tools/localization.d.ts +0 -0
- /package/dist/{src → cjs/src}/types.d.ts +0 -0
- /package/dist/{src → cjs/src}/util/assertions.d.ts +0 -0
- /package/dist/{src → cjs/src}/util/fileToBase64.d.ts +0 -0
- /package/dist/{src → cjs/src}/util/untilNextAnimationFrame.d.ts +0 -0
- /package/dist/{src → cjs/src}/util/waitForTimeout.d.ts +0 -0
- /package/dist/{build_tools/BundledFile.js → mjs/build_tools/BundledFile.mjs} +0 -0
- /package/dist/{src/rendering/caching/types.js → mjs/build_tools/buildTranslationTemplate.d.ts} +0 -0
- /package/dist/{src/toolbar/types.js → mjs/build_tools/bundle.d.ts} +0 -0
- /package/dist/{src/EventDispatcher.js → mjs/src/EventDispatcher.mjs} +0 -0
- /package/dist/{src/commands/Command.js → mjs/src/commands/Command.mjs} +0 -0
- /package/dist/{src/commands/lib.js → mjs/src/commands/lib.d.ts} +0 -0
- /package/dist/{src/commands/localization.js → mjs/src/commands/localization.mjs} +0 -0
- /package/dist/{src/components/localization.js → mjs/src/components/localization.mjs} +0 -0
- /package/dist/{src/components/util/describeComponentList.js → mjs/src/components/util/describeComponentList.mjs} +0 -0
- /package/dist/{src/math/Triangle.js → mjs/src/math/Triangle.mjs} +0 -0
- /package/dist/{src/math/Vec3.js → mjs/src/math/Vec3.mjs} +0 -0
- /package/dist/{src/math/lib.js → mjs/src/math/lib.d.ts} +0 -0
- /package/dist/{src/math/rounding.js → mjs/src/math/rounding.mjs} +0 -0
- /package/dist/{src/rendering/localization.js → mjs/src/rendering/localization.mjs} +0 -0
- /package/dist/{src/testing/loadExpectExtensions.js → mjs/src/testing/loadExpectExtensions.mjs} +0 -0
- /package/dist/{src/toolbar/lib.js → mjs/src/toolbar/lib.d.ts} +0 -0
- /package/dist/{src/toolbar/localization.js → mjs/src/toolbar/localization.mjs} +0 -0
- /package/dist/{src/toolbar/widgets/lib.js → mjs/src/toolbar/widgets/lib.d.ts} +0 -0
- /package/dist/{src/tools/SelectionTool/types.js → mjs/src/tools/SelectionTool/types.mjs} +0 -0
- /package/dist/{src/tools/ToolEnabledGroup.js → mjs/src/tools/ToolEnabledGroup.mjs} +0 -0
- /package/dist/{src/tools/localization.js → mjs/src/tools/localization.mjs} +0 -0
- /package/dist/{src/types.js → mjs/src/types.mjs} +0 -0
- /package/dist/{src/util/assertions.js → mjs/src/util/assertions.mjs} +0 -0
- /package/dist/{src/util/fileToBase64.js → mjs/src/util/fileToBase64.mjs} +0 -0
- /package/dist/{src/util/untilNextAnimationFrame.js → mjs/src/util/untilNextAnimationFrame.mjs} +0 -0
- /package/dist/{src/util/waitForTimeout.js → mjs/src/util/waitForTimeout.mjs} +0 -0
@@ -0,0 +1,326 @@
|
|
1
|
+
"use strict";
|
2
|
+
// A cache record with sub-nodes.
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
5
|
+
};
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
7
|
+
const Color4_1 = __importDefault(require("../../Color4"));
|
8
|
+
const EditorImage_1 = require("../../EditorImage");
|
9
|
+
const Rect2_1 = __importDefault(require("../../math/Rect2"));
|
10
|
+
// 3x3 divisions for each node.
|
11
|
+
const cacheDivisionSize = 3;
|
12
|
+
// True: Show rendering updates.
|
13
|
+
const debugMode = false;
|
14
|
+
class RenderingCacheNode {
|
15
|
+
constructor(region, cacheState) {
|
16
|
+
this.region = region;
|
17
|
+
this.cacheState = cacheState;
|
18
|
+
// invariant: instantiatedChildren.length === 9
|
19
|
+
this.instantiatedChildren = [];
|
20
|
+
this.parent = null;
|
21
|
+
this.cachedRenderer = null;
|
22
|
+
// invariant: sortedInAscendingOrder(renderedIds)
|
23
|
+
this.renderedIds = [];
|
24
|
+
this.renderedMaxZIndex = null;
|
25
|
+
}
|
26
|
+
// Creates a previous layer of the cache tree and adds this as a child near the
|
27
|
+
// center of the previous layer's children.
|
28
|
+
// Returns this' parent if it already exists.
|
29
|
+
generateParent() {
|
30
|
+
if (this.parent) {
|
31
|
+
return this.parent;
|
32
|
+
}
|
33
|
+
const parentRegion = Rect2_1.default.fromCorners(this.region.topLeft.minus(this.region.size), this.region.bottomRight.plus(this.region.size));
|
34
|
+
const parent = new RenderingCacheNode(parentRegion, this.cacheState);
|
35
|
+
parent.generateChildren();
|
36
|
+
// Ensure the new node is matches the middle child's region.
|
37
|
+
const checkTolerance = this.region.maxDimension / 100;
|
38
|
+
const middleChildIdx = (parent.instantiatedChildren.length - 1) / 2;
|
39
|
+
if (!parent.instantiatedChildren[middleChildIdx].region.eq(this.region, checkTolerance)) {
|
40
|
+
console.error(parent.instantiatedChildren[middleChildIdx].region, '≠', this.region);
|
41
|
+
throw new Error('Logic error: [this] is not contained within its parent\'s center child');
|
42
|
+
}
|
43
|
+
// Replace the middle child
|
44
|
+
parent.instantiatedChildren[middleChildIdx] = this;
|
45
|
+
this.parent = parent;
|
46
|
+
return parent;
|
47
|
+
}
|
48
|
+
// Generates children, if missing.
|
49
|
+
generateChildren() {
|
50
|
+
if (this.instantiatedChildren.length === 0) {
|
51
|
+
const childRects = this.region.divideIntoGrid(cacheDivisionSize, cacheDivisionSize);
|
52
|
+
if (this.region.size.x === 0 || this.region.size.y === 0) {
|
53
|
+
console.warn('Cache element has zero size! Not generating children.');
|
54
|
+
return;
|
55
|
+
}
|
56
|
+
for (const rect of childRects) {
|
57
|
+
const child = new RenderingCacheNode(rect, this.cacheState);
|
58
|
+
child.parent = this;
|
59
|
+
this.instantiatedChildren.push(child);
|
60
|
+
}
|
61
|
+
}
|
62
|
+
this.checkRep();
|
63
|
+
}
|
64
|
+
// Returns CacheNodes directly contained within this.
|
65
|
+
getChildren() {
|
66
|
+
this.checkRep();
|
67
|
+
this.generateChildren();
|
68
|
+
return this.instantiatedChildren;
|
69
|
+
}
|
70
|
+
smallestChildContaining(rect) {
|
71
|
+
var _a;
|
72
|
+
const largerThanChildren = rect.maxDimension > this.region.maxDimension / cacheDivisionSize;
|
73
|
+
if (!this.region.containsRect(rect) || largerThanChildren) {
|
74
|
+
return null;
|
75
|
+
}
|
76
|
+
for (const child of this.getChildren()) {
|
77
|
+
if (child.region.containsRect(rect)) {
|
78
|
+
return (_a = child.smallestChildContaining(rect)) !== null && _a !== void 0 ? _a : child;
|
79
|
+
}
|
80
|
+
}
|
81
|
+
return null;
|
82
|
+
}
|
83
|
+
// => [true] iff [this] can be rendered without too much scaling
|
84
|
+
renderingWouldBeHighEnoughResolution(viewport) {
|
85
|
+
// Determine how 1px in this corresponds to 1px on the canvas.
|
86
|
+
// this.region.w is in canvas units. Thus,
|
87
|
+
const sizeOfThisPixelOnCanvas = this.region.w / this.cacheState.props.blockResolution.x;
|
88
|
+
const sizeOfThisPixelOnScreen = viewport.getScaleFactor() * sizeOfThisPixelOnCanvas;
|
89
|
+
if (sizeOfThisPixelOnScreen > this.cacheState.props.maxScale) {
|
90
|
+
return false;
|
91
|
+
}
|
92
|
+
return true;
|
93
|
+
}
|
94
|
+
// => [true] if all children of this can be rendered from their caches.
|
95
|
+
allChildrenCanRender(viewport, leavesSortedById) {
|
96
|
+
if (this.instantiatedChildren.length === 0) {
|
97
|
+
return false;
|
98
|
+
}
|
99
|
+
for (const child of this.instantiatedChildren) {
|
100
|
+
if (!child.region.intersects(viewport.visibleRect)) {
|
101
|
+
continue;
|
102
|
+
}
|
103
|
+
if (!child.renderingIsUpToDate(this.idsOfIntersecting(leavesSortedById))) {
|
104
|
+
return false;
|
105
|
+
}
|
106
|
+
}
|
107
|
+
return true;
|
108
|
+
}
|
109
|
+
computeSortedByLeafIds(leaves) {
|
110
|
+
const ids = leaves.slice();
|
111
|
+
ids.sort((a, b) => a.getId() - b.getId());
|
112
|
+
return ids;
|
113
|
+
}
|
114
|
+
// Returns a list of the ids of the nodes intersecting this
|
115
|
+
idsOfIntersecting(nodes) {
|
116
|
+
const result = [];
|
117
|
+
for (const node of nodes) {
|
118
|
+
if (node.getBBox().intersects(this.region)) {
|
119
|
+
result.push(node.getId());
|
120
|
+
}
|
121
|
+
}
|
122
|
+
return result;
|
123
|
+
}
|
124
|
+
// Returns true iff all elems of this.renderedIds are in sortedIds.
|
125
|
+
// sortedIds should be sorted by z-index (or some other order, so long as they are
|
126
|
+
// sorted by the same thing as this.renderedIds.)
|
127
|
+
allRenderedIdsIn(sortedIds) {
|
128
|
+
if (this.renderedIds.length > sortedIds.length) {
|
129
|
+
return false;
|
130
|
+
}
|
131
|
+
for (let i = 0; i < this.renderedIds.length; i++) {
|
132
|
+
if (sortedIds[i] !== this.renderedIds[i]) {
|
133
|
+
return false;
|
134
|
+
}
|
135
|
+
}
|
136
|
+
return true;
|
137
|
+
}
|
138
|
+
renderingIsUpToDate(sortedIds) {
|
139
|
+
if (this.cachedRenderer === null || sortedIds.length !== this.renderedIds.length) {
|
140
|
+
return false;
|
141
|
+
}
|
142
|
+
return this.allRenderedIdsIn(sortedIds);
|
143
|
+
}
|
144
|
+
// Render all [items] within [viewport]
|
145
|
+
renderItems(screenRenderer, items, viewport) {
|
146
|
+
var _a, _b;
|
147
|
+
if (!viewport.visibleRect.intersects(this.region)
|
148
|
+
|| items.length === 0) {
|
149
|
+
return;
|
150
|
+
}
|
151
|
+
const newItems = [];
|
152
|
+
// Divide [items] until nodes are leaves or smaller than this
|
153
|
+
for (const item of items) {
|
154
|
+
const bbox = item.getBBox();
|
155
|
+
if (!bbox.intersects(this.region)) {
|
156
|
+
continue;
|
157
|
+
}
|
158
|
+
if (bbox.maxDimension >= this.region.maxDimension) {
|
159
|
+
newItems.push(...item.getChildrenOrSelfIntersectingRegion(this.region));
|
160
|
+
}
|
161
|
+
else {
|
162
|
+
newItems.push(item);
|
163
|
+
}
|
164
|
+
}
|
165
|
+
items = newItems;
|
166
|
+
// Can we cache at all?
|
167
|
+
if (!this.cacheState.props.isOfCorrectType(screenRenderer)) {
|
168
|
+
items.forEach(item => item.render(screenRenderer, viewport.visibleRect));
|
169
|
+
return;
|
170
|
+
}
|
171
|
+
if (debugMode) {
|
172
|
+
screenRenderer.drawRect(this.region, 0.5 * viewport.getSizeOfPixelOnCanvas(), { fill: Color4_1.default.yellow });
|
173
|
+
}
|
174
|
+
// Could we render direclty from [this] or do we need to recurse?
|
175
|
+
const couldRender = this.renderingWouldBeHighEnoughResolution(viewport);
|
176
|
+
if (!couldRender) {
|
177
|
+
for (const child of this.getChildren()) {
|
178
|
+
child.renderItems(screenRenderer, items.filter(item => {
|
179
|
+
return item.getBBox().intersects(child.region);
|
180
|
+
}), viewport);
|
181
|
+
}
|
182
|
+
}
|
183
|
+
else {
|
184
|
+
// Determine whether we already have rendered the items
|
185
|
+
const tooSmallToRender = (rect) => rect.w / this.region.w < 1 / this.cacheState.props.blockResolution.x;
|
186
|
+
const leaves = [];
|
187
|
+
for (const item of items) {
|
188
|
+
leaves.push(...item.getLeavesIntersectingRegion(this.region, tooSmallToRender));
|
189
|
+
}
|
190
|
+
(0, EditorImage_1.sortLeavesByZIndex)(leaves);
|
191
|
+
const leavesByIds = this.computeSortedByLeafIds(leaves);
|
192
|
+
// No intersecting leaves? No need to render
|
193
|
+
if (leavesByIds.length === 0) {
|
194
|
+
return;
|
195
|
+
}
|
196
|
+
const leafIds = leavesByIds.map(leaf => leaf.getId());
|
197
|
+
let thisRenderer;
|
198
|
+
if (!this.renderingIsUpToDate(leafIds)) {
|
199
|
+
if (this.allChildrenCanRender(viewport, leavesByIds)) {
|
200
|
+
for (const child of this.getChildren()) {
|
201
|
+
child.renderItems(screenRenderer, items, viewport);
|
202
|
+
}
|
203
|
+
return;
|
204
|
+
}
|
205
|
+
let leafApproxRenderTime = 0;
|
206
|
+
for (const leaf of leavesByIds) {
|
207
|
+
leafApproxRenderTime += leaf.getContent().getProportionalRenderingTime();
|
208
|
+
}
|
209
|
+
// Is it worth it to render the items?
|
210
|
+
if (leafApproxRenderTime > this.cacheState.props.minProportionalRenderTimePerCache) {
|
211
|
+
let fullRerenderNeeded = true;
|
212
|
+
if (!this.cachedRenderer) {
|
213
|
+
this.cachedRenderer = this.cacheState.recordManager.allocCanvas(this.region, () => this.onRegionDealloc());
|
214
|
+
}
|
215
|
+
else if (leavesByIds.length > this.renderedIds.length && this.allRenderedIdsIn(leafIds) && this.renderedMaxZIndex !== null) {
|
216
|
+
// We often don't need to do a full re-render even if something's changed.
|
217
|
+
// Check whether we can just draw on top of the existing cache.
|
218
|
+
const newLeaves = [];
|
219
|
+
let minNewZIndex = null;
|
220
|
+
for (let i = 0; i < leavesByIds.length; i++) {
|
221
|
+
const leaf = leavesByIds[i];
|
222
|
+
const content = leaf.getContent();
|
223
|
+
const zIndex = content.getZIndex();
|
224
|
+
if (i >= this.renderedIds.length || leaf.getId() !== this.renderedIds[i]) {
|
225
|
+
newLeaves.push(leaf);
|
226
|
+
if (minNewZIndex === null || zIndex < minNewZIndex) {
|
227
|
+
minNewZIndex = zIndex;
|
228
|
+
}
|
229
|
+
}
|
230
|
+
}
|
231
|
+
if (minNewZIndex !== null && minNewZIndex > this.renderedMaxZIndex) {
|
232
|
+
fullRerenderNeeded = false;
|
233
|
+
thisRenderer = this.cachedRenderer.startRender();
|
234
|
+
// Looping is faster than re-sorting.
|
235
|
+
for (let i = 0; i < leaves.length; i++) {
|
236
|
+
const leaf = leaves[i];
|
237
|
+
const zIndex = leaf.getContent().getZIndex();
|
238
|
+
if (zIndex > this.renderedMaxZIndex) {
|
239
|
+
leaf.render(thisRenderer, this.region);
|
240
|
+
this.renderedMaxZIndex = zIndex;
|
241
|
+
}
|
242
|
+
}
|
243
|
+
if (debugMode) {
|
244
|
+
screenRenderer.drawRect(this.region, viewport.getSizeOfPixelOnCanvas(), { fill: Color4_1.default.clay });
|
245
|
+
}
|
246
|
+
}
|
247
|
+
}
|
248
|
+
else if (debugMode) {
|
249
|
+
console.log('Decided on a full re-render. Reason: At least one of the following is false:', '\n leafIds.length > this.renderedIds.length: ', leafIds.length > this.renderedIds.length, '\n this.allRenderedIdsIn(leafIds): ', this.allRenderedIdsIn(leafIds), '\n this.renderedMaxZIndex !== null: ', this.renderedMaxZIndex !== null, '\n\nthis.rerenderedIds: ', this.renderedIds, ', leafIds: ', leafIds);
|
250
|
+
}
|
251
|
+
if (fullRerenderNeeded) {
|
252
|
+
thisRenderer = this.cachedRenderer.startRender();
|
253
|
+
thisRenderer.clear();
|
254
|
+
this.renderedMaxZIndex = null;
|
255
|
+
for (const leaf of leaves) {
|
256
|
+
const content = leaf.getContent();
|
257
|
+
(_a = this.renderedMaxZIndex) !== null && _a !== void 0 ? _a : (this.renderedMaxZIndex = content.getZIndex());
|
258
|
+
this.renderedMaxZIndex = Math.max(this.renderedMaxZIndex, content.getZIndex());
|
259
|
+
leaf.render(thisRenderer, this.region);
|
260
|
+
}
|
261
|
+
if (debugMode) {
|
262
|
+
screenRenderer.drawRect(this.region, viewport.getSizeOfPixelOnCanvas(), { fill: Color4_1.default.red });
|
263
|
+
}
|
264
|
+
}
|
265
|
+
this.renderedIds = leafIds;
|
266
|
+
}
|
267
|
+
else {
|
268
|
+
(_b = this.cachedRenderer) === null || _b === void 0 ? void 0 : _b.dealloc();
|
269
|
+
// Slightly increase the clip region to prevent seams.
|
270
|
+
// Divide by two because grownBy expands the rectangle on all sides.
|
271
|
+
const pixelSize = viewport.getSizeOfPixelOnCanvas();
|
272
|
+
const expandedRegion = new Rect2_1.default(this.region.x, this.region.y, this.region.w + pixelSize, this.region.h + pixelSize);
|
273
|
+
const clip = true;
|
274
|
+
screenRenderer.startObject(expandedRegion, clip);
|
275
|
+
for (const leaf of leaves) {
|
276
|
+
leaf.render(screenRenderer, this.region.intersection(viewport.visibleRect));
|
277
|
+
}
|
278
|
+
screenRenderer.endObject();
|
279
|
+
}
|
280
|
+
}
|
281
|
+
else {
|
282
|
+
thisRenderer = this.cachedRenderer.startRender();
|
283
|
+
}
|
284
|
+
if (thisRenderer) {
|
285
|
+
const transformMat = this.cachedRenderer.getTransform(this.region).inverse();
|
286
|
+
screenRenderer.renderFromOtherOfSameType(transformMat, thisRenderer);
|
287
|
+
}
|
288
|
+
// Can we clean up this' children? (Are they unused?)
|
289
|
+
if (this.instantiatedChildren.every(child => child.isEmpty())) {
|
290
|
+
this.instantiatedChildren = [];
|
291
|
+
}
|
292
|
+
}
|
293
|
+
this.checkRep();
|
294
|
+
}
|
295
|
+
// Returns true iff this/its children have no cached state.
|
296
|
+
isEmpty() {
|
297
|
+
if (this.cachedRenderer !== null) {
|
298
|
+
return false;
|
299
|
+
}
|
300
|
+
return this.instantiatedChildren.every(child => child.isEmpty());
|
301
|
+
}
|
302
|
+
onRegionDealloc() {
|
303
|
+
this.cachedRenderer = null;
|
304
|
+
if (this.isEmpty()) {
|
305
|
+
this.instantiatedChildren = [];
|
306
|
+
}
|
307
|
+
}
|
308
|
+
checkRep() {
|
309
|
+
if (this.instantiatedChildren.length !== cacheDivisionSize * cacheDivisionSize && this.instantiatedChildren.length !== 0) {
|
310
|
+
throw new Error(`Repcheck: Wrong number of children. Got ${this.instantiatedChildren.length}`);
|
311
|
+
}
|
312
|
+
if (this.renderedIds[1] !== undefined && this.renderedIds[0] >= this.renderedIds[1]) {
|
313
|
+
console.error(this.renderedIds);
|
314
|
+
throw new Error('Repcheck: First two ids are not in ascending order!');
|
315
|
+
}
|
316
|
+
for (const child of this.instantiatedChildren) {
|
317
|
+
if (child.parent !== this) {
|
318
|
+
throw new Error('Children should be linked to their parents!');
|
319
|
+
}
|
320
|
+
}
|
321
|
+
if (this.cachedRenderer && !this.cachedRenderer.isAllocd()) {
|
322
|
+
throw new Error('this\' cachedRenderer != null, but is dealloc\'d');
|
323
|
+
}
|
324
|
+
}
|
325
|
+
}
|
326
|
+
exports.default = RenderingCacheNode;
|
@@ -0,0 +1,27 @@
|
|
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
|
+
exports.createCache = void 0;
|
7
|
+
const Vec2_1 = require("../../math/Vec2");
|
8
|
+
const DummyRenderer_1 = __importDefault(require("../renderers/DummyRenderer"));
|
9
|
+
const createEditor_1 = __importDefault(require("../../testing/createEditor"));
|
10
|
+
const RenderingCache_1 = __importDefault(require("./RenderingCache"));
|
11
|
+
// Override any default test options with [cacheOptions]
|
12
|
+
const createCache = (onRenderAlloc, cacheOptions) => {
|
13
|
+
const editor = (0, createEditor_1.default)();
|
14
|
+
const cache = new RenderingCache_1.default(Object.assign({ createRenderer() {
|
15
|
+
const renderer = new DummyRenderer_1.default(editor.viewport);
|
16
|
+
onRenderAlloc === null || onRenderAlloc === void 0 ? void 0 : onRenderAlloc(renderer);
|
17
|
+
return renderer;
|
18
|
+
},
|
19
|
+
isOfCorrectType(renderer) {
|
20
|
+
return renderer instanceof DummyRenderer_1.default;
|
21
|
+
}, blockResolution: Vec2_1.Vec2.of(500, 500), cacheSize: 500 * 10 * 4, maxScale: 2, minProportionalRenderTimePerCache: 0, minProportionalRenderTimeToUseCache: 0 }, cacheOptions));
|
22
|
+
return {
|
23
|
+
cache,
|
24
|
+
editor
|
25
|
+
};
|
26
|
+
};
|
27
|
+
exports.createCache = createCache;
|
@@ -1,3 +1,5 @@
|
|
1
1
|
export { default as AbstractRenderer } from './renderers/AbstractRenderer';
|
2
2
|
export { default as DummyRenderer } from './renderers/DummyRenderer';
|
3
|
+
export { default as SVGRenderer } from './renderers/SVGRenderer';
|
4
|
+
export { default as CanvasRenderer } from './renderers/CanvasRenderer';
|
3
5
|
export { default as Display } from './Display';
|
@@ -0,0 +1,16 @@
|
|
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
|
+
exports.Display = exports.CanvasRenderer = exports.SVGRenderer = exports.DummyRenderer = exports.AbstractRenderer = void 0;
|
7
|
+
var AbstractRenderer_1 = require("./renderers/AbstractRenderer");
|
8
|
+
Object.defineProperty(exports, "AbstractRenderer", { enumerable: true, get: function () { return __importDefault(AbstractRenderer_1).default; } });
|
9
|
+
var DummyRenderer_1 = require("./renderers/DummyRenderer");
|
10
|
+
Object.defineProperty(exports, "DummyRenderer", { enumerable: true, get: function () { return __importDefault(DummyRenderer_1).default; } });
|
11
|
+
var SVGRenderer_1 = require("./renderers/SVGRenderer");
|
12
|
+
Object.defineProperty(exports, "SVGRenderer", { enumerable: true, get: function () { return __importDefault(SVGRenderer_1).default; } });
|
13
|
+
var CanvasRenderer_1 = require("./renderers/CanvasRenderer");
|
14
|
+
Object.defineProperty(exports, "CanvasRenderer", { enumerable: true, get: function () { return __importDefault(CanvasRenderer_1).default; } });
|
15
|
+
var Display_1 = require("./Display");
|
16
|
+
Object.defineProperty(exports, "Display", { enumerable: true, get: function () { return __importDefault(Display_1).default; } });
|
@@ -0,0 +1,12 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.defaultTextRendererLocalization = void 0;
|
4
|
+
exports.defaultTextRendererLocalization = {
|
5
|
+
pathNodeCount: (count) => `There are ${count} visible path objects.`,
|
6
|
+
textNodeCount: (count) => `There are ${count} visible text nodes.`,
|
7
|
+
imageNodeCount: (nodeCount) => `There are ${nodeCount} visible image nodes.`,
|
8
|
+
textNode: (content) => `Text: ${content}`,
|
9
|
+
imageNode: (label) => `Image: ${label}`,
|
10
|
+
unlabeledImageNode: 'Unlabeled image',
|
11
|
+
rerenderAsText: 'Re-render as text',
|
12
|
+
};
|
@@ -0,0 +1,170 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
26
|
+
const Path_1 = __importStar(require("../../math/Path"));
|
27
|
+
const Vec2_1 = require("../../math/Vec2");
|
28
|
+
const RenderingStyle_1 = require("../RenderingStyle");
|
29
|
+
class AbstractRenderer {
|
30
|
+
constructor(viewport) {
|
31
|
+
this.viewport = viewport;
|
32
|
+
// If null, this' transformation is linked to the Viewport
|
33
|
+
this.selfTransform = null;
|
34
|
+
this.transformStack = [];
|
35
|
+
this.objectLevel = 0;
|
36
|
+
this.currentPaths = null;
|
37
|
+
}
|
38
|
+
// this.canvasToScreen, etc. should be used instead of the corresponding
|
39
|
+
// methods on Viewport.
|
40
|
+
getViewport() { return this.viewport; }
|
41
|
+
setDraftMode(_draftMode) { }
|
42
|
+
flushPath() {
|
43
|
+
if (!this.currentPaths) {
|
44
|
+
return;
|
45
|
+
}
|
46
|
+
let lastStyle = null;
|
47
|
+
for (const path of this.currentPaths) {
|
48
|
+
const { startPoint, commands, style } = path;
|
49
|
+
if (!lastStyle || !(0, RenderingStyle_1.stylesEqual)(lastStyle, style)) {
|
50
|
+
if (lastStyle) {
|
51
|
+
this.endPath(lastStyle);
|
52
|
+
}
|
53
|
+
this.beginPath(startPoint);
|
54
|
+
lastStyle = style;
|
55
|
+
}
|
56
|
+
else {
|
57
|
+
this.moveTo(startPoint);
|
58
|
+
}
|
59
|
+
for (const command of commands) {
|
60
|
+
if (command.kind === Path_1.PathCommandType.LineTo) {
|
61
|
+
this.lineTo(command.point);
|
62
|
+
}
|
63
|
+
else if (command.kind === Path_1.PathCommandType.MoveTo) {
|
64
|
+
this.moveTo(command.point);
|
65
|
+
}
|
66
|
+
else if (command.kind === Path_1.PathCommandType.CubicBezierTo) {
|
67
|
+
this.traceCubicBezierCurve(command.controlPoint1, command.controlPoint2, command.endPoint);
|
68
|
+
}
|
69
|
+
else if (command.kind === Path_1.PathCommandType.QuadraticBezierTo) {
|
70
|
+
this.traceQuadraticBezierCurve(command.controlPoint, command.endPoint);
|
71
|
+
}
|
72
|
+
}
|
73
|
+
}
|
74
|
+
if (lastStyle) {
|
75
|
+
this.endPath(lastStyle);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
drawPath(path) {
|
79
|
+
// If we're being called outside of an object,
|
80
|
+
// we can't delay rendering
|
81
|
+
if (this.objectLevel === 0) {
|
82
|
+
this.currentPaths = [path];
|
83
|
+
this.flushPath();
|
84
|
+
this.currentPaths = null;
|
85
|
+
}
|
86
|
+
else {
|
87
|
+
// Otherwise, don't render paths all at once. This prevents faint lines between
|
88
|
+
// segments of the same stroke from being visible.
|
89
|
+
this.currentPaths.push(path);
|
90
|
+
}
|
91
|
+
}
|
92
|
+
// Strokes a rectangle. Boundary lines have width [lineWidth] and are filled with [lineFill].
|
93
|
+
// This is equivalent to `drawPath(Path.fromRect(...).toRenderable(...))`.
|
94
|
+
drawRect(rect, lineWidth, lineFill) {
|
95
|
+
const path = Path_1.default.fromRect(rect, lineWidth);
|
96
|
+
this.drawPath(path.toRenderable(lineFill));
|
97
|
+
}
|
98
|
+
// Fills a rectangle.
|
99
|
+
fillRect(rect, fill) {
|
100
|
+
const path = Path_1.default.fromRect(rect);
|
101
|
+
this.drawPath(path.toRenderable({ fill }));
|
102
|
+
}
|
103
|
+
// Note the start of an object with the given bounding box.
|
104
|
+
// Renderers are not required to support [clip]
|
105
|
+
startObject(_boundingBox, _clip) {
|
106
|
+
this.currentPaths = [];
|
107
|
+
this.objectLevel++;
|
108
|
+
}
|
109
|
+
/**
|
110
|
+
* Notes the end of an object.
|
111
|
+
* @param _loaderData - a map from strings to JSON-ifyable objects
|
112
|
+
* and contains properties attached to the object by whatever loader loaded the image. This
|
113
|
+
* is used to preserve attributes not supported by js-draw when loading/saving an image.
|
114
|
+
* Renderers may ignore this.
|
115
|
+
*
|
116
|
+
* @param _objectTags - a list of labels (e.g. `className`s) to be attached to the object.
|
117
|
+
* Renderers may ignore this.
|
118
|
+
*/
|
119
|
+
endObject(_loaderData, _objectTags) {
|
120
|
+
// Render the paths all at once
|
121
|
+
this.flushPath();
|
122
|
+
this.currentPaths = null;
|
123
|
+
this.objectLevel--;
|
124
|
+
if (this.objectLevel < 0) {
|
125
|
+
throw new Error('More objects have ended than have been started (negative object nesting level)!');
|
126
|
+
}
|
127
|
+
}
|
128
|
+
getNestingLevel() {
|
129
|
+
return this.objectLevel;
|
130
|
+
}
|
131
|
+
// Returns true iff other can be rendered onto this without data loss.
|
132
|
+
canRenderFromWithoutDataLoss(_other) {
|
133
|
+
return false;
|
134
|
+
}
|
135
|
+
// MUST throw if other and this are not of the same base class.
|
136
|
+
renderFromOtherOfSameType(_renderTo, other) {
|
137
|
+
throw new Error(`Unable to render from ${other}: Not implemented`);
|
138
|
+
}
|
139
|
+
// Set a transformation to apply to things before rendering,
|
140
|
+
// replacing the viewport's transform.
|
141
|
+
setTransform(transform) {
|
142
|
+
this.selfTransform = transform;
|
143
|
+
}
|
144
|
+
pushTransform(transform) {
|
145
|
+
this.transformStack.push(this.selfTransform);
|
146
|
+
this.setTransform(this.getCanvasToScreenTransform().rightMul(transform));
|
147
|
+
}
|
148
|
+
popTransform() {
|
149
|
+
var _a;
|
150
|
+
if (this.transformStack.length === 0) {
|
151
|
+
throw new Error('Unable to pop more transforms than have been pushed!');
|
152
|
+
}
|
153
|
+
this.setTransform((_a = this.transformStack.pop()) !== null && _a !== void 0 ? _a : null);
|
154
|
+
}
|
155
|
+
// Get the matrix that transforms a vector on the canvas to a vector on this'
|
156
|
+
// rendering target.
|
157
|
+
getCanvasToScreenTransform() {
|
158
|
+
if (this.selfTransform) {
|
159
|
+
return this.selfTransform;
|
160
|
+
}
|
161
|
+
return this.viewport.canvasToScreenTransform;
|
162
|
+
}
|
163
|
+
canvasToScreen(vec) {
|
164
|
+
return this.getCanvasToScreenTransform().transformVec2(vec);
|
165
|
+
}
|
166
|
+
getSizeOfCanvasPixelOnScreen() {
|
167
|
+
return this.getCanvasToScreenTransform().transformVec3(Vec2_1.Vec2.unitX).length();
|
168
|
+
}
|
169
|
+
}
|
170
|
+
exports.default = AbstractRenderer;
|
@@ -6,6 +6,26 @@ import Viewport from '../../Viewport';
|
|
6
6
|
import RenderingStyle from '../RenderingStyle';
|
7
7
|
import TextStyle from '../TextRenderingStyle';
|
8
8
|
import AbstractRenderer, { RenderableImage, RenderablePathSpec } from './AbstractRenderer';
|
9
|
+
/**
|
10
|
+
* Renders onto a `CanvasRenderingContext2D`.
|
11
|
+
*
|
12
|
+
* @example
|
13
|
+
* ```ts
|
14
|
+
* const editor = new Editor(document.body);
|
15
|
+
*
|
16
|
+
* const canvas = document.createElement('canvas');
|
17
|
+
* const ctx = canvas.getContext('2d');
|
18
|
+
*
|
19
|
+
* // Ensure that the canvas can fit the entire rendering
|
20
|
+
* const viewport = editor.image.getImportExportViewport();
|
21
|
+
* canvas.width = viewport.getScreenRectSize().x;
|
22
|
+
* canvas.height = viewport.getScreenRectSize().y;
|
23
|
+
*
|
24
|
+
* // Render editor.image onto the renderer
|
25
|
+
* const renderer = new CanvasRenderer(ctx, viewport);
|
26
|
+
* editor.image.render(renderer, viewport);
|
27
|
+
* ```
|
28
|
+
*/
|
9
29
|
export default class CanvasRenderer extends AbstractRenderer {
|
10
30
|
private ctx;
|
11
31
|
private ignoreObjectsAboveLevel;
|
@@ -14,6 +34,11 @@ export default class CanvasRenderer extends AbstractRenderer {
|
|
14
34
|
private minSquareCurveApproxDist;
|
15
35
|
private minRenderSizeAnyDimen;
|
16
36
|
private minRenderSizeBothDimens;
|
37
|
+
/**
|
38
|
+
* Creates a new `CanvasRenderer` that renders to the given rendering context.
|
39
|
+
* The `viewport` is used to determine the translation/rotation/scaling of the content
|
40
|
+
* to draw.
|
41
|
+
*/
|
17
42
|
constructor(ctx: CanvasRenderingContext2D, viewport: Viewport);
|
18
43
|
private transformBy;
|
19
44
|
canRenderFromWithoutDataLoss(other: AbstractRenderer): boolean;
|