@twick/2d 0.11.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 (537) hide show
  1. package/LICENSE +21 -0
  2. package/editor/editor/NodeInspectorConfig.d.ts +3 -0
  3. package/editor/editor/NodeInspectorConfig.d.ts.map +1 -0
  4. package/editor/editor/PreviewOverlayConfig.d.ts +3 -0
  5. package/editor/editor/PreviewOverlayConfig.d.ts.map +1 -0
  6. package/editor/editor/Provider.d.ts +17 -0
  7. package/editor/editor/Provider.d.ts.map +1 -0
  8. package/editor/editor/SceneGraphTabConfig.d.ts +3 -0
  9. package/editor/editor/SceneGraphTabConfig.d.ts.map +1 -0
  10. package/editor/editor/icons/CircleIcon.d.ts +2 -0
  11. package/editor/editor/icons/CircleIcon.d.ts.map +1 -0
  12. package/editor/editor/icons/CodeBlockIcon.d.ts +2 -0
  13. package/editor/editor/icons/CodeBlockIcon.d.ts.map +1 -0
  14. package/editor/editor/icons/CurveIcon.d.ts +2 -0
  15. package/editor/editor/icons/CurveIcon.d.ts.map +1 -0
  16. package/editor/editor/icons/GridIcon.d.ts +2 -0
  17. package/editor/editor/icons/GridIcon.d.ts.map +1 -0
  18. package/editor/editor/icons/IconMap.d.ts +3 -0
  19. package/editor/editor/icons/IconMap.d.ts.map +1 -0
  20. package/editor/editor/icons/ImgIcon.d.ts +2 -0
  21. package/editor/editor/icons/ImgIcon.d.ts.map +1 -0
  22. package/editor/editor/icons/LayoutIcon.d.ts +2 -0
  23. package/editor/editor/icons/LayoutIcon.d.ts.map +1 -0
  24. package/editor/editor/icons/LineIcon.d.ts +2 -0
  25. package/editor/editor/icons/LineIcon.d.ts.map +1 -0
  26. package/editor/editor/icons/NodeIcon.d.ts +2 -0
  27. package/editor/editor/icons/NodeIcon.d.ts.map +1 -0
  28. package/editor/editor/icons/RayIcon.d.ts +2 -0
  29. package/editor/editor/icons/RayIcon.d.ts.map +1 -0
  30. package/editor/editor/icons/RectIcon.d.ts +2 -0
  31. package/editor/editor/icons/RectIcon.d.ts.map +1 -0
  32. package/editor/editor/icons/ShapeIcon.d.ts +2 -0
  33. package/editor/editor/icons/ShapeIcon.d.ts.map +1 -0
  34. package/editor/editor/icons/TxtIcon.d.ts +2 -0
  35. package/editor/editor/icons/TxtIcon.d.ts.map +1 -0
  36. package/editor/editor/icons/VideoIcon.d.ts +2 -0
  37. package/editor/editor/icons/VideoIcon.d.ts.map +1 -0
  38. package/editor/editor/icons/View2DIcon.d.ts +2 -0
  39. package/editor/editor/icons/View2DIcon.d.ts.map +1 -0
  40. package/editor/editor/index.d.ts +4 -0
  41. package/editor/editor/index.d.ts.map +1 -0
  42. package/editor/editor/tree/DetachedRoot.d.ts +2 -0
  43. package/editor/editor/tree/DetachedRoot.d.ts.map +1 -0
  44. package/editor/editor/tree/NodeElement.d.ts +8 -0
  45. package/editor/editor/tree/NodeElement.d.ts.map +1 -0
  46. package/editor/editor/tree/TreeElement.d.ts +15 -0
  47. package/editor/editor/tree/TreeElement.d.ts.map +1 -0
  48. package/editor/editor/tree/TreeRoot.d.ts +3 -0
  49. package/editor/editor/tree/TreeRoot.d.ts.map +1 -0
  50. package/editor/editor/tree/ViewRoot.d.ts +2 -0
  51. package/editor/editor/tree/ViewRoot.d.ts.map +1 -0
  52. package/editor/editor/tree/index.d.ts +4 -0
  53. package/editor/editor/tree/index.d.ts.map +1 -0
  54. package/editor/editor/tsconfig.build.tsbuildinfo +1 -0
  55. package/editor/index.css +33 -0
  56. package/editor/index.js +341 -0
  57. package/editor/index.js.map +1 -0
  58. package/lib/code/CodeCursor.d.ts +83 -0
  59. package/lib/code/CodeCursor.d.ts.map +1 -0
  60. package/lib/code/CodeCursor.js +306 -0
  61. package/lib/code/CodeDiffer.d.ts +28 -0
  62. package/lib/code/CodeDiffer.d.ts.map +1 -0
  63. package/lib/code/CodeDiffer.js +51 -0
  64. package/lib/code/CodeFragment.d.ts +42 -0
  65. package/lib/code/CodeFragment.d.ts.map +1 -0
  66. package/lib/code/CodeFragment.js +72 -0
  67. package/lib/code/CodeHighlighter.d.ts +71 -0
  68. package/lib/code/CodeHighlighter.d.ts.map +1 -0
  69. package/lib/code/CodeHighlighter.js +2 -0
  70. package/lib/code/CodeMetrics.d.ts +11 -0
  71. package/lib/code/CodeMetrics.d.ts.map +1 -0
  72. package/lib/code/CodeMetrics.js +29 -0
  73. package/lib/code/CodeRange.d.ts +41 -0
  74. package/lib/code/CodeRange.d.ts.map +1 -0
  75. package/lib/code/CodeRange.js +179 -0
  76. package/lib/code/CodeScope.d.ts +16 -0
  77. package/lib/code/CodeScope.d.ts.map +1 -0
  78. package/lib/code/CodeScope.js +72 -0
  79. package/lib/code/CodeSelection.d.ts +6 -0
  80. package/lib/code/CodeSelection.d.ts.map +1 -0
  81. package/lib/code/CodeSelection.js +13 -0
  82. package/lib/code/CodeSignal.d.ts +60 -0
  83. package/lib/code/CodeSignal.d.ts.map +1 -0
  84. package/lib/code/CodeSignal.js +194 -0
  85. package/lib/code/CodeTokenizer.d.ts +8 -0
  86. package/lib/code/CodeTokenizer.d.ts.map +1 -0
  87. package/lib/code/CodeTokenizer.js +50 -0
  88. package/lib/code/DefaultHighlightStyle.d.ts +3 -0
  89. package/lib/code/DefaultHighlightStyle.d.ts.map +1 -0
  90. package/lib/code/DefaultHighlightStyle.js +98 -0
  91. package/lib/code/LezerHighlighter.d.ts +22 -0
  92. package/lib/code/LezerHighlighter.d.ts.map +1 -0
  93. package/lib/code/LezerHighlighter.js +89 -0
  94. package/lib/code/diff.d.ts +31 -0
  95. package/lib/code/diff.d.ts.map +1 -0
  96. package/lib/code/diff.js +236 -0
  97. package/lib/code/extractRange.d.ts +17 -0
  98. package/lib/code/extractRange.d.ts.map +1 -0
  99. package/lib/code/extractRange.js +102 -0
  100. package/lib/code/index.d.ts +14 -0
  101. package/lib/code/index.d.ts.map +1 -0
  102. package/lib/code/index.js +14 -0
  103. package/lib/components/Audio.d.ts +14 -0
  104. package/lib/components/Audio.d.ts.map +1 -0
  105. package/lib/components/Audio.js +118 -0
  106. package/lib/components/Bezier.d.ts +23 -0
  107. package/lib/components/Bezier.d.ts.map +1 -0
  108. package/lib/components/Bezier.js +81 -0
  109. package/lib/components/Circle.d.ts +193 -0
  110. package/lib/components/Circle.d.ts.map +1 -0
  111. package/lib/components/Circle.js +178 -0
  112. package/lib/components/Code.d.ts +231 -0
  113. package/lib/components/Code.d.ts.map +1 -0
  114. package/lib/components/Code.js +325 -0
  115. package/lib/components/CodeBlock.d.ts +133 -0
  116. package/lib/components/CodeBlock.d.ts.map +1 -0
  117. package/lib/components/CodeBlock.js +461 -0
  118. package/lib/components/CubicBezier.d.ts +70 -0
  119. package/lib/components/CubicBezier.d.ts.map +1 -0
  120. package/lib/components/CubicBezier.js +81 -0
  121. package/lib/components/Curve.d.ts +204 -0
  122. package/lib/components/Curve.d.ts.map +1 -0
  123. package/lib/components/Curve.js +284 -0
  124. package/lib/components/Grid.d.ts +76 -0
  125. package/lib/components/Grid.d.ts.map +1 -0
  126. package/lib/components/Grid.js +91 -0
  127. package/lib/components/Icon.d.ts +59 -0
  128. package/lib/components/Icon.d.ts.map +1 -0
  129. package/lib/components/Icon.js +58 -0
  130. package/lib/components/Img.d.ts +118 -0
  131. package/lib/components/Img.d.ts.map +1 -0
  132. package/lib/components/Img.js +245 -0
  133. package/lib/components/Knot.d.ts +90 -0
  134. package/lib/components/Knot.d.ts.map +1 -0
  135. package/lib/components/Knot.js +68 -0
  136. package/lib/components/Latex.d.ts +39 -0
  137. package/lib/components/Latex.d.ts.map +1 -0
  138. package/lib/components/Latex.js +101 -0
  139. package/lib/components/Layout.d.ts +419 -0
  140. package/lib/components/Layout.d.ts.map +1 -0
  141. package/lib/components/Layout.js +706 -0
  142. package/lib/components/Line.d.ts +160 -0
  143. package/lib/components/Line.d.ts.map +1 -0
  144. package/lib/components/Line.js +346 -0
  145. package/lib/components/Media.d.ts +65 -0
  146. package/lib/components/Media.d.ts.map +1 -0
  147. package/lib/components/Media.js +303 -0
  148. package/lib/components/Node.d.ts +836 -0
  149. package/lib/components/Node.d.ts.map +1 -0
  150. package/lib/components/Node.js +1317 -0
  151. package/lib/components/Path.d.ts +20 -0
  152. package/lib/components/Path.d.ts.map +1 -0
  153. package/lib/components/Path.js +97 -0
  154. package/lib/components/Polygon.d.ts +113 -0
  155. package/lib/components/Polygon.d.ts.map +1 -0
  156. package/lib/components/Polygon.js +123 -0
  157. package/lib/components/QuadBezier.d.ts +62 -0
  158. package/lib/components/QuadBezier.d.ts.map +1 -0
  159. package/lib/components/QuadBezier.js +76 -0
  160. package/lib/components/Ray.d.ts +62 -0
  161. package/lib/components/Ray.d.ts.map +1 -0
  162. package/lib/components/Ray.js +96 -0
  163. package/lib/components/Rect.d.ts +114 -0
  164. package/lib/components/Rect.d.ts.map +1 -0
  165. package/lib/components/Rect.js +76 -0
  166. package/lib/components/Rive.d.ts +22 -0
  167. package/lib/components/Rive.d.ts.map +1 -0
  168. package/lib/components/Rive.js +117 -0
  169. package/lib/components/SVG.d.ts +178 -0
  170. package/lib/components/SVG.d.ts.map +1 -0
  171. package/lib/components/SVG.js +577 -0
  172. package/lib/components/Shape.d.ts +40 -0
  173. package/lib/components/Shape.d.ts.map +1 -0
  174. package/lib/components/Shape.js +134 -0
  175. package/lib/components/Spline.d.ts +89 -0
  176. package/lib/components/Spline.d.ts.map +1 -0
  177. package/lib/components/Spline.js +256 -0
  178. package/lib/components/Txt.d.ts +53 -0
  179. package/lib/components/Txt.d.ts.map +1 -0
  180. package/lib/components/Txt.js +173 -0
  181. package/lib/components/TxtLeaf.d.ts +21 -0
  182. package/lib/components/TxtLeaf.d.ts.map +1 -0
  183. package/lib/components/TxtLeaf.js +181 -0
  184. package/lib/components/Video.d.ts +69 -0
  185. package/lib/components/Video.d.ts.map +1 -0
  186. package/lib/components/Video.js +283 -0
  187. package/lib/components/View2D.d.ts +28 -0
  188. package/lib/components/View2D.d.ts.map +1 -0
  189. package/lib/components/View2D.js +93 -0
  190. package/lib/components/index.d.ts +29 -0
  191. package/lib/components/index.d.ts.map +1 -0
  192. package/lib/components/index.js +29 -0
  193. package/lib/components/types.d.ts +17 -0
  194. package/lib/components/types.d.ts.map +1 -0
  195. package/lib/components/types.js +2 -0
  196. package/lib/curves/ArcSegment.d.ts +26 -0
  197. package/lib/curves/ArcSegment.d.ts.map +1 -0
  198. package/lib/curves/ArcSegment.js +97 -0
  199. package/lib/curves/CircleSegment.d.ts +18 -0
  200. package/lib/curves/CircleSegment.d.ts.map +1 -0
  201. package/lib/curves/CircleSegment.js +52 -0
  202. package/lib/curves/CubicBezierSegment.d.ts +18 -0
  203. package/lib/curves/CubicBezierSegment.d.ts.map +1 -0
  204. package/lib/curves/CubicBezierSegment.js +55 -0
  205. package/lib/curves/CurveDrawingInfo.d.ts +11 -0
  206. package/lib/curves/CurveDrawingInfo.d.ts.map +1 -0
  207. package/lib/curves/CurveDrawingInfo.js +2 -0
  208. package/lib/curves/CurvePoint.d.ts +15 -0
  209. package/lib/curves/CurvePoint.d.ts.map +1 -0
  210. package/lib/curves/CurvePoint.js +2 -0
  211. package/lib/curves/CurveProfile.d.ts +7 -0
  212. package/lib/curves/CurveProfile.d.ts.map +1 -0
  213. package/lib/curves/CurveProfile.js +2 -0
  214. package/lib/curves/KnotInfo.d.ts +12 -0
  215. package/lib/curves/KnotInfo.d.ts.map +1 -0
  216. package/lib/curves/KnotInfo.js +2 -0
  217. package/lib/curves/LineSegment.d.ts +16 -0
  218. package/lib/curves/LineSegment.d.ts.map +1 -0
  219. package/lib/curves/LineSegment.js +45 -0
  220. package/lib/curves/Polynomial.d.ts +118 -0
  221. package/lib/curves/Polynomial.d.ts.map +1 -0
  222. package/lib/curves/Polynomial.js +259 -0
  223. package/lib/curves/Polynomial2D.d.ts +22 -0
  224. package/lib/curves/Polynomial2D.d.ts.map +1 -0
  225. package/lib/curves/Polynomial2D.js +45 -0
  226. package/lib/curves/PolynomialSegment.d.ts +39 -0
  227. package/lib/curves/PolynomialSegment.d.ts.map +1 -0
  228. package/lib/curves/PolynomialSegment.js +86 -0
  229. package/lib/curves/QuadBezierSegment.d.ts +17 -0
  230. package/lib/curves/QuadBezierSegment.d.ts.map +1 -0
  231. package/lib/curves/QuadBezierSegment.js +49 -0
  232. package/lib/curves/Segment.d.ts +9 -0
  233. package/lib/curves/Segment.d.ts.map +1 -0
  234. package/lib/curves/Segment.js +3 -0
  235. package/lib/curves/UniformPolynomialCurveSampler.d.ts +43 -0
  236. package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +1 -0
  237. package/lib/curves/UniformPolynomialCurveSampler.js +73 -0
  238. package/lib/curves/createCurveProfileLerp.d.ts +32 -0
  239. package/lib/curves/createCurveProfileLerp.d.ts.map +1 -0
  240. package/lib/curves/createCurveProfileLerp.js +351 -0
  241. package/lib/curves/getBezierSplineProfile.d.ts +12 -0
  242. package/lib/curves/getBezierSplineProfile.d.ts.map +1 -0
  243. package/lib/curves/getBezierSplineProfile.js +137 -0
  244. package/lib/curves/getCircleProfile.d.ts +4 -0
  245. package/lib/curves/getCircleProfile.d.ts.map +1 -0
  246. package/lib/curves/getCircleProfile.js +44 -0
  247. package/lib/curves/getPathProfile.d.ts +3 -0
  248. package/lib/curves/getPathProfile.d.ts.map +1 -0
  249. package/lib/curves/getPathProfile.js +128 -0
  250. package/lib/curves/getPointAtDistance.d.ts +4 -0
  251. package/lib/curves/getPointAtDistance.d.ts.map +1 -0
  252. package/lib/curves/getPointAtDistance.js +15 -0
  253. package/lib/curves/getPolylineProfile.d.ts +4 -0
  254. package/lib/curves/getPolylineProfile.d.ts.map +1 -0
  255. package/lib/curves/getPolylineProfile.js +58 -0
  256. package/lib/curves/getRectProfile.d.ts +4 -0
  257. package/lib/curves/getRectProfile.d.ts.map +1 -0
  258. package/lib/curves/getRectProfile.js +57 -0
  259. package/lib/curves/index.d.ts +17 -0
  260. package/lib/curves/index.d.ts.map +1 -0
  261. package/lib/curves/index.js +17 -0
  262. package/lib/decorators/canvasStyleSignal.d.ts +5 -0
  263. package/lib/decorators/canvasStyleSignal.d.ts.map +1 -0
  264. package/lib/decorators/canvasStyleSignal.js +12 -0
  265. package/lib/decorators/colorSignal.d.ts +2 -0
  266. package/lib/decorators/colorSignal.d.ts.map +1 -0
  267. package/lib/decorators/colorSignal.js +9 -0
  268. package/lib/decorators/compound.d.ts +26 -0
  269. package/lib/decorators/compound.d.ts.map +1 -0
  270. package/lib/decorators/compound.js +49 -0
  271. package/lib/decorators/computed.d.ts +9 -0
  272. package/lib/decorators/computed.d.ts.map +1 -0
  273. package/lib/decorators/computed.js +18 -0
  274. package/lib/decorators/defaultStyle.d.ts +2 -0
  275. package/lib/decorators/defaultStyle.d.ts.map +1 -0
  276. package/lib/decorators/defaultStyle.js +14 -0
  277. package/lib/decorators/filtersSignal.d.ts +13 -0
  278. package/lib/decorators/filtersSignal.d.ts.map +1 -0
  279. package/lib/decorators/filtersSignal.js +73 -0
  280. package/lib/decorators/index.d.ts +11 -0
  281. package/lib/decorators/index.d.ts.map +1 -0
  282. package/lib/decorators/index.js +11 -0
  283. package/lib/decorators/initializers.d.ts +4 -0
  284. package/lib/decorators/initializers.d.ts.map +1 -0
  285. package/lib/decorators/initializers.js +27 -0
  286. package/lib/decorators/nodeName.d.ts +9 -0
  287. package/lib/decorators/nodeName.d.ts.map +1 -0
  288. package/lib/decorators/nodeName.js +13 -0
  289. package/lib/decorators/signal.d.ts +183 -0
  290. package/lib/decorators/signal.d.ts.map +1 -0
  291. package/lib/decorators/signal.js +285 -0
  292. package/lib/decorators/spacingSignal.d.ts +2 -0
  293. package/lib/decorators/spacingSignal.d.ts.map +1 -0
  294. package/lib/decorators/spacingSignal.js +15 -0
  295. package/lib/decorators/vector2Signal.d.ts +9 -0
  296. package/lib/decorators/vector2Signal.d.ts.map +1 -0
  297. package/lib/decorators/vector2Signal.js +15 -0
  298. package/lib/index.d.ts +9 -0
  299. package/lib/index.d.ts.map +1 -0
  300. package/lib/index.js +9 -0
  301. package/lib/jsx-dev-runtime.d.ts +3 -0
  302. package/lib/jsx-dev-runtime.d.ts.map +1 -0
  303. package/lib/jsx-dev-runtime.js +3 -0
  304. package/lib/jsx-runtime.d.ts +12 -0
  305. package/lib/jsx-runtime.d.ts.map +1 -0
  306. package/lib/jsx-runtime.js +23 -0
  307. package/lib/partials/Filter.d.ts +82 -0
  308. package/lib/partials/Filter.d.ts.map +1 -0
  309. package/lib/partials/Filter.js +135 -0
  310. package/lib/partials/Gradient.d.ts +31 -0
  311. package/lib/partials/Gradient.d.ts.map +1 -0
  312. package/lib/partials/Gradient.js +63 -0
  313. package/lib/partials/Pattern.d.ts +13 -0
  314. package/lib/partials/Pattern.d.ts.map +1 -0
  315. package/lib/partials/Pattern.js +27 -0
  316. package/lib/partials/ShaderConfig.d.ts +81 -0
  317. package/lib/partials/ShaderConfig.d.ts.map +1 -0
  318. package/lib/partials/ShaderConfig.js +25 -0
  319. package/lib/partials/index.d.ts +5 -0
  320. package/lib/partials/index.d.ts.map +1 -0
  321. package/lib/partials/index.js +5 -0
  322. package/lib/partials/types.d.ts +35 -0
  323. package/lib/partials/types.d.ts.map +1 -0
  324. package/lib/partials/types.js +2 -0
  325. package/lib/scenes/Scene2D.d.ts +29 -0
  326. package/lib/scenes/Scene2D.d.ts.map +1 -0
  327. package/lib/scenes/Scene2D.js +180 -0
  328. package/lib/scenes/index.d.ts +4 -0
  329. package/lib/scenes/index.d.ts.map +1 -0
  330. package/lib/scenes/index.js +4 -0
  331. package/lib/scenes/makeScene2D.d.ts +5 -0
  332. package/lib/scenes/makeScene2D.d.ts.map +1 -0
  333. package/lib/scenes/makeScene2D.js +11 -0
  334. package/lib/scenes/useScene2D.d.ts +3 -0
  335. package/lib/scenes/useScene2D.d.ts.map +1 -0
  336. package/lib/scenes/useScene2D.js +5 -0
  337. package/lib/tsconfig.build.tsbuildinfo +1 -0
  338. package/lib/utils/CanvasUtils.d.ts +23 -0
  339. package/lib/utils/CanvasUtils.d.ts.map +1 -0
  340. package/lib/utils/CanvasUtils.js +138 -0
  341. package/lib/utils/diff.d.ts +31 -0
  342. package/lib/utils/diff.d.ts.map +1 -0
  343. package/lib/utils/diff.js +97 -0
  344. package/lib/utils/index.d.ts +3 -0
  345. package/lib/utils/index.d.ts.map +1 -0
  346. package/lib/utils/index.js +3 -0
  347. package/lib/utils/is.d.ts +8 -0
  348. package/lib/utils/is.d.ts.map +1 -0
  349. package/lib/utils/is.js +10 -0
  350. package/lib/utils/makeSignalExtensions.d.ts +4 -0
  351. package/lib/utils/makeSignalExtensions.d.ts.map +1 -0
  352. package/lib/utils/makeSignalExtensions.js +20 -0
  353. package/lib/utils/video/ffmpeg-client.d.ts +5 -0
  354. package/lib/utils/video/ffmpeg-client.d.ts.map +1 -0
  355. package/lib/utils/video/ffmpeg-client.js +32 -0
  356. package/lib/utils/video/mp4-parser-manager.d.ts +3 -0
  357. package/lib/utils/video/mp4-parser-manager.d.ts.map +1 -0
  358. package/lib/utils/video/mp4-parser-manager.js +55 -0
  359. package/lib/utils/video/parser/index.d.ts +2 -0
  360. package/lib/utils/video/parser/index.d.ts.map +1 -0
  361. package/lib/utils/video/parser/index.js +2 -0
  362. package/lib/utils/video/parser/parser.d.ts +21 -0
  363. package/lib/utils/video/parser/parser.d.ts.map +1 -0
  364. package/lib/utils/video/parser/parser.js +168 -0
  365. package/lib/utils/video/parser/sampler.d.ts +16 -0
  366. package/lib/utils/video/parser/sampler.d.ts.map +1 -0
  367. package/lib/utils/video/parser/sampler.js +56 -0
  368. package/lib/utils/video/parser/segment.d.ts +48 -0
  369. package/lib/utils/video/parser/segment.d.ts.map +1 -0
  370. package/lib/utils/video/parser/segment.js +239 -0
  371. package/lib/utils/video/parser/sink.d.ts +9 -0
  372. package/lib/utils/video/parser/sink.d.ts.map +1 -0
  373. package/lib/utils/video/parser/sink.js +22 -0
  374. package/lib/utils/video/parser/utils.d.ts +10 -0
  375. package/lib/utils/video/parser/utils.d.ts.map +1 -0
  376. package/lib/utils/video/parser/utils.js +22 -0
  377. package/package.json +53 -0
  378. package/src/editor/NodeInspectorConfig.tsx +76 -0
  379. package/src/editor/PreviewOverlayConfig.tsx +67 -0
  380. package/src/editor/Provider.tsx +93 -0
  381. package/src/editor/SceneGraphTabConfig.tsx +81 -0
  382. package/src/editor/icons/CircleIcon.tsx +7 -0
  383. package/src/editor/icons/CodeBlockIcon.tsx +8 -0
  384. package/src/editor/icons/CurveIcon.tsx +7 -0
  385. package/src/editor/icons/GridIcon.tsx +7 -0
  386. package/src/editor/icons/IconMap.ts +35 -0
  387. package/src/editor/icons/ImgIcon.tsx +8 -0
  388. package/src/editor/icons/LayoutIcon.tsx +9 -0
  389. package/src/editor/icons/LineIcon.tsx +7 -0
  390. package/src/editor/icons/NodeIcon.tsx +7 -0
  391. package/src/editor/icons/RayIcon.tsx +7 -0
  392. package/src/editor/icons/RectIcon.tsx +7 -0
  393. package/src/editor/icons/ShapeIcon.tsx +7 -0
  394. package/src/editor/icons/TxtIcon.tsx +8 -0
  395. package/src/editor/icons/VideoIcon.tsx +7 -0
  396. package/src/editor/icons/View2DIcon.tsx +10 -0
  397. package/src/editor/index.css +0 -0
  398. package/src/editor/index.ts +17 -0
  399. package/src/editor/tree/DetachedRoot.tsx +23 -0
  400. package/src/editor/tree/NodeElement.tsx +74 -0
  401. package/src/editor/tree/TreeElement.tsx +72 -0
  402. package/src/editor/tree/TreeRoot.tsx +10 -0
  403. package/src/editor/tree/ViewRoot.tsx +20 -0
  404. package/src/editor/tree/index.module.scss +38 -0
  405. package/src/editor/tree/index.ts +3 -0
  406. package/src/editor/tsconfig.build.json +5 -0
  407. package/src/editor/tsconfig.json +12 -0
  408. package/src/editor/tsdoc.json +4 -0
  409. package/src/editor/vite-env.d.ts +1 -0
  410. package/src/lib/code/CodeCursor.ts +445 -0
  411. package/src/lib/code/CodeDiffer.ts +78 -0
  412. package/src/lib/code/CodeFragment.ts +97 -0
  413. package/src/lib/code/CodeHighlighter.ts +75 -0
  414. package/src/lib/code/CodeMetrics.ts +47 -0
  415. package/src/lib/code/CodeRange.test.ts +74 -0
  416. package/src/lib/code/CodeRange.ts +216 -0
  417. package/src/lib/code/CodeScope.ts +101 -0
  418. package/src/lib/code/CodeSelection.ts +24 -0
  419. package/src/lib/code/CodeSignal.ts +327 -0
  420. package/src/lib/code/CodeTokenizer.ts +54 -0
  421. package/src/lib/code/DefaultHighlightStyle.ts +98 -0
  422. package/src/lib/code/LezerHighlighter.ts +113 -0
  423. package/src/lib/code/diff.test.ts +311 -0
  424. package/src/lib/code/diff.ts +319 -0
  425. package/src/lib/code/extractRange.ts +126 -0
  426. package/src/lib/code/index.ts +13 -0
  427. package/src/lib/components/Audio.ts +131 -0
  428. package/src/lib/components/Bezier.ts +105 -0
  429. package/src/lib/components/Circle.ts +266 -0
  430. package/src/lib/components/Code.ts +526 -0
  431. package/src/lib/components/CodeBlock.ts +576 -0
  432. package/src/lib/components/CubicBezier.ts +112 -0
  433. package/src/lib/components/Curve.ts +455 -0
  434. package/src/lib/components/Grid.ts +135 -0
  435. package/src/lib/components/Icon.ts +96 -0
  436. package/src/lib/components/Img.ts +319 -0
  437. package/src/lib/components/Knot.ts +157 -0
  438. package/src/lib/components/Latex.ts +122 -0
  439. package/src/lib/components/Layout.ts +1092 -0
  440. package/src/lib/components/Line.ts +429 -0
  441. package/src/lib/components/Media.ts +379 -0
  442. package/src/lib/components/Node.ts +1940 -0
  443. package/src/lib/components/Path.ts +137 -0
  444. package/src/lib/components/Polygon.ts +171 -0
  445. package/src/lib/components/QuadBezier.ts +100 -0
  446. package/src/lib/components/Ray.ts +125 -0
  447. package/src/lib/components/Rect.ts +187 -0
  448. package/src/lib/components/Rive.ts +156 -0
  449. package/src/lib/components/SVG.ts +797 -0
  450. package/src/lib/components/Shape.ts +143 -0
  451. package/src/lib/components/Spline.ts +344 -0
  452. package/src/lib/components/Txt.test.tsx +81 -0
  453. package/src/lib/components/Txt.ts +203 -0
  454. package/src/lib/components/TxtLeaf.ts +205 -0
  455. package/src/lib/components/Video.ts +397 -0
  456. package/src/lib/components/View2D.ts +98 -0
  457. package/src/lib/components/__tests__/children.test.tsx +142 -0
  458. package/src/lib/components/__tests__/clone.test.tsx +126 -0
  459. package/src/lib/components/__tests__/generatorTest.ts +28 -0
  460. package/src/lib/components/__tests__/mockScene2D.ts +45 -0
  461. package/src/lib/components/__tests__/query.test.tsx +122 -0
  462. package/src/lib/components/__tests__/state.test.tsx +60 -0
  463. package/src/lib/components/index.ts +28 -0
  464. package/src/lib/components/types.ts +35 -0
  465. package/src/lib/curves/ArcSegment.ts +159 -0
  466. package/src/lib/curves/CircleSegment.ts +77 -0
  467. package/src/lib/curves/CubicBezierSegment.ts +78 -0
  468. package/src/lib/curves/CurveDrawingInfo.ts +11 -0
  469. package/src/lib/curves/CurvePoint.ts +15 -0
  470. package/src/lib/curves/CurveProfile.ts +7 -0
  471. package/src/lib/curves/KnotInfo.ts +10 -0
  472. package/src/lib/curves/LineSegment.ts +62 -0
  473. package/src/lib/curves/Polynomial.ts +355 -0
  474. package/src/lib/curves/Polynomial2D.ts +62 -0
  475. package/src/lib/curves/PolynomialSegment.ts +124 -0
  476. package/src/lib/curves/QuadBezierSegment.ts +64 -0
  477. package/src/lib/curves/Segment.ts +17 -0
  478. package/src/lib/curves/UniformPolynomialCurveSampler.ts +94 -0
  479. package/src/lib/curves/createCurveProfileLerp.ts +471 -0
  480. package/src/lib/curves/getBezierSplineProfile.ts +223 -0
  481. package/src/lib/curves/getCircleProfile.ts +86 -0
  482. package/src/lib/curves/getPathProfile.ts +178 -0
  483. package/src/lib/curves/getPointAtDistance.ts +21 -0
  484. package/src/lib/curves/getPolylineProfile.test.ts +21 -0
  485. package/src/lib/curves/getPolylineProfile.ts +89 -0
  486. package/src/lib/curves/getRectProfile.ts +139 -0
  487. package/src/lib/curves/index.ts +16 -0
  488. package/src/lib/decorators/canvasStyleSignal.ts +16 -0
  489. package/src/lib/decorators/colorSignal.ts +9 -0
  490. package/src/lib/decorators/compound.ts +72 -0
  491. package/src/lib/decorators/computed.ts +18 -0
  492. package/src/lib/decorators/defaultStyle.ts +18 -0
  493. package/src/lib/decorators/filtersSignal.ts +136 -0
  494. package/src/lib/decorators/index.ts +10 -0
  495. package/src/lib/decorators/initializers.ts +32 -0
  496. package/src/lib/decorators/nodeName.ts +13 -0
  497. package/src/lib/decorators/signal.test.ts +90 -0
  498. package/src/lib/decorators/signal.ts +345 -0
  499. package/src/lib/decorators/spacingSignal.ts +15 -0
  500. package/src/lib/decorators/vector2Signal.ts +30 -0
  501. package/src/lib/globals.d.ts +2 -0
  502. package/src/lib/index.ts +8 -0
  503. package/src/lib/jsx-dev-runtime.ts +2 -0
  504. package/src/lib/jsx-runtime.ts +46 -0
  505. package/src/lib/parse-svg-path.d.ts +14 -0
  506. package/src/lib/partials/Filter.ts +180 -0
  507. package/src/lib/partials/Gradient.ts +102 -0
  508. package/src/lib/partials/Pattern.ts +34 -0
  509. package/src/lib/partials/ShaderConfig.ts +117 -0
  510. package/src/lib/partials/index.ts +4 -0
  511. package/src/lib/partials/types.ts +58 -0
  512. package/src/lib/scenes/Scene2D.ts +242 -0
  513. package/src/lib/scenes/index.ts +3 -0
  514. package/src/lib/scenes/makeScene2D.ts +16 -0
  515. package/src/lib/scenes/useScene2D.ts +6 -0
  516. package/src/lib/tsconfig.build.json +5 -0
  517. package/src/lib/tsconfig.json +10 -0
  518. package/src/lib/tsdoc.json +4 -0
  519. package/src/lib/utils/CanvasUtils.ts +306 -0
  520. package/src/lib/utils/diff.test.ts +453 -0
  521. package/src/lib/utils/diff.ts +148 -0
  522. package/src/lib/utils/index.ts +2 -0
  523. package/src/lib/utils/is.ts +11 -0
  524. package/src/lib/utils/makeSignalExtensions.ts +30 -0
  525. package/src/lib/utils/video/declarations.d.ts +1 -0
  526. package/src/lib/utils/video/ffmpeg-client.ts +50 -0
  527. package/src/lib/utils/video/mp4-parser-manager.ts +72 -0
  528. package/src/lib/utils/video/parser/index.ts +1 -0
  529. package/src/lib/utils/video/parser/parser.ts +257 -0
  530. package/src/lib/utils/video/parser/sampler.ts +72 -0
  531. package/src/lib/utils/video/parser/segment.ts +302 -0
  532. package/src/lib/utils/video/parser/sink.ts +29 -0
  533. package/src/lib/utils/video/parser/utils.ts +31 -0
  534. package/src/tsconfig.base.json +19 -0
  535. package/src/tsconfig.build.json +8 -0
  536. package/src/tsconfig.json +5 -0
  537. package/tsconfig.project.json +7 -0
