@twick/2d 0.14.18 → 0.14.19

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 (536) hide show
  1. package/LICENSE +21 -21
  2. package/package.json +4 -4
  3. package/src/editor/NodeInspectorConfig.tsx +76 -76
  4. package/src/editor/PreviewOverlayConfig.tsx +67 -67
  5. package/src/editor/Provider.tsx +93 -93
  6. package/src/editor/SceneGraphTabConfig.tsx +81 -81
  7. package/src/editor/icons/CircleIcon.tsx +7 -7
  8. package/src/editor/icons/CodeBlockIcon.tsx +8 -8
  9. package/src/editor/icons/CurveIcon.tsx +7 -7
  10. package/src/editor/icons/GridIcon.tsx +7 -7
  11. package/src/editor/icons/IconMap.ts +35 -35
  12. package/src/editor/icons/ImgIcon.tsx +8 -8
  13. package/src/editor/icons/LayoutIcon.tsx +9 -9
  14. package/src/editor/icons/LineIcon.tsx +7 -7
  15. package/src/editor/icons/NodeIcon.tsx +7 -7
  16. package/src/editor/icons/RayIcon.tsx +7 -7
  17. package/src/editor/icons/RectIcon.tsx +7 -7
  18. package/src/editor/icons/ShapeIcon.tsx +7 -7
  19. package/src/editor/icons/TxtIcon.tsx +8 -8
  20. package/src/editor/icons/VideoIcon.tsx +7 -7
  21. package/src/editor/icons/View2DIcon.tsx +10 -10
  22. package/src/editor/index.ts +17 -17
  23. package/src/editor/tree/DetachedRoot.tsx +23 -23
  24. package/src/editor/tree/NodeElement.tsx +74 -74
  25. package/src/editor/tree/TreeElement.tsx +72 -72
  26. package/src/editor/tree/TreeRoot.tsx +10 -10
  27. package/src/editor/tree/ViewRoot.tsx +20 -20
  28. package/src/editor/tree/index.module.scss +38 -38
  29. package/src/editor/tree/index.ts +3 -3
  30. package/src/editor/tsconfig.build.json +5 -5
  31. package/src/editor/tsconfig.json +12 -12
  32. package/src/editor/tsdoc.json +4 -4
  33. package/src/editor/vite-env.d.ts +1 -1
  34. package/src/lib/code/CodeCursor.ts +445 -445
  35. package/src/lib/code/CodeDiffer.ts +78 -78
  36. package/src/lib/code/CodeFragment.ts +97 -97
  37. package/src/lib/code/CodeHighlighter.ts +75 -75
  38. package/src/lib/code/CodeMetrics.ts +47 -47
  39. package/src/lib/code/CodeRange.test.ts +74 -74
  40. package/src/lib/code/CodeRange.ts +216 -216
  41. package/src/lib/code/CodeScope.ts +101 -101
  42. package/src/lib/code/CodeSelection.ts +24 -24
  43. package/src/lib/code/CodeSignal.ts +327 -327
  44. package/src/lib/code/CodeTokenizer.ts +54 -54
  45. package/src/lib/code/DefaultHighlightStyle.ts +98 -98
  46. package/src/lib/code/LezerHighlighter.ts +113 -113
  47. package/src/lib/code/diff.test.ts +311 -311
  48. package/src/lib/code/diff.ts +319 -319
  49. package/src/lib/code/extractRange.ts +126 -126
  50. package/src/lib/code/index.ts +13 -13
  51. package/src/lib/components/Audio.ts +168 -168
  52. package/src/lib/components/Bezier.ts +105 -105
  53. package/src/lib/components/Circle.ts +266 -266
  54. package/src/lib/components/Code.ts +526 -526
  55. package/src/lib/components/CodeBlock.ts +576 -576
  56. package/src/lib/components/CubicBezier.ts +112 -112
  57. package/src/lib/components/Curve.ts +455 -455
  58. package/src/lib/components/Grid.ts +135 -135
  59. package/src/lib/components/Icon.ts +96 -96
  60. package/src/lib/components/Img.ts +319 -319
  61. package/src/lib/components/Knot.ts +157 -157
  62. package/src/lib/components/Latex.ts +122 -122
  63. package/src/lib/components/Layout.ts +1092 -1092
  64. package/src/lib/components/Line.ts +429 -429
  65. package/src/lib/components/Media.ts +576 -576
  66. package/src/lib/components/Node.ts +1940 -1940
  67. package/src/lib/components/Path.ts +137 -137
  68. package/src/lib/components/Polygon.ts +171 -171
  69. package/src/lib/components/QuadBezier.ts +100 -100
  70. package/src/lib/components/Ray.ts +125 -125
  71. package/src/lib/components/Rect.ts +187 -187
  72. package/src/lib/components/Rive.ts +156 -156
  73. package/src/lib/components/SVG.ts +797 -797
  74. package/src/lib/components/Shape.ts +143 -143
  75. package/src/lib/components/Spline.ts +344 -344
  76. package/src/lib/components/Txt.test.tsx +81 -81
  77. package/src/lib/components/Txt.ts +203 -203
  78. package/src/lib/components/TxtLeaf.ts +205 -205
  79. package/src/lib/components/Video.ts +461 -461
  80. package/src/lib/components/View2D.ts +98 -98
  81. package/src/lib/components/__tests__/children.test.tsx +142 -142
  82. package/src/lib/components/__tests__/clone.test.tsx +126 -126
  83. package/src/lib/components/__tests__/generatorTest.ts +28 -28
  84. package/src/lib/components/__tests__/mockScene2D.ts +45 -45
  85. package/src/lib/components/__tests__/query.test.tsx +122 -122
  86. package/src/lib/components/__tests__/state.test.tsx +60 -60
  87. package/src/lib/components/index.ts +28 -28
  88. package/src/lib/components/types.ts +35 -35
  89. package/src/lib/curves/ArcSegment.ts +159 -159
  90. package/src/lib/curves/CircleSegment.ts +77 -77
  91. package/src/lib/curves/CubicBezierSegment.ts +78 -78
  92. package/src/lib/curves/CurveDrawingInfo.ts +11 -11
  93. package/src/lib/curves/CurvePoint.ts +15 -15
  94. package/src/lib/curves/CurveProfile.ts +7 -7
  95. package/src/lib/curves/KnotInfo.ts +10 -10
  96. package/src/lib/curves/LineSegment.ts +62 -62
  97. package/src/lib/curves/Polynomial.ts +355 -355
  98. package/src/lib/curves/Polynomial2D.ts +62 -62
  99. package/src/lib/curves/PolynomialSegment.ts +124 -124
  100. package/src/lib/curves/QuadBezierSegment.ts +64 -64
  101. package/src/lib/curves/Segment.ts +17 -17
  102. package/src/lib/curves/UniformPolynomialCurveSampler.ts +94 -94
  103. package/src/lib/curves/createCurveProfileLerp.ts +471 -471
  104. package/src/lib/curves/getBezierSplineProfile.ts +223 -223
  105. package/src/lib/curves/getCircleProfile.ts +86 -86
  106. package/src/lib/curves/getPathProfile.ts +178 -178
  107. package/src/lib/curves/getPointAtDistance.ts +21 -21
  108. package/src/lib/curves/getPolylineProfile.test.ts +21 -21
  109. package/src/lib/curves/getPolylineProfile.ts +89 -89
  110. package/src/lib/curves/getRectProfile.ts +139 -139
  111. package/src/lib/curves/index.ts +16 -16
  112. package/src/lib/decorators/canvasStyleSignal.ts +16 -16
  113. package/src/lib/decorators/colorSignal.ts +9 -9
  114. package/src/lib/decorators/compound.ts +72 -72
  115. package/src/lib/decorators/computed.ts +18 -18
  116. package/src/lib/decorators/defaultStyle.ts +18 -18
  117. package/src/lib/decorators/filtersSignal.ts +136 -136
  118. package/src/lib/decorators/index.ts +10 -10
  119. package/src/lib/decorators/initializers.ts +32 -32
  120. package/src/lib/decorators/nodeName.ts +13 -13
  121. package/src/lib/decorators/signal.test.ts +90 -90
  122. package/src/lib/decorators/signal.ts +345 -345
  123. package/src/lib/decorators/spacingSignal.ts +15 -15
  124. package/src/lib/decorators/vector2Signal.ts +30 -30
  125. package/src/lib/globals.d.ts +2 -2
  126. package/src/lib/index.ts +8 -8
  127. package/src/lib/jsx-dev-runtime.ts +2 -2
  128. package/src/lib/jsx-runtime.ts +46 -46
  129. package/src/lib/parse-svg-path.d.ts +14 -14
  130. package/src/lib/partials/Filter.ts +180 -180
  131. package/src/lib/partials/Gradient.ts +102 -102
  132. package/src/lib/partials/Pattern.ts +34 -34
  133. package/src/lib/partials/ShaderConfig.ts +117 -117
  134. package/src/lib/partials/index.ts +4 -4
  135. package/src/lib/partials/types.ts +58 -58
  136. package/src/lib/scenes/Scene2D.ts +242 -242
  137. package/src/lib/scenes/index.ts +3 -3
  138. package/src/lib/scenes/makeScene2D.ts +16 -16
  139. package/src/lib/scenes/useScene2D.ts +6 -6
  140. package/src/lib/tsconfig.build.json +5 -5
  141. package/src/lib/tsconfig.json +10 -10
  142. package/src/lib/tsdoc.json +4 -4
  143. package/src/lib/utils/CanvasUtils.ts +306 -306
  144. package/src/lib/utils/diff.test.ts +453 -453
  145. package/src/lib/utils/diff.ts +148 -148
  146. package/src/lib/utils/index.ts +2 -2
  147. package/src/lib/utils/is.ts +11 -11
  148. package/src/lib/utils/makeSignalExtensions.ts +30 -30
  149. package/src/lib/utils/video/declarations.d.ts +1 -1
  150. package/src/lib/utils/video/ffmpeg-client.ts +50 -50
  151. package/src/lib/utils/video/mp4-parser-manager.ts +72 -72
  152. package/src/lib/utils/video/parser/index.ts +1 -1
  153. package/src/lib/utils/video/parser/parser.ts +257 -257
  154. package/src/lib/utils/video/parser/sampler.ts +72 -72
  155. package/src/lib/utils/video/parser/segment.ts +302 -302
  156. package/src/lib/utils/video/parser/sink.ts +29 -29
  157. package/src/lib/utils/video/parser/utils.ts +31 -31
  158. package/src/tsconfig.base.json +19 -19
  159. package/src/tsconfig.build.json +8 -8
  160. package/src/tsconfig.json +5 -5
  161. package/tsconfig.project.json +7 -7
  162. package/editor/editor/NodeInspectorConfig.d.ts +0 -3
  163. package/editor/editor/NodeInspectorConfig.d.ts.map +0 -1
  164. package/editor/editor/PreviewOverlayConfig.d.ts +0 -3
  165. package/editor/editor/PreviewOverlayConfig.d.ts.map +0 -1
  166. package/editor/editor/Provider.d.ts +0 -17
  167. package/editor/editor/Provider.d.ts.map +0 -1
  168. package/editor/editor/SceneGraphTabConfig.d.ts +0 -3
  169. package/editor/editor/SceneGraphTabConfig.d.ts.map +0 -1
  170. package/editor/editor/icons/CircleIcon.d.ts +0 -2
  171. package/editor/editor/icons/CircleIcon.d.ts.map +0 -1
  172. package/editor/editor/icons/CodeBlockIcon.d.ts +0 -2
  173. package/editor/editor/icons/CodeBlockIcon.d.ts.map +0 -1
  174. package/editor/editor/icons/CurveIcon.d.ts +0 -2
  175. package/editor/editor/icons/CurveIcon.d.ts.map +0 -1
  176. package/editor/editor/icons/GridIcon.d.ts +0 -2
  177. package/editor/editor/icons/GridIcon.d.ts.map +0 -1
  178. package/editor/editor/icons/IconMap.d.ts +0 -3
  179. package/editor/editor/icons/IconMap.d.ts.map +0 -1
  180. package/editor/editor/icons/ImgIcon.d.ts +0 -2
  181. package/editor/editor/icons/ImgIcon.d.ts.map +0 -1
  182. package/editor/editor/icons/LayoutIcon.d.ts +0 -2
  183. package/editor/editor/icons/LayoutIcon.d.ts.map +0 -1
  184. package/editor/editor/icons/LineIcon.d.ts +0 -2
  185. package/editor/editor/icons/LineIcon.d.ts.map +0 -1
  186. package/editor/editor/icons/NodeIcon.d.ts +0 -2
  187. package/editor/editor/icons/NodeIcon.d.ts.map +0 -1
  188. package/editor/editor/icons/RayIcon.d.ts +0 -2
  189. package/editor/editor/icons/RayIcon.d.ts.map +0 -1
  190. package/editor/editor/icons/RectIcon.d.ts +0 -2
  191. package/editor/editor/icons/RectIcon.d.ts.map +0 -1
  192. package/editor/editor/icons/ShapeIcon.d.ts +0 -2
  193. package/editor/editor/icons/ShapeIcon.d.ts.map +0 -1
  194. package/editor/editor/icons/TxtIcon.d.ts +0 -2
  195. package/editor/editor/icons/TxtIcon.d.ts.map +0 -1
  196. package/editor/editor/icons/VideoIcon.d.ts +0 -2
  197. package/editor/editor/icons/VideoIcon.d.ts.map +0 -1
  198. package/editor/editor/icons/View2DIcon.d.ts +0 -2
  199. package/editor/editor/icons/View2DIcon.d.ts.map +0 -1
  200. package/editor/editor/index.d.ts +0 -4
  201. package/editor/editor/index.d.ts.map +0 -1
  202. package/editor/editor/tree/DetachedRoot.d.ts +0 -2
  203. package/editor/editor/tree/DetachedRoot.d.ts.map +0 -1
  204. package/editor/editor/tree/NodeElement.d.ts +0 -8
  205. package/editor/editor/tree/NodeElement.d.ts.map +0 -1
  206. package/editor/editor/tree/TreeElement.d.ts +0 -15
  207. package/editor/editor/tree/TreeElement.d.ts.map +0 -1
  208. package/editor/editor/tree/TreeRoot.d.ts +0 -3
  209. package/editor/editor/tree/TreeRoot.d.ts.map +0 -1
  210. package/editor/editor/tree/ViewRoot.d.ts +0 -2
  211. package/editor/editor/tree/ViewRoot.d.ts.map +0 -1
  212. package/editor/editor/tree/index.d.ts +0 -4
  213. package/editor/editor/tree/index.d.ts.map +0 -1
  214. package/editor/editor/tsconfig.build.tsbuildinfo +0 -1
  215. package/editor/index.css +0 -33
  216. package/editor/index.js +0 -341
  217. package/editor/index.js.map +0 -1
  218. package/lib/code/CodeCursor.d.ts +0 -83
  219. package/lib/code/CodeCursor.d.ts.map +0 -1
  220. package/lib/code/CodeCursor.js +0 -306
  221. package/lib/code/CodeDiffer.d.ts +0 -28
  222. package/lib/code/CodeDiffer.d.ts.map +0 -1
  223. package/lib/code/CodeDiffer.js +0 -51
  224. package/lib/code/CodeFragment.d.ts +0 -42
  225. package/lib/code/CodeFragment.d.ts.map +0 -1
  226. package/lib/code/CodeFragment.js +0 -72
  227. package/lib/code/CodeHighlighter.d.ts +0 -71
  228. package/lib/code/CodeHighlighter.d.ts.map +0 -1
  229. package/lib/code/CodeHighlighter.js +0 -2
  230. package/lib/code/CodeMetrics.d.ts +0 -11
  231. package/lib/code/CodeMetrics.d.ts.map +0 -1
  232. package/lib/code/CodeMetrics.js +0 -29
  233. package/lib/code/CodeRange.d.ts +0 -41
  234. package/lib/code/CodeRange.d.ts.map +0 -1
  235. package/lib/code/CodeRange.js +0 -179
  236. package/lib/code/CodeScope.d.ts +0 -16
  237. package/lib/code/CodeScope.d.ts.map +0 -1
  238. package/lib/code/CodeScope.js +0 -72
  239. package/lib/code/CodeSelection.d.ts +0 -6
  240. package/lib/code/CodeSelection.d.ts.map +0 -1
  241. package/lib/code/CodeSelection.js +0 -13
  242. package/lib/code/CodeSignal.d.ts +0 -60
  243. package/lib/code/CodeSignal.d.ts.map +0 -1
  244. package/lib/code/CodeSignal.js +0 -194
  245. package/lib/code/CodeTokenizer.d.ts +0 -8
  246. package/lib/code/CodeTokenizer.d.ts.map +0 -1
  247. package/lib/code/CodeTokenizer.js +0 -50
  248. package/lib/code/DefaultHighlightStyle.d.ts +0 -3
  249. package/lib/code/DefaultHighlightStyle.d.ts.map +0 -1
  250. package/lib/code/DefaultHighlightStyle.js +0 -98
  251. package/lib/code/LezerHighlighter.d.ts +0 -22
  252. package/lib/code/LezerHighlighter.d.ts.map +0 -1
  253. package/lib/code/LezerHighlighter.js +0 -89
  254. package/lib/code/diff.d.ts +0 -31
  255. package/lib/code/diff.d.ts.map +0 -1
  256. package/lib/code/diff.js +0 -236
  257. package/lib/code/extractRange.d.ts +0 -17
  258. package/lib/code/extractRange.d.ts.map +0 -1
  259. package/lib/code/extractRange.js +0 -102
  260. package/lib/code/index.d.ts +0 -14
  261. package/lib/code/index.d.ts.map +0 -1
  262. package/lib/code/index.js +0 -14
  263. package/lib/components/Audio.d.ts +0 -14
  264. package/lib/components/Audio.d.ts.map +0 -1
  265. package/lib/components/Audio.js +0 -148
  266. package/lib/components/Bezier.d.ts +0 -23
  267. package/lib/components/Bezier.d.ts.map +0 -1
  268. package/lib/components/Bezier.js +0 -81
  269. package/lib/components/Circle.d.ts +0 -193
  270. package/lib/components/Circle.d.ts.map +0 -1
  271. package/lib/components/Circle.js +0 -178
  272. package/lib/components/Code.d.ts +0 -231
  273. package/lib/components/Code.d.ts.map +0 -1
  274. package/lib/components/Code.js +0 -325
  275. package/lib/components/CodeBlock.d.ts +0 -133
  276. package/lib/components/CodeBlock.d.ts.map +0 -1
  277. package/lib/components/CodeBlock.js +0 -461
  278. package/lib/components/CubicBezier.d.ts +0 -70
  279. package/lib/components/CubicBezier.d.ts.map +0 -1
  280. package/lib/components/CubicBezier.js +0 -81
  281. package/lib/components/Curve.d.ts +0 -204
  282. package/lib/components/Curve.d.ts.map +0 -1
  283. package/lib/components/Curve.js +0 -284
  284. package/lib/components/Grid.d.ts +0 -76
  285. package/lib/components/Grid.d.ts.map +0 -1
  286. package/lib/components/Grid.js +0 -91
  287. package/lib/components/Icon.d.ts +0 -59
  288. package/lib/components/Icon.d.ts.map +0 -1
  289. package/lib/components/Icon.js +0 -58
  290. package/lib/components/Img.d.ts +0 -118
  291. package/lib/components/Img.d.ts.map +0 -1
  292. package/lib/components/Img.js +0 -245
  293. package/lib/components/Knot.d.ts +0 -90
  294. package/lib/components/Knot.d.ts.map +0 -1
  295. package/lib/components/Knot.js +0 -68
  296. package/lib/components/Latex.d.ts +0 -39
  297. package/lib/components/Latex.d.ts.map +0 -1
  298. package/lib/components/Latex.js +0 -101
  299. package/lib/components/Layout.d.ts +0 -419
  300. package/lib/components/Layout.d.ts.map +0 -1
  301. package/lib/components/Layout.js +0 -706
  302. package/lib/components/Line.d.ts +0 -160
  303. package/lib/components/Line.d.ts.map +0 -1
  304. package/lib/components/Line.js +0 -346
  305. package/lib/components/Media.d.ts +0 -70
  306. package/lib/components/Media.d.ts.map +0 -1
  307. package/lib/components/Media.js +0 -493
  308. package/lib/components/Node.d.ts +0 -836
  309. package/lib/components/Node.d.ts.map +0 -1
  310. package/lib/components/Node.js +0 -1317
  311. package/lib/components/Path.d.ts +0 -20
  312. package/lib/components/Path.d.ts.map +0 -1
  313. package/lib/components/Path.js +0 -97
  314. package/lib/components/Polygon.d.ts +0 -113
  315. package/lib/components/Polygon.d.ts.map +0 -1
  316. package/lib/components/Polygon.js +0 -123
  317. package/lib/components/QuadBezier.d.ts +0 -62
  318. package/lib/components/QuadBezier.d.ts.map +0 -1
  319. package/lib/components/QuadBezier.js +0 -76
  320. package/lib/components/Ray.d.ts +0 -62
  321. package/lib/components/Ray.d.ts.map +0 -1
  322. package/lib/components/Ray.js +0 -96
  323. package/lib/components/Rect.d.ts +0 -114
  324. package/lib/components/Rect.d.ts.map +0 -1
  325. package/lib/components/Rect.js +0 -76
  326. package/lib/components/Rive.d.ts +0 -22
  327. package/lib/components/Rive.d.ts.map +0 -1
  328. package/lib/components/Rive.js +0 -117
  329. package/lib/components/SVG.d.ts +0 -178
  330. package/lib/components/SVG.d.ts.map +0 -1
  331. package/lib/components/SVG.js +0 -577
  332. package/lib/components/Shape.d.ts +0 -40
  333. package/lib/components/Shape.d.ts.map +0 -1
  334. package/lib/components/Shape.js +0 -134
  335. package/lib/components/Spline.d.ts +0 -89
  336. package/lib/components/Spline.d.ts.map +0 -1
  337. package/lib/components/Spline.js +0 -256
  338. package/lib/components/Txt.d.ts +0 -53
  339. package/lib/components/Txt.d.ts.map +0 -1
  340. package/lib/components/Txt.js +0 -173
  341. package/lib/components/TxtLeaf.d.ts +0 -21
  342. package/lib/components/TxtLeaf.d.ts.map +0 -1
  343. package/lib/components/TxtLeaf.js +0 -181
  344. package/lib/components/Video.d.ts +0 -69
  345. package/lib/components/Video.d.ts.map +0 -1
  346. package/lib/components/Video.js +0 -342
  347. package/lib/components/View2D.d.ts +0 -28
  348. package/lib/components/View2D.d.ts.map +0 -1
  349. package/lib/components/View2D.js +0 -93
  350. package/lib/components/index.d.ts +0 -29
  351. package/lib/components/index.d.ts.map +0 -1
  352. package/lib/components/index.js +0 -29
  353. package/lib/components/types.d.ts +0 -17
  354. package/lib/components/types.d.ts.map +0 -1
  355. package/lib/components/types.js +0 -2
  356. package/lib/curves/ArcSegment.d.ts +0 -26
  357. package/lib/curves/ArcSegment.d.ts.map +0 -1
  358. package/lib/curves/ArcSegment.js +0 -97
  359. package/lib/curves/CircleSegment.d.ts +0 -18
  360. package/lib/curves/CircleSegment.d.ts.map +0 -1
  361. package/lib/curves/CircleSegment.js +0 -52
  362. package/lib/curves/CubicBezierSegment.d.ts +0 -18
  363. package/lib/curves/CubicBezierSegment.d.ts.map +0 -1
  364. package/lib/curves/CubicBezierSegment.js +0 -55
  365. package/lib/curves/CurveDrawingInfo.d.ts +0 -11
  366. package/lib/curves/CurveDrawingInfo.d.ts.map +0 -1
  367. package/lib/curves/CurveDrawingInfo.js +0 -2
  368. package/lib/curves/CurvePoint.d.ts +0 -15
  369. package/lib/curves/CurvePoint.d.ts.map +0 -1
  370. package/lib/curves/CurvePoint.js +0 -2
  371. package/lib/curves/CurveProfile.d.ts +0 -7
  372. package/lib/curves/CurveProfile.d.ts.map +0 -1
  373. package/lib/curves/CurveProfile.js +0 -2
  374. package/lib/curves/KnotInfo.d.ts +0 -12
  375. package/lib/curves/KnotInfo.d.ts.map +0 -1
  376. package/lib/curves/KnotInfo.js +0 -2
  377. package/lib/curves/LineSegment.d.ts +0 -16
  378. package/lib/curves/LineSegment.d.ts.map +0 -1
  379. package/lib/curves/LineSegment.js +0 -45
  380. package/lib/curves/Polynomial.d.ts +0 -118
  381. package/lib/curves/Polynomial.d.ts.map +0 -1
  382. package/lib/curves/Polynomial.js +0 -259
  383. package/lib/curves/Polynomial2D.d.ts +0 -22
  384. package/lib/curves/Polynomial2D.d.ts.map +0 -1
  385. package/lib/curves/Polynomial2D.js +0 -45
  386. package/lib/curves/PolynomialSegment.d.ts +0 -39
  387. package/lib/curves/PolynomialSegment.d.ts.map +0 -1
  388. package/lib/curves/PolynomialSegment.js +0 -86
  389. package/lib/curves/QuadBezierSegment.d.ts +0 -17
  390. package/lib/curves/QuadBezierSegment.d.ts.map +0 -1
  391. package/lib/curves/QuadBezierSegment.js +0 -49
  392. package/lib/curves/Segment.d.ts +0 -9
  393. package/lib/curves/Segment.d.ts.map +0 -1
  394. package/lib/curves/Segment.js +0 -3
  395. package/lib/curves/UniformPolynomialCurveSampler.d.ts +0 -43
  396. package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +0 -1
  397. package/lib/curves/UniformPolynomialCurveSampler.js +0 -73
  398. package/lib/curves/createCurveProfileLerp.d.ts +0 -32
  399. package/lib/curves/createCurveProfileLerp.d.ts.map +0 -1
  400. package/lib/curves/createCurveProfileLerp.js +0 -351
  401. package/lib/curves/getBezierSplineProfile.d.ts +0 -12
  402. package/lib/curves/getBezierSplineProfile.d.ts.map +0 -1
  403. package/lib/curves/getBezierSplineProfile.js +0 -137
  404. package/lib/curves/getCircleProfile.d.ts +0 -4
  405. package/lib/curves/getCircleProfile.d.ts.map +0 -1
  406. package/lib/curves/getCircleProfile.js +0 -44
  407. package/lib/curves/getPathProfile.d.ts +0 -3
  408. package/lib/curves/getPathProfile.d.ts.map +0 -1
  409. package/lib/curves/getPathProfile.js +0 -128
  410. package/lib/curves/getPointAtDistance.d.ts +0 -4
  411. package/lib/curves/getPointAtDistance.d.ts.map +0 -1
  412. package/lib/curves/getPointAtDistance.js +0 -15
  413. package/lib/curves/getPolylineProfile.d.ts +0 -4
  414. package/lib/curves/getPolylineProfile.d.ts.map +0 -1
  415. package/lib/curves/getPolylineProfile.js +0 -58
  416. package/lib/curves/getRectProfile.d.ts +0 -4
  417. package/lib/curves/getRectProfile.d.ts.map +0 -1
  418. package/lib/curves/getRectProfile.js +0 -57
  419. package/lib/curves/index.d.ts +0 -17
  420. package/lib/curves/index.d.ts.map +0 -1
  421. package/lib/curves/index.js +0 -17
  422. package/lib/decorators/canvasStyleSignal.d.ts +0 -5
  423. package/lib/decorators/canvasStyleSignal.d.ts.map +0 -1
  424. package/lib/decorators/canvasStyleSignal.js +0 -12
  425. package/lib/decorators/colorSignal.d.ts +0 -2
  426. package/lib/decorators/colorSignal.d.ts.map +0 -1
  427. package/lib/decorators/colorSignal.js +0 -9
  428. package/lib/decorators/compound.d.ts +0 -26
  429. package/lib/decorators/compound.d.ts.map +0 -1
  430. package/lib/decorators/compound.js +0 -49
  431. package/lib/decorators/computed.d.ts +0 -9
  432. package/lib/decorators/computed.d.ts.map +0 -1
  433. package/lib/decorators/computed.js +0 -18
  434. package/lib/decorators/defaultStyle.d.ts +0 -2
  435. package/lib/decorators/defaultStyle.d.ts.map +0 -1
  436. package/lib/decorators/defaultStyle.js +0 -14
  437. package/lib/decorators/filtersSignal.d.ts +0 -13
  438. package/lib/decorators/filtersSignal.d.ts.map +0 -1
  439. package/lib/decorators/filtersSignal.js +0 -73
  440. package/lib/decorators/index.d.ts +0 -11
  441. package/lib/decorators/index.d.ts.map +0 -1
  442. package/lib/decorators/index.js +0 -11
  443. package/lib/decorators/initializers.d.ts +0 -4
  444. package/lib/decorators/initializers.d.ts.map +0 -1
  445. package/lib/decorators/initializers.js +0 -27
  446. package/lib/decorators/nodeName.d.ts +0 -9
  447. package/lib/decorators/nodeName.d.ts.map +0 -1
  448. package/lib/decorators/nodeName.js +0 -13
  449. package/lib/decorators/signal.d.ts +0 -183
  450. package/lib/decorators/signal.d.ts.map +0 -1
  451. package/lib/decorators/signal.js +0 -285
  452. package/lib/decorators/spacingSignal.d.ts +0 -2
  453. package/lib/decorators/spacingSignal.d.ts.map +0 -1
  454. package/lib/decorators/spacingSignal.js +0 -15
  455. package/lib/decorators/vector2Signal.d.ts +0 -9
  456. package/lib/decorators/vector2Signal.d.ts.map +0 -1
  457. package/lib/decorators/vector2Signal.js +0 -15
  458. package/lib/index.d.ts +0 -9
  459. package/lib/index.d.ts.map +0 -1
  460. package/lib/index.js +0 -9
  461. package/lib/jsx-dev-runtime.d.ts +0 -3
  462. package/lib/jsx-dev-runtime.d.ts.map +0 -1
  463. package/lib/jsx-dev-runtime.js +0 -3
  464. package/lib/jsx-runtime.d.ts +0 -12
  465. package/lib/jsx-runtime.d.ts.map +0 -1
  466. package/lib/jsx-runtime.js +0 -23
  467. package/lib/partials/Filter.d.ts +0 -82
  468. package/lib/partials/Filter.d.ts.map +0 -1
  469. package/lib/partials/Filter.js +0 -135
  470. package/lib/partials/Gradient.d.ts +0 -31
  471. package/lib/partials/Gradient.d.ts.map +0 -1
  472. package/lib/partials/Gradient.js +0 -63
  473. package/lib/partials/Pattern.d.ts +0 -13
  474. package/lib/partials/Pattern.d.ts.map +0 -1
  475. package/lib/partials/Pattern.js +0 -27
  476. package/lib/partials/ShaderConfig.d.ts +0 -81
  477. package/lib/partials/ShaderConfig.d.ts.map +0 -1
  478. package/lib/partials/ShaderConfig.js +0 -25
  479. package/lib/partials/index.d.ts +0 -5
  480. package/lib/partials/index.d.ts.map +0 -1
  481. package/lib/partials/index.js +0 -5
  482. package/lib/partials/types.d.ts +0 -35
  483. package/lib/partials/types.d.ts.map +0 -1
  484. package/lib/partials/types.js +0 -2
  485. package/lib/scenes/Scene2D.d.ts +0 -29
  486. package/lib/scenes/Scene2D.d.ts.map +0 -1
  487. package/lib/scenes/Scene2D.js +0 -180
  488. package/lib/scenes/index.d.ts +0 -4
  489. package/lib/scenes/index.d.ts.map +0 -1
  490. package/lib/scenes/index.js +0 -4
  491. package/lib/scenes/makeScene2D.d.ts +0 -5
  492. package/lib/scenes/makeScene2D.d.ts.map +0 -1
  493. package/lib/scenes/makeScene2D.js +0 -11
  494. package/lib/scenes/useScene2D.d.ts +0 -3
  495. package/lib/scenes/useScene2D.d.ts.map +0 -1
  496. package/lib/scenes/useScene2D.js +0 -5
  497. package/lib/tsconfig.build.tsbuildinfo +0 -1
  498. package/lib/utils/CanvasUtils.d.ts +0 -23
  499. package/lib/utils/CanvasUtils.d.ts.map +0 -1
  500. package/lib/utils/CanvasUtils.js +0 -138
  501. package/lib/utils/diff.d.ts +0 -31
  502. package/lib/utils/diff.d.ts.map +0 -1
  503. package/lib/utils/diff.js +0 -97
  504. package/lib/utils/index.d.ts +0 -3
  505. package/lib/utils/index.d.ts.map +0 -1
  506. package/lib/utils/index.js +0 -3
  507. package/lib/utils/is.d.ts +0 -8
  508. package/lib/utils/is.d.ts.map +0 -1
  509. package/lib/utils/is.js +0 -10
  510. package/lib/utils/makeSignalExtensions.d.ts +0 -4
  511. package/lib/utils/makeSignalExtensions.d.ts.map +0 -1
  512. package/lib/utils/makeSignalExtensions.js +0 -20
  513. package/lib/utils/video/ffmpeg-client.d.ts +0 -5
  514. package/lib/utils/video/ffmpeg-client.d.ts.map +0 -1
  515. package/lib/utils/video/ffmpeg-client.js +0 -32
  516. package/lib/utils/video/mp4-parser-manager.d.ts +0 -3
  517. package/lib/utils/video/mp4-parser-manager.d.ts.map +0 -1
  518. package/lib/utils/video/mp4-parser-manager.js +0 -55
  519. package/lib/utils/video/parser/index.d.ts +0 -2
  520. package/lib/utils/video/parser/index.d.ts.map +0 -1
  521. package/lib/utils/video/parser/index.js +0 -2
  522. package/lib/utils/video/parser/parser.d.ts +0 -21
  523. package/lib/utils/video/parser/parser.d.ts.map +0 -1
  524. package/lib/utils/video/parser/parser.js +0 -168
  525. package/lib/utils/video/parser/sampler.d.ts +0 -16
  526. package/lib/utils/video/parser/sampler.d.ts.map +0 -1
  527. package/lib/utils/video/parser/sampler.js +0 -56
  528. package/lib/utils/video/parser/segment.d.ts +0 -48
  529. package/lib/utils/video/parser/segment.d.ts.map +0 -1
  530. package/lib/utils/video/parser/segment.js +0 -239
  531. package/lib/utils/video/parser/sink.d.ts +0 -9
  532. package/lib/utils/video/parser/sink.d.ts.map +0 -1
  533. package/lib/utils/video/parser/sink.js +0 -22
  534. package/lib/utils/video/parser/utils.d.ts +0 -10
  535. package/lib/utils/video/parser/utils.d.ts.map +0 -1
  536. package/lib/utils/video/parser/utils.js +0 -22
@@ -1,60 +1,60 @@
1
- import {createSignal, join, waitFor} from '@twick/core';
2
- import {describe, expect, it} from 'vitest';
3
- import {Circle} from '../Circle';
4
- import {generatorTest} from './generatorTest';
5
- import {mockScene2D} from './mockScene2D';
6
-
7
- describe('state', () => {
8
- mockScene2D();
9
-
10
- it('Restoring state', () => {
11
- const signal = createSignal(45);
12
- const circle = (
13
- <Circle lineWidth={8} startAngle={signal} end={0.5} />
14
- ) as Circle;
15
- circle.save();
16
-
17
- circle.lineWidth(16);
18
- circle.startAngle(90);
19
- circle.end(0.25);
20
-
21
- circle.restore();
22
-
23
- expect(circle.lineWidth()).toBe(8);
24
- expect(circle.startAngle()).toBe(45);
25
- expect(circle.end()).toBe(0.5);
26
-
27
- signal(180);
28
-
29
- expect(circle.startAngle()).toBe(45);
30
- expect(circle.startArrow.context.isInitial()).toBe(true);
31
- });
32
-
33
- it(
34
- 'Tweening state',
35
- generatorTest(function* () {
36
- const signal = createSignal(20);
37
- const circle = (
38
- <Circle lineWidth={8} startAngle={signal} end={0.5} />
39
- ) as Circle;
40
- circle.save();
41
-
42
- circle.lineWidth(16);
43
- circle.startAngle(40);
44
- circle.end(0.3);
45
-
46
- const task = yield circle.restore(2);
47
- yield* waitFor(1);
48
-
49
- expect(circle.lineWidth()).closeTo(12, 0.0001);
50
- expect(circle.startAngle()).closeTo(30, 0.0001);
51
- expect(circle.end()).closeTo(0.4, 0.0001);
52
-
53
- yield* join(task);
54
-
55
- expect(circle.lineWidth()).toBe(8);
56
- expect(circle.startAngle()).toBe(20);
57
- expect(circle.end()).toBe(0.5);
58
- }),
59
- );
60
- });
1
+ import {createSignal, join, waitFor} from '@twick/core';
2
+ import {describe, expect, it} from 'vitest';
3
+ import {Circle} from '../Circle';
4
+ import {generatorTest} from './generatorTest';
5
+ import {mockScene2D} from './mockScene2D';
6
+
7
+ describe('state', () => {
8
+ mockScene2D();
9
+
10
+ it('Restoring state', () => {
11
+ const signal = createSignal(45);
12
+ const circle = (
13
+ <Circle lineWidth={8} startAngle={signal} end={0.5} />
14
+ ) as Circle;
15
+ circle.save();
16
+
17
+ circle.lineWidth(16);
18
+ circle.startAngle(90);
19
+ circle.end(0.25);
20
+
21
+ circle.restore();
22
+
23
+ expect(circle.lineWidth()).toBe(8);
24
+ expect(circle.startAngle()).toBe(45);
25
+ expect(circle.end()).toBe(0.5);
26
+
27
+ signal(180);
28
+
29
+ expect(circle.startAngle()).toBe(45);
30
+ expect(circle.startArrow.context.isInitial()).toBe(true);
31
+ });
32
+
33
+ it(
34
+ 'Tweening state',
35
+ generatorTest(function* () {
36
+ const signal = createSignal(20);
37
+ const circle = (
38
+ <Circle lineWidth={8} startAngle={signal} end={0.5} />
39
+ ) as Circle;
40
+ circle.save();
41
+
42
+ circle.lineWidth(16);
43
+ circle.startAngle(40);
44
+ circle.end(0.3);
45
+
46
+ const task = yield circle.restore(2);
47
+ yield* waitFor(1);
48
+
49
+ expect(circle.lineWidth()).closeTo(12, 0.0001);
50
+ expect(circle.startAngle()).closeTo(30, 0.0001);
51
+ expect(circle.end()).closeTo(0.4, 0.0001);
52
+
53
+ yield* join(task);
54
+
55
+ expect(circle.lineWidth()).toBe(8);
56
+ expect(circle.startAngle()).toBe(20);
57
+ expect(circle.end()).toBe(0.5);
58
+ }),
59
+ );
60
+ });
@@ -1,28 +1,28 @@
1
- export * from './Audio';
2
- export * from './Bezier';
3
- export * from './Circle';
4
- export * from './Code';
5
- export * from './CubicBezier';
6
- export * from './Curve';
7
- export * from './Grid';
8
- export * from './Icon';
9
- export * from './Img';
10
- export * from './Knot';
11
- export * from './Latex';
12
- export * from './Layout';
13
- export * from './Line';
14
- export * from './Media';
15
- export * from './Node';
16
- export * from './Path';
17
- export * from './Polygon';
18
- export * from './QuadBezier';
19
- export * from './Ray';
20
- export * from './Rect';
21
- export * from './Rive';
22
- export * from './Shape';
23
- export * from './Spline';
24
- export * from './SVG';
25
- export * from './Txt';
26
- export * from './types';
27
- export * from './Video';
28
- export * from './View2D';
1
+ export * from './Audio';
2
+ export * from './Bezier';
3
+ export * from './Circle';
4
+ export * from './Code';
5
+ export * from './CubicBezier';
6
+ export * from './Curve';
7
+ export * from './Grid';
8
+ export * from './Icon';
9
+ export * from './Img';
10
+ export * from './Knot';
11
+ export * from './Latex';
12
+ export * from './Layout';
13
+ export * from './Line';
14
+ export * from './Media';
15
+ export * from './Node';
16
+ export * from './Path';
17
+ export * from './Polygon';
18
+ export * from './QuadBezier';
19
+ export * from './Ray';
20
+ export * from './Rect';
21
+ export * from './Rive';
22
+ export * from './Shape';
23
+ export * from './Spline';
24
+ export * from './SVG';
25
+ export * from './Txt';
26
+ export * from './types';
27
+ export * from './Video';
28
+ export * from './View2D';
@@ -1,35 +1,35 @@
1
- import type {ReferenceReceiver} from '@twick/core';
2
- import type {Node} from './Node';
3
-
4
- export type ComponentChild =
5
- | Node
6
- | object
7
- | string
8
- | number
9
- | bigint
10
- | boolean
11
- | null
12
- | undefined;
13
-
14
- export type ComponentChildren = ComponentChild | ComponentChild[];
15
- export type NodeChildren = Node | Node[];
16
-
17
- export type PropsOf<T> =
18
- T extends NodeConstructor<infer P>
19
- ? P
20
- : T extends FunctionComponent<infer P>
21
- ? P
22
- : never;
23
-
24
- export interface JSXProps {
25
- children?: ComponentChildren;
26
- ref?: ReferenceReceiver<Node>;
27
- }
28
-
29
- export interface FunctionComponent<T = any> {
30
- (props: T): Node | null;
31
- }
32
-
33
- export interface NodeConstructor<TProps = any, TNode = Node> {
34
- new (props: TProps): TNode;
35
- }
1
+ import type {ReferenceReceiver} from '@twick/core';
2
+ import type {Node} from './Node';
3
+
4
+ export type ComponentChild =
5
+ | Node
6
+ | object
7
+ | string
8
+ | number
9
+ | bigint
10
+ | boolean
11
+ | null
12
+ | undefined;
13
+
14
+ export type ComponentChildren = ComponentChild | ComponentChild[];
15
+ export type NodeChildren = Node | Node[];
16
+
17
+ export type PropsOf<T> =
18
+ T extends NodeConstructor<infer P>
19
+ ? P
20
+ : T extends FunctionComponent<infer P>
21
+ ? P
22
+ : never;
23
+
24
+ export interface JSXProps {
25
+ children?: ComponentChildren;
26
+ ref?: ReferenceReceiver<Node>;
27
+ }
28
+
29
+ export interface FunctionComponent<T = any> {
30
+ (props: T): Node | null;
31
+ }
32
+
33
+ export interface NodeConstructor<TProps = any, TNode = Node> {
34
+ new (props: TProps): TNode;
35
+ }
@@ -1,159 +1,159 @@
1
- import {
2
- BBox,
3
- DEG2RAD,
4
- Matrix2D,
5
- Vector2,
6
- lazy,
7
- transformVector,
8
- } from '@twick/core';
9
- import {View2D} from '../components/View2D';
10
- import type {CurvePoint} from './CurvePoint';
11
- import {Segment} from './Segment';
12
-
13
- export class ArcSegment extends Segment {
14
- @lazy(() => {
15
- const root = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
16
- const el = document.createElementNS('http://www.w3.org/2000/svg', 'path');
17
- root.appendChild(el);
18
- View2D.shadowRoot.appendChild(root);
19
- return el;
20
- })
21
- private static el: SVGPathElement;
22
- public readonly center: Vector2;
23
- // angle in radian
24
- public readonly startAngle: number;
25
- public readonly deltaAngle: number;
26
- public readonly xAxisRotation: number;
27
- private xAxisRotationMatrix: DOMMatrix;
28
- public override readonly points: Vector2[];
29
- private length: number;
30
-
31
- public constructor(
32
- public readonly startPoint: Vector2,
33
- public readonly radius: Vector2,
34
- public readonly xAxisRotationDegree: number,
35
- public readonly largeArcFlag: number,
36
- public readonly sweepFlag: number,
37
- public readonly endPoint: Vector2,
38
- ) {
39
- super();
40
-
41
- this.xAxisRotation = this.xAxisRotationDegree * DEG2RAD;
42
- this.radius = new Vector2(Math.abs(radius.x), Math.abs(radius.y));
43
-
44
- const rotationMatrix =
45
- Matrix2D.fromRotation(-xAxisRotationDegree).domMatrix;
46
- const pAccent = transformVector(
47
- startPoint.sub(endPoint).div(2),
48
- rotationMatrix,
49
- );
50
-
51
- const L =
52
- (pAccent.x * pAccent.x) / (radius.x * radius.x) +
53
- (pAccent.y * pAccent.y) / (radius.y * radius.y);
54
-
55
- if (L > 1) {
56
- const Lsqrt = Math.sqrt(L);
57
- radius.x = Lsqrt * radius.x;
58
- radius.y = Lsqrt * radius.y;
59
- }
60
-
61
- const cAccent = new Vector2(
62
- radius.ctg * pAccent.y,
63
- radius.perpendicular.ctg * pAccent.x,
64
- ).scale(
65
- Math.sqrt(
66
- 1 /
67
- ((pAccent.x * pAccent.x) / (radius.x * radius.x) +
68
- (pAccent.y * pAccent.y) / (radius.y * radius.y)) -
69
- 1,
70
- ) * (largeArcFlag === sweepFlag ? -1 : 1),
71
- );
72
-
73
- this.xAxisRotationMatrix =
74
- Matrix2D.fromRotation(xAxisRotationDegree).domMatrix;
75
- const rotatedCAccent = transformVector(cAccent, this.xAxisRotationMatrix);
76
- this.center = rotatedCAccent.add(startPoint.add(endPoint).div(2));
77
-
78
- const q = pAccent.sub(cAccent).div(radius);
79
- const s = pAccent.scale(-1).sub(cAccent).div(radius);
80
- this.startAngle = q.radians;
81
- this.deltaAngle = Vector2.angleBetween(q, s) % (Math.PI * 2);
82
- if (this.sweepFlag === 0 && this.deltaAngle > 0) {
83
- this.deltaAngle -= Math.PI * 2;
84
- }
85
- if (this.sweepFlag === 1 && this.deltaAngle < 0) {
86
- this.deltaAngle += Math.PI * 2;
87
- }
88
-
89
- ArcSegment.el.setAttribute(
90
- 'd',
91
- `M ${this.startPoint.x} ${this.startPoint.y} A ${this.radius.x} ${this.radius.y} ${this.xAxisRotationDegree} ${this.largeArcFlag} ${this.sweepFlag} ${this.endPoint.x} ${this.endPoint.y}`,
92
- );
93
- this.length = ArcSegment.el.getTotalLength();
94
-
95
- const bbox = new BBox(ArcSegment.el.getBBox());
96
- this.points = [bbox.topLeft, bbox.bottomRight];
97
- }
98
-
99
- public getAnglePosition(angle: number) {
100
- const rotatedVector = transformVector(
101
- this.radius.mul(Vector2.fromRadians(angle)),
102
- this.xAxisRotationMatrix,
103
- );
104
- return rotatedVector.add(this.center);
105
- }
106
-
107
- public getAngleDerivative(angle: number) {
108
- const derivative = new Vector2(
109
- -this.radius.x * Math.sin(angle),
110
- this.radius.y * Math.cos(angle),
111
- );
112
- return transformVector(derivative, this.xAxisRotationMatrix);
113
- }
114
-
115
- public draw(
116
- context: CanvasRenderingContext2D | Path2D,
117
- start: number,
118
- end: number,
119
- move: boolean,
120
- ): [CurvePoint, CurvePoint] {
121
- const startAngle = this.startAngle + this.deltaAngle * start;
122
- const endAngle = this.startAngle + this.deltaAngle * end;
123
- const startPos = this.getPoint(start);
124
- const endPos = this.getPoint(end);
125
-
126
- if (move) context.moveTo(startPos.position.x, startPos.position.y);
127
-
128
- context.ellipse(
129
- this.center.x,
130
- this.center.y,
131
- this.radius.x,
132
- this.radius.y,
133
- this.xAxisRotation,
134
- startAngle,
135
- endAngle,
136
- this.sweepFlag === 0,
137
- );
138
-
139
- return [startPos, endPos];
140
- }
141
-
142
- public getPoint(distance: number): CurvePoint {
143
- const angle = this.startAngle + distance * this.deltaAngle;
144
- const tangent = this.getAngleDerivative(angle).normalized;
145
- return {
146
- position:
147
- distance === 0
148
- ? this.startPoint
149
- : distance === 1
150
- ? this.endPoint
151
- : this.getAnglePosition(angle),
152
- tangent,
153
- normal: tangent.perpendicular,
154
- };
155
- }
156
- public get arcLength(): number {
157
- return this.length;
158
- }
159
- }
1
+ import {
2
+ BBox,
3
+ DEG2RAD,
4
+ Matrix2D,
5
+ Vector2,
6
+ lazy,
7
+ transformVector,
8
+ } from '@twick/core';
9
+ import {View2D} from '../components/View2D';
10
+ import type {CurvePoint} from './CurvePoint';
11
+ import {Segment} from './Segment';
12
+
13
+ export class ArcSegment extends Segment {
14
+ @lazy(() => {
15
+ const root = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
16
+ const el = document.createElementNS('http://www.w3.org/2000/svg', 'path');
17
+ root.appendChild(el);
18
+ View2D.shadowRoot.appendChild(root);
19
+ return el;
20
+ })
21
+ private static el: SVGPathElement;
22
+ public readonly center: Vector2;
23
+ // angle in radian
24
+ public readonly startAngle: number;
25
+ public readonly deltaAngle: number;
26
+ public readonly xAxisRotation: number;
27
+ private xAxisRotationMatrix: DOMMatrix;
28
+ public override readonly points: Vector2[];
29
+ private length: number;
30
+
31
+ public constructor(
32
+ public readonly startPoint: Vector2,
33
+ public readonly radius: Vector2,
34
+ public readonly xAxisRotationDegree: number,
35
+ public readonly largeArcFlag: number,
36
+ public readonly sweepFlag: number,
37
+ public readonly endPoint: Vector2,
38
+ ) {
39
+ super();
40
+
41
+ this.xAxisRotation = this.xAxisRotationDegree * DEG2RAD;
42
+ this.radius = new Vector2(Math.abs(radius.x), Math.abs(radius.y));
43
+
44
+ const rotationMatrix =
45
+ Matrix2D.fromRotation(-xAxisRotationDegree).domMatrix;
46
+ const pAccent = transformVector(
47
+ startPoint.sub(endPoint).div(2),
48
+ rotationMatrix,
49
+ );
50
+
51
+ const L =
52
+ (pAccent.x * pAccent.x) / (radius.x * radius.x) +
53
+ (pAccent.y * pAccent.y) / (radius.y * radius.y);
54
+
55
+ if (L > 1) {
56
+ const Lsqrt = Math.sqrt(L);
57
+ radius.x = Lsqrt * radius.x;
58
+ radius.y = Lsqrt * radius.y;
59
+ }
60
+
61
+ const cAccent = new Vector2(
62
+ radius.ctg * pAccent.y,
63
+ radius.perpendicular.ctg * pAccent.x,
64
+ ).scale(
65
+ Math.sqrt(
66
+ 1 /
67
+ ((pAccent.x * pAccent.x) / (radius.x * radius.x) +
68
+ (pAccent.y * pAccent.y) / (radius.y * radius.y)) -
69
+ 1,
70
+ ) * (largeArcFlag === sweepFlag ? -1 : 1),
71
+ );
72
+
73
+ this.xAxisRotationMatrix =
74
+ Matrix2D.fromRotation(xAxisRotationDegree).domMatrix;
75
+ const rotatedCAccent = transformVector(cAccent, this.xAxisRotationMatrix);
76
+ this.center = rotatedCAccent.add(startPoint.add(endPoint).div(2));
77
+
78
+ const q = pAccent.sub(cAccent).div(radius);
79
+ const s = pAccent.scale(-1).sub(cAccent).div(radius);
80
+ this.startAngle = q.radians;
81
+ this.deltaAngle = Vector2.angleBetween(q, s) % (Math.PI * 2);
82
+ if (this.sweepFlag === 0 && this.deltaAngle > 0) {
83
+ this.deltaAngle -= Math.PI * 2;
84
+ }
85
+ if (this.sweepFlag === 1 && this.deltaAngle < 0) {
86
+ this.deltaAngle += Math.PI * 2;
87
+ }
88
+
89
+ ArcSegment.el.setAttribute(
90
+ 'd',
91
+ `M ${this.startPoint.x} ${this.startPoint.y} A ${this.radius.x} ${this.radius.y} ${this.xAxisRotationDegree} ${this.largeArcFlag} ${this.sweepFlag} ${this.endPoint.x} ${this.endPoint.y}`,
92
+ );
93
+ this.length = ArcSegment.el.getTotalLength();
94
+
95
+ const bbox = new BBox(ArcSegment.el.getBBox());
96
+ this.points = [bbox.topLeft, bbox.bottomRight];
97
+ }
98
+
99
+ public getAnglePosition(angle: number) {
100
+ const rotatedVector = transformVector(
101
+ this.radius.mul(Vector2.fromRadians(angle)),
102
+ this.xAxisRotationMatrix,
103
+ );
104
+ return rotatedVector.add(this.center);
105
+ }
106
+
107
+ public getAngleDerivative(angle: number) {
108
+ const derivative = new Vector2(
109
+ -this.radius.x * Math.sin(angle),
110
+ this.radius.y * Math.cos(angle),
111
+ );
112
+ return transformVector(derivative, this.xAxisRotationMatrix);
113
+ }
114
+
115
+ public draw(
116
+ context: CanvasRenderingContext2D | Path2D,
117
+ start: number,
118
+ end: number,
119
+ move: boolean,
120
+ ): [CurvePoint, CurvePoint] {
121
+ const startAngle = this.startAngle + this.deltaAngle * start;
122
+ const endAngle = this.startAngle + this.deltaAngle * end;
123
+ const startPos = this.getPoint(start);
124
+ const endPos = this.getPoint(end);
125
+
126
+ if (move) context.moveTo(startPos.position.x, startPos.position.y);
127
+
128
+ context.ellipse(
129
+ this.center.x,
130
+ this.center.y,
131
+ this.radius.x,
132
+ this.radius.y,
133
+ this.xAxisRotation,
134
+ startAngle,
135
+ endAngle,
136
+ this.sweepFlag === 0,
137
+ );
138
+
139
+ return [startPos, endPos];
140
+ }
141
+
142
+ public getPoint(distance: number): CurvePoint {
143
+ const angle = this.startAngle + distance * this.deltaAngle;
144
+ const tangent = this.getAngleDerivative(angle).normalized;
145
+ return {
146
+ position:
147
+ distance === 0
148
+ ? this.startPoint
149
+ : distance === 1
150
+ ? this.endPoint
151
+ : this.getAnglePosition(angle),
152
+ tangent,
153
+ normal: tangent.perpendicular,
154
+ };
155
+ }
156
+ public get arcLength(): number {
157
+ return this.length;
158
+ }
159
+ }