@twick/2d 0.14.21 → 0.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (493) hide show
  1. package/dist/index.cjs +10806 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.cts +4657 -0
  4. package/dist/index.d.ts +4657 -0
  5. package/dist/index.js +10768 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/jsx-runtime.d.mts +1 -0
  8. package/dist/jsx-runtime.d.ts +1 -0
  9. package/editor/index.css +24 -22
  10. package/editor/index.css.map +1 -0
  11. package/editor/index.d.ts +5 -0
  12. package/editor/index.js +472 -258
  13. package/editor/index.js.map +1 -1
  14. package/package.json +54 -27
  15. package/tsconfig.project.json +3 -2
  16. package/lib/code/CodeCursor.d.ts +0 -83
  17. package/lib/code/CodeCursor.d.ts.map +0 -1
  18. package/lib/code/CodeCursor.js +0 -306
  19. package/lib/code/CodeDiffer.d.ts +0 -28
  20. package/lib/code/CodeDiffer.d.ts.map +0 -1
  21. package/lib/code/CodeDiffer.js +0 -51
  22. package/lib/code/CodeFragment.d.ts +0 -42
  23. package/lib/code/CodeFragment.d.ts.map +0 -1
  24. package/lib/code/CodeFragment.js +0 -72
  25. package/lib/code/CodeHighlighter.d.ts +0 -71
  26. package/lib/code/CodeHighlighter.d.ts.map +0 -1
  27. package/lib/code/CodeHighlighter.js +0 -2
  28. package/lib/code/CodeMetrics.d.ts +0 -11
  29. package/lib/code/CodeMetrics.d.ts.map +0 -1
  30. package/lib/code/CodeMetrics.js +0 -29
  31. package/lib/code/CodeRange.d.ts +0 -41
  32. package/lib/code/CodeRange.d.ts.map +0 -1
  33. package/lib/code/CodeRange.js +0 -179
  34. package/lib/code/CodeScope.d.ts +0 -16
  35. package/lib/code/CodeScope.d.ts.map +0 -1
  36. package/lib/code/CodeScope.js +0 -72
  37. package/lib/code/CodeSelection.d.ts +0 -6
  38. package/lib/code/CodeSelection.d.ts.map +0 -1
  39. package/lib/code/CodeSelection.js +0 -13
  40. package/lib/code/CodeSignal.d.ts +0 -60
  41. package/lib/code/CodeSignal.d.ts.map +0 -1
  42. package/lib/code/CodeSignal.js +0 -194
  43. package/lib/code/CodeTokenizer.d.ts +0 -8
  44. package/lib/code/CodeTokenizer.d.ts.map +0 -1
  45. package/lib/code/CodeTokenizer.js +0 -50
  46. package/lib/code/DefaultHighlightStyle.d.ts +0 -3
  47. package/lib/code/DefaultHighlightStyle.d.ts.map +0 -1
  48. package/lib/code/DefaultHighlightStyle.js +0 -98
  49. package/lib/code/LezerHighlighter.d.ts +0 -22
  50. package/lib/code/LezerHighlighter.d.ts.map +0 -1
  51. package/lib/code/LezerHighlighter.js +0 -89
  52. package/lib/code/diff.d.ts +0 -31
  53. package/lib/code/diff.d.ts.map +0 -1
  54. package/lib/code/diff.js +0 -236
  55. package/lib/code/extractRange.d.ts +0 -17
  56. package/lib/code/extractRange.d.ts.map +0 -1
  57. package/lib/code/extractRange.js +0 -102
  58. package/lib/code/index.d.ts +0 -14
  59. package/lib/code/index.d.ts.map +0 -1
  60. package/lib/code/index.js +0 -14
  61. package/lib/components/Audio.d.ts +0 -14
  62. package/lib/components/Audio.d.ts.map +0 -1
  63. package/lib/components/Audio.js +0 -148
  64. package/lib/components/Bezier.d.ts +0 -23
  65. package/lib/components/Bezier.d.ts.map +0 -1
  66. package/lib/components/Bezier.js +0 -81
  67. package/lib/components/Circle.d.ts +0 -193
  68. package/lib/components/Circle.d.ts.map +0 -1
  69. package/lib/components/Circle.js +0 -178
  70. package/lib/components/Code.d.ts +0 -231
  71. package/lib/components/Code.d.ts.map +0 -1
  72. package/lib/components/Code.js +0 -325
  73. package/lib/components/CodeBlock.d.ts +0 -133
  74. package/lib/components/CodeBlock.d.ts.map +0 -1
  75. package/lib/components/CodeBlock.js +0 -461
  76. package/lib/components/CubicBezier.d.ts +0 -70
  77. package/lib/components/CubicBezier.d.ts.map +0 -1
  78. package/lib/components/CubicBezier.js +0 -81
  79. package/lib/components/Curve.d.ts +0 -204
  80. package/lib/components/Curve.d.ts.map +0 -1
  81. package/lib/components/Curve.js +0 -284
  82. package/lib/components/Grid.d.ts +0 -76
  83. package/lib/components/Grid.d.ts.map +0 -1
  84. package/lib/components/Grid.js +0 -91
  85. package/lib/components/Icon.d.ts +0 -59
  86. package/lib/components/Icon.d.ts.map +0 -1
  87. package/lib/components/Icon.js +0 -58
  88. package/lib/components/Img.d.ts +0 -118
  89. package/lib/components/Img.d.ts.map +0 -1
  90. package/lib/components/Img.js +0 -245
  91. package/lib/components/Knot.d.ts +0 -90
  92. package/lib/components/Knot.d.ts.map +0 -1
  93. package/lib/components/Knot.js +0 -68
  94. package/lib/components/Latex.d.ts +0 -39
  95. package/lib/components/Latex.d.ts.map +0 -1
  96. package/lib/components/Latex.js +0 -101
  97. package/lib/components/Layout.d.ts +0 -419
  98. package/lib/components/Layout.d.ts.map +0 -1
  99. package/lib/components/Layout.js +0 -706
  100. package/lib/components/Line.d.ts +0 -160
  101. package/lib/components/Line.d.ts.map +0 -1
  102. package/lib/components/Line.js +0 -346
  103. package/lib/components/Media.d.ts +0 -70
  104. package/lib/components/Media.d.ts.map +0 -1
  105. package/lib/components/Media.js +0 -493
  106. package/lib/components/Node.d.ts +0 -836
  107. package/lib/components/Node.d.ts.map +0 -1
  108. package/lib/components/Node.js +0 -1317
  109. package/lib/components/Path.d.ts +0 -20
  110. package/lib/components/Path.d.ts.map +0 -1
  111. package/lib/components/Path.js +0 -97
  112. package/lib/components/Polygon.d.ts +0 -113
  113. package/lib/components/Polygon.d.ts.map +0 -1
  114. package/lib/components/Polygon.js +0 -123
  115. package/lib/components/QuadBezier.d.ts +0 -62
  116. package/lib/components/QuadBezier.d.ts.map +0 -1
  117. package/lib/components/QuadBezier.js +0 -76
  118. package/lib/components/Ray.d.ts +0 -62
  119. package/lib/components/Ray.d.ts.map +0 -1
  120. package/lib/components/Ray.js +0 -96
  121. package/lib/components/Rect.d.ts +0 -114
  122. package/lib/components/Rect.d.ts.map +0 -1
  123. package/lib/components/Rect.js +0 -76
  124. package/lib/components/Rive.d.ts +0 -22
  125. package/lib/components/Rive.d.ts.map +0 -1
  126. package/lib/components/Rive.js +0 -117
  127. package/lib/components/SVG.d.ts +0 -178
  128. package/lib/components/SVG.d.ts.map +0 -1
  129. package/lib/components/SVG.js +0 -577
  130. package/lib/components/Shape.d.ts +0 -40
  131. package/lib/components/Shape.d.ts.map +0 -1
  132. package/lib/components/Shape.js +0 -134
  133. package/lib/components/Spline.d.ts +0 -89
  134. package/lib/components/Spline.d.ts.map +0 -1
  135. package/lib/components/Spline.js +0 -256
  136. package/lib/components/Txt.d.ts +0 -53
  137. package/lib/components/Txt.d.ts.map +0 -1
  138. package/lib/components/Txt.js +0 -173
  139. package/lib/components/TxtLeaf.d.ts +0 -21
  140. package/lib/components/TxtLeaf.d.ts.map +0 -1
  141. package/lib/components/TxtLeaf.js +0 -181
  142. package/lib/components/Video.d.ts +0 -69
  143. package/lib/components/Video.d.ts.map +0 -1
  144. package/lib/components/Video.js +0 -342
  145. package/lib/components/View2D.d.ts +0 -28
  146. package/lib/components/View2D.d.ts.map +0 -1
  147. package/lib/components/View2D.js +0 -93
  148. package/lib/components/index.d.ts +0 -29
  149. package/lib/components/index.d.ts.map +0 -1
  150. package/lib/components/index.js +0 -29
  151. package/lib/components/types.d.ts +0 -17
  152. package/lib/components/types.d.ts.map +0 -1
  153. package/lib/components/types.js +0 -2
  154. package/lib/curves/ArcSegment.d.ts +0 -26
  155. package/lib/curves/ArcSegment.d.ts.map +0 -1
  156. package/lib/curves/ArcSegment.js +0 -97
  157. package/lib/curves/CircleSegment.d.ts +0 -18
  158. package/lib/curves/CircleSegment.d.ts.map +0 -1
  159. package/lib/curves/CircleSegment.js +0 -52
  160. package/lib/curves/CubicBezierSegment.d.ts +0 -18
  161. package/lib/curves/CubicBezierSegment.d.ts.map +0 -1
  162. package/lib/curves/CubicBezierSegment.js +0 -55
  163. package/lib/curves/CurveDrawingInfo.d.ts +0 -11
  164. package/lib/curves/CurveDrawingInfo.d.ts.map +0 -1
  165. package/lib/curves/CurveDrawingInfo.js +0 -2
  166. package/lib/curves/CurvePoint.d.ts +0 -15
  167. package/lib/curves/CurvePoint.d.ts.map +0 -1
  168. package/lib/curves/CurvePoint.js +0 -2
  169. package/lib/curves/CurveProfile.d.ts +0 -7
  170. package/lib/curves/CurveProfile.d.ts.map +0 -1
  171. package/lib/curves/CurveProfile.js +0 -2
  172. package/lib/curves/KnotInfo.d.ts +0 -12
  173. package/lib/curves/KnotInfo.d.ts.map +0 -1
  174. package/lib/curves/KnotInfo.js +0 -2
  175. package/lib/curves/LineSegment.d.ts +0 -16
  176. package/lib/curves/LineSegment.d.ts.map +0 -1
  177. package/lib/curves/LineSegment.js +0 -45
  178. package/lib/curves/Polynomial.d.ts +0 -118
  179. package/lib/curves/Polynomial.d.ts.map +0 -1
  180. package/lib/curves/Polynomial.js +0 -259
  181. package/lib/curves/Polynomial2D.d.ts +0 -22
  182. package/lib/curves/Polynomial2D.d.ts.map +0 -1
  183. package/lib/curves/Polynomial2D.js +0 -45
  184. package/lib/curves/PolynomialSegment.d.ts +0 -39
  185. package/lib/curves/PolynomialSegment.d.ts.map +0 -1
  186. package/lib/curves/PolynomialSegment.js +0 -86
  187. package/lib/curves/QuadBezierSegment.d.ts +0 -17
  188. package/lib/curves/QuadBezierSegment.d.ts.map +0 -1
  189. package/lib/curves/QuadBezierSegment.js +0 -49
  190. package/lib/curves/Segment.d.ts +0 -9
  191. package/lib/curves/Segment.d.ts.map +0 -1
  192. package/lib/curves/Segment.js +0 -3
  193. package/lib/curves/UniformPolynomialCurveSampler.d.ts +0 -43
  194. package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +0 -1
  195. package/lib/curves/UniformPolynomialCurveSampler.js +0 -73
  196. package/lib/curves/createCurveProfileLerp.d.ts +0 -32
  197. package/lib/curves/createCurveProfileLerp.d.ts.map +0 -1
  198. package/lib/curves/createCurveProfileLerp.js +0 -351
  199. package/lib/curves/getBezierSplineProfile.d.ts +0 -12
  200. package/lib/curves/getBezierSplineProfile.d.ts.map +0 -1
  201. package/lib/curves/getBezierSplineProfile.js +0 -137
  202. package/lib/curves/getCircleProfile.d.ts +0 -4
  203. package/lib/curves/getCircleProfile.d.ts.map +0 -1
  204. package/lib/curves/getCircleProfile.js +0 -44
  205. package/lib/curves/getPathProfile.d.ts +0 -3
  206. package/lib/curves/getPathProfile.d.ts.map +0 -1
  207. package/lib/curves/getPathProfile.js +0 -128
  208. package/lib/curves/getPointAtDistance.d.ts +0 -4
  209. package/lib/curves/getPointAtDistance.d.ts.map +0 -1
  210. package/lib/curves/getPointAtDistance.js +0 -15
  211. package/lib/curves/getPolylineProfile.d.ts +0 -4
  212. package/lib/curves/getPolylineProfile.d.ts.map +0 -1
  213. package/lib/curves/getPolylineProfile.js +0 -58
  214. package/lib/curves/getRectProfile.d.ts +0 -4
  215. package/lib/curves/getRectProfile.d.ts.map +0 -1
  216. package/lib/curves/getRectProfile.js +0 -57
  217. package/lib/curves/index.d.ts +0 -17
  218. package/lib/curves/index.d.ts.map +0 -1
  219. package/lib/curves/index.js +0 -17
  220. package/lib/decorators/canvasStyleSignal.d.ts +0 -5
  221. package/lib/decorators/canvasStyleSignal.d.ts.map +0 -1
  222. package/lib/decorators/canvasStyleSignal.js +0 -12
  223. package/lib/decorators/colorSignal.d.ts +0 -2
  224. package/lib/decorators/colorSignal.d.ts.map +0 -1
  225. package/lib/decorators/colorSignal.js +0 -9
  226. package/lib/decorators/compound.d.ts +0 -26
  227. package/lib/decorators/compound.d.ts.map +0 -1
  228. package/lib/decorators/compound.js +0 -49
  229. package/lib/decorators/computed.d.ts +0 -9
  230. package/lib/decorators/computed.d.ts.map +0 -1
  231. package/lib/decorators/computed.js +0 -18
  232. package/lib/decorators/defaultStyle.d.ts +0 -2
  233. package/lib/decorators/defaultStyle.d.ts.map +0 -1
  234. package/lib/decorators/defaultStyle.js +0 -14
  235. package/lib/decorators/filtersSignal.d.ts +0 -13
  236. package/lib/decorators/filtersSignal.d.ts.map +0 -1
  237. package/lib/decorators/filtersSignal.js +0 -73
  238. package/lib/decorators/index.d.ts +0 -11
  239. package/lib/decorators/index.d.ts.map +0 -1
  240. package/lib/decorators/index.js +0 -11
  241. package/lib/decorators/initializers.d.ts +0 -4
  242. package/lib/decorators/initializers.d.ts.map +0 -1
  243. package/lib/decorators/initializers.js +0 -27
  244. package/lib/decorators/nodeName.d.ts +0 -9
  245. package/lib/decorators/nodeName.d.ts.map +0 -1
  246. package/lib/decorators/nodeName.js +0 -13
  247. package/lib/decorators/signal.d.ts +0 -183
  248. package/lib/decorators/signal.d.ts.map +0 -1
  249. package/lib/decorators/signal.js +0 -285
  250. package/lib/decorators/spacingSignal.d.ts +0 -2
  251. package/lib/decorators/spacingSignal.d.ts.map +0 -1
  252. package/lib/decorators/spacingSignal.js +0 -15
  253. package/lib/decorators/vector2Signal.d.ts +0 -9
  254. package/lib/decorators/vector2Signal.d.ts.map +0 -1
  255. package/lib/decorators/vector2Signal.js +0 -15
  256. package/lib/index.d.ts +0 -9
  257. package/lib/index.d.ts.map +0 -1
  258. package/lib/index.js +0 -9
  259. package/lib/jsx-dev-runtime.d.ts +0 -3
  260. package/lib/jsx-dev-runtime.d.ts.map +0 -1
  261. package/lib/jsx-dev-runtime.js +0 -3
  262. package/lib/jsx-runtime.d.ts +0 -12
  263. package/lib/jsx-runtime.d.ts.map +0 -1
  264. package/lib/jsx-runtime.js +0 -23
  265. package/lib/partials/Filter.d.ts +0 -82
  266. package/lib/partials/Filter.d.ts.map +0 -1
  267. package/lib/partials/Filter.js +0 -135
  268. package/lib/partials/Gradient.d.ts +0 -31
  269. package/lib/partials/Gradient.d.ts.map +0 -1
  270. package/lib/partials/Gradient.js +0 -63
  271. package/lib/partials/Pattern.d.ts +0 -13
  272. package/lib/partials/Pattern.d.ts.map +0 -1
  273. package/lib/partials/Pattern.js +0 -27
  274. package/lib/partials/ShaderConfig.d.ts +0 -81
  275. package/lib/partials/ShaderConfig.d.ts.map +0 -1
  276. package/lib/partials/ShaderConfig.js +0 -25
  277. package/lib/partials/index.d.ts +0 -5
  278. package/lib/partials/index.d.ts.map +0 -1
  279. package/lib/partials/index.js +0 -5
  280. package/lib/partials/types.d.ts +0 -35
  281. package/lib/partials/types.d.ts.map +0 -1
  282. package/lib/partials/types.js +0 -2
  283. package/lib/scenes/Scene2D.d.ts +0 -29
  284. package/lib/scenes/Scene2D.d.ts.map +0 -1
  285. package/lib/scenes/Scene2D.js +0 -180
  286. package/lib/scenes/index.d.ts +0 -4
  287. package/lib/scenes/index.d.ts.map +0 -1
  288. package/lib/scenes/index.js +0 -4
  289. package/lib/scenes/makeScene2D.d.ts +0 -5
  290. package/lib/scenes/makeScene2D.d.ts.map +0 -1
  291. package/lib/scenes/makeScene2D.js +0 -11
  292. package/lib/scenes/useScene2D.d.ts +0 -3
  293. package/lib/scenes/useScene2D.d.ts.map +0 -1
  294. package/lib/scenes/useScene2D.js +0 -5
  295. package/lib/tsconfig.build.tsbuildinfo +0 -1
  296. package/lib/utils/CanvasUtils.d.ts +0 -23
  297. package/lib/utils/CanvasUtils.d.ts.map +0 -1
  298. package/lib/utils/CanvasUtils.js +0 -138
  299. package/lib/utils/diff.d.ts +0 -31
  300. package/lib/utils/diff.d.ts.map +0 -1
  301. package/lib/utils/diff.js +0 -97
  302. package/lib/utils/index.d.ts +0 -3
  303. package/lib/utils/index.d.ts.map +0 -1
  304. package/lib/utils/index.js +0 -3
  305. package/lib/utils/is.d.ts +0 -8
  306. package/lib/utils/is.d.ts.map +0 -1
  307. package/lib/utils/is.js +0 -10
  308. package/lib/utils/makeSignalExtensions.d.ts +0 -4
  309. package/lib/utils/makeSignalExtensions.d.ts.map +0 -1
  310. package/lib/utils/makeSignalExtensions.js +0 -20
  311. package/lib/utils/video/ffmpeg-client.d.ts +0 -5
  312. package/lib/utils/video/ffmpeg-client.d.ts.map +0 -1
  313. package/lib/utils/video/ffmpeg-client.js +0 -32
  314. package/lib/utils/video/mp4-parser-manager.d.ts +0 -3
  315. package/lib/utils/video/mp4-parser-manager.d.ts.map +0 -1
  316. package/lib/utils/video/mp4-parser-manager.js +0 -55
  317. package/lib/utils/video/parser/index.d.ts +0 -2
  318. package/lib/utils/video/parser/index.d.ts.map +0 -1
  319. package/lib/utils/video/parser/index.js +0 -2
  320. package/lib/utils/video/parser/parser.d.ts +0 -21
  321. package/lib/utils/video/parser/parser.d.ts.map +0 -1
  322. package/lib/utils/video/parser/parser.js +0 -168
  323. package/lib/utils/video/parser/sampler.d.ts +0 -16
  324. package/lib/utils/video/parser/sampler.d.ts.map +0 -1
  325. package/lib/utils/video/parser/sampler.js +0 -56
  326. package/lib/utils/video/parser/segment.d.ts +0 -48
  327. package/lib/utils/video/parser/segment.d.ts.map +0 -1
  328. package/lib/utils/video/parser/segment.js +0 -239
  329. package/lib/utils/video/parser/sink.d.ts +0 -9
  330. package/lib/utils/video/parser/sink.d.ts.map +0 -1
  331. package/lib/utils/video/parser/sink.js +0 -22
  332. package/lib/utils/video/parser/utils.d.ts +0 -10
  333. package/lib/utils/video/parser/utils.d.ts.map +0 -1
  334. package/lib/utils/video/parser/utils.js +0 -22
  335. package/src/editor/NodeInspectorConfig.tsx +0 -76
  336. package/src/editor/PreviewOverlayConfig.tsx +0 -67
  337. package/src/editor/Provider.tsx +0 -93
  338. package/src/editor/SceneGraphTabConfig.tsx +0 -81
  339. package/src/editor/icons/CircleIcon.tsx +0 -7
  340. package/src/editor/icons/CodeBlockIcon.tsx +0 -8
  341. package/src/editor/icons/CurveIcon.tsx +0 -7
  342. package/src/editor/icons/GridIcon.tsx +0 -7
  343. package/src/editor/icons/IconMap.ts +0 -35
  344. package/src/editor/icons/ImgIcon.tsx +0 -8
  345. package/src/editor/icons/LayoutIcon.tsx +0 -9
  346. package/src/editor/icons/LineIcon.tsx +0 -7
  347. package/src/editor/icons/NodeIcon.tsx +0 -7
  348. package/src/editor/icons/RayIcon.tsx +0 -7
  349. package/src/editor/icons/RectIcon.tsx +0 -7
  350. package/src/editor/icons/ShapeIcon.tsx +0 -7
  351. package/src/editor/icons/TxtIcon.tsx +0 -8
  352. package/src/editor/icons/VideoIcon.tsx +0 -7
  353. package/src/editor/icons/View2DIcon.tsx +0 -10
  354. package/src/editor/index.css +0 -0
  355. package/src/editor/index.ts +0 -17
  356. package/src/editor/tree/DetachedRoot.tsx +0 -23
  357. package/src/editor/tree/NodeElement.tsx +0 -74
  358. package/src/editor/tree/TreeElement.tsx +0 -72
  359. package/src/editor/tree/TreeRoot.tsx +0 -10
  360. package/src/editor/tree/ViewRoot.tsx +0 -20
  361. package/src/editor/tree/index.module.scss +0 -38
  362. package/src/editor/tree/index.ts +0 -3
  363. package/src/editor/tsconfig.build.json +0 -5
  364. package/src/editor/tsconfig.json +0 -12
  365. package/src/editor/tsdoc.json +0 -4
  366. package/src/editor/vite-env.d.ts +0 -1
  367. package/src/lib/code/CodeCursor.ts +0 -445
  368. package/src/lib/code/CodeDiffer.ts +0 -78
  369. package/src/lib/code/CodeFragment.ts +0 -97
  370. package/src/lib/code/CodeHighlighter.ts +0 -75
  371. package/src/lib/code/CodeMetrics.ts +0 -47
  372. package/src/lib/code/CodeRange.test.ts +0 -74
  373. package/src/lib/code/CodeRange.ts +0 -216
  374. package/src/lib/code/CodeScope.ts +0 -101
  375. package/src/lib/code/CodeSelection.ts +0 -24
  376. package/src/lib/code/CodeSignal.ts +0 -327
  377. package/src/lib/code/CodeTokenizer.ts +0 -54
  378. package/src/lib/code/DefaultHighlightStyle.ts +0 -98
  379. package/src/lib/code/LezerHighlighter.ts +0 -113
  380. package/src/lib/code/diff.test.ts +0 -311
  381. package/src/lib/code/diff.ts +0 -319
  382. package/src/lib/code/extractRange.ts +0 -126
  383. package/src/lib/code/index.ts +0 -13
  384. package/src/lib/components/Audio.ts +0 -168
  385. package/src/lib/components/Bezier.ts +0 -105
  386. package/src/lib/components/Circle.ts +0 -266
  387. package/src/lib/components/Code.ts +0 -526
  388. package/src/lib/components/CodeBlock.ts +0 -576
  389. package/src/lib/components/CubicBezier.ts +0 -112
  390. package/src/lib/components/Curve.ts +0 -455
  391. package/src/lib/components/Grid.ts +0 -135
  392. package/src/lib/components/Icon.ts +0 -96
  393. package/src/lib/components/Img.ts +0 -319
  394. package/src/lib/components/Knot.ts +0 -157
  395. package/src/lib/components/Latex.ts +0 -122
  396. package/src/lib/components/Layout.ts +0 -1092
  397. package/src/lib/components/Line.ts +0 -429
  398. package/src/lib/components/Media.ts +0 -576
  399. package/src/lib/components/Node.ts +0 -1940
  400. package/src/lib/components/Path.ts +0 -137
  401. package/src/lib/components/Polygon.ts +0 -171
  402. package/src/lib/components/QuadBezier.ts +0 -100
  403. package/src/lib/components/Ray.ts +0 -125
  404. package/src/lib/components/Rect.ts +0 -187
  405. package/src/lib/components/Rive.ts +0 -156
  406. package/src/lib/components/SVG.ts +0 -797
  407. package/src/lib/components/Shape.ts +0 -143
  408. package/src/lib/components/Spline.ts +0 -344
  409. package/src/lib/components/Txt.test.tsx +0 -81
  410. package/src/lib/components/Txt.ts +0 -203
  411. package/src/lib/components/TxtLeaf.ts +0 -205
  412. package/src/lib/components/Video.ts +0 -461
  413. package/src/lib/components/View2D.ts +0 -98
  414. package/src/lib/components/__tests__/children.test.tsx +0 -142
  415. package/src/lib/components/__tests__/clone.test.tsx +0 -126
  416. package/src/lib/components/__tests__/generatorTest.ts +0 -28
  417. package/src/lib/components/__tests__/mockScene2D.ts +0 -45
  418. package/src/lib/components/__tests__/query.test.tsx +0 -122
  419. package/src/lib/components/__tests__/state.test.tsx +0 -60
  420. package/src/lib/components/index.ts +0 -28
  421. package/src/lib/components/types.ts +0 -35
  422. package/src/lib/curves/ArcSegment.ts +0 -159
  423. package/src/lib/curves/CircleSegment.ts +0 -77
  424. package/src/lib/curves/CubicBezierSegment.ts +0 -78
  425. package/src/lib/curves/CurveDrawingInfo.ts +0 -11
  426. package/src/lib/curves/CurvePoint.ts +0 -15
  427. package/src/lib/curves/CurveProfile.ts +0 -7
  428. package/src/lib/curves/KnotInfo.ts +0 -10
  429. package/src/lib/curves/LineSegment.ts +0 -62
  430. package/src/lib/curves/Polynomial.ts +0 -355
  431. package/src/lib/curves/Polynomial2D.ts +0 -62
  432. package/src/lib/curves/PolynomialSegment.ts +0 -124
  433. package/src/lib/curves/QuadBezierSegment.ts +0 -64
  434. package/src/lib/curves/Segment.ts +0 -17
  435. package/src/lib/curves/UniformPolynomialCurveSampler.ts +0 -94
  436. package/src/lib/curves/createCurveProfileLerp.ts +0 -471
  437. package/src/lib/curves/getBezierSplineProfile.ts +0 -223
  438. package/src/lib/curves/getCircleProfile.ts +0 -86
  439. package/src/lib/curves/getPathProfile.ts +0 -178
  440. package/src/lib/curves/getPointAtDistance.ts +0 -21
  441. package/src/lib/curves/getPolylineProfile.test.ts +0 -21
  442. package/src/lib/curves/getPolylineProfile.ts +0 -89
  443. package/src/lib/curves/getRectProfile.ts +0 -139
  444. package/src/lib/curves/index.ts +0 -16
  445. package/src/lib/decorators/canvasStyleSignal.ts +0 -16
  446. package/src/lib/decorators/colorSignal.ts +0 -9
  447. package/src/lib/decorators/compound.ts +0 -72
  448. package/src/lib/decorators/computed.ts +0 -18
  449. package/src/lib/decorators/defaultStyle.ts +0 -18
  450. package/src/lib/decorators/filtersSignal.ts +0 -136
  451. package/src/lib/decorators/index.ts +0 -10
  452. package/src/lib/decorators/initializers.ts +0 -32
  453. package/src/lib/decorators/nodeName.ts +0 -13
  454. package/src/lib/decorators/signal.test.ts +0 -90
  455. package/src/lib/decorators/signal.ts +0 -345
  456. package/src/lib/decorators/spacingSignal.ts +0 -15
  457. package/src/lib/decorators/vector2Signal.ts +0 -30
  458. package/src/lib/globals.d.ts +0 -2
  459. package/src/lib/index.ts +0 -8
  460. package/src/lib/jsx-dev-runtime.ts +0 -2
  461. package/src/lib/jsx-runtime.ts +0 -46
  462. package/src/lib/parse-svg-path.d.ts +0 -14
  463. package/src/lib/partials/Filter.ts +0 -180
  464. package/src/lib/partials/Gradient.ts +0 -102
  465. package/src/lib/partials/Pattern.ts +0 -34
  466. package/src/lib/partials/ShaderConfig.ts +0 -117
  467. package/src/lib/partials/index.ts +0 -4
  468. package/src/lib/partials/types.ts +0 -58
  469. package/src/lib/scenes/Scene2D.ts +0 -242
  470. package/src/lib/scenes/index.ts +0 -3
  471. package/src/lib/scenes/makeScene2D.ts +0 -16
  472. package/src/lib/scenes/useScene2D.ts +0 -6
  473. package/src/lib/tsconfig.build.json +0 -5
  474. package/src/lib/tsconfig.json +0 -10
  475. package/src/lib/tsdoc.json +0 -4
  476. package/src/lib/utils/CanvasUtils.ts +0 -306
  477. package/src/lib/utils/diff.test.ts +0 -453
  478. package/src/lib/utils/diff.ts +0 -148
  479. package/src/lib/utils/index.ts +0 -2
  480. package/src/lib/utils/is.ts +0 -11
  481. package/src/lib/utils/makeSignalExtensions.ts +0 -30
  482. package/src/lib/utils/video/declarations.d.ts +0 -1
  483. package/src/lib/utils/video/ffmpeg-client.ts +0 -50
  484. package/src/lib/utils/video/mp4-parser-manager.ts +0 -72
  485. package/src/lib/utils/video/parser/index.ts +0 -1
  486. package/src/lib/utils/video/parser/parser.ts +0 -257
  487. package/src/lib/utils/video/parser/sampler.ts +0 -72
  488. package/src/lib/utils/video/parser/segment.ts +0 -302
  489. package/src/lib/utils/video/parser/sink.ts +0 -29
  490. package/src/lib/utils/video/parser/utils.ts +0 -31
  491. package/src/tsconfig.base.json +0 -19
  492. package/src/tsconfig.build.json +0 -8
  493. package/src/tsconfig.json +0 -5