@@ -0,0 +1,73 @@
1
+ import { clamp, remap } from '@twick/core';
2
+ /**
3
+ * Class to uniformly sample points on a given polynomial curve.
4
+ *
5
+ * @remarks
6
+ * In order to uniformly sample points from non-linear curves, this sampler
7
+ * re-parameterizes the curve by arclength.
8
+ */
9
+ export class UniformPolynomialCurveSampler {
10
+ /**
11
+ * @param curve - The curve to sample
12
+ * @param samples - How many points to sample from the provided curve. The
13
+ * more points get sampled, the higher the resolution–and
14
+ * therefore precision–of the sampler.
15
+ */
16
+ constructor(curve, samples = 20) {
17
+ this.curve = curve;
18
+ this.sampledDistances = [];
19
+ this.resample(samples);
20
+ }
21
+ /**
22
+ * Discard all previously sampled points and resample the provided number of
23
+ * points from the curve.
24
+ *
25
+ * @param samples - The number of points to sample.
26
+ */
27
+ resample(samples) {
28
+ this.sampledDistances = [0];
29
+ let length = 0;
30
+ let previous = this.curve.eval(0).position;
31
+ for (let i = 1; i < samples; i++) {
32
+ const t = i / (samples - 1);
33
+ const curvePoint = this.curve.eval(t);
34
+ const segmentLength = previous.sub(curvePoint.position).magnitude;
35
+ length += segmentLength;
36
+ this.sampledDistances.push(length);
37
+ previous = curvePoint.position;
38
+ }
39
+ // Account for any accumulated floating point errors and explicitly set the
40
+ // distance of the last point to the arclength of the curve.
41
+ this.sampledDistances[this.sampledDistances.length - 1] =
42
+ this.curve.arcLength;
43
+ }
44
+ /**
45
+ * Return the point at the provided distance along the sampled curve's
46
+ * arclength.
47
+ *
48
+ * @param distance - The distance along the curve's arclength for which to
49
+ * retrieve the point.
50
+ */
51
+ pointAtDistance(distance) {
52
+ return this.curve.eval(this.distanceToT(distance));
53
+ }
54
+ /**
55
+ * Return the t value for the point at the provided distance along the sampled
56
+ * curve's arc length.
57
+ *
58
+ * @param distance - The distance along the arclength
59
+ */
60
+ distanceToT(distance) {
61
+ const samples = this.sampledDistances.length;
62
+ distance = clamp(0, this.curve.arcLength, distance);
63
+ for (let i = 0; i < samples; i++) {
64
+ const lower = this.sampledDistances[i];
65
+ const upper = this.sampledDistances[i + 1];
66
+ if (distance >= lower && distance <= upper) {
67
+ return remap(lower, upper, i / (samples - 1), (i + 1) / (samples - 1), distance);
68
+ }
69
+ }
70
+ return 1;
71
+ }
72
+ }
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVW5pZm9ybVBvbHlub21pYWxDdXJ2ZVNhbXBsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2N1cnZlcy9Vbmlmb3JtUG9seW5vbWlhbEN1cnZlU2FtcGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsS0FBSyxFQUFFLEtBQUssRUFBQyxNQUFNLGFBQWEsQ0FBQztBQUl6Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sNkJBQTZCO0lBR3hDOzs7OztPQUtHO0lBQ0gsWUFDbUIsS0FBd0IsRUFDekMsT0FBTyxHQUFHLEVBQUU7UUFESyxVQUFLLEdBQUwsS0FBSyxDQUFtQjtRQVRuQyxxQkFBZ0IsR0FBYSxFQUFFLENBQUM7UUFZdEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxRQUFRLENBQUMsT0FBZTtRQUM3QixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUU1QixJQUFJLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDZixJQUFJLFFBQVEsR0FBWSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUM7UUFDcEQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ2pDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsQ0FBQztZQUM1QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0QyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxTQUFTLENBQUM7WUFFbEUsTUFBTSxJQUFJLGFBQWEsQ0FBQztZQUV4QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ25DLFFBQVEsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDO1FBQ2pDLENBQUM7UUFFRCwyRUFBMkU7UUFDM0UsNERBQTREO1FBQzVELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztZQUNyRCxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQztJQUN6QixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0ksZUFBZSxDQUFDLFFBQWdCO1FBQ3JDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLFdBQVcsQ0FBQyxRQUFnQjtRQUNqQyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDO1FBQzdDLFFBQVEsR0FBRyxLQUFLLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXBELEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNqQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdkMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUMzQyxJQUFJLFFBQVEsSUFBSSxLQUFLLElBQUksUUFBUSxJQUFJLEtBQUssRUFBRSxDQUFDO2dCQUMzQyxPQUFPLEtBQUssQ0FDVixLQUFLLEVBQ0wsS0FBSyxFQUNMLENBQUMsR0FBRyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsRUFDakIsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLEVBQ3ZCLFFBQVEsQ0FDVCxDQUFDO1lBQ0osQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7Q0FDRiJ9
@@ -0,0 +1,32 @@
1
+ import { Vector2 } from '@twick/core';
2
+ import type { CurveProfile } from './CurveProfile';
3
+ /**
4
+ * Calculate polygon perimeter
5
+ * @param points - polygon points
6
+ * @returns - perimeter of polygon
7
+ */
8
+ export declare function polygonLength(points: Vector2[]): number;
9
+ /**
10
+ * Calculate total moving point distance when morphing between polygon points
11
+ * @param points - first polygon points
12
+ * @param reference - second polygon points
13
+ * @param offset - offset for first polygon points
14
+ * @returns
15
+ */
16
+ export declare function calculateLerpDistance(points: Vector2[], reference: Vector2[], offset: number): number;
17
+ /**
18
+ * Interpolate between two polygon points.
19
+ * @param from - source polygon points
20
+ * @param to - target polygon points
21
+ * @param value - interpolation progress
22
+ * @returns - new polygon points
23
+ */
24
+ export declare function polygonPointsLerp(from: Vector2[], to: Vector2[], value: number): Vector2[];
25
+ /**
26
+ * Create interpolator to tween between two curve
27
+ * @param a - source curve
28
+ * @param b - target curve
29
+ * @returns - curve interpolator
30
+ */
31
+ export declare function createCurveProfileLerp(a: CurveProfile, b: CurveProfile): (progress: number) => CurveProfile;
32
+ //# sourceMappingURL=createCurveProfileLerp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createCurveProfileLerp.d.ts","sourceRoot":"","sources":["../../src/lib/curves/createCurveProfileLerp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,aAAa,CAAC;AACpC,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAsLjD;;;;GAIG;AAEH,wBAAgB,aAAa,CAAC,MAAM,EAAE,OAAO,EAAE,UAK9C;AAqCD;;;;;;GAMG;AAEH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,OAAO,EAAE,EACjB,SAAS,EAAE,OAAO,EAAE,EACpB,MAAM,EAAE,MAAM,UAYf;AAyKD;;;;;;GAMG;AAEH,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,OAAO,EAAE,EACf,EAAE,EAAE,OAAO,EAAE,EACb,KAAK,EAAE,MAAM,GACZ,OAAO,EAAE,CAWX;AAED;;;;;GAKG;AAEH,wBAAgB,sBAAsB,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,YAAY,cAGnD,MAAM,kBAYzB"}
@@ -0,0 +1,351 @@
1
+ import { Vector2 } from '@twick/core';
2
+ import { LineSegment } from './LineSegment';
3
+ import { getPointAtDistance } from './getPointAtDistance';
4
+ import { getPolylineProfile } from './getPolylineProfile';
5
+ /**
6
+ * Split segments of polygon until distance between adjacent point is less than or equal maxLength. This function mutate original points.
7
+ * @param points - Polygon points
8
+ * @param maxLength - max distance between two point
9
+ */
10
+ function bisect(points, maxLength) {
11
+ for (let i = 0; i < points.length - 1; i++) {
12
+ const a = points[i];
13
+ let b = points[i + 1];
14
+ while (a.sub(b).magnitude > maxLength) {
15
+ b = Vector2.lerp(a, b, 0.5);
16
+ points.splice(i + 1, 0, b);
17
+ }
18
+ }
19
+ }
20
+ /**
21
+ * Convert curve which only contain LineSegment into polygon.
22
+ * @param curve - curve to convert. curve must contain 1 subpath
23
+ * @param maxLength - max distance between two point
24
+ * @returns - null if curve contain segment other than LineSegment
25
+ */
26
+ function exactPolygonPoints(curve, maxLength) {
27
+ const points = [];
28
+ let endPoint = null;
29
+ for (const segment of curve.segments) {
30
+ if (!(segment instanceof LineSegment))
31
+ return null;
32
+ points.push(segment.from);
33
+ endPoint = segment.to;
34
+ }
35
+ if (endPoint)
36
+ points.push(endPoint);
37
+ if (!Number.isNaN(maxLength) && maxLength > 0) {
38
+ bisect(points, maxLength);
39
+ }
40
+ return points;
41
+ }
42
+ /**
43
+ * Calculate area of polygon
44
+ * @param points - polygon points
45
+ * @returns - area of polygon
46
+ */
47
+ function polygonArea(points) {
48
+ return (points.reduce((area, a, i) => {
49
+ const b = points[(i + 1) % points.length];
50
+ return area + (a.y * b.x - a.x * b.y);
51
+ }, 0) / 2);
52
+ }
53
+ /**
54
+ * Convert curve into polygon by sampling curve profile
55
+ * @param curve - curve to convert. curve must contain only 1 subpath
56
+ * @param maxLength - max distance between point
57
+ * @returns - always return polygon points
58
+ */
59
+ function approximatePolygonPoints(curve, maxLength) {
60
+ const points = [];
61
+ let numPoints = 3;
62
+ if (!Number.isNaN(maxLength) && maxLength > 0) {
63
+ numPoints = Math.max(numPoints, Math.ceil(curve.arcLength / maxLength));
64
+ }
65
+ for (let i = 0; i < numPoints; i += 1) {
66
+ const point = getPointAtDistance(curve, curve.arcLength * (i / (numPoints - 1)));
67
+ points.push(point.position);
68
+ }
69
+ if (polygonArea(points) > 0)
70
+ points.reverse();
71
+ return points;
72
+ }
73
+ /**
74
+ * Split curve into subpaths
75
+ * @param curve - curve to split
76
+ * @returns - subpaths of curve
77
+ */
78
+ function splitCurve(curve) {
79
+ if (curve.segments.length === 0)
80
+ return [];
81
+ let current = {
82
+ arcLength: 0,
83
+ minSin: 0,
84
+ segments: [],
85
+ closed: false,
86
+ };
87
+ let endPoint = null;
88
+ const composite = [current];
89
+ for (const segment of curve.segments) {
90
+ const start = segment.getPoint(0).position;
91
+ if (endPoint && !start.equals(endPoint)) {
92
+ current = {
93
+ arcLength: 0,
94
+ minSin: 0,
95
+ segments: [],
96
+ closed: false,
97
+ };
98
+ composite.push(current);
99
+ }
100
+ current.segments.push(segment);
101
+ current.arcLength += segment.arcLength;
102
+ endPoint = segment.getPoint(1).position;
103
+ }
104
+ for (const sub of composite) {
105
+ sub.closed = sub.segments[0]
106
+ .getPoint(0)
107
+ .position.equals(sub.segments[sub.segments.length - 1].getPoint(1).position);
108
+ }
109
+ return composite;
110
+ }
111
+ /**
112
+ * Convert curve into polygon use best possible method
113
+ * @param curve - curve to convert
114
+ * @param maxLength - max distance between two point
115
+ * @returns - polgon points
116
+ */
117
+ function subcurveToPolygon(curve, maxLength) {
118
+ const points = exactPolygonPoints(curve, maxLength) ||
119
+ approximatePolygonPoints(curve, maxLength);
120
+ return {
121
+ points: [...points],
122
+ closed: curve.closed,
123
+ };
124
+ }
125
+ /**
126
+ * Calculate polygon perimeter
127
+ * @param points - polygon points
128
+ * @returns - perimeter of polygon
129
+ */
130
+ export function polygonLength(points) {
131
+ return points.reduce((length, point, i) => {
132
+ if (i)
133
+ return length + points[i - 1].sub(point).magnitude;
134
+ return 0;
135
+ }, 0);
136
+ }
137
+ /**s
138
+ * Sample additional points for polygon to better match its pair. This will mutate original points.
139
+ * @param points - polygon points
140
+ * @param numPoints - number of points to be added
141
+ */
142
+ function addPoints(points, numPoints) {
143
+ const desiredLength = points.length + numPoints;
144
+ const step = polygonLength(points) / numPoints;
145
+ let i = 0;
146
+ let cursor = 0;
147
+ let insertAt = step / 2;
148
+ while (points.length < desiredLength) {
149
+ const a = points[i];
150
+ const b = points[(i + 1) % points.length];
151
+ const length = a.sub(b).magnitude;
152
+ if (insertAt <= cursor + length) {
153
+ points.splice(i + 1, 0, length
154
+ ? Vector2.lerp(a, b, (insertAt - cursor) / length)
155
+ : new Vector2(a));
156
+ insertAt += step;
157
+ }
158
+ else {
159
+ cursor += length;
160
+ i += 1;
161
+ }
162
+ }
163
+ }
164
+ /**
165
+ * Calculate total moving point distance when morphing between polygon points
166
+ * @param points - first polygon points
167
+ * @param reference - second polygon points
168
+ * @param offset - offset for first polygon points
169
+ * @returns
170
+ */
171
+ export function calculateLerpDistance(points, reference, offset) {
172
+ const len = points.length;
173
+ let sumOfSquares = 0;
174
+ for (let i = 0; i < reference.length; i += 1) {
175
+ const a = points[(offset + i) % len];
176
+ const b = reference[i];
177
+ sumOfSquares += a.sub(b).squaredMagnitude;
178
+ }
179
+ return sumOfSquares;
180
+ }
181
+ /**
182
+ * Rotate polygon in order to minimize moving points.
183
+ * @param polygon - polygon to be rotated
184
+ * @param reference - polygon to be reference
185
+ */
186
+ function rotatePolygon(polygon, reference) {
187
+ const { points, closed } = polygon;
188
+ const len = points.length;
189
+ if (!closed) {
190
+ const originalDistance = calculateLerpDistance(points, reference.points, 0);
191
+ const reversedPoints = [...points].reverse();
192
+ const reversedDistance = calculateLerpDistance(reversedPoints, reference.points, 0);
193
+ if (reversedDistance < originalDistance)
194
+ polygon.points = reversedPoints;
195
+ }
196
+ else {
197
+ let minDistance = Infinity;
198
+ let bestOffset = 0;
199
+ const last = points.pop();
200
+ // Closed polygon first point must equal last point
201
+ // When we rotate polygon, first point is changed which mean last point also must changed
202
+ // When we remove last point, calculateLerpDistance will assume last point is equal first point
203
+ // Proof:
204
+ // len = points.length = reference.length - 1
205
+ // When i = 0:
206
+ // (offset + i) % len = offset % len
207
+ // When i = reference.length - 1 or i = len
208
+ // (offset + i) % len = (offset + len) % len = offset % len
209
+ for (let offset = 0; offset < len; offset += 1) {
210
+ const distance = calculateLerpDistance(points, reference.points, offset);
211
+ if (distance < minDistance) {
212
+ minDistance = distance;
213
+ bestOffset = offset;
214
+ }
215
+ }
216
+ if (last)
217
+ points.push(last);
218
+ if (bestOffset) {
219
+ points.pop();
220
+ const spliced = points.splice(0, bestOffset);
221
+ points.splice(points.length, 0, ...spliced);
222
+ points.push(points[0]);
223
+ }
224
+ }
225
+ }
226
+ /**
227
+ * Round polygon's points coordinate to a specified amount of decimal
228
+ * @param points - polygon point to be rounded
229
+ * @param round - amount of decimal
230
+ * @returns - new polygon point
231
+ */
232
+ function roundPolygon({ points, ...rest }, round) {
233
+ const pow = round >= 1 ? 10 ** round : 1;
234
+ return {
235
+ points: points.map(point => {
236
+ const [x, y] = [point.x, point.y].map(n => Math.round(n * pow) / pow);
237
+ return new Vector2(x, y);
238
+ }),
239
+ ...rest,
240
+ };
241
+ }
242
+ /**
243
+ * Create two polygon to tween between sub curve/path
244
+ * @param from - source curve
245
+ * @param to - targe curve
246
+ * @param precision - desired distance between two point
247
+ * @param round - amount of decimal when rounding
248
+ * @returns two polygon ready to tween
249
+ */
250
+ function getSubcurveInterpolationPolygon(from, to, precision, round) {
251
+ const morphPrecision = precision;
252
+ const fromRing = subcurveToPolygon(from, morphPrecision);
253
+ const toRing = subcurveToPolygon(to, morphPrecision);
254
+ const diff = fromRing.points.length - toRing.points.length;
255
+ addPoints(fromRing.points, diff < 0 ? diff * -1 : 0);
256
+ addPoints(toRing.points, diff > 0 ? diff : 0);
257
+ if (!from.closed && to.closed)
258
+ rotatePolygon(toRing, fromRing);
259
+ else
260
+ rotatePolygon(fromRing, toRing);
261
+ return {
262
+ from: roundPolygon(fromRing, round),
263
+ to: roundPolygon(toRing, round),
264
+ };
265
+ }
266
+ /**
267
+ * Make two sub curve list have equal length
268
+ * @param subcurves - List to add
269
+ * @param reference - Reference list
270
+ */
271
+ function balanceSubcurves(subcurves, reference) {
272
+ for (let i = subcurves.length; i < reference.length; i++) {
273
+ const point = reference[i].segments[0].getPoint(0).position;
274
+ subcurves.push({
275
+ arcLength: 0,
276
+ closed: false,
277
+ minSin: 0,
278
+ segments: [new LineSegment(point, point)],
279
+ });
280
+ }
281
+ }
282
+ /**
283
+ * Create two polygon to tween between curve
284
+ * @param from - source curve
285
+ * @param to - targe curve
286
+ * @param precision - desired distance between two point
287
+ * @param round - amount of decimal when rounding
288
+ * @returns list that contain list of polygon before and after tween
289
+ */
290
+ function getInterpolationPolygon(from, to, precision, round) {
291
+ const fromSub = splitCurve(from);
292
+ const toSub = splitCurve(to);
293
+ if (fromSub.length < toSub.length)
294
+ balanceSubcurves(fromSub, toSub);
295
+ else
296
+ balanceSubcurves(toSub, fromSub);
297
+ return fromSub.map((sub, i) => getSubcurveInterpolationPolygon(sub, toSub[i], precision, round));
298
+ }
299
+ /**
300
+ * Add curve into another curve
301
+ * @param target - target curve
302
+ * @param source - curve to add
303
+ */
304
+ function addCurveToCurve(target, source) {
305
+ const { segments, arcLength, minSin } = source;
306
+ target.segments.push(...segments);
307
+ target.arcLength += arcLength;
308
+ target.minSin = Math.min(target.minSin, minSin);
309
+ }
310
+ /**
311
+ * Interpolate between two polygon points.
312
+ * @param from - source polygon points
313
+ * @param to - target polygon points
314
+ * @param value - interpolation progress
315
+ * @returns - new polygon points
316
+ */
317
+ export function polygonPointsLerp(from, to, value) {
318
+ const points = [];
319
+ if (value === 0)
320
+ return [...from];
321
+ if (value === 1)
322
+ return [...to];
323
+ for (let i = 0; i < from.length; i++) {
324
+ const a = from[i];
325
+ const b = to[i];
326
+ points.push(Vector2.lerp(a, b, value));
327
+ }
328
+ return points;
329
+ }
330
+ /**
331
+ * Create interpolator to tween between two curve
332
+ * @param a - source curve
333
+ * @param b - target curve
334
+ * @returns - curve interpolator
335
+ */
336
+ export function createCurveProfileLerp(a, b) {
337
+ const interpolations = getInterpolationPolygon(a, b, 5, 4);
338
+ return (progress) => {
339
+ const curve = {
340
+ segments: [],
341
+ arcLength: 0,
342
+ minSin: 1,
343
+ };
344
+ for (const { from, to } of interpolations) {
345
+ const points = polygonPointsLerp(from.points, to.points, progress);
346
+ addCurveToCurve(curve, getPolylineProfile(points, 0, false));
347
+ }
348
+ return curve;
349
+ };
350
+ }
351
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlQ3VydmVQcm9maWxlTGVycC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvY3VydmVzL2NyZWF0ZUN1cnZlUHJvZmlsZUxlcnAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLGFBQWEsQ0FBQztBQUVwQyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBZ0J4RDs7OztHQUlHO0FBRUgsU0FBUyxNQUFNLENBQUMsTUFBaUIsRUFBRSxTQUFpQjtJQUNsRCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUMzQyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDcEIsSUFBSSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUN0QixPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxHQUFHLFNBQVMsRUFBRSxDQUFDO1lBQ3RDLENBQUMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7WUFDNUIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM3QixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUM7QUFFRDs7Ozs7R0FLRztBQUVILFNBQVMsa0JBQWtCLENBQ3pCLEtBQXNCLEVBQ3RCLFNBQWlCO0lBRWpCLE1BQU0sTUFBTSxHQUFjLEVBQUUsQ0FBQztJ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
@@ -0,0 +1,12 @@
1
+ import type { CurveProfile } from './CurveProfile';
2
+ import type { KnotInfo } from './KnotInfo';
3
+ /**
4
+ * Calculate the curve profile of a spline based on a set of knots.
5
+ *
6
+ * @param knots - The knots defining the spline
7
+ * @param closed - Whether the spline should be closed or not
8
+ * @param smoothness - The desired smoothness of the spline when using auto
9
+ * calculated handles.
10
+ */
11
+ export declare function getBezierSplineProfile(knots: KnotInfo[], closed: boolean, smoothness: number): CurveProfile;
12
+ //# sourceMappingURL=getBezierSplineProfile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getBezierSplineProfile.d.ts","sourceRoot":"","sources":["../../src/lib/curves/getBezierSplineProfile.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,YAAY,CAAC;AAsGzC;;;;;;;GAOG;AACH,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,QAAQ,EAAE,EACjB,MAAM,EAAE,OAAO,EACf,UAAU,EAAE,MAAM,GACjB,YAAY,CAyGd"}
@@ -0,0 +1,137 @@
1
+ import { Vector2, clamp } from '@twick/core';
2
+ import { CubicBezierSegment } from './CubicBezierSegment';
3
+ import { QuadBezierSegment } from './QuadBezierSegment';
4
+ function isCubicSegment(segment) {
5
+ return segment instanceof CubicBezierSegment;
6
+ }
7
+ /**
8
+ * Update a given knot's handles to be a blend between the user provided handles
9
+ * and a set of auto calculated handles that smoothly connect the knot to its
10
+ * two neighboring knots.
11
+ *
12
+ * @param knot - The knot for which to calculate the handles
13
+ * @param previous - The previous knot in the spline, relative to the provided
14
+ * knot.
15
+ * @param next - The next knot in the spline, relative to the provided knot.
16
+ * @param smoothness - The desired smoothness of the spline. Affects the scaling
17
+ * of the auto calculated handles.
18
+ */
19
+ function calculateSmoothHandles(knot, previous, next, smoothness) {
20
+ if (knot.auto.start === 0 && knot.auto.end === 0) {
21
+ return;
22
+ }
23
+ // See for reference:
24
+ // http://scaledinnovation.com/analytics/splines/aboutSplines.html
25
+ const distanceToPrev = knot.position.sub(previous.position).magnitude;
26
+ const distanceToNext = next.position.sub(knot.position).magnitude;
27
+ const fa = (smoothness * distanceToPrev) / (distanceToPrev + distanceToNext);
28
+ const fb = smoothness - fa;
29
+ const startHandle = new Vector2(knot.position.x - fa * (next.position.x - previous.position.x), knot.position.y - fa * (next.position.y - previous.position.y));
30
+ const endHandle = new Vector2(knot.position.x + fb * (next.position.x - previous.position.x), knot.position.y + fb * (next.position.y - previous.position.y));
31
+ knot.startHandle = knot.startHandle.lerp(startHandle, knot.auto.start);
32
+ knot.endHandle = knot.endHandle.lerp(endHandle, knot.auto.end);
33
+ }
34
+ /**
35
+ * Calculate the `minSin` value of the curve profile so that miter joins get
36
+ * taken into account properly.
37
+ */
38
+ function updateMinSin(profile) {
39
+ for (let i = 0; i < profile.segments.length; i++) {
40
+ const segmentA = profile.segments[i];
41
+ const segmentB = profile.segments[(i + 1) % profile.segments.length];
42
+ // Quadratic Bézier segments will always join smoothly with the previous
43
+ // segment. This means that we can skip the segment since it's impossible
44
+ // to have a miter join between the two segments.
45
+ if (!isCubicSegment(segmentA) || !isCubicSegment(segmentB)) {
46
+ continue;
47
+ }
48
+ const startVector = segmentA.p2.sub(segmentA.p3).normalized.safe;
49
+ const endVector = segmentB.p1.sub(segmentB.p0).normalized.safe;
50
+ const dot = startVector.dot(endVector);
51
+ // A miter join can only occur if the handle is broken, so we can skip the
52
+ // segment if the handles are mirrored.
53
+ const isBroken = 1 - Math.abs(dot) > 0.0001;
54
+ if (!isBroken) {
55
+ continue;
56
+ }
57
+ const angleBetween = Math.acos(clamp(-1, 1, dot));
58
+ const angleSin = Math.sin(angleBetween / 2);
59
+ profile.minSin = Math.min(profile.minSin, Math.abs(angleSin));
60
+ }
61
+ }
62
+ function addSegmentToProfile(profile, p0, p1, p2, p3) {
63
+ const segment = p3 !== undefined
64
+ ? new CubicBezierSegment(p0, p1, p2, p3)
65
+ : new QuadBezierSegment(p0, p1, p2);
66
+ profile.segments.push(segment);
67
+ profile.arcLength += segment.arcLength;
68
+ }
69
+ /**
70
+ * Calculate the curve profile of a spline based on a set of knots.
71
+ *
72
+ * @param knots - The knots defining the spline
73
+ * @param closed - Whether the spline should be closed or not
74
+ * @param smoothness - The desired smoothness of the spline when using auto
75
+ * calculated handles.
76
+ */
77
+ export function getBezierSplineProfile(knots, closed, smoothness) {
78
+ const profile = {
79
+ segments: [],
80
+ arcLength: 0,
81
+ minSin: 1,
82
+ };
83
+ // First, we want to calculate the actual handle positions for each knot. We
84
+ // do so using the knot's `auto` value to blend between the user-provided
85
+ // handles and the auto calculated smooth handles.
86
+ const numberOfKnots = knots.length;
87
+ for (let i = 0; i < numberOfKnots; i++) {
88
+ // Calculating the auto handles for a given knot requires both of the knot's
89
+ // neighboring knots. To make sure that this works properly for the first
90
+ // and last knots of the spline, we want to make sure to wrap around to the
91
+ // beginning and end of the array, respectively.
92
+ const prevIndex = (i - 1 + numberOfKnots) % numberOfKnots;
93
+ const nextIndex = (i + 1) % numberOfKnots;
94
+ calculateSmoothHandles(knots[i], knots[prevIndex], knots[nextIndex], smoothness);
95
+ }
96
+ const firstKnot = knots[0];
97
+ const secondKnot = knots[1];
98
+ // Drawing the first and last segments of a spline has a few edge cases we
99
+ // need to consider:
100
+ // If the spline is not closed and the first knot should use the auto
101
+ // calculated handles, we want to draw a quadratic Bézier curve instead of a
102
+ // cubic one.
103
+ if (!closed && firstKnot.auto.start === 1 && firstKnot.auto.end === 1) {
104
+ addSegmentToProfile(profile, firstKnot.position, secondKnot.startHandle, secondKnot.position);
105
+ }
106
+ else {
107
+ // Otherwise, draw a cubic Bézier segment like we do for the other segments.
108
+ addSegmentToProfile(profile, firstKnot.position, firstKnot.endHandle, secondKnot.startHandle, secondKnot.position);
109
+ }
110
+ // Add all intermediate spline segments as cubic Bézier curve segments.
111
+ for (let i = 1; i < numberOfKnots - 2; i++) {
112
+ const start = knots[i];
113
+ const end = knots[i + 1];
114
+ addSegmentToProfile(profile, start.position, start.endHandle, end.startHandle, end.position);
115
+ }
116
+ const lastKnot = knots.at(-1);
117
+ const secondToLastKnot = knots.at(-2);
118
+ if (knots.length > 2) {
119
+ // Similar to the first segment, we also want to draw the last segment as a
120
+ // quadratic Bézier curve if the curve is not closed and the knot should
121
+ // use the auto calculated handles.
122
+ if (!closed && lastKnot.auto.start === 1 && lastKnot.auto.end === 1) {
123
+ addSegmentToProfile(profile, secondToLastKnot.position, secondToLastKnot.endHandle, lastKnot.position);
124
+ }
125
+ else {
126
+ addSegmentToProfile(profile, secondToLastKnot.position, secondToLastKnot.endHandle, lastKnot.startHandle, lastKnot.position);
127
+ }
128
+ }
129
+ // If the spline should be closed, add one final cubic Bézier segment
130
+ // connecting the last and first knots.
131
+ if (closed) {
132
+ addSegmentToProfile(profile, lastKnot.position, lastKnot.endHandle, firstKnot.startHandle, firstKnot.position);
133
+ }
134
+ updateMinSin(profile);
135
+ return profile;
136
+ }
137
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0QmV6aWVyU3BsaW5lUHJvZmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvY3VydmVzL2dldEJlemllclNwbGluZVByb2ZpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUMsTUFBTSxhQUFhLENBQUM7QUFDM0MsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFJeEQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFFdEQsU0FBUyxjQUFjLENBQ3JCLE9BQTBCO0lBRTFCLE9BQU8sT0FBTyxZQUFZLGtCQUFrQixDQUFDO0FBQy9DLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7R0FXRztBQUNILFNBQVMsc0JBQXNCLENBQzdCLElBQWMsRUFDZCxRQUFrQixFQUNsQixJQUFjLEVBQ2QsVUFBa0I7SUFFbEIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDakQsT0FBTztJQUNULENBQUM7SUFFRCxxQkFBcUI7SUFDckIsa0VBQWtFO0lBQ2xFLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDdEUsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNsRSxNQUFNLEVBQUUsR0FBRyxDQUFDLFVBQVUsR0FBRyxjQUFjLENBQUMsR0FBRyxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUMsQ0FBQztJQUM3RSxNQUFNLEVBQUUsR0FBRyxVQUFVLEdBQUcsRUFBRSxDQUFDO0lBQzNCLE1BQU0sV0FBVyxHQUFHLElB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
@@ -0,0 +1,4 @@
1
+ import { Vector2 } from '@twick/core';
2
+ import type { CurveProfile } from './CurveProfile';
3
+ export declare function getCircleProfile(size: Vector2, startAngle: number, endAngle: number, closed: boolean, counterclockwise?: boolean): CurveProfile;
4
+ //# sourceMappingURL=getCircleProfile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getCircleProfile.d.ts","sourceRoot":"","sources":["../../src/lib/curves/getCircleProfile.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,aAAa,CAAC;AAEpC,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAIjD,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,OAAO,EACb,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,OAAO,EACf,gBAAgB,UAAQ,GACvB,YAAY,CAkDd"}