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.
Files changed (627) hide show
  1. package/CHANGELOG.md +3 -0
  2. package/dist/cjs/src/Color4.d.ts +61 -0
  3. package/dist/cjs/src/Color4.js +197 -0
  4. package/dist/cjs/src/Editor.d.ts +308 -0
  5. package/dist/cjs/src/Editor.js +904 -0
  6. package/dist/cjs/src/EditorImage.d.ts +97 -0
  7. package/dist/cjs/src/EditorImage.js +486 -0
  8. package/dist/cjs/src/EventDispatcher.d.ts +30 -0
  9. package/dist/cjs/src/EventDispatcher.js +57 -0
  10. package/dist/cjs/src/Pointer.d.ts +24 -0
  11. package/dist/cjs/src/Pointer.js +84 -0
  12. package/dist/cjs/src/SVGLoader.d.ts +48 -0
  13. package/dist/cjs/src/SVGLoader.js +472 -0
  14. package/dist/cjs/src/UndoRedoHistory.d.ts +19 -0
  15. package/dist/cjs/src/UndoRedoHistory.js +93 -0
  16. package/dist/cjs/src/Viewport.d.ts +71 -0
  17. package/dist/cjs/src/Viewport.js +264 -0
  18. package/dist/cjs/src/bundle/bundled.d.ts +4 -0
  19. package/dist/cjs/src/bundle/bundled.js +24 -0
  20. package/dist/cjs/src/commands/Command.d.ts +16 -0
  21. package/dist/cjs/src/commands/Command.js +34 -0
  22. package/dist/cjs/src/commands/Duplicate.d.ts +14 -0
  23. package/dist/cjs/src/commands/Duplicate.js +39 -0
  24. package/dist/cjs/src/commands/Erase.d.ts +14 -0
  25. package/dist/cjs/src/commands/Erase.js +63 -0
  26. package/dist/cjs/src/commands/SerializableCommand.d.ts +12 -0
  27. package/dist/cjs/src/commands/SerializableCommand.js +42 -0
  28. package/dist/cjs/src/commands/UnresolvedCommand.d.ts +14 -0
  29. package/dist/cjs/src/commands/UnresolvedCommand.js +28 -0
  30. package/dist/cjs/src/commands/invertCommand.d.ts +4 -0
  31. package/dist/cjs/src/commands/invertCommand.js +49 -0
  32. package/dist/cjs/src/commands/lib.d.ts +7 -0
  33. package/dist/cjs/src/commands/lib.js +18 -0
  34. package/dist/cjs/src/commands/localization.d.ts +23 -0
  35. package/dist/cjs/src/commands/localization.js +24 -0
  36. package/dist/cjs/src/commands/uniteCommands.d.ts +4 -0
  37. package/dist/cjs/src/commands/uniteCommands.js +121 -0
  38. package/dist/cjs/src/components/AbstractComponent.d.ts +73 -0
  39. package/dist/cjs/src/components/AbstractComponent.js +258 -0
  40. package/dist/cjs/src/components/ImageBackground.d.ts +42 -0
  41. package/dist/cjs/src/components/ImageBackground.js +146 -0
  42. package/dist/cjs/src/components/ImageComponent.d.ts +31 -0
  43. package/dist/cjs/src/components/ImageComponent.js +152 -0
  44. package/dist/cjs/src/components/RestylableComponent.d.ts +24 -0
  45. package/dist/cjs/src/components/RestylableComponent.js +88 -0
  46. package/dist/cjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
  47. package/dist/cjs/src/components/SVGGlobalAttributesObject.js +65 -0
  48. package/dist/cjs/src/components/Stroke.d.ts +40 -0
  49. package/dist/cjs/src/components/Stroke.js +191 -0
  50. package/dist/cjs/src/components/TextComponent.d.ts +53 -0
  51. package/dist/cjs/src/components/TextComponent.js +258 -0
  52. package/dist/cjs/src/components/UnknownSVGObject.d.ts +18 -0
  53. package/dist/cjs/src/components/UnknownSVGObject.js +50 -0
  54. package/dist/cjs/src/components/builders/ArrowBuilder.d.ts +19 -0
  55. package/dist/cjs/src/components/builders/ArrowBuilder.js +117 -0
  56. package/dist/cjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
  57. package/dist/cjs/src/components/builders/FreehandLineBuilder.js +173 -0
  58. package/dist/cjs/src/components/builders/LineBuilder.d.ts +18 -0
  59. package/dist/cjs/src/components/builders/LineBuilder.js +89 -0
  60. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  61. package/dist/cjs/src/components/builders/PressureSensitiveFreehandLineBuilder.js +347 -0
  62. package/dist/cjs/src/components/builders/RectangleBuilder.d.ts +20 -0
  63. package/dist/cjs/src/components/builders/RectangleBuilder.js +59 -0
  64. package/dist/cjs/src/components/builders/types.d.ts +12 -0
  65. package/dist/cjs/src/components/builders/types.js +2 -0
  66. package/dist/cjs/src/components/lib.d.ts +12 -0
  67. package/dist/cjs/src/components/lib.js +43 -0
  68. package/dist/cjs/src/components/localization.d.ts +11 -0
  69. package/dist/cjs/src/components/localization.js +13 -0
  70. package/dist/cjs/src/components/util/StrokeSmoother.d.ts +35 -0
  71. package/dist/cjs/src/components/util/StrokeSmoother.js +217 -0
  72. package/dist/cjs/src/components/util/describeComponentList.d.ts +4 -0
  73. package/dist/cjs/src/components/util/describeComponentList.js +16 -0
  74. package/dist/cjs/src/lib.d.ts +34 -0
  75. package/dist/cjs/src/lib.js +63 -0
  76. package/dist/cjs/src/localization.d.ts +14 -0
  77. package/dist/cjs/src/localization.js +13 -0
  78. package/dist/cjs/src/localizations/de.d.ts +3 -0
  79. package/dist/cjs/src/localizations/de.js +6 -0
  80. package/dist/cjs/src/localizations/en.d.ts +3 -0
  81. package/dist/cjs/src/localizations/en.js +6 -0
  82. package/dist/cjs/src/localizations/es.d.ts +3 -0
  83. package/dist/cjs/src/localizations/es.js +20 -0
  84. package/dist/cjs/src/localizations/getLocalizationTable.d.ts +3 -0
  85. package/dist/cjs/src/localizations/getLocalizationTable.js +50 -0
  86. package/dist/cjs/src/math/LineSegment2.d.ts +24 -0
  87. package/dist/cjs/src/math/LineSegment2.js +131 -0
  88. package/dist/cjs/src/math/Mat33.d.ts +118 -0
  89. package/dist/cjs/src/math/Mat33.js +332 -0
  90. package/dist/cjs/src/math/Path.d.ts +71 -0
  91. package/dist/cjs/src/math/Path.js +655 -0
  92. package/dist/cjs/src/math/Rect2.d.ts +52 -0
  93. package/dist/cjs/src/math/Rect2.js +234 -0
  94. package/dist/cjs/src/math/Triangle.d.ts +11 -0
  95. package/dist/cjs/src/math/Triangle.js +22 -0
  96. package/dist/cjs/src/math/Vec2.d.ts +13 -0
  97. package/dist/cjs/src/math/Vec2.js +19 -0
  98. package/dist/cjs/src/math/Vec3.d.ts +106 -0
  99. package/dist/cjs/src/math/Vec3.js +177 -0
  100. package/dist/cjs/src/math/lib.d.ts +7 -0
  101. package/dist/cjs/src/math/lib.js +18 -0
  102. package/dist/cjs/src/math/rounding.d.ts +4 -0
  103. package/dist/cjs/src/math/rounding.js +135 -0
  104. package/dist/cjs/src/rendering/Display.d.ts +75 -0
  105. package/dist/cjs/src/rendering/Display.js +214 -0
  106. package/dist/cjs/src/rendering/RenderingStyle.d.ts +31 -0
  107. package/dist/cjs/src/rendering/RenderingStyle.js +48 -0
  108. package/dist/cjs/src/rendering/TextRenderingStyle.d.ts +36 -0
  109. package/dist/cjs/src/rendering/TextRenderingStyle.js +29 -0
  110. package/dist/cjs/src/rendering/caching/CacheRecord.d.ts +20 -0
  111. package/dist/cjs/src/rendering/caching/CacheRecord.js +61 -0
  112. package/dist/cjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
  113. package/dist/cjs/src/rendering/caching/CacheRecordManager.js +50 -0
  114. package/dist/cjs/src/rendering/caching/RenderingCache.d.ts +11 -0
  115. package/dist/cjs/src/rendering/caching/RenderingCache.js +51 -0
  116. package/dist/cjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
  117. package/dist/cjs/src/rendering/caching/RenderingCacheNode.js +326 -0
  118. package/dist/cjs/src/rendering/caching/testUtils.d.ts +9 -0
  119. package/dist/cjs/src/rendering/caching/testUtils.js +27 -0
  120. package/dist/cjs/src/rendering/caching/types.d.ts +19 -0
  121. package/dist/cjs/src/rendering/caching/types.js +2 -0
  122. package/dist/cjs/src/rendering/lib.d.ts +5 -0
  123. package/dist/cjs/src/rendering/lib.js +17 -0
  124. package/dist/cjs/src/rendering/localization.d.ts +10 -0
  125. package/dist/cjs/src/rendering/localization.js +12 -0
  126. package/dist/cjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
  127. package/dist/cjs/src/rendering/renderers/AbstractRenderer.js +170 -0
  128. package/dist/cjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
  129. package/dist/cjs/src/rendering/renderers/CanvasRenderer.js +236 -0
  130. package/dist/cjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
  131. package/dist/cjs/src/rendering/renderers/DummyRenderer.js +112 -0
  132. package/dist/cjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
  133. package/dist/cjs/src/rendering/renderers/SVGRenderer.js +311 -0
  134. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  135. package/dist/cjs/src/rendering/renderers/TextOnlyRenderer.js +63 -0
  136. package/dist/cjs/src/testing/beforeEachFile.d.ts +1 -0
  137. package/dist/cjs/src/testing/beforeEachFile.js +12 -0
  138. package/dist/cjs/src/testing/createEditor.d.ts +4 -0
  139. package/dist/cjs/src/testing/createEditor.js +14 -0
  140. package/dist/cjs/src/testing/lib.d.ts +2 -0
  141. package/dist/cjs/src/testing/lib.js +10 -0
  142. package/dist/cjs/src/testing/loadExpectExtensions.d.ts +2 -0
  143. package/dist/cjs/src/testing/loadExpectExtensions.js +28 -0
  144. package/dist/cjs/src/testing/sendPenEvent.d.ts +12 -0
  145. package/dist/cjs/src/testing/sendPenEvent.js +24 -0
  146. package/dist/cjs/src/testing/sendTouchEvent.d.ts +42 -0
  147. package/dist/cjs/src/testing/sendTouchEvent.js +87 -0
  148. package/dist/cjs/src/toolbar/HTMLToolbar.d.ts +103 -0
  149. package/dist/cjs/src/toolbar/HTMLToolbar.js +383 -0
  150. package/dist/cjs/src/toolbar/IconProvider.d.ts +62 -0
  151. package/dist/cjs/src/toolbar/IconProvider.js +660 -0
  152. package/dist/cjs/src/toolbar/lib.d.ts +3 -0
  153. package/dist/cjs/src/toolbar/lib.js +24 -0
  154. package/dist/cjs/src/toolbar/localization.d.ts +49 -0
  155. package/dist/cjs/src/toolbar/localization.js +51 -0
  156. package/dist/cjs/src/toolbar/makeColorInput.d.ts +6 -0
  157. package/dist/cjs/src/toolbar/makeColorInput.js +120 -0
  158. package/dist/cjs/src/toolbar/types.d.ts +4 -0
  159. package/dist/cjs/src/toolbar/types.js +2 -0
  160. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
  161. package/dist/cjs/src/toolbar/widgets/ActionButtonWidget.js +31 -0
  162. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
  163. package/dist/cjs/src/toolbar/widgets/BaseToolWidget.js +50 -0
  164. package/dist/cjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
  165. package/dist/cjs/src/toolbar/widgets/BaseWidget.js +313 -0
  166. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
  167. package/dist/cjs/src/toolbar/widgets/DocumentPropertiesWidget.js +126 -0
  168. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
  169. package/dist/cjs/src/toolbar/widgets/EraserToolWidget.js +63 -0
  170. package/dist/cjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
  171. package/dist/cjs/src/toolbar/widgets/HandToolWidget.js +201 -0
  172. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
  173. package/dist/cjs/src/toolbar/widgets/InsertImageWidget.js +176 -0
  174. package/dist/cjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
  175. package/dist/cjs/src/toolbar/widgets/OverflowWidget.js +77 -0
  176. package/dist/cjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
  177. package/dist/cjs/src/toolbar/widgets/PenToolWidget.js +226 -0
  178. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
  179. package/dist/cjs/src/toolbar/widgets/SelectionToolWidget.js +153 -0
  180. package/dist/cjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
  181. package/dist/cjs/src/toolbar/widgets/TextToolWidget.js +115 -0
  182. package/dist/cjs/src/toolbar/widgets/lib.d.ts +10 -0
  183. package/dist/cjs/src/toolbar/widgets/lib.js +26 -0
  184. package/dist/cjs/src/tools/BaseTool.d.ts +22 -0
  185. package/dist/cjs/src/tools/BaseTool.js +66 -0
  186. package/dist/cjs/src/tools/Eraser.d.ts +23 -0
  187. package/dist/cjs/src/tools/Eraser.js +112 -0
  188. package/dist/cjs/src/tools/FindTool.d.ts +21 -0
  189. package/dist/cjs/src/tools/FindTool.js +121 -0
  190. package/dist/cjs/src/tools/PanZoom.d.ts +52 -0
  191. package/dist/cjs/src/tools/PanZoom.js +421 -0
  192. package/dist/cjs/src/tools/PasteHandler.d.ts +23 -0
  193. package/dist/cjs/src/tools/PasteHandler.js +99 -0
  194. package/dist/cjs/src/tools/Pen.d.ts +39 -0
  195. package/dist/cjs/src/tools/Pen.js +179 -0
  196. package/dist/cjs/src/tools/PipetteTool.d.ts +18 -0
  197. package/dist/cjs/src/tools/PipetteTool.js +45 -0
  198. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  199. package/dist/cjs/src/tools/SelectionTool/SelectAllShortcutHandler.js +28 -0
  200. package/dist/cjs/src/tools/SelectionTool/Selection.d.ts +64 -0
  201. package/dist/cjs/src/tools/SelectionTool/Selection.js +488 -0
  202. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
  203. package/dist/cjs/src/tools/SelectionTool/SelectionHandle.js +85 -0
  204. package/dist/cjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
  205. package/dist/cjs/src/tools/SelectionTool/SelectionTool.js +405 -0
  206. package/dist/cjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
  207. package/dist/cjs/src/tools/SelectionTool/TransformMode.js +107 -0
  208. package/dist/cjs/src/tools/SelectionTool/types.d.ts +9 -0
  209. package/dist/cjs/src/tools/SelectionTool/types.js +14 -0
  210. package/dist/cjs/src/tools/TextTool.d.ts +33 -0
  211. package/dist/cjs/src/tools/TextTool.js +262 -0
  212. package/dist/cjs/src/tools/ToolController.d.ts +18 -0
  213. package/dist/cjs/src/tools/ToolController.js +187 -0
  214. package/dist/cjs/src/tools/ToolEnabledGroup.d.ts +6 -0
  215. package/dist/cjs/src/tools/ToolEnabledGroup.js +14 -0
  216. package/dist/cjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
  217. package/dist/cjs/src/tools/ToolSwitcherShortcut.js +38 -0
  218. package/dist/cjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
  219. package/dist/cjs/src/tools/ToolbarShortcutHandler.js +29 -0
  220. package/dist/cjs/src/tools/UndoRedoShortcut.d.ts +8 -0
  221. package/dist/cjs/src/tools/UndoRedoShortcut.js +28 -0
  222. package/dist/cjs/src/tools/lib.d.ts +16 -0
  223. package/dist/cjs/src/tools/lib.js +36 -0
  224. package/dist/cjs/src/tools/localization.d.ts +28 -0
  225. package/dist/cjs/src/tools/localization.js +30 -0
  226. package/dist/cjs/src/types.d.ts +151 -0
  227. package/dist/cjs/src/types.js +38 -0
  228. package/dist/cjs/src/util/assertions.d.ts +23 -0
  229. package/dist/cjs/src/util/assertions.js +51 -0
  230. package/dist/cjs/src/util/fileToBase64.d.ts +3 -0
  231. package/dist/cjs/src/util/fileToBase64.js +15 -0
  232. package/dist/cjs/src/util/untilNextAnimationFrame.d.ts +3 -0
  233. package/dist/cjs/src/util/untilNextAnimationFrame.js +9 -0
  234. package/dist/cjs/src/util/waitForTimeout.d.ts +2 -0
  235. package/dist/cjs/src/util/waitForTimeout.js +9 -0
  236. package/dist/mjs/src/Color4.d.ts +61 -0
  237. package/dist/mjs/src/Color4.mjs +193 -0
  238. package/dist/mjs/src/Editor.d.ts +308 -0
  239. package/dist/mjs/src/Editor.mjs +874 -0
  240. package/dist/mjs/src/EditorImage.d.ts +97 -0
  241. package/dist/mjs/src/EditorImage.mjs +477 -0
  242. package/dist/mjs/src/EventDispatcher.d.ts +30 -0
  243. package/dist/mjs/src/EventDispatcher.mjs +54 -0
  244. package/dist/mjs/src/Pointer.d.ts +24 -0
  245. package/dist/mjs/src/Pointer.mjs +80 -0
  246. package/dist/mjs/src/SVGLoader.d.ts +48 -0
  247. package/dist/mjs/src/SVGLoader.mjs +442 -0
  248. package/dist/mjs/src/UndoRedoHistory.d.ts +19 -0
  249. package/dist/mjs/src/UndoRedoHistory.mjs +91 -0
  250. package/dist/mjs/src/Viewport.d.ts +71 -0
  251. package/dist/mjs/src/Viewport.mjs +256 -0
  252. package/dist/mjs/src/bundle/bundled.d.ts +4 -0
  253. package/dist/mjs/src/bundle/bundled.mjs +5 -0
  254. package/dist/mjs/src/commands/Command.d.ts +16 -0
  255. package/dist/mjs/src/commands/Command.mjs +30 -0
  256. package/dist/mjs/src/commands/Duplicate.d.ts +14 -0
  257. package/dist/mjs/src/commands/Duplicate.mjs +33 -0
  258. package/dist/mjs/src/commands/Erase.d.ts +14 -0
  259. package/dist/mjs/src/commands/Erase.mjs +57 -0
  260. package/dist/mjs/src/commands/SerializableCommand.d.ts +12 -0
  261. package/dist/mjs/src/commands/SerializableCommand.mjs +36 -0
  262. package/dist/mjs/src/commands/UnresolvedCommand.d.ts +14 -0
  263. package/dist/mjs/src/commands/UnresolvedCommand.mjs +22 -0
  264. package/dist/mjs/src/commands/invertCommand.d.ts +4 -0
  265. package/dist/mjs/src/commands/invertCommand.mjs +44 -0
  266. package/dist/mjs/src/commands/lib.d.ts +7 -0
  267. package/dist/mjs/src/commands/lib.mjs +7 -0
  268. package/dist/mjs/src/commands/localization.d.ts +23 -0
  269. package/dist/mjs/src/commands/localization.mjs +21 -0
  270. package/dist/mjs/src/commands/uniteCommands.d.ts +4 -0
  271. package/dist/mjs/src/commands/uniteCommands.mjs +116 -0
  272. package/dist/mjs/src/components/AbstractComponent.d.ts +73 -0
  273. package/dist/mjs/src/components/AbstractComponent.mjs +252 -0
  274. package/dist/mjs/src/components/ImageBackground.d.ts +42 -0
  275. package/dist/mjs/src/components/ImageBackground.mjs +139 -0
  276. package/dist/mjs/src/components/ImageComponent.d.ts +31 -0
  277. package/dist/mjs/src/components/ImageComponent.mjs +146 -0
  278. package/dist/mjs/src/components/RestylableComponent.d.ts +24 -0
  279. package/dist/mjs/src/components/RestylableComponent.mjs +80 -0
  280. package/dist/mjs/src/components/SVGGlobalAttributesObject.d.ts +21 -0
  281. package/dist/mjs/src/components/SVGGlobalAttributesObject.mjs +59 -0
  282. package/dist/mjs/src/components/Stroke.d.ts +40 -0
  283. package/dist/mjs/src/components/Stroke.mjs +185 -0
  284. package/dist/mjs/src/components/TextComponent.d.ts +53 -0
  285. package/dist/mjs/src/components/TextComponent.mjs +252 -0
  286. package/dist/mjs/src/components/UnknownSVGObject.d.ts +18 -0
  287. package/dist/mjs/src/components/UnknownSVGObject.mjs +44 -0
  288. package/dist/mjs/src/components/builders/ArrowBuilder.d.ts +19 -0
  289. package/dist/mjs/src/components/builders/ArrowBuilder.mjs +86 -0
  290. package/dist/mjs/src/components/builders/FreehandLineBuilder.d.ts +33 -0
  291. package/dist/mjs/src/components/builders/FreehandLineBuilder.mjs +165 -0
  292. package/dist/mjs/src/components/builders/LineBuilder.d.ts +18 -0
  293. package/dist/mjs/src/components/builders/LineBuilder.mjs +58 -0
  294. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +36 -0
  295. package/dist/mjs/src/components/builders/PressureSensitiveFreehandLineBuilder.mjs +339 -0
  296. package/dist/mjs/src/components/builders/RectangleBuilder.d.ts +20 -0
  297. package/dist/mjs/src/components/builders/RectangleBuilder.mjs +50 -0
  298. package/dist/mjs/src/components/builders/types.d.ts +12 -0
  299. package/dist/mjs/src/components/builders/types.mjs +1 -0
  300. package/dist/mjs/src/components/lib.d.ts +12 -0
  301. package/dist/mjs/src/components/lib.mjs +12 -0
  302. package/dist/mjs/src/components/localization.d.ts +11 -0
  303. package/dist/mjs/src/components/localization.mjs +10 -0
  304. package/dist/mjs/src/components/util/StrokeSmoother.d.ts +35 -0
  305. package/dist/mjs/src/components/util/StrokeSmoother.mjs +210 -0
  306. package/dist/mjs/src/components/util/describeComponentList.d.ts +4 -0
  307. package/dist/mjs/src/components/util/describeComponentList.mjs +14 -0
  308. package/dist/mjs/src/lib.d.ts +34 -0
  309. package/dist/mjs/src/lib.mjs +34 -0
  310. package/dist/mjs/src/localization.d.ts +14 -0
  311. package/dist/mjs/src/localization.mjs +10 -0
  312. package/dist/mjs/src/localizations/de.d.ts +3 -0
  313. package/dist/mjs/src/localizations/de.mjs +4 -0
  314. package/dist/mjs/src/localizations/en.d.ts +3 -0
  315. package/dist/mjs/src/localizations/en.mjs +4 -0
  316. package/dist/mjs/src/localizations/es.d.ts +3 -0
  317. package/dist/mjs/src/localizations/es.mjs +18 -0
  318. package/dist/mjs/src/localizations/getLocalizationTable.d.ts +3 -0
  319. package/dist/mjs/src/localizations/getLocalizationTable.mjs +45 -0
  320. package/dist/mjs/src/math/LineSegment2.d.ts +24 -0
  321. package/dist/mjs/src/math/LineSegment2.mjs +125 -0
  322. package/dist/mjs/src/math/Mat33.d.ts +118 -0
  323. package/dist/mjs/src/math/Mat33.mjs +326 -0
  324. package/dist/mjs/src/math/Path.d.ts +71 -0
  325. package/dist/mjs/src/math/Path.mjs +648 -0
  326. package/dist/mjs/src/math/Rect2.d.ts +52 -0
  327. package/dist/mjs/src/math/Rect2.mjs +228 -0
  328. package/dist/mjs/src/math/Triangle.d.ts +11 -0
  329. package/dist/mjs/src/math/Triangle.mjs +19 -0
  330. package/dist/mjs/src/math/Vec2.d.ts +13 -0
  331. package/dist/mjs/src/math/Vec2.mjs +13 -0
  332. package/dist/mjs/src/math/Vec3.d.ts +106 -0
  333. package/dist/mjs/src/math/Vec3.mjs +174 -0
  334. package/dist/mjs/src/math/lib.d.ts +7 -0
  335. package/dist/mjs/src/math/lib.mjs +7 -0
  336. package/dist/mjs/src/math/rounding.d.ts +4 -0
  337. package/dist/mjs/src/math/rounding.mjs +128 -0
  338. package/dist/mjs/src/rendering/Display.d.ts +75 -0
  339. package/dist/mjs/src/rendering/Display.mjs +207 -0
  340. package/dist/mjs/src/rendering/RenderingStyle.d.ts +31 -0
  341. package/dist/mjs/src/rendering/RenderingStyle.mjs +38 -0
  342. package/dist/mjs/src/rendering/TextRenderingStyle.d.ts +36 -0
  343. package/dist/mjs/src/rendering/TextRenderingStyle.mjs +23 -0
  344. package/dist/mjs/src/rendering/caching/CacheRecord.d.ts +20 -0
  345. package/dist/mjs/src/rendering/caching/CacheRecord.mjs +55 -0
  346. package/dist/mjs/src/rendering/caching/CacheRecordManager.d.ts +12 -0
  347. package/dist/mjs/src/rendering/caching/CacheRecordManager.mjs +43 -0
  348. package/dist/mjs/src/rendering/caching/RenderingCache.d.ts +11 -0
  349. package/dist/mjs/src/rendering/caching/RenderingCache.mjs +45 -0
  350. package/dist/mjs/src/rendering/caching/RenderingCacheNode.d.ts +29 -0
  351. package/dist/mjs/src/rendering/caching/RenderingCacheNode.mjs +320 -0
  352. package/dist/mjs/src/rendering/caching/testUtils.d.ts +9 -0
  353. package/dist/mjs/src/rendering/caching/testUtils.mjs +20 -0
  354. package/dist/mjs/src/rendering/caching/types.d.ts +19 -0
  355. package/dist/mjs/src/rendering/caching/types.mjs +1 -0
  356. package/dist/mjs/src/rendering/lib.d.ts +5 -0
  357. package/dist/mjs/src/rendering/lib.mjs +5 -0
  358. package/dist/mjs/src/rendering/localization.d.ts +10 -0
  359. package/dist/mjs/src/rendering/localization.mjs +9 -0
  360. package/dist/mjs/src/rendering/renderers/AbstractRenderer.d.ts +68 -0
  361. package/dist/mjs/src/rendering/renderers/AbstractRenderer.mjs +144 -0
  362. package/dist/mjs/src/rendering/renderers/CanvasRenderer.d.ts +63 -0
  363. package/dist/mjs/src/rendering/renderers/CanvasRenderer.mjs +230 -0
  364. package/dist/mjs/src/rendering/renderers/DummyRenderer.d.ts +35 -0
  365. package/dist/mjs/src/rendering/renderers/DummyRenderer.mjs +106 -0
  366. package/dist/mjs/src/rendering/renderers/SVGRenderer.d.ts +57 -0
  367. package/dist/mjs/src/rendering/renderers/SVGRenderer.mjs +304 -0
  368. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.d.ts +29 -0
  369. package/dist/mjs/src/rendering/renderers/TextOnlyRenderer.mjs +57 -0
  370. package/dist/mjs/src/testing/beforeEachFile.d.ts +1 -0
  371. package/dist/mjs/src/testing/beforeEachFile.mjs +7 -0
  372. package/dist/mjs/src/testing/createEditor.d.ts +4 -0
  373. package/dist/mjs/src/testing/createEditor.mjs +9 -0
  374. package/dist/mjs/src/testing/lib.d.ts +2 -0
  375. package/dist/mjs/src/testing/lib.mjs +2 -0
  376. package/dist/mjs/src/testing/loadExpectExtensions.d.ts +2 -0
  377. package/dist/mjs/src/testing/loadExpectExtensions.mjs +24 -0
  378. package/dist/mjs/src/testing/sendPenEvent.d.ts +12 -0
  379. package/dist/mjs/src/testing/sendPenEvent.mjs +19 -0
  380. package/dist/mjs/src/testing/sendTouchEvent.d.ts +42 -0
  381. package/dist/mjs/src/testing/sendTouchEvent.mjs +62 -0
  382. package/dist/mjs/src/toolbar/HTMLToolbar.d.ts +103 -0
  383. package/dist/mjs/src/toolbar/HTMLToolbar.mjs +376 -0
  384. package/dist/mjs/src/toolbar/IconProvider.d.ts +62 -0
  385. package/dist/mjs/src/toolbar/IconProvider.mjs +654 -0
  386. package/dist/mjs/src/toolbar/lib.d.ts +3 -0
  387. package/dist/mjs/src/toolbar/lib.mjs +3 -0
  388. package/dist/mjs/src/toolbar/localization.d.ts +49 -0
  389. package/dist/mjs/src/toolbar/localization.mjs +48 -0
  390. package/dist/mjs/src/toolbar/makeColorInput.d.ts +6 -0
  391. package/dist/mjs/src/toolbar/makeColorInput.mjs +113 -0
  392. package/dist/mjs/src/toolbar/types.d.ts +4 -0
  393. package/dist/mjs/src/toolbar/types.mjs +1 -0
  394. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.d.ts +15 -0
  395. package/dist/mjs/src/toolbar/widgets/ActionButtonWidget.mjs +25 -0
  396. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.d.ts +11 -0
  397. package/dist/mjs/src/toolbar/widgets/BaseToolWidget.mjs +44 -0
  398. package/dist/mjs/src/toolbar/widgets/BaseWidget.d.ts +72 -0
  399. package/dist/mjs/src/toolbar/widgets/BaseWidget.mjs +307 -0
  400. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.d.ts +18 -0
  401. package/dist/mjs/src/toolbar/widgets/DocumentPropertiesWidget.mjs +120 -0
  402. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.d.ts +17 -0
  403. package/dist/mjs/src/toolbar/widgets/EraserToolWidget.mjs +57 -0
  404. package/dist/mjs/src/toolbar/widgets/HandToolWidget.d.ts +17 -0
  405. package/dist/mjs/src/toolbar/widgets/HandToolWidget.mjs +172 -0
  406. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.d.ts +19 -0
  407. package/dist/mjs/src/toolbar/widgets/InsertImageWidget.mjs +170 -0
  408. package/dist/mjs/src/toolbar/widgets/OverflowWidget.d.ts +25 -0
  409. package/dist/mjs/src/toolbar/widgets/OverflowWidget.mjs +71 -0
  410. package/dist/mjs/src/toolbar/widgets/PenToolWidget.d.ts +27 -0
  411. package/dist/mjs/src/toolbar/widgets/PenToolWidget.mjs +220 -0
  412. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.d.ts +13 -0
  413. package/dist/mjs/src/toolbar/widgets/SelectionToolWidget.mjs +147 -0
  414. package/dist/mjs/src/toolbar/widgets/TextToolWidget.d.ts +16 -0
  415. package/dist/mjs/src/toolbar/widgets/TextToolWidget.mjs +109 -0
  416. package/dist/mjs/src/toolbar/widgets/lib.d.ts +10 -0
  417. package/dist/mjs/src/toolbar/widgets/lib.mjs +10 -0
  418. package/dist/mjs/src/tools/BaseTool.d.ts +22 -0
  419. package/dist/mjs/src/tools/BaseTool.mjs +63 -0
  420. package/dist/mjs/src/tools/Eraser.d.ts +23 -0
  421. package/dist/mjs/src/tools/Eraser.mjs +106 -0
  422. package/dist/mjs/src/tools/FindTool.d.ts +21 -0
  423. package/dist/mjs/src/tools/FindTool.mjs +114 -0
  424. package/dist/mjs/src/tools/PanZoom.d.ts +52 -0
  425. package/dist/mjs/src/tools/PanZoom.mjs +414 -0
  426. package/dist/mjs/src/tools/PasteHandler.d.ts +23 -0
  427. package/dist/mjs/src/tools/PasteHandler.mjs +93 -0
  428. package/dist/mjs/src/tools/Pen.d.ts +39 -0
  429. package/dist/mjs/src/tools/Pen.mjs +173 -0
  430. package/dist/mjs/src/tools/PipetteTool.d.ts +18 -0
  431. package/dist/mjs/src/tools/PipetteTool.mjs +39 -0
  432. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.d.ts +8 -0
  433. package/dist/mjs/src/tools/SelectionTool/SelectAllShortcutHandler.mjs +22 -0
  434. package/dist/mjs/src/tools/SelectionTool/Selection.d.ts +64 -0
  435. package/dist/mjs/src/tools/SelectionTool/Selection.mjs +459 -0
  436. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.d.ts +38 -0
  437. package/dist/mjs/src/tools/SelectionTool/SelectionHandle.mjs +81 -0
  438. package/dist/mjs/src/tools/SelectionTool/SelectionTool.d.ts +36 -0
  439. package/dist/mjs/src/tools/SelectionTool/SelectionTool.mjs +398 -0
  440. package/dist/mjs/src/tools/SelectionTool/TransformMode.d.ts +34 -0
  441. package/dist/mjs/src/tools/SelectionTool/TransformMode.mjs +98 -0
  442. package/dist/mjs/src/tools/SelectionTool/types.d.ts +9 -0
  443. package/dist/mjs/src/tools/SelectionTool/types.mjs +11 -0
  444. package/dist/mjs/src/tools/TextTool.d.ts +33 -0
  445. package/dist/mjs/src/tools/TextTool.mjs +256 -0
  446. package/dist/mjs/src/tools/ToolController.d.ts +18 -0
  447. package/dist/mjs/src/tools/ToolController.mjs +158 -0
  448. package/dist/mjs/src/tools/ToolEnabledGroup.d.ts +6 -0
  449. package/dist/mjs/src/tools/ToolEnabledGroup.mjs +11 -0
  450. package/dist/mjs/src/tools/ToolSwitcherShortcut.d.ts +16 -0
  451. package/dist/mjs/src/tools/ToolSwitcherShortcut.mjs +32 -0
  452. package/dist/mjs/src/tools/ToolbarShortcutHandler.d.ts +12 -0
  453. package/dist/mjs/src/tools/ToolbarShortcutHandler.mjs +23 -0
  454. package/dist/mjs/src/tools/UndoRedoShortcut.d.ts +8 -0
  455. package/dist/mjs/src/tools/UndoRedoShortcut.mjs +22 -0
  456. package/dist/mjs/src/tools/lib.d.ts +16 -0
  457. package/dist/mjs/src/tools/lib.mjs +16 -0
  458. package/dist/mjs/src/tools/localization.d.ts +28 -0
  459. package/dist/mjs/src/tools/localization.mjs +27 -0
  460. package/dist/mjs/src/types.d.ts +151 -0
  461. package/dist/mjs/src/types.mjs +35 -0
  462. package/dist/mjs/src/util/assertions.d.ts +23 -0
  463. package/dist/mjs/src/util/assertions.mjs +45 -0
  464. package/dist/mjs/src/util/fileToBase64.d.ts +3 -0
  465. package/dist/mjs/src/util/fileToBase64.mjs +13 -0
  466. package/dist/mjs/src/util/untilNextAnimationFrame.d.ts +3 -0
  467. package/dist/mjs/src/util/untilNextAnimationFrame.mjs +7 -0
  468. package/dist/mjs/src/util/waitForTimeout.d.ts +2 -0
  469. package/dist/mjs/src/util/waitForTimeout.mjs +7 -0
  470. package/package.json +1 -1
  471. package/src/Color4.test.ts +40 -0
  472. package/src/Color4.ts +236 -0
  473. package/src/Editor.css +86 -0
  474. package/src/Editor.loadFrom.test.ts +24 -0
  475. package/src/Editor.toSVG.test.ts +111 -0
  476. package/src/Editor.ts +1122 -0
  477. package/src/EditorImage.test.ts +120 -0
  478. package/src/EditorImage.ts +603 -0
  479. package/src/EventDispatcher.test.ts +123 -0
  480. package/src/EventDispatcher.ts +71 -0
  481. package/src/Pointer.ts +127 -0
  482. package/src/SVGLoader.test.ts +114 -0
  483. package/src/SVGLoader.ts +511 -0
  484. package/src/UndoRedoHistory.test.ts +33 -0
  485. package/src/UndoRedoHistory.ts +102 -0
  486. package/src/Viewport.ts +319 -0
  487. package/src/bundle/bundled.ts +7 -0
  488. package/src/commands/Command.ts +45 -0
  489. package/src/commands/Duplicate.ts +48 -0
  490. package/src/commands/Erase.ts +74 -0
  491. package/src/commands/SerializableCommand.ts +49 -0
  492. package/src/commands/UnresolvedCommand.ts +37 -0
  493. package/src/commands/invertCommand.ts +51 -0
  494. package/src/commands/lib.ts +16 -0
  495. package/src/commands/localization.ts +47 -0
  496. package/src/commands/uniteCommands.test.ts +23 -0
  497. package/src/commands/uniteCommands.ts +135 -0
  498. package/src/components/AbstractComponent.transformBy.test.ts +22 -0
  499. package/src/components/AbstractComponent.ts +364 -0
  500. package/src/components/ImageBackground.test.ts +35 -0
  501. package/src/components/ImageBackground.ts +176 -0
  502. package/src/components/ImageComponent.ts +171 -0
  503. package/src/components/RestylableComponent.ts +142 -0
  504. package/src/components/SVGGlobalAttributesObject.ts +81 -0
  505. package/src/components/Stroke.test.ts +139 -0
  506. package/src/components/Stroke.ts +245 -0
  507. package/src/components/TextComponent.test.ts +99 -0
  508. package/src/components/TextComponent.ts +315 -0
  509. package/src/components/UnknownSVGObject.test.ts +10 -0
  510. package/src/components/UnknownSVGObject.ts +60 -0
  511. package/src/components/builders/ArrowBuilder.ts +107 -0
  512. package/src/components/builders/FreehandLineBuilder.ts +212 -0
  513. package/src/components/builders/LineBuilder.ts +77 -0
  514. package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +454 -0
  515. package/src/components/builders/RectangleBuilder.ts +74 -0
  516. package/src/components/builders/types.ts +15 -0
  517. package/src/components/lib.ts +25 -0
  518. package/src/components/localization.ts +22 -0
  519. package/src/components/util/StrokeSmoother.ts +293 -0
  520. package/src/components/util/describeComponentList.ts +18 -0
  521. package/src/lib.ts +37 -0
  522. package/src/localization.ts +34 -0
  523. package/src/localizations/de.ts +98 -0
  524. package/src/localizations/en.ts +8 -0
  525. package/src/localizations/es.ts +74 -0
  526. package/src/localizations/getLocalizationTable.test.ts +27 -0
  527. package/src/localizations/getLocalizationTable.ts +55 -0
  528. package/src/math/LineSegment2.test.ts +99 -0
  529. package/src/math/LineSegment2.ts +160 -0
  530. package/src/math/Mat33.test.ts +244 -0
  531. package/src/math/Mat33.ts +437 -0
  532. package/src/math/Path.fromString.test.ts +223 -0
  533. package/src/math/Path.test.ts +198 -0
  534. package/src/math/Path.toString.test.ts +77 -0
  535. package/src/math/Path.ts +790 -0
  536. package/src/math/Rect2.test.ts +204 -0
  537. package/src/math/Rect2.ts +315 -0
  538. package/src/math/Triangle.ts +29 -0
  539. package/src/math/Vec2.test.ts +30 -0
  540. package/src/math/Vec2.ts +18 -0
  541. package/src/math/Vec3.test.ts +44 -0
  542. package/src/math/Vec3.ts +218 -0
  543. package/src/math/lib.ts +15 -0
  544. package/src/math/rounding.test.ts +65 -0
  545. package/src/math/rounding.ts +156 -0
  546. package/src/rendering/Display.ts +249 -0
  547. package/src/rendering/RenderingStyle.test.ts +68 -0
  548. package/src/rendering/RenderingStyle.ts +55 -0
  549. package/src/rendering/TextRenderingStyle.ts +45 -0
  550. package/src/rendering/caching/CacheRecord.test.ts +49 -0
  551. package/src/rendering/caching/CacheRecord.ts +77 -0
  552. package/src/rendering/caching/CacheRecordManager.ts +71 -0
  553. package/src/rendering/caching/RenderingCache.test.ts +44 -0
  554. package/src/rendering/caching/RenderingCache.ts +66 -0
  555. package/src/rendering/caching/RenderingCacheNode.ts +405 -0
  556. package/src/rendering/caching/testUtils.ts +35 -0
  557. package/src/rendering/caching/types.ts +34 -0
  558. package/src/rendering/lib.ts +6 -0
  559. package/src/rendering/localization.ts +20 -0
  560. package/src/rendering/renderers/AbstractRenderer.ts +222 -0
  561. package/src/rendering/renderers/CanvasRenderer.ts +296 -0
  562. package/src/rendering/renderers/DummyRenderer.test.ts +42 -0
  563. package/src/rendering/renderers/DummyRenderer.ts +136 -0
  564. package/src/rendering/renderers/SVGRenderer.ts +354 -0
  565. package/src/rendering/renderers/TextOnlyRenderer.ts +70 -0
  566. package/src/styles.js +7 -0
  567. package/src/testing/beforeEachFile.ts +8 -0
  568. package/src/testing/createEditor.ts +11 -0
  569. package/src/testing/global.d.ts +17 -0
  570. package/src/testing/lib.ts +3 -0
  571. package/src/testing/loadExpectExtensions.ts +25 -0
  572. package/src/testing/sendPenEvent.ts +31 -0
  573. package/src/testing/sendTouchEvent.ts +78 -0
  574. package/src/toolbar/HTMLToolbar.ts +492 -0
  575. package/src/toolbar/IconProvider.ts +736 -0
  576. package/src/toolbar/lib.ts +4 -0
  577. package/src/toolbar/localization.ts +106 -0
  578. package/src/toolbar/makeColorInput.ts +145 -0
  579. package/src/toolbar/toolbar.css +213 -0
  580. package/src/toolbar/types.ts +5 -0
  581. package/src/toolbar/widgets/ActionButtonWidget.ts +39 -0
  582. package/src/toolbar/widgets/BaseToolWidget.ts +56 -0
  583. package/src/toolbar/widgets/BaseWidget.ts +377 -0
  584. package/src/toolbar/widgets/DocumentPropertiesWidget.ts +167 -0
  585. package/src/toolbar/widgets/EraserToolWidget.ts +85 -0
  586. package/src/toolbar/widgets/HandToolWidget.ts +250 -0
  587. package/src/toolbar/widgets/InsertImageWidget.css +44 -0
  588. package/src/toolbar/widgets/InsertImageWidget.ts +223 -0
  589. package/src/toolbar/widgets/OverflowWidget.css +27 -0
  590. package/src/toolbar/widgets/OverflowWidget.ts +92 -0
  591. package/src/toolbar/widgets/PenToolWidget.ts +288 -0
  592. package/src/toolbar/widgets/SelectionToolWidget.ts +190 -0
  593. package/src/toolbar/widgets/TextToolWidget.ts +145 -0
  594. package/src/toolbar/widgets/lib.ts +13 -0
  595. package/src/tools/BaseTool.ts +76 -0
  596. package/src/tools/Eraser.test.ts +103 -0
  597. package/src/tools/Eraser.ts +139 -0
  598. package/src/tools/FindTool.css +7 -0
  599. package/src/tools/FindTool.ts +152 -0
  600. package/src/tools/PanZoom.test.ts +310 -0
  601. package/src/tools/PanZoom.ts +520 -0
  602. package/src/tools/PasteHandler.ts +95 -0
  603. package/src/tools/Pen.test.ts +194 -0
  604. package/src/tools/Pen.ts +226 -0
  605. package/src/tools/PipetteTool.ts +55 -0
  606. package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +28 -0
  607. package/src/tools/SelectionTool/Selection.ts +607 -0
  608. package/src/tools/SelectionTool/SelectionHandle.ts +108 -0
  609. package/src/tools/SelectionTool/SelectionTool.css +23 -0
  610. package/src/tools/SelectionTool/SelectionTool.test.ts +261 -0
  611. package/src/tools/SelectionTool/SelectionTool.ts +480 -0
  612. package/src/tools/SelectionTool/TransformMode.ts +114 -0
  613. package/src/tools/SelectionTool/types.ts +11 -0
  614. package/src/tools/TextTool.ts +326 -0
  615. package/src/tools/ToolController.ts +178 -0
  616. package/src/tools/ToolEnabledGroup.ts +14 -0
  617. package/src/tools/ToolSwitcherShortcut.ts +39 -0
  618. package/src/tools/ToolbarShortcutHandler.ts +34 -0
  619. package/src/tools/UndoRedoShortcut.test.ts +56 -0
  620. package/src/tools/UndoRedoShortcut.ts +25 -0
  621. package/src/tools/lib.ts +21 -0
  622. package/src/tools/localization.ts +66 -0
  623. package/src/types.ts +234 -0
  624. package/src/util/assertions.ts +55 -0
  625. package/src/util/fileToBase64.ts +18 -0
  626. package/src/util/untilNextAnimationFrame.ts +9 -0
  627. package/src/util/waitForTimeout.ts +9 -0
@@ -0,0 +1,218 @@
1
+
2
+
3
+ /**
4
+ * A vector with three components. Can also be used to represent a two-component vector.
5
+ *
6
+ * A `Vec3` is immutable.
7
+ */
8
+ export default class Vec3 {
9
+ private constructor(
10
+ public readonly x: number,
11
+ public readonly y: number,
12
+ public readonly z: number
13
+ ) {
14
+ }
15
+
16
+ /** Returns the x, y components of this. */
17
+ public get xy(): { x: number; y: number } {
18
+ // Useful for APIs that behave differently if .z is present.
19
+ return {
20
+ x: this.x,
21
+ y: this.y,
22
+ };
23
+ }
24
+
25
+ public static of(x: number, y: number, z: number): Vec3 {
26
+ return new Vec3(x, y, z);
27
+ }
28
+
29
+ /** Returns this' `idx`th component. For example, `Vec3.of(1, 2, 3).at(1) → 2`. */
30
+ public at(idx: number): number {
31
+ if (idx === 0) return this.x;
32
+ if (idx === 1) return this.y;
33
+ if (idx === 2) return this.z;
34
+
35
+ throw new Error(`${idx} out of bounds!`);
36
+ }
37
+
38
+ /** Alias for this.magnitude. */
39
+ public length(): number {
40
+ return this.magnitude();
41
+ }
42
+
43
+ public magnitude(): number {
44
+ return Math.sqrt(this.dot(this));
45
+ }
46
+
47
+ public magnitudeSquared(): number {
48
+ return this.dot(this);
49
+ }
50
+
51
+ /**
52
+ * Return this' angle in the XY plane (treats this as a Vec2).
53
+ *
54
+ * This is equivalent to `Math.atan2(vec.y, vec.x)`.
55
+ */
56
+ public angle(): number {
57
+ return Math.atan2(this.y, this.x);
58
+ }
59
+
60
+ /**
61
+ * Returns a unit vector in the same direction as this.
62
+ *
63
+ * If `this` has zero length, the resultant vector has `NaN` components.
64
+ */
65
+ public normalized(): Vec3 {
66
+ const norm = this.magnitude();
67
+ return Vec3.of(this.x / norm, this.y / norm, this.z / norm);
68
+ }
69
+
70
+ /** @returns A copy of `this` multiplied by a scalar. */
71
+ public times(c: number): Vec3 {
72
+ return Vec3.of(this.x * c, this.y * c, this.z * c);
73
+ }
74
+
75
+ public plus(v: Vec3): Vec3 {
76
+ return Vec3.of(this.x + v.x, this.y + v.y, this.z + v.z);
77
+ }
78
+
79
+ public minus(v: Vec3): Vec3 {
80
+ return Vec3.of(this.x - v.x, this.y - v.y, this.z - v.z);
81
+ }
82
+
83
+ public dot(other: Vec3): number {
84
+ return this.x * other.x + this.y * other.y + this.z * other.z;
85
+ }
86
+
87
+ public cross(other: Vec3): Vec3 {
88
+ // | i j k |
89
+ // | x1 y1 z1| = (i)(y1z2 - y2z1) - (j)(x1z2 - x2z1) + (k)(x1y2 - x2y1)
90
+ // | x2 y2 z2|
91
+ return Vec3.of(
92
+ this.y * other.z - other.y * this.z,
93
+ other.x * this.z - this.x * other.z,
94
+ this.x * other.y - other.x * this.y
95
+ );
96
+ }
97
+
98
+ /**
99
+ * If `other` is a `Vec3`, multiplies `this` component-wise by `other`. Otherwise,
100
+ * if `other is a `number`, returns the result of scalar multiplication.
101
+ *
102
+ * @example
103
+ * ```
104
+ * Vec3.of(1, 2, 3).scale(Vec3.of(2, 4, 6)); // → Vec3(2, 8, 18)
105
+ * ```
106
+ */
107
+ public scale(other: Vec3|number): Vec3 {
108
+ if (typeof other === 'number') {
109
+ return this.times(other);
110
+ }
111
+
112
+ return Vec3.of(
113
+ this.x * other.x,
114
+ this.y * other.y,
115
+ this.z * other.z,
116
+ );
117
+ }
118
+
119
+ /**
120
+ * Returns a vector orthogonal to this. If this is a Vec2, returns `this` rotated
121
+ * 90 degrees counter-clockwise.
122
+ */
123
+ public orthog(): Vec3 {
124
+ // If parallel to the z-axis
125
+ if (this.dot(Vec3.unitX) === 0 && this.dot(Vec3.unitY) === 0) {
126
+ return this.dot(Vec3.unitX) === 0 ? Vec3.unitX : this.cross(Vec3.unitX).normalized();
127
+ }
128
+
129
+ return this.cross(Vec3.unitZ.times(-1)).normalized();
130
+ }
131
+
132
+ /** Returns this plus a vector of length `distance` in `direction`. */
133
+ public extend(distance: number, direction: Vec3): Vec3 {
134
+ return this.plus(direction.normalized().times(distance));
135
+ }
136
+
137
+ /** Returns a vector `fractionTo` of the way to target from this. */
138
+ public lerp(target: Vec3, fractionTo: number): Vec3 {
139
+ return this.times(1 - fractionTo).plus(target.times(fractionTo));
140
+ }
141
+
142
+ /**
143
+ * `zip` Maps a component of this and a corresponding component of
144
+ * `other` to a component of the output vector.
145
+ *
146
+ * @example
147
+ * ```
148
+ * const a = Vec3.of(1, 2, 3);
149
+ * const b = Vec3.of(0.5, 2.1, 2.9);
150
+ *
151
+ * const zipped = a.zip(b, (aComponent, bComponent) => {
152
+ * return Math.min(aComponent, bComponent);
153
+ * });
154
+ *
155
+ * console.log(zipped.toString()); // → Vec(0.5, 2, 2.9)
156
+ * ```
157
+ */
158
+ public zip(
159
+ other: Vec3, zip: (componentInThis: number, componentInOther: number)=> number
160
+ ): Vec3 {
161
+ return Vec3.of(
162
+ zip(other.x, this.x),
163
+ zip(other.y, this.y),
164
+ zip(other.z, this.z)
165
+ );
166
+ }
167
+
168
+ /**
169
+ * Returns a vector with each component acted on by `fn`.
170
+ *
171
+ * @example
172
+ * ```
173
+ * console.log(Vec3.of(1, 2, 3).map(val => val + 1)); // → Vec(2, 3, 4)
174
+ * ```
175
+ */
176
+ public map(fn: (component: number, index: number)=> number): Vec3 {
177
+ return Vec3.of(
178
+ fn(this.x, 0), fn(this.y, 1), fn(this.z, 2)
179
+ );
180
+ }
181
+
182
+ public asArray(): [ number, number, number ] {
183
+ return [this.x, this.y, this.z];
184
+ }
185
+
186
+ /**
187
+ * [fuzz] The maximum difference between two components for this and [other]
188
+ * to be considered equal.
189
+ *
190
+ * @example
191
+ * ```
192
+ * Vec3.of(1, 2, 3).eq(Vec3.of(4, 5, 6), 100); // → true
193
+ * Vec3.of(1, 2, 3).eq(Vec3.of(4, 5, 6), 0.1); // → false
194
+ * Vec3.of(1, 2, 3).eq(Vec3.of(4, 5, 6), 3); // → true
195
+ * Vec3.of(1, 2, 3).eq(Vec3.of(4, 5, 6), 3.01); // → true
196
+ * Vec3.of(1, 2, 3).eq(Vec3.of(4, 5, 6), 2.99); // → false
197
+ * ```
198
+ */
199
+ public eq(other: Vec3, fuzz: number = 1e-10): boolean {
200
+ for (let i = 0; i < 3; i++) {
201
+ if (Math.abs(other.at(i) - this.at(i)) > fuzz) {
202
+ return false;
203
+ }
204
+ }
205
+
206
+ return true;
207
+ }
208
+
209
+ public toString(): string {
210
+ return `Vec(${this.x}, ${this.y}, ${this.z})`;
211
+ }
212
+
213
+
214
+ public static unitX = Vec3.of(1, 0, 0);
215
+ public static unitY = Vec3.of(0, 1, 0);
216
+ public static unitZ = Vec3.of(0, 0, 1);
217
+ public static zero = Vec3.of(0, 0, 0);
218
+ }
@@ -0,0 +1,15 @@
1
+ import LineSegment2 from './LineSegment2';
2
+ import Mat33 from './Mat33';
3
+ import Path from './Path';
4
+ import Rect2 from './Rect2';
5
+ import { Vec2 } from './Vec2';
6
+ import Vec3 from './Vec3';
7
+
8
+ export {
9
+ LineSegment2,
10
+ Mat33,
11
+ Path,
12
+ Rect2,
13
+ Vec3,
14
+ Vec2,
15
+ };
@@ -0,0 +1,65 @@
1
+ import { cleanUpNumber, toRoundedString, toStringOfSamePrecision } from './rounding';
2
+
3
+ describe('toRoundedString', () => {
4
+ it('should round up numbers endings similar to .999999999999999', () => {
5
+ expect(toRoundedString(0.999999999)).toBe('1');
6
+ expect(toRoundedString(0.899999999)).toBe('.9');
7
+ expect(toRoundedString(9.999999999)).toBe('10');
8
+ expect(toRoundedString(-10.999999999)).toBe('-11');
9
+ });
10
+
11
+ it('should round up numbers similar to 10.999999998', () => {
12
+ expect(toRoundedString(10.999999998)).toBe('11');
13
+ });
14
+
15
+ it('should round strings with multiple digits after the ending decimal points', () => {
16
+ expect(toRoundedString(292.2 - 292.8)).toBe('-.6');
17
+ expect(toRoundedString(4.06425600000023)).toBe('4.064256');
18
+ });
19
+
20
+ it('should round down strings ending endings similar to .00000001', () => {
21
+ expect(toRoundedString(10.00000001)).toBe('10');
22
+ expect(toRoundedString(-30.00000001)).toBe('-30');
23
+ expect(toRoundedString(-14.20000000000002)).toBe('-14.2');
24
+ });
25
+
26
+ it('should not round numbers insufficiently close to the next', () => {
27
+ expect(toRoundedString(-10.9999)).toBe('-10.9999');
28
+ expect(toRoundedString(-10.0001)).toBe('-10.0001');
29
+ expect(toRoundedString(-10.123499)).toBe('-10.123499');
30
+ expect(toRoundedString(0.00123499)).toBe('.00123499');
31
+ });
32
+ });
33
+
34
+ it('toStringOfSamePrecision', () => {
35
+ expect(toStringOfSamePrecision(1.23456, '1.12')).toBe('1.23');
36
+ expect(toStringOfSamePrecision(1.23456, '1.120')).toBe('1.235');
37
+ expect(toStringOfSamePrecision(1.23456, '1.1')).toBe('1.2');
38
+ expect(toStringOfSamePrecision(1.23456, '1.1', '5.32')).toBe('1.23');
39
+ expect(toStringOfSamePrecision(-1.23456, '1.1', '5.32')).toBe('-1.23');
40
+ expect(toStringOfSamePrecision(-1.99999, '1.1', '5.32')).toBe('-2');
41
+ expect(toStringOfSamePrecision(1.99999, '1.1', '5.32')).toBe('2');
42
+ expect(toStringOfSamePrecision(1.89999, '1.1', '5.32')).toBe('1.9');
43
+ expect(toStringOfSamePrecision(9.99999999, '-1.1234')).toBe('10');
44
+ expect(toStringOfSamePrecision(9.999999998999996, '100')).toBe('10');
45
+ expect(toStringOfSamePrecision(0.000012345, '0.000012')).toBe('.000012');
46
+ expect(toStringOfSamePrecision(0.000012645, '.000012')).toBe('.000013');
47
+ expect(toStringOfSamePrecision(-0.09999999999999432, '291.3')).toBe('-.1');
48
+ expect(toStringOfSamePrecision(-0.9999999999999432, '291.3')).toBe('-1');
49
+ expect(toStringOfSamePrecision(9998.9, '.1', '-11')).toBe('9998.9');
50
+ expect(toStringOfSamePrecision(-14.20000000000002, '.000001', '-11')).toBe('-14.2');
51
+ });
52
+
53
+ it('cleanUpNumber', () => {
54
+ expect(cleanUpNumber('000.0000')).toBe('0');
55
+ expect(cleanUpNumber('-000.0000')).toBe('0');
56
+ expect(cleanUpNumber('0.0000')).toBe('0');
57
+ expect(cleanUpNumber('0.001')).toBe('.001');
58
+ expect(cleanUpNumber('-0.001')).toBe('-.001');
59
+ expect(cleanUpNumber('-0.000000001')).toBe('-.000000001');
60
+ expect(cleanUpNumber('-0.00000000100')).toBe('-.000000001');
61
+ expect(cleanUpNumber('1234')).toBe('1234');
62
+ expect(cleanUpNumber('1234.5')).toBe('1234.5');
63
+ expect(cleanUpNumber('1234.500')).toBe('1234.5');
64
+ expect(cleanUpNumber('1.1368683772161603e-13')).toBe('0');
65
+ });
@@ -0,0 +1,156 @@
1
+ // @packageDocumentation @internal
2
+
3
+ // Clean up stringified numbers
4
+ export const cleanUpNumber = (text: string) => {
5
+ // Regular expression substitions can be somewhat expensive. Only do them
6
+ // if necessary.
7
+
8
+ if (text.indexOf('e') > 0) {
9
+ // Round to zero.
10
+ if (text.match(/[eE][-]\d{2,}$/)) {
11
+ return '0';
12
+ }
13
+ }
14
+
15
+ const lastChar = text.charAt(text.length - 1);
16
+ if (lastChar === '0' || lastChar === '.') {
17
+ // Remove trailing zeroes
18
+ text = text.replace(/([.]\d*[^0]+)0+$/, '$1');
19
+ text = text.replace(/[.]0+$/, '.');
20
+
21
+ // Remove trailing period
22
+ text = text.replace(/[.]$/, '');
23
+ }
24
+
25
+ const firstChar = text.charAt(0);
26
+ if (firstChar === '0' || firstChar === '-') {
27
+ // Remove unnecessary leading zeroes.
28
+ text = text.replace(/^(0+)[.]/, '.');
29
+ text = text.replace(/^-(0+)[.]/, '-.');
30
+ text = text.replace(/^(-?)0+$/, '$10');
31
+ }
32
+
33
+ if (text === '-0') {
34
+ return '0';
35
+ }
36
+
37
+ return text;
38
+ };
39
+
40
+ export const toRoundedString = (num: number): string => {
41
+ // Try to remove rounding errors. If the number ends in at least three/four zeroes
42
+ // (or nines) just one or two digits, it's probably a rounding error.
43
+ const fixRoundingUpExp = /^([-]?\d*\.\d{3,})0{4,}\d{1,4}$/;
44
+ const hasRoundingDownExp = /^([-]?)(\d*)\.(\d{3,}9{4,})\d{1,4}$/;
45
+
46
+ let text = num.toString(10);
47
+ if (text.indexOf('.') === -1) {
48
+ return text;
49
+ }
50
+
51
+ const roundingDownMatch = hasRoundingDownExp.exec(text);
52
+ if (roundingDownMatch) {
53
+ const negativeSign = roundingDownMatch[1];
54
+ const postDecimalString = roundingDownMatch[3];
55
+ const lastDigit = parseInt(postDecimalString.charAt(postDecimalString.length - 1), 10);
56
+ const postDecimal = parseInt(postDecimalString, 10);
57
+ const preDecimal = parseInt(roundingDownMatch[2], 10);
58
+
59
+ const origPostDecimalString = roundingDownMatch[3];
60
+
61
+ let newPostDecimal = (postDecimal + 10 - lastDigit).toString();
62
+ let carry = 0;
63
+ if (newPostDecimal.length > postDecimal.toString().length) {
64
+ // Left-shift
65
+ newPostDecimal = newPostDecimal.substring(1);
66
+ carry = 1;
67
+ }
68
+
69
+ // parseInt(...).toString() removes leading zeroes. Add them back.
70
+ while (newPostDecimal.length < origPostDecimalString.length) {
71
+ newPostDecimal = carry.toString(10) + newPostDecimal;
72
+ carry = 0;
73
+ }
74
+
75
+ text = `${negativeSign + (preDecimal + carry).toString()}.${newPostDecimal}`;
76
+ }
77
+
78
+ text = text.replace(fixRoundingUpExp, '$1');
79
+
80
+ return cleanUpNumber(text);
81
+ };
82
+
83
+ const numberExp = /^([-]?)(\d*)[.](\d+)$/;
84
+ export const getLenAfterDecimal = (numberAsString: string) => {
85
+ const numberMatch = numberExp.exec(numberAsString);
86
+ if (!numberMatch) {
87
+ // If not a match, either the number is exponential notation (or is something
88
+ // like NaN or Infinity)
89
+ if (numberAsString.search(/[eE]/) !== -1 || /^[a-zA-Z]+$/.exec(numberAsString)) {
90
+ return -1;
91
+ // Or it has no decimal point
92
+ } else {
93
+ return 0;
94
+ }
95
+ }
96
+
97
+ const afterDecimalLen = numberMatch[3].length;
98
+ return afterDecimalLen;
99
+ };
100
+
101
+ // [reference] should be a string representation of a base-10 number (no exponential (e.g. 10e10))
102
+ export const toStringOfSamePrecision = (num: number, ...references: string[]): string => {
103
+ const text = num.toString(10);
104
+ const textMatch = numberExp.exec(text);
105
+ if (!textMatch) {
106
+ return text;
107
+ }
108
+
109
+ let decimalPlaces = -1;
110
+ for (const reference of references) {
111
+ decimalPlaces = Math.max(getLenAfterDecimal(reference), decimalPlaces);
112
+ }
113
+
114
+ if (decimalPlaces === -1) {
115
+ return toRoundedString(num);
116
+ }
117
+
118
+ // Make text's after decimal length match [afterDecimalLen].
119
+ let postDecimal = textMatch[3].substring(0, decimalPlaces);
120
+ let preDecimal = textMatch[2];
121
+ const nextDigit = textMatch[3].charAt(decimalPlaces);
122
+
123
+ if (nextDigit !== '') {
124
+ const asNumber = parseInt(nextDigit, 10);
125
+ if (asNumber >= 5) {
126
+ // Don't attempt to parseInt() an empty string.
127
+ if (postDecimal.length > 0) {
128
+ const leadingZeroMatch = /^(0+)(\d*)$/.exec(postDecimal);
129
+
130
+ let leadingZeroes = '';
131
+ let postLeading = postDecimal;
132
+ if (leadingZeroMatch) {
133
+ leadingZeroes = leadingZeroMatch[1];
134
+ postLeading = leadingZeroMatch[2];
135
+ }
136
+
137
+ postDecimal = (parseInt(postDecimal) + 1).toString();
138
+
139
+ // If postDecimal got longer, remove leading zeroes if possible
140
+ if (postDecimal.length > postLeading.length && leadingZeroes.length > 0) {
141
+ leadingZeroes = leadingZeroes.substring(1);
142
+ }
143
+
144
+ postDecimal = leadingZeroes + postDecimal;
145
+ }
146
+
147
+ if (postDecimal.length === 0 || postDecimal.length > decimalPlaces) {
148
+ preDecimal = (parseInt(preDecimal) + 1).toString();
149
+ postDecimal = postDecimal.substring(1);
150
+ }
151
+ }
152
+ }
153
+
154
+ const negativeSign = textMatch[1];
155
+ return cleanUpNumber(`${negativeSign}${preDecimal}.${postDecimal}`);
156
+ };
@@ -0,0 +1,249 @@
1
+ import AbstractRenderer from './renderers/AbstractRenderer';
2
+ import CanvasRenderer from './renderers/CanvasRenderer';
3
+ import { Editor } from '../Editor';
4
+ import { EditorEventType } from '../types';
5
+ import DummyRenderer from './renderers/DummyRenderer';
6
+ import { Point2, Vec2 } from '../math/Vec2';
7
+ import RenderingCache from './caching/RenderingCache';
8
+ import TextOnlyRenderer from './renderers/TextOnlyRenderer';
9
+ import Color4 from '../Color4';
10
+
11
+ export enum RenderingMode {
12
+ DummyRenderer,
13
+ CanvasRenderer,
14
+ // SVGRenderer is not supported by the main display
15
+ }
16
+
17
+ /**
18
+ * Handles `HTMLCanvasElement`s (or other drawing surfaces if being used) used to display the editor's contents.
19
+ *
20
+ * @example
21
+ * ```
22
+ * const editor = new Editor(document.body);
23
+ * const w = editor.display.width;
24
+ * const h = editor.display.height;
25
+ * const center = Vec2.of(w / 2, h / 2);
26
+ * const colorAtCenter = editor.display.getColorAt(center);
27
+ * ```
28
+ */
29
+ export default class Display {
30
+ private dryInkRenderer: AbstractRenderer;
31
+ private wetInkRenderer: AbstractRenderer;
32
+ private textRenderer: TextOnlyRenderer;
33
+ private textRerenderOutput: HTMLElement|null = null;
34
+ private cache: RenderingCache;
35
+ private resizeSurfacesCallback?: ()=> void;
36
+ private flattenCallback?: ()=> void;
37
+
38
+ /** @internal */
39
+ public constructor(
40
+ private editor: Editor, mode: RenderingMode, private parent: HTMLElement|null
41
+ ) {
42
+ if (mode === RenderingMode.CanvasRenderer) {
43
+ this.initializeCanvasRendering();
44
+ } else if (mode === RenderingMode.DummyRenderer) {
45
+ this.dryInkRenderer = new DummyRenderer(editor.viewport);
46
+ this.wetInkRenderer = new DummyRenderer(editor.viewport);
47
+ } else {
48
+ throw new Error(`Unknown rendering mode, ${mode}!`);
49
+ }
50
+
51
+ this.textRenderer = new TextOnlyRenderer(editor.viewport, editor.localization);
52
+ this.initializeTextRendering();
53
+
54
+ const cacheBlockResolution = Vec2.of(600, 600);
55
+ this.cache = new RenderingCache({
56
+ createRenderer: () => {
57
+ if (mode === RenderingMode.DummyRenderer) {
58
+ return new DummyRenderer(editor.viewport);
59
+ } else if (mode !== RenderingMode.CanvasRenderer) {
60
+ throw new Error('Unspported rendering mode');
61
+ }
62
+
63
+ // Make the canvas slightly larger than each cache block to prevent
64
+ // seams.
65
+ const canvas = document.createElement('canvas');
66
+ canvas.width = cacheBlockResolution.x + 1;
67
+ canvas.height = cacheBlockResolution.y + 1;
68
+ const ctx = canvas.getContext('2d');
69
+
70
+ return new CanvasRenderer(ctx!, editor.viewport);
71
+ },
72
+ isOfCorrectType: (renderer) => {
73
+ return this.dryInkRenderer.canRenderFromWithoutDataLoss(renderer);
74
+ },
75
+ blockResolution: cacheBlockResolution,
76
+ cacheSize: 600 * 600 * 4 * 90,
77
+ maxScale: 1.3,
78
+
79
+ // Require about 20 strokes with 4 parts each to cache an image in one of the
80
+ // parts of the cache grid.
81
+ minProportionalRenderTimePerCache: 20 * 4,
82
+
83
+ // Require about 105 strokes with 4 parts each to use the cache at all.
84
+ minProportionalRenderTimeToUseCache: 105 * 4,
85
+ });
86
+
87
+ this.editor.notifier.on(EditorEventType.DisplayResized, event => {
88
+ if (event.kind !== EditorEventType.DisplayResized) {
89
+ throw new Error('Mismatched event.kinds!');
90
+ }
91
+
92
+ this.resizeSurfacesCallback?.();
93
+ });
94
+ }
95
+
96
+ /**
97
+ * @returns the visible width of the display (e.g. how much
98
+ * space the display's element takes up in the x direction
99
+ * in the DOM).
100
+ */
101
+ public get width(): number {
102
+ return this.dryInkRenderer.displaySize().x;
103
+ }
104
+
105
+ public get height(): number {
106
+ return this.dryInkRenderer.displaySize().y;
107
+ }
108
+
109
+ /** @internal */
110
+ public getCache() {
111
+ return this.cache;
112
+ }
113
+
114
+ /**
115
+ * @returns the color at the given point on the dry ink renderer, or `null` if `screenPos`
116
+ * is not on the display.
117
+ */
118
+ public getColorAt = (_screenPos: Point2): Color4|null => {
119
+ return null;
120
+ };
121
+
122
+ private initializeCanvasRendering() {
123
+ const dryInkCanvas = document.createElement('canvas');
124
+ const wetInkCanvas = document.createElement('canvas');
125
+ const dryInkCtx = dryInkCanvas.getContext('2d')!;
126
+ const wetInkCtx = wetInkCanvas.getContext('2d')!;
127
+
128
+ this.dryInkRenderer = new CanvasRenderer(dryInkCtx, this.editor.viewport);
129
+ this.wetInkRenderer = new CanvasRenderer(wetInkCtx, this.editor.viewport);
130
+
131
+ dryInkCanvas.className = 'dryInkCanvas';
132
+ wetInkCanvas.className = 'wetInkCanvas';
133
+
134
+ if (this.parent) {
135
+ this.parent.appendChild(dryInkCanvas);
136
+ this.parent.appendChild(wetInkCanvas);
137
+ }
138
+
139
+ this.resizeSurfacesCallback = () => {
140
+ const hasSizeMismatch = (canvas: HTMLCanvasElement): boolean => {
141
+ return canvas.clientHeight !== canvas.height || canvas.clientWidth !== canvas.width;
142
+ };
143
+
144
+ // Ensure that the drawing surfaces sizes match the
145
+ // canvas' sizes to prevent stretching.
146
+ if (hasSizeMismatch(dryInkCanvas) || hasSizeMismatch(wetInkCanvas)) {
147
+ dryInkCanvas.width = dryInkCanvas.clientWidth;
148
+ dryInkCanvas.height = dryInkCanvas.clientHeight;
149
+ wetInkCanvas.width = wetInkCanvas.clientWidth;
150
+ wetInkCanvas.height = wetInkCanvas.clientHeight;
151
+
152
+ this.editor.notifier.dispatch(EditorEventType.DisplayResized, {
153
+ kind: EditorEventType.DisplayResized,
154
+ newSize: Vec2.of(
155
+ this.width,
156
+ this.height,
157
+ ),
158
+ });
159
+ }
160
+ };
161
+ this.resizeSurfacesCallback();
162
+
163
+ this.flattenCallback = () => {
164
+ dryInkCtx.drawImage(wetInkCanvas, 0, 0);
165
+ };
166
+
167
+ this.getColorAt = (screenPos: Point2) => {
168
+ const pixel = dryInkCtx.getImageData(screenPos.x, screenPos.y, 1, 1);
169
+ const data = pixel?.data;
170
+
171
+ if (data) {
172
+ const color = Color4.ofRGBA(data[0] / 255, data[1] / 255, data[2] / 255, data[3] / 255);
173
+ return color;
174
+ }
175
+ return null;
176
+ };
177
+ }
178
+
179
+ private initializeTextRendering() {
180
+ const textRendererOutputContainer = document.createElement('div');
181
+ textRendererOutputContainer.classList.add('textRendererOutputContainer');
182
+
183
+ const rerenderButton = document.createElement('button');
184
+ rerenderButton.classList.add('rerenderButton');
185
+ rerenderButton.innerText = this.editor.localization.rerenderAsText;
186
+
187
+ this.textRerenderOutput = document.createElement('div');
188
+ this.textRerenderOutput.setAttribute('aria-live', 'polite');
189
+
190
+ rerenderButton.onclick = () => {
191
+ this.rerenderAsText();
192
+ };
193
+
194
+ textRendererOutputContainer.replaceChildren(rerenderButton, this.textRerenderOutput);
195
+ this.editor.createHTMLOverlay(textRendererOutputContainer);
196
+ }
197
+
198
+ /**
199
+ * Rerenders the text-based display.
200
+ * The text-based display is intended for screen readers and can be navigated to by pressing `tab`.
201
+ */
202
+ public rerenderAsText() {
203
+ this.textRenderer.clear();
204
+ this.editor.image.render(this.textRenderer, this.editor.viewport);
205
+
206
+ if (this.textRerenderOutput) {
207
+ this.textRerenderOutput.innerText = this.textRenderer.getDescription();
208
+ }
209
+ }
210
+
211
+ /**
212
+ * Clears the drawing surfaces and otherwise prepares for a rerender.
213
+ *
214
+ * @returns the dry ink renderer.
215
+ */
216
+ public startRerender(): AbstractRenderer {
217
+ this.resizeSurfacesCallback?.();
218
+ this.wetInkRenderer.clear();
219
+ this.dryInkRenderer.clear();
220
+
221
+ return this.dryInkRenderer;
222
+ }
223
+
224
+ /**
225
+ * If `draftMode`, the dry ink renderer is configured to render
226
+ * low-quality output.
227
+ */
228
+ public setDraftMode(draftMode: boolean) {
229
+ this.dryInkRenderer.setDraftMode(draftMode);
230
+ }
231
+
232
+ /** @internal */
233
+ public getDryInkRenderer(): AbstractRenderer {
234
+ return this.dryInkRenderer;
235
+ }
236
+
237
+ /**
238
+ * @returns The renderer used for showing action previews (e.g. an unfinished stroke).
239
+ * The `wetInkRenderer`'s surface is stacked above the `dryInkRenderer`'s.
240
+ */
241
+ public getWetInkRenderer(): AbstractRenderer {
242
+ return this.wetInkRenderer;
243
+ }
244
+
245
+ /** Re-renders the contents of the wetInkRenderer onto the dryInkRenderer. */
246
+ public flatten() {
247
+ this.flattenCallback?.();
248
+ }
249
+ }