@@ -1,242 +0,0 @@
1
- import type {
2
- AssetInfo,
3
- FullSceneDescription,
4
- Inspectable,
5
- InspectedAttributes,
6
- InspectedElement,
7
- Scene,
8
- ThreadGeneratorFactory,
9
- } from '@twick/core';
10
- import {
11
- GeneratorScene,
12
- SceneRenderEvent,
13
- Vector2,
14
- transformVectorAsPoint,
15
- useLogger,
16
- } from '@twick/core';
17
- import type {Node} from '../components';
18
- import {Audio, Media, Video, View2D} from '../components';
19
-
20
- export class Scene2D extends GeneratorScene<View2D> implements Inspectable {
21
- private view: View2D | null = null;
22
- private registeredNodes = new Map<string, Node>();
23
- private readonly nodeCounters = new Map<string, number>();
24
- private assetHash = Date.now().toString();
25
-
26
- public constructor(
27
- description: FullSceneDescription<ThreadGeneratorFactory<View2D>>,
28
- ) {
29
- super(description);
30
- this.recreateView();
31
- if (import.meta.hot) {
32
- import.meta.hot.on('twick:assets', () => {
33
- this.assetHash = Date.now().toString();
34
- this.getView().assetHash(this.assetHash);
35
- });
36
- }
37
- }
38
-
39
- public getView(): View2D {
40
- return this.view!;
41
- }
42
-
43
- public override next(): Promise<void> {
44
- this.getView()
45
- ?.playbackState(this.playback.state)
46
- .globalTime(this.playback.time);
47
- return super.next();
48
- }
49
-
50
- public async draw(context: CanvasRenderingContext2D) {
51
- context.save();
52
- this.renderLifecycle.dispatch([SceneRenderEvent.BeforeRender, context]);
53
- context.save();
54
- this.renderLifecycle.dispatch([SceneRenderEvent.BeginRender, context]);
55
- this.getView()
56
- .playbackState(this.playback.state)
57
- .globalTime(this.playback.time)
58
- .fps(this.playback.fps);
59
- await this.getView().render(context);
60
- this.renderLifecycle.dispatch([SceneRenderEvent.FinishRender, context]);
61
- context.restore();
62
- this.renderLifecycle.dispatch([SceneRenderEvent.AfterRender, context]);
63
- context.restore();
64
- }
65
-
66
- public override reset(previousScene?: Scene): Promise<void> {
67
- for (const key of this.registeredNodes.keys()) {
68
- try {
69
- this.registeredNodes.get(key)!.dispose();
70
- } catch (e: any) {
71
- this.logger.error(e);
72
- }
73
- }
74
- this.registeredNodes.clear();
75
- this.registeredNodes = new Map<string, Node>();
76
- this.nodeCounters.clear();
77
- this.recreateView();
78
-
79
- return super.reset(previousScene);
80
- }
81
-
82
- public inspectPosition(x: number, y: number): InspectedElement | null {
83
- const node = this.getNodeByPosition(x, y);
84
- return node?.key;
85
- }
86
-
87
- public getNodeByPosition(x: number, y: number): Node | null {
88
- return this.execute(() => this.getView().hit(new Vector2(x, y)) ?? null);
89
- }
90
-
91
- public validateInspection(
92
- element: InspectedElement | null,
93
- ): InspectedElement | null {
94
- return this.getNode(element)?.key ?? null;
95
- }
96
-
97
- public inspectAttributes(
98
- element: InspectedElement,
99
- ): InspectedAttributes | null {
100
- const node = this.getNode(element);
101
- if (!node) return null;
102
-
103
- const attributes: Record<string, any> = {
104
- stack: node.creationStack,
105
- key: node.key,
106
- };
107
- for (const {key, meta, signal} of node) {
108
- if (!meta.inspectable) continue;
109
- attributes[key] = signal();
110
- }
111
-
112
- return attributes;
113
- }
114
-
115
- public drawOverlay(
116
- element: InspectedElement,
117
- matrix: DOMMatrix,
118
- context: CanvasRenderingContext2D,
119
- ): void {
120
- const node = this.getNode(element);
121
- if (node) {
122
- this.execute(() => {
123
- node.drawOverlay(context, matrix.multiply(node.localToWorld()));
124
- });
125
- }
126
- }
127
-
128
- public transformMousePosition(x: number, y: number): Vector2 | null {
129
- return transformVectorAsPoint(
130
- new Vector2(x, y),
131
- this.getView().localToParent().inverse(),
132
- );
133
- }
134
-
135
- public registerNode(node: Node, key?: string): [string, () => void] {
136
- const className = node.constructor?.name ?? 'unknown';
137
- const counter = (this.nodeCounters.get(className) ?? 0) + 1;
138
- this.nodeCounters.set(className, counter);
139
-
140
- if (key && this.registeredNodes.has(key)) {
141
- useLogger().error({
142
- message: `Duplicated node key: "${key}".`,
143
- inspect: key,
144
- stack: new Error().stack,
145
- });
146
- key = undefined;
147
- }
148
-
149
- key ??= `${this.name}/${className}[${counter}]`;
150
- this.registeredNodes.set(key, node);
151
- const currentNodeMap = this.registeredNodes;
152
- return [key, () => currentNodeMap.delete(key!)];
153
- }
154
-
155
- public getNode(key: any): Node | null {
156
- if (typeof key !== 'string') return null;
157
- return this.registeredNodes.get(key) ?? null;
158
- }
159
-
160
- public *getDetachedNodes() {
161
- for (const node of this.registeredNodes.values()) {
162
- if (!node.parent() && node !== this.view) yield node;
163
- }
164
- }
165
-
166
- public override getMediaAssets(): Array<AssetInfo> {
167
- const playingVideos = Array.from(this.registeredNodes.values())
168
- .filter((node): node is Video => node instanceof Video)
169
- .filter(video => (video as Video).isPlaying());
170
-
171
- const playingAudios = Array.from(this.registeredNodes.values())
172
- .filter((node): node is Audio => node instanceof Audio)
173
- .filter(audio => (audio as Audio).isPlaying());
174
-
175
- const returnObjects: AssetInfo[] = [];
176
-
177
- returnObjects.push(
178
- ...playingVideos.map(vid => ({
179
- key: vid.key,
180
- type: 'video' as const,
181
- src: vid.src(),
182
- decoder: vid.decoder(),
183
- playbackRate:
184
- typeof vid.playbackRate === 'function'
185
- ? vid.playbackRate()
186
- : vid.playbackRate,
187
- volume: vid.getVolume(),
188
- currentTime: vid.getCurrentTime(),
189
- duration: vid.getDuration(),
190
- })),
191
- );
192
-
193
- returnObjects.push(
194
- ...playingAudios.map(audio => ({
195
- key: audio.key,
196
- type: 'audio' as const,
197
- src: audio.src(),
198
- playbackRate:
199
- typeof audio.playbackRate === 'function'
200
- ? audio.playbackRate()
201
- : audio.playbackRate,
202
- volume: audio.getVolume(),
203
- currentTime: audio.getCurrentTime(),
204
- duration: audio.getDuration(),
205
- })),
206
- );
207
-
208
- return returnObjects;
209
- }
210
-
211
- public override stopAllMedia() {
212
- const playingMedia = Array.from(this.registeredNodes.values())
213
- .filter((node): node is Media => node instanceof Media)
214
- .filter(video => (video as Media).isPlaying());
215
-
216
- for (const media of playingMedia) {
217
- media.dispose();
218
- }
219
- }
220
-
221
- public override adjustVolume(volumeScale: number) {
222
- const mediaNodes = Array.from(this.registeredNodes.values()).filter(
223
- (node): node is Media => node instanceof Media,
224
- );
225
-
226
- for (const media of mediaNodes) {
227
- media.setVolume(media.getVolume() * volumeScale);
228
- }
229
- }
230
-
231
- protected recreateView() {
232
- this.execute(() => {
233
- const size = this.getSize();
234
- this.view = new View2D({
235
- position: size.scale(this.resolutionScale / 2),
236
- scale: this.resolutionScale,
237
- assetHash: this.assetHash,
238
- size,
239
- });
240
- });
241
- }
242
- }
@@ -1,3 +0,0 @@
1
- export * from './makeScene2D';
2
- export * from './Scene2D';
3
- export * from './useScene2D';
@@ -1,16 +0,0 @@
1
- import type {DescriptionOf, ThreadGeneratorFactory} from '@twick/core';
2
- import type {View2D} from '../components';
3
- import {Scene2D} from './Scene2D';
4
-
5
- export function makeScene2D(
6
- name: string,
7
- runner: ThreadGeneratorFactory<View2D>,
8
- ): DescriptionOf<Scene2D> {
9
- return {
10
- klass: Scene2D,
11
- name,
12
- config: runner,
13
- stack: new Error().stack,
14
- plugins: ['@twick/2d/editor'],
15
- };
16
- }
@@ -1,6 +0,0 @@
1
- import {useScene} from '@twick/core';
2
- import type {Scene2D} from './Scene2D';
3
-
4
- export function useScene2D(): Scene2D {
5
- return <Scene2D>useScene();
6
- }
@@ -1,5 +0,0 @@
1
- {
2
- "extends": "./tsconfig.json",
3
- "include": ["**/*"],
4
- "exclude": ["**/*.test.*", "**/__tests__/**/*"]
5
- }
@@ -1,10 +0,0 @@
1
- {
2
- "extends": "../tsconfig.base.json",
3
- "compilerOptions": {
4
- "types": ["node"],
5
- "jsx": "react-jsx",
6
- "jsxImportSource": "@twick/2d/src/lib"
7
- },
8
- "include": ["**/*"],
9
- "exclude": []
10
- }
@@ -1,4 +0,0 @@
1
- {
2
- "$schema": "https://developer.microsoft.com/json-schemas/tsdoc/v0/tsdoc.schema.json",
3
- "extends": ["../../../../tsdoc.json"]
4
- }
@@ -1,306 +0,0 @@
1
- import type {BBox, Spacing} from '@twick/core';
2
- import {Color, Vector2} from '@twick/core';
3
- import type {CanvasStyle, PossibleCanvasStyle} from '../partials';
4
- import {Gradient, Pattern} from '../partials';
5
-
6
- export function canvasStyleParser(style: PossibleCanvasStyle) {
7
- if (style === null) {
8
- return null;
9
- }
10
- if (style instanceof Gradient) {
11
- return style;
12
- }
13
- if (style instanceof Pattern) {
14
- return style;
15
- }
16
-
17
- return new Color(style);
18
- }
19
-
20
- export function resolveCanvasStyle(
21
- style: CanvasStyle,
22
- context: CanvasRenderingContext2D,
23
- ): string | CanvasGradient | CanvasPattern {
24
- if (style === null) {
25
- return '';
26
- }
27
- if (style instanceof Color) {
28
- return (<Color>style).serialize();
29
- }
30
- if (style instanceof Gradient) {
31
- return style.canvasGradient(context);
32
- }
33
- if (style instanceof Pattern) {
34
- return style.canvasPattern(context) ?? '';
35
- }
36
-
37
- return '';
38
- }
39
-
40
- export function drawRoundRect(
41
- context: CanvasRenderingContext2D | Path2D,
42
- rect: BBox,
43
- radius: Spacing,
44
- smoothCorners: boolean,
45
- cornerSharpness: number,
46
- ) {
47
- if (
48
- radius.top === 0 &&
49
- radius.right === 0 &&
50
- radius.bottom === 0 &&
51
- radius.left === 0
52
- ) {
53
- drawRect(context, rect);
54
- return;
55
- }
56
-
57
- const topLeft = adjustRectRadius(radius.top, radius.right, radius.left, rect);
58
- const topRight = adjustRectRadius(
59
- radius.right,
60
- radius.top,
61
- radius.bottom,
62
- rect,
63
- );
64
- const bottomRight = adjustRectRadius(
65
- radius.bottom,
66
- radius.left,
67
- radius.right,
68
- rect,
69
- );
70
- const bottomLeft = adjustRectRadius(
71
- radius.left,
72
- radius.bottom,
73
- radius.top,
74
- rect,
75
- );
76
-
77
- if (smoothCorners) {
78
- const sharpness = (radius: number): number => {
79
- const val = radius * cornerSharpness;
80
- return radius - val;
81
- };
82
-
83
- context.moveTo(rect.left + topLeft, rect.top);
84
- context.lineTo(rect.right - topRight, rect.top);
85
-
86
- context.bezierCurveTo(
87
- rect.right - sharpness(topRight),
88
- rect.top,
89
- rect.right,
90
- rect.top + sharpness(topRight),
91
- rect.right,
92
- rect.top + topRight,
93
- );
94
- context.lineTo(rect.right, rect.bottom - bottomRight);
95
-
96
- context.bezierCurveTo(
97
- rect.right,
98
- rect.bottom - sharpness(bottomRight),
99
- rect.right - sharpness(bottomRight),
100
- rect.bottom,
101
- rect.right - bottomRight,
102
- rect.bottom,
103
- );
104
- context.lineTo(rect.left + bottomLeft, rect.bottom);
105
-
106
- context.bezierCurveTo(
107
- rect.left + sharpness(bottomLeft),
108
- rect.bottom,
109
- rect.left,
110
- rect.bottom - sharpness(bottomLeft),
111
- rect.left,
112
- rect.bottom - bottomLeft,
113
- );
114
- context.lineTo(rect.left, rect.top + topLeft);
115
-
116
- context.bezierCurveTo(
117
- rect.left,
118
- rect.top + sharpness(topLeft),
119
- rect.left + sharpness(topLeft),
120
- rect.top,
121
- rect.left + topLeft,
122
- rect.top,
123
- );
124
- return;
125
- }
126
-
127
- context.moveTo(rect.left + topLeft, rect.top);
128
- context.arcTo(rect.right, rect.top, rect.right, rect.bottom, topRight);
129
- context.arcTo(rect.right, rect.bottom, rect.left, rect.bottom, bottomRight);
130
- context.arcTo(rect.left, rect.bottom, rect.left, rect.top, bottomLeft);
131
- context.arcTo(rect.left, rect.top, rect.right, rect.top, topLeft);
132
- }
133
-
134
- export function adjustRectRadius(
135
- radius: number,
136
- horizontal: number,
137
- vertical: number,
138
- rect: BBox,
139
- ): number {
140
- const width =
141
- radius + horizontal > rect.width
142
- ? rect.width * (radius / (radius + horizontal))
143
- : radius;
144
- const height =
145
- radius + vertical > rect.height
146
- ? rect.height * (radius / (radius + vertical))
147
- : radius;
148
-
149
- return Math.min(width, height);
150
- }
151
-
152
- export function drawRect(
153
- context: CanvasRenderingContext2D | Path2D,
154
- rect: BBox,
155
- ) {
156
- context.rect(rect.x, rect.y, rect.width, rect.height);
157
- }
158
-
159
- export function fillRect(context: CanvasRenderingContext2D, rect: BBox) {
160
- context.fillRect(rect.x, rect.y, rect.width, rect.height);
161
- }
162
-
163
- export function strokeRect(context: CanvasRenderingContext2D, rect: BBox) {
164
- context.strokeRect(rect.x, rect.y, rect.width, rect.height);
165
- }
166
-
167
- export function drawPolygon(
168
- path: CanvasRenderingContext2D | Path2D,
169
- rect: BBox,
170
- sides: number,
171
- ) {
172
- const size = rect.size.scale(0.5);
173
- for (let i = 0; i <= sides; i++) {
174
- const theta = (i * 2 * Math.PI) / sides;
175
- const direction = Vector2.fromRadians(theta).perpendicular;
176
- const vertex = direction.mul(size);
177
- if (i === 0) {
178
- moveTo(path, vertex);
179
- } else {
180
- lineTo(path, vertex);
181
- }
182
- }
183
- path.closePath();
184
- }
185
-
186
- export function drawImage(
187
- context: CanvasRenderingContext2D,
188
- image: CanvasImageSource,
189
- destination: BBox,
190
- ): void;
191
- export function drawImage(
192
- context: CanvasRenderingContext2D,
193
- image: CanvasImageSource,
194
- source: BBox,
195
- destination: BBox,
196
- ): void;
197
- export function drawImage(
198
- context: CanvasRenderingContext2D,
199
- image: CanvasImageSource,
200
- first: BBox,
201
- second?: BBox,
202
- ): void {
203
- if (second) {
204
- context.drawImage(
205
- image,
206
- first.x,
207
- first.y,
208
- first.width,
209
- first.height,
210
- second.x,
211
- second.y,
212
- second.width,
213
- second.height,
214
- );
215
- } else {
216
- context.drawImage(image, first.x, first.y, first.width, first.height);
217
- }
218
- }
219
-
220
- export function moveTo(
221
- context: CanvasRenderingContext2D | Path2D,
222
- position: Vector2,
223
- ) {
224
- context.moveTo(position.x, position.y);
225
- }
226
-
227
- export function lineTo(
228
- context: CanvasRenderingContext2D | Path2D,
229
- position: Vector2,
230
- ) {
231
- context.lineTo(position.x, position.y);
232
- }
233
-
234
- export function arcTo(
235
- context: CanvasRenderingContext2D | Path2D,
236
- through: Vector2,
237
- position: Vector2,
238
- radius: number,
239
- ) {
240
- context.arcTo(through.x, through.y, position.x, position.y, radius);
241
- }
242
-
243
- export function drawLine(
244
- context: CanvasRenderingContext2D | Path2D,
245
- points: Vector2[],
246
- ) {
247
- if (points.length < 2) return;
248
- moveTo(context, points[0]);
249
- for (const point of points.slice(1)) {
250
- lineTo(context, point);
251
- }
252
- }
253
-
254
- export function drawPivot(
255
- context: CanvasRenderingContext2D | Path2D,
256
- offset: Vector2,
257
- radius = 8,
258
- ) {
259
- lineTo(context, offset.addY(-radius));
260
- lineTo(context, offset.addY(radius));
261
- lineTo(context, offset);
262
- lineTo(context, offset.addX(-radius));
263
- arc(context, offset, radius);
264
- }
265
-
266
- export function arc(
267
- context: CanvasRenderingContext2D | Path2D,
268
- center: Vector2,
269
- radius: number,
270
- startAngle = 0,
271
- endAngle = Math.PI * 2,
272
- counterclockwise = false,
273
- ) {
274
- context.arc(
275
- center.x,
276
- center.y,
277
- radius,
278
- startAngle,
279
- endAngle,
280
- counterclockwise,
281
- );
282
- }
283
-
284
- export function bezierCurveTo(
285
- context: CanvasRenderingContext2D | Path2D,
286
- controlPoint1: Vector2,
287
- controlPoint2: Vector2,
288
- to: Vector2,
289
- ) {
290
- context.bezierCurveTo(
291
- controlPoint1.x,
292
- controlPoint1.y,
293
- controlPoint2.x,
294
- controlPoint2.y,
295
- to.x,
296
- to.y,
297
- );
298
- }
299
-
300
- export function quadraticCurveTo(
301
- context: CanvasRenderingContext2D | Path2D,
302
- controlPoint: Vector2,
303
- to: Vector2,
304
- ) {
305
- context.quadraticCurveTo(controlPoint.x, controlPoint.y, to.x, to.y);
306
- }