@linkiez/dxf-renew 5.3.1

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 (447) hide show
  1. package/.eslintignore +17 -0
  2. package/.eslintrc.json +61 -0
  3. package/.gitattributes +4 -0
  4. package/.github/instructions/project-en_US.instructions.md +352 -0
  5. package/.github/workflows/release.yml +110 -0
  6. package/.husky/commit-msg +4 -0
  7. package/.husky/pre-commit +1 -0
  8. package/.prettierignore +1 -0
  9. package/.prettierrc.json +6 -0
  10. package/.releaserc.json +76 -0
  11. package/.travis.yml +6 -0
  12. package/.yarn/install-state.gz +0 -0
  13. package/.yarnrc.yml +1 -0
  14. package/CHANGELOG.md +134 -0
  15. package/CONTRIBUTING.md +271 -0
  16. package/LICENSE +21 -0
  17. package/PLAN.md +517 -0
  18. package/README.md +306 -0
  19. package/build.mjs +66 -0
  20. package/commitlint.config.js +25 -0
  21. package/dist/dxf.js +7234 -0
  22. package/docs/CODE_PATTERNS.md +182 -0
  23. package/docs/DIMENSION_SUMMARY.md +248 -0
  24. package/docs/DIMENSION_SUMMARY.pt-BR.md +248 -0
  25. package/docs/IMPLEMENTED-2D-ENTITIES.md +54 -0
  26. package/docs/IMPLEMENTED-2D-ENTITIES.pt-BR.md +54 -0
  27. package/docs/TEXT-MTEXT-DIMENSION-SUPPORT.md +241 -0
  28. package/docs/TEXT-MTEXT-DIMENSION-SUPPORT.pt-BR.md +169 -0
  29. package/docs/autocad_2012_pdf_dxf-reference_enu.md +8272 -0
  30. package/examples/dxf.html +36 -0
  31. package/examples/example.es5.js +30 -0
  32. package/examples/example.es6.js +30 -0
  33. package/examples/text-dimension-viewer.html +133 -0
  34. package/lib/Helper.cjs +89 -0
  35. package/lib/Helper.cjs.map +7 -0
  36. package/lib/Helper.js +59 -0
  37. package/lib/Helper.js.map +7 -0
  38. package/lib/applyTransforms.cjs +59 -0
  39. package/lib/applyTransforms.cjs.map +7 -0
  40. package/lib/applyTransforms.js +39 -0
  41. package/lib/applyTransforms.js.map +7 -0
  42. package/lib/cli.cjs +53 -0
  43. package/lib/cli.cjs.map +7 -0
  44. package/lib/cli.js +29 -0
  45. package/lib/cli.js.map +7 -0
  46. package/lib/config.cjs +30 -0
  47. package/lib/config.cjs.map +7 -0
  48. package/lib/config.js +10 -0
  49. package/lib/config.js.map +7 -0
  50. package/lib/constants.cjs +39 -0
  51. package/lib/constants.cjs.map +7 -0
  52. package/lib/constants.js +15 -0
  53. package/lib/constants.js.map +7 -0
  54. package/lib/denormalise.cjs +148 -0
  55. package/lib/denormalise.cjs.map +7 -0
  56. package/lib/denormalise.js +118 -0
  57. package/lib/denormalise.js.map +7 -0
  58. package/lib/dimensionToSVG.cjs +307 -0
  59. package/lib/dimensionToSVG.cjs.map +7 -0
  60. package/lib/dimensionToSVG.js +273 -0
  61. package/lib/dimensionToSVG.js.map +7 -0
  62. package/lib/entityToPolyline.cjs +248 -0
  63. package/lib/entityToPolyline.cjs.map +7 -0
  64. package/lib/entityToPolyline.js +213 -0
  65. package/lib/entityToPolyline.js.map +7 -0
  66. package/lib/getRGBForEntity.cjs +53 -0
  67. package/lib/getRGBForEntity.cjs.map +7 -0
  68. package/lib/getRGBForEntity.js +23 -0
  69. package/lib/getRGBForEntity.js.map +7 -0
  70. package/lib/groupEntitiesByLayer.cjs +34 -0
  71. package/lib/groupEntitiesByLayer.cjs.map +7 -0
  72. package/lib/groupEntitiesByLayer.js +14 -0
  73. package/lib/groupEntitiesByLayer.js.map +7 -0
  74. package/lib/handlers/blocks.cjs +93 -0
  75. package/lib/handlers/blocks.cjs.map +7 -0
  76. package/lib/handlers/blocks.js +63 -0
  77. package/lib/handlers/blocks.js.map +7 -0
  78. package/lib/handlers/entities.cjs +118 -0
  79. package/lib/handlers/entities.cjs.map +7 -0
  80. package/lib/handlers/entities.js +88 -0
  81. package/lib/handlers/entities.js.map +7 -0
  82. package/lib/handlers/entity/arc.cjs +82 -0
  83. package/lib/handlers/entity/arc.cjs.map +7 -0
  84. package/lib/handlers/entity/arc.js +47 -0
  85. package/lib/handlers/entity/arc.js.map +7 -0
  86. package/lib/handlers/entity/attdef.cjs +318 -0
  87. package/lib/handlers/entity/attdef.cjs.map +7 -0
  88. package/lib/handlers/entity/attdef.js +282 -0
  89. package/lib/handlers/entity/attdef.js.map +7 -0
  90. package/lib/handlers/entity/attrib.cjs +52 -0
  91. package/lib/handlers/entity/attrib.cjs.map +7 -0
  92. package/lib/handlers/entity/attrib.js +27 -0
  93. package/lib/handlers/entity/attrib.js.map +7 -0
  94. package/lib/handlers/entity/circle.cjs +73 -0
  95. package/lib/handlers/entity/circle.cjs.map +7 -0
  96. package/lib/handlers/entity/circle.js +38 -0
  97. package/lib/handlers/entity/circle.js.map +7 -0
  98. package/lib/handlers/entity/common.cjs +83 -0
  99. package/lib/handlers/entity/common.cjs.map +7 -0
  100. package/lib/handlers/entity/common.js +63 -0
  101. package/lib/handlers/entity/common.js.map +7 -0
  102. package/lib/handlers/entity/dimension.cjs +203 -0
  103. package/lib/handlers/entity/dimension.cjs.map +7 -0
  104. package/lib/handlers/entity/dimension.js +168 -0
  105. package/lib/handlers/entity/dimension.js.map +7 -0
  106. package/lib/handlers/entity/ellipse.cjs +88 -0
  107. package/lib/handlers/entity/ellipse.cjs.map +7 -0
  108. package/lib/handlers/entity/ellipse.js +53 -0
  109. package/lib/handlers/entity/ellipse.js.map +7 -0
  110. package/lib/handlers/entity/hatch.cjs +470 -0
  111. package/lib/handlers/entity/hatch.cjs.map +7 -0
  112. package/lib/handlers/entity/hatch.js +435 -0
  113. package/lib/handlers/entity/hatch.js.map +7 -0
  114. package/lib/handlers/entity/insert.cjs +106 -0
  115. package/lib/handlers/entity/insert.cjs.map +7 -0
  116. package/lib/handlers/entity/insert.js +71 -0
  117. package/lib/handlers/entity/insert.js.map +7 -0
  118. package/lib/handlers/entity/line.cjs +84 -0
  119. package/lib/handlers/entity/line.cjs.map +7 -0
  120. package/lib/handlers/entity/line.js +49 -0
  121. package/lib/handlers/entity/line.js.map +7 -0
  122. package/lib/handlers/entity/lwpolyline.cjs +82 -0
  123. package/lib/handlers/entity/lwpolyline.cjs.map +7 -0
  124. package/lib/handlers/entity/lwpolyline.js +47 -0
  125. package/lib/handlers/entity/lwpolyline.js.map +7 -0
  126. package/lib/handlers/entity/mtext.cjs +121 -0
  127. package/lib/handlers/entity/mtext.cjs.map +7 -0
  128. package/lib/handlers/entity/mtext.js +85 -0
  129. package/lib/handlers/entity/mtext.js.map +7 -0
  130. package/lib/handlers/entity/ole2Frame.cjs +98 -0
  131. package/lib/handlers/entity/ole2Frame.cjs.map +7 -0
  132. package/lib/handlers/entity/ole2Frame.js +63 -0
  133. package/lib/handlers/entity/ole2Frame.js.map +7 -0
  134. package/lib/handlers/entity/point.cjs +73 -0
  135. package/lib/handlers/entity/point.cjs.map +7 -0
  136. package/lib/handlers/entity/point.js +38 -0
  137. package/lib/handlers/entity/point.js.map +7 -0
  138. package/lib/handlers/entity/polyline.cjs +70 -0
  139. package/lib/handlers/entity/polyline.cjs.map +7 -0
  140. package/lib/handlers/entity/polyline.js +35 -0
  141. package/lib/handlers/entity/polyline.js.map +7 -0
  142. package/lib/handlers/entity/solid.cjs +101 -0
  143. package/lib/handlers/entity/solid.cjs.map +7 -0
  144. package/lib/handlers/entity/solid.js +66 -0
  145. package/lib/handlers/entity/solid.js.map +7 -0
  146. package/lib/handlers/entity/spline.cjs +109 -0
  147. package/lib/handlers/entity/spline.cjs.map +7 -0
  148. package/lib/handlers/entity/spline.js +74 -0
  149. package/lib/handlers/entity/spline.js.map +7 -0
  150. package/lib/handlers/entity/text.cjs +85 -0
  151. package/lib/handlers/entity/text.cjs.map +7 -0
  152. package/lib/handlers/entity/text.js +49 -0
  153. package/lib/handlers/entity/text.js.map +7 -0
  154. package/lib/handlers/entity/threeDFace.cjs +98 -0
  155. package/lib/handlers/entity/threeDFace.cjs.map +7 -0
  156. package/lib/handlers/entity/threeDFace.js +63 -0
  157. package/lib/handlers/entity/threeDFace.js.map +7 -0
  158. package/lib/handlers/entity/vertex.cjs +78 -0
  159. package/lib/handlers/entity/vertex.cjs.map +7 -0
  160. package/lib/handlers/entity/vertex.js +53 -0
  161. package/lib/handlers/entity/vertex.js.map +7 -0
  162. package/lib/handlers/entity/viewport.cjs +153 -0
  163. package/lib/handlers/entity/viewport.cjs.map +7 -0
  164. package/lib/handlers/entity/viewport.js +118 -0
  165. package/lib/handlers/entity/viewport.js.map +7 -0
  166. package/lib/handlers/header.cjs +92 -0
  167. package/lib/handlers/header.cjs.map +7 -0
  168. package/lib/handlers/header.js +72 -0
  169. package/lib/handlers/header.js.map +7 -0
  170. package/lib/handlers/objects.cjs +170 -0
  171. package/lib/handlers/objects.cjs.map +7 -0
  172. package/lib/handlers/objects.js +150 -0
  173. package/lib/handlers/objects.js.map +7 -0
  174. package/lib/handlers/tables.cjs +587 -0
  175. package/lib/handlers/tables.cjs.map +7 -0
  176. package/lib/handlers/tables.js +557 -0
  177. package/lib/handlers/tables.js.map +7 -0
  178. package/lib/index.cjs +60 -0
  179. package/lib/index.cjs.map +7 -0
  180. package/lib/index.js +19 -0
  181. package/lib/index.js.map +7 -0
  182. package/lib/parseString.cjs +118 -0
  183. package/lib/parseString.cjs.map +7 -0
  184. package/lib/parseString.js +88 -0
  185. package/lib/parseString.js.map +7 -0
  186. package/lib/toPolylines.cjs +69 -0
  187. package/lib/toPolylines.cjs.map +7 -0
  188. package/lib/toPolylines.js +39 -0
  189. package/lib/toPolylines.js.map +7 -0
  190. package/lib/toSVG.cjs +395 -0
  191. package/lib/toSVG.cjs.map +7 -0
  192. package/lib/toSVG.js +361 -0
  193. package/lib/toSVG.js.map +7 -0
  194. package/lib/types/arc-entity.cjs +17 -0
  195. package/lib/types/arc-entity.cjs.map +7 -0
  196. package/lib/types/arc-entity.js +1 -0
  197. package/lib/types/arc-entity.js.map +7 -0
  198. package/lib/types/base-entity.cjs +17 -0
  199. package/lib/types/base-entity.cjs.map +7 -0
  200. package/lib/types/base-entity.js +1 -0
  201. package/lib/types/base-entity.js.map +7 -0
  202. package/lib/types/circle-entity.cjs +17 -0
  203. package/lib/types/circle-entity.cjs.map +7 -0
  204. package/lib/types/circle-entity.js +1 -0
  205. package/lib/types/circle-entity.js.map +7 -0
  206. package/lib/types/common.cjs +17 -0
  207. package/lib/types/common.cjs.map +7 -0
  208. package/lib/types/common.js +1 -0
  209. package/lib/types/common.js.map +7 -0
  210. package/lib/types/dimension-entity.cjs +17 -0
  211. package/lib/types/dimension-entity.cjs.map +7 -0
  212. package/lib/types/dimension-entity.js +1 -0
  213. package/lib/types/dimension-entity.js.map +7 -0
  214. package/lib/types/dxf.cjs +17 -0
  215. package/lib/types/dxf.cjs.map +7 -0
  216. package/lib/types/dxf.js +1 -0
  217. package/lib/types/dxf.js.map +7 -0
  218. package/lib/types/ellipse-entity.cjs +17 -0
  219. package/lib/types/ellipse-entity.cjs.map +7 -0
  220. package/lib/types/ellipse-entity.js +1 -0
  221. package/lib/types/ellipse-entity.js.map +7 -0
  222. package/lib/types/entity.cjs +17 -0
  223. package/lib/types/entity.cjs.map +7 -0
  224. package/lib/types/entity.js +1 -0
  225. package/lib/types/entity.js.map +7 -0
  226. package/lib/types/handler-internal.cjs +17 -0
  227. package/lib/types/handler-internal.cjs.map +7 -0
  228. package/lib/types/handler-internal.js +1 -0
  229. package/lib/types/handler-internal.js.map +7 -0
  230. package/lib/types/handler.cjs +17 -0
  231. package/lib/types/handler.cjs.map +7 -0
  232. package/lib/types/handler.js +1 -0
  233. package/lib/types/handler.js.map +7 -0
  234. package/lib/types/hatch-entity.cjs +17 -0
  235. package/lib/types/hatch-entity.cjs.map +7 -0
  236. package/lib/types/hatch-entity.js +1 -0
  237. package/lib/types/hatch-entity.js.map +7 -0
  238. package/lib/types/helper.cjs +17 -0
  239. package/lib/types/helper.cjs.map +7 -0
  240. package/lib/types/helper.js +1 -0
  241. package/lib/types/helper.js.map +7 -0
  242. package/lib/types/index.cjs +77 -0
  243. package/lib/types/index.cjs.map +7 -0
  244. package/lib/types/index.js +29 -0
  245. package/lib/types/index.js.map +7 -0
  246. package/lib/types/insert-entity.cjs +17 -0
  247. package/lib/types/insert-entity.cjs.map +7 -0
  248. package/lib/types/insert-entity.js +1 -0
  249. package/lib/types/insert-entity.js.map +7 -0
  250. package/lib/types/layer-groups.cjs +17 -0
  251. package/lib/types/layer-groups.cjs.map +7 -0
  252. package/lib/types/layer-groups.js +1 -0
  253. package/lib/types/layer-groups.js.map +7 -0
  254. package/lib/types/line-entity.cjs +17 -0
  255. package/lib/types/line-entity.cjs.map +7 -0
  256. package/lib/types/line-entity.js +1 -0
  257. package/lib/types/line-entity.js.map +7 -0
  258. package/lib/types/mtext-entity.cjs +17 -0
  259. package/lib/types/mtext-entity.cjs.map +7 -0
  260. package/lib/types/mtext-entity.js +1 -0
  261. package/lib/types/mtext-entity.js.map +7 -0
  262. package/lib/types/ole2frame-entity.cjs +17 -0
  263. package/lib/types/ole2frame-entity.cjs.map +7 -0
  264. package/lib/types/ole2frame-entity.js +1 -0
  265. package/lib/types/ole2frame-entity.js.map +7 -0
  266. package/lib/types/options.cjs +17 -0
  267. package/lib/types/options.cjs.map +7 -0
  268. package/lib/types/options.js +1 -0
  269. package/lib/types/options.js.map +7 -0
  270. package/lib/types/point-entity.cjs +17 -0
  271. package/lib/types/point-entity.cjs.map +7 -0
  272. package/lib/types/point-entity.js +1 -0
  273. package/lib/types/point-entity.js.map +7 -0
  274. package/lib/types/polyline-entity.cjs +17 -0
  275. package/lib/types/polyline-entity.cjs.map +7 -0
  276. package/lib/types/polyline-entity.js +1 -0
  277. package/lib/types/polyline-entity.js.map +7 -0
  278. package/lib/types/polylines.cjs +17 -0
  279. package/lib/types/polylines.cjs.map +7 -0
  280. package/lib/types/polylines.js +1 -0
  281. package/lib/types/polylines.js.map +7 -0
  282. package/lib/types/solid-entity.cjs +17 -0
  283. package/lib/types/solid-entity.cjs.map +7 -0
  284. package/lib/types/solid-entity.js +1 -0
  285. package/lib/types/solid-entity.js.map +7 -0
  286. package/lib/types/spline-entity.cjs +17 -0
  287. package/lib/types/spline-entity.cjs.map +7 -0
  288. package/lib/types/spline-entity.js +1 -0
  289. package/lib/types/spline-entity.js.map +7 -0
  290. package/lib/types/svg.cjs +17 -0
  291. package/lib/types/svg.cjs.map +7 -0
  292. package/lib/types/svg.js +1 -0
  293. package/lib/types/svg.js.map +7 -0
  294. package/lib/types/tables.cjs +17 -0
  295. package/lib/types/tables.cjs.map +7 -0
  296. package/lib/types/tables.js +1 -0
  297. package/lib/types/tables.js.map +7 -0
  298. package/lib/types/text-entity.cjs +17 -0
  299. package/lib/types/text-entity.cjs.map +7 -0
  300. package/lib/types/text-entity.js +1 -0
  301. package/lib/types/text-entity.js.map +7 -0
  302. package/lib/types/util-types.cjs +17 -0
  303. package/lib/types/util-types.cjs.map +7 -0
  304. package/lib/types/util-types.js +1 -0
  305. package/lib/types/util-types.js.map +7 -0
  306. package/lib/types/vecks.d.cjs +2 -0
  307. package/lib/types/vecks.d.cjs.map +7 -0
  308. package/lib/types/vecks.d.js +1 -0
  309. package/lib/types/vecks.d.js.map +7 -0
  310. package/lib/types/viewport-entity.cjs +17 -0
  311. package/lib/types/viewport-entity.cjs.map +7 -0
  312. package/lib/types/viewport-entity.js +1 -0
  313. package/lib/types/viewport-entity.js.map +7 -0
  314. package/lib/types.cjs +23 -0
  315. package/lib/types.cjs.map +7 -0
  316. package/lib/types.js +2 -0
  317. package/lib/types.js.map +7 -0
  318. package/lib/util/bSpline.cjs +95 -0
  319. package/lib/util/bSpline.cjs.map +7 -0
  320. package/lib/util/bSpline.js +65 -0
  321. package/lib/util/bSpline.js.map +7 -0
  322. package/lib/util/colors.cjs +283 -0
  323. package/lib/util/colors.cjs.map +7 -0
  324. package/lib/util/colors.js +263 -0
  325. package/lib/util/colors.js.map +7 -0
  326. package/lib/util/createArcForLWPolyline.cjs +84 -0
  327. package/lib/util/createArcForLWPolyline.cjs.map +7 -0
  328. package/lib/util/createArcForLWPolyline.js +64 -0
  329. package/lib/util/createArcForLWPolyline.js.map +7 -0
  330. package/lib/util/dxfColorToRGB.cjs +115 -0
  331. package/lib/util/dxfColorToRGB.cjs.map +7 -0
  332. package/lib/util/dxfColorToRGB.js +90 -0
  333. package/lib/util/dxfColorToRGB.js.map +7 -0
  334. package/lib/util/insertKnot.cjs +77 -0
  335. package/lib/util/insertKnot.cjs.map +7 -0
  336. package/lib/util/insertKnot.js +57 -0
  337. package/lib/util/insertKnot.js.map +7 -0
  338. package/lib/util/logger.cjs +53 -0
  339. package/lib/util/logger.cjs.map +7 -0
  340. package/lib/util/logger.js +23 -0
  341. package/lib/util/logger.js.map +7 -0
  342. package/lib/util/rgbToColorAttribute.cjs +32 -0
  343. package/lib/util/rgbToColorAttribute.cjs.map +7 -0
  344. package/lib/util/rgbToColorAttribute.js +12 -0
  345. package/lib/util/rgbToColorAttribute.js.map +7 -0
  346. package/lib/util/rotate.cjs +30 -0
  347. package/lib/util/rotate.cjs.map +7 -0
  348. package/lib/util/rotate.js +10 -0
  349. package/lib/util/rotate.js.map +7 -0
  350. package/lib/util/round10.cjs +38 -0
  351. package/lib/util/round10.cjs.map +7 -0
  352. package/lib/util/round10.js +18 -0
  353. package/lib/util/round10.js.map +7 -0
  354. package/lib/util/toPiecewiseBezier.cjs +90 -0
  355. package/lib/util/toPiecewiseBezier.cjs.map +7 -0
  356. package/lib/util/toPiecewiseBezier.js +54 -0
  357. package/lib/util/toPiecewiseBezier.js.map +7 -0
  358. package/lib/util/transformBoundingBoxAndElement.cjs +80 -0
  359. package/lib/util/transformBoundingBoxAndElement.cjs.map +7 -0
  360. package/lib/util/transformBoundingBoxAndElement.js +60 -0
  361. package/lib/util/transformBoundingBoxAndElement.js.map +7 -0
  362. package/package.json +127 -0
  363. package/src/Helper.ts +71 -0
  364. package/src/applyTransforms.ts +54 -0
  365. package/src/cli.ts +41 -0
  366. package/src/config.ts +10 -0
  367. package/src/constants.ts +14 -0
  368. package/src/denormalise.ts +153 -0
  369. package/src/dimensionToSVG.ts +427 -0
  370. package/src/entityToPolyline.ts +338 -0
  371. package/src/getRGBForEntity.ts +28 -0
  372. package/src/groupEntitiesByLayer.ts +14 -0
  373. package/src/handlers/blocks.ts +65 -0
  374. package/src/handlers/entities.ts +111 -0
  375. package/src/handlers/entity/arc.ts +61 -0
  376. package/src/handlers/entity/attdef.ts +284 -0
  377. package/src/handlers/entity/attrib.ts +29 -0
  378. package/src/handlers/entity/circle.ts +47 -0
  379. package/src/handlers/entity/common.ts +79 -0
  380. package/src/handlers/entity/dimension.ts +217 -0
  381. package/src/handlers/entity/ellipse.ts +55 -0
  382. package/src/handlers/entity/hatch.ts +471 -0
  383. package/src/handlers/entity/insert.ts +73 -0
  384. package/src/handlers/entity/line.ts +56 -0
  385. package/src/handlers/entity/lwpolyline.ts +54 -0
  386. package/src/handlers/entity/mtext.ts +150 -0
  387. package/src/handlers/entity/ole2Frame.ts +64 -0
  388. package/src/handlers/entity/point.ts +47 -0
  389. package/src/handlers/entity/polyline.ts +49 -0
  390. package/src/handlers/entity/solid.ts +73 -0
  391. package/src/handlers/entity/spline.ts +103 -0
  392. package/src/handlers/entity/text.ts +83 -0
  393. package/src/handlers/entity/threeDFace.ts +69 -0
  394. package/src/handlers/entity/vertex.ts +55 -0
  395. package/src/handlers/entity/viewport.ts +119 -0
  396. package/src/handlers/header.ts +73 -0
  397. package/src/handlers/objects.ts +152 -0
  398. package/src/handlers/tables.ts +581 -0
  399. package/src/index.ts +19 -0
  400. package/src/parseString.ts +97 -0
  401. package/src/toPolylines.ts +47 -0
  402. package/src/toSVG.ts +518 -0
  403. package/src/types/README.md +91 -0
  404. package/src/types/arc-entity.ts +10 -0
  405. package/src/types/base-entity.ts +25 -0
  406. package/src/types/circle-entity.ts +8 -0
  407. package/src/types/common.ts +37 -0
  408. package/src/types/dimension-entity.ts +23 -0
  409. package/src/types/dxf.ts +64 -0
  410. package/src/types/ellipse-entity.ts +13 -0
  411. package/src/types/entity.ts +32 -0
  412. package/src/types/handler-internal.ts +51 -0
  413. package/src/types/handler.ts +10 -0
  414. package/src/types/hatch-entity.ts +127 -0
  415. package/src/types/helper.ts +12 -0
  416. package/src/types/index.ts +53 -0
  417. package/src/types/insert-entity.ts +19 -0
  418. package/src/types/layer-groups.ts +8 -0
  419. package/src/types/line-entity.ts +10 -0
  420. package/src/types/mtext-entity.ts +35 -0
  421. package/src/types/ole2frame-entity.ts +35 -0
  422. package/src/types/options.ts +17 -0
  423. package/src/types/point-entity.ts +7 -0
  424. package/src/types/polyline-entity.ts +20 -0
  425. package/src/types/polylines.ts +22 -0
  426. package/src/types/solid-entity.ts +9 -0
  427. package/src/types/spline-entity.ts +12 -0
  428. package/src/types/svg.ts +31 -0
  429. package/src/types/tables.ts +414 -0
  430. package/src/types/text-entity.ts +23 -0
  431. package/src/types/util-types.ts +27 -0
  432. package/src/types/vecks.d.ts +29 -0
  433. package/src/types/viewport-entity.ts +81 -0
  434. package/src/types.ts +5 -0
  435. package/src/util/bSpline.ts +97 -0
  436. package/src/util/colors.ts +266 -0
  437. package/src/util/createArcForLWPolyline.ts +93 -0
  438. package/src/util/diagram.png +0 -0
  439. package/src/util/dxfColorToRGB.ts +106 -0
  440. package/src/util/insertKnot.ts +69 -0
  441. package/src/util/logger.ts +23 -0
  442. package/src/util/rgbToColorAttribute.ts +14 -0
  443. package/src/util/rotate.ts +14 -0
  444. package/src/util/round10.ts +24 -0
  445. package/src/util/toPiecewiseBezier.ts +70 -0
  446. package/src/util/transformBoundingBoxAndElement.ts +74 -0
  447. package/tsconfig.json +34 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/dimensionToSVG.ts"],
4
+ "sourcesContent": ["import { Box2 } from 'vecks'\n\nimport colors from './util/colors'\n\nimport type { DimensionEntity } from './types'\nimport type { DimStyleTable } from './types/dxf'\nimport type { BoundsAndElement } from './types/svg'\n\n/**\n * Convert DXF color number to SVG color string\n */\nfunction colorNumberToSVG(colorNumber?: number): string {\n if (colorNumber === undefined || colorNumber < 0) {\n return 'currentColor'\n }\n\n // DXF color 0 is ByBlock, 256 is ByLayer, 7 is white/black (depends on bg)\n if (colorNumber === 0 || colorNumber === 256) {\n return 'currentColor'\n }\n\n // Get RGB from color table\n const rgb = colors[colorNumber]\n if (!rgb) {\n return 'currentColor'\n }\n\n return `rgb(${rgb[0]},${rgb[1]},${rgb[2]})`\n}\n\n/**\n * Get dimension colors and weights from DIMSTYLE with defaults\n */\nfunction getDimensionColors(dimStyle?: DimStyleTable): {\n dimLineColor: string\n extLineColor: string\n textColor: string\n dimLineWeight: number\n extLineWeight: number\n} {\n return {\n dimLineColor: colorNumberToSVG(dimStyle?.dimClrd),\n extLineColor: colorNumberToSVG(dimStyle?.dimClre),\n textColor: colorNumberToSVG(dimStyle?.dimClrt),\n dimLineWeight: dimStyle?.dimLwd ?? 0.5,\n extLineWeight: dimStyle?.dimLwe ?? 0.5,\n }\n}\n\n/**\n * Render DIMENSION entity to SVG with proper DIMSTYLE support\n */\nexport default function dimensionToSVG(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n // Dispatch to appropriate renderer based on dimension type\n switch (entity.dimensionType) {\n case 0: // Rotated, horizontal, or vertical\n case 1: // Aligned\n return renderLinearDimension(entity, dimStyle)\n case 2: // Angular\n return renderAngularDimension(entity, dimStyle)\n case 3: // Diameter\n return renderDiameterDimension(entity, dimStyle)\n case 4: // Radius\n return renderRadialDimension(entity, dimStyle)\n case 6: // Ordinate\n return renderOrdinateDimension(entity, dimStyle)\n default:\n // Fallback to simple line rendering\n return renderFallbackDimension(entity)\n }\n}\n\n/**\n * Create SVG marker definition for dimension arrows\n */\nexport function createArrowMarker(\n id: string,\n size: number,\n color: string,\n): string {\n const arrowPath = `M 0 0 L ${size} ${size / 2} L 0 ${size} z`\n return `<marker id=\"${id}\" markerWidth=\"${size}\" markerHeight=\"${size}\" refX=\"${size}\" refY=\"${size / 2}\" orient=\"auto\" markerUnits=\"strokeWidth\">\n <path d=\"${arrowPath}\" fill=\"${color}\" />\n </marker>`\n}\n\n/**\n * Render linear dimension (rotated, horizontal, vertical, or aligned)\n */\nfunction renderLinearDimension(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n const markers: string[] = []\n\n // Get dimension style properties with defaults\n const arrowSize = dimStyle?.dimAsz ?? 2.5\n const textHeight = dimStyle?.dimTxt ?? 2.5\n const extLineOffset = dimStyle?.dimExo ?? 0.625\n const extLineExtension = dimStyle?.dimExe ?? 1.25\n const { dimLineColor, extLineColor, textColor, dimLineWeight, extLineWeight } = getDimensionColors(dimStyle)\n\n // Extract dimension geometry\n const defPoint1X = entity.measureStart?.x ?? 0\n const defPoint1Y = entity.measureStart?.y ?? 0\n const defPoint2X = entity.measureEnd?.x ?? 0\n const defPoint2Y = entity.measureEnd?.y ?? 0\n const dimLineY = entity.start?.y ?? 0\n const textX = entity.textMidpoint?.x ?? (defPoint1X + defPoint2X) / 2\n const textY = entity.textMidpoint?.y ?? (defPoint1Y + defPoint2Y) / 2\n\n // Calculate dimension line angle\n const angle = Math.atan2(defPoint2Y - defPoint1Y, defPoint2X - defPoint1X)\n const perpAngle = angle + Math.PI / 2\n\n // Calculate dimension line endpoints\n const dimLine1X = defPoint1X + Math.cos(perpAngle) * (dimLineY - defPoint1Y)\n const dimLine1Y = defPoint1Y + Math.sin(perpAngle) * (dimLineY - defPoint1Y)\n const dimLine2X = defPoint2X + Math.cos(perpAngle) * (dimLineY - defPoint2Y)\n const dimLine2Y = defPoint2Y + Math.sin(perpAngle) * (dimLineY - defPoint2Y)\n\n // Expand bounding box\n bbox.expandByPoint({ x: defPoint1X, y: defPoint1Y })\n bbox.expandByPoint({ x: defPoint2X, y: defPoint2Y })\n bbox.expandByPoint({ x: dimLine1X, y: dimLine1Y })\n bbox.expandByPoint({ x: dimLine2X, y: dimLine2Y })\n bbox.expandByPoint({ x: textX, y: textY })\n\n // Create unique marker IDs for arrows\n const markerId1 = `dim-arrow-start-${Date.now()}`\n const markerId2 = `dim-arrow-end-${Date.now()}`\n\n // Create arrow markers with dimension line color\n markers.push(\n createArrowMarker(markerId1, arrowSize, dimLineColor),\n createArrowMarker(markerId2, arrowSize, dimLineColor),\n )\n\n // Draw extension lines\n const extLine1StartX = defPoint1X + Math.cos(perpAngle) * extLineOffset\n const extLine1StartY = defPoint1Y + Math.sin(perpAngle) * extLineOffset\n const extLine1EndX = dimLine1X + Math.cos(perpAngle) * extLineExtension\n const extLine1EndY = dimLine1Y + Math.sin(perpAngle) * extLineExtension\n\n const extLine2StartX = defPoint2X + Math.cos(perpAngle) * extLineOffset\n const extLine2StartY = defPoint2Y + Math.sin(perpAngle) * extLineOffset\n const extLine2EndX = dimLine2X + Math.cos(perpAngle) * extLineExtension\n const extLine2EndY = dimLine2Y + Math.sin(perpAngle) * extLineExtension\n\n elements.push(\n `<line x1=\"${extLine1StartX}\" y1=\"${extLine1StartY}\" x2=\"${extLine1EndX}\" y2=\"${extLine1EndY}\" stroke=\"${extLineColor}\" stroke-width=\"${extLineWeight}\" />`,\n `<line x1=\"${extLine2StartX}\" y1=\"${extLine2StartY}\" x2=\"${extLine2EndX}\" y2=\"${extLine2EndY}\" stroke=\"${extLineColor}\" stroke-width=\"${extLineWeight}\" />`,\n `<line x1=\"${dimLine1X}\" y1=\"${dimLine1Y}\" x2=\"${dimLine2X}\" y2=\"${dimLine2Y}\" stroke=\"${dimLineColor}\" stroke-width=\"${dimLineWeight}\" marker-start=\"url(#${markerId1})\" marker-end=\"url(#${markerId2})\" />`,\n )\n\n // Add dimension text\n if (entity.text) {\n const textRotation = (angle * 180) / Math.PI\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"${textHeight}\" fill=\"${textColor}\" text-anchor=\"middle\" transform=\"rotate(${-textRotation} ${textX} ${textY}) scale(1,-1) translate(0 ${-2 * textY})\">${entity.text}</text>`,\n )\n }\n\n return {\n bbox,\n element: `<defs>${markers.join('')}</defs><g>${elements.join('')}</g>`,\n }\n}\n\n/**\n * Render angular dimension\n */\nfunction renderAngularDimension(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n const markers: string[] = []\n\n // Get dimension style properties\n const arrowSize = dimStyle?.dimAsz ?? 2.5\n const textHeight = dimStyle?.dimTxt ?? 2.5\n const { dimLineColor, extLineColor, textColor, dimLineWeight, extLineWeight } = getDimensionColors(dimStyle)\n\n // Extract points\n const centerX = entity.start?.x ?? 0\n const centerY = entity.start?.y ?? 0\n const x1 = entity.measureStart?.x ?? 0\n const y1 = entity.measureStart?.y ?? 0\n const x2 = entity.measureEnd?.x ?? 0\n const y2 = entity.measureEnd?.y ?? 0\n const textX = entity.textMidpoint?.x ?? centerX\n const textY = entity.textMidpoint?.y ?? centerY\n\n bbox.expandByPoint({ x: centerX, y: centerY })\n bbox.expandByPoint({ x: x1, y: y1 })\n bbox.expandByPoint({ x: x2, y: y2 })\n bbox.expandByPoint({ x: textX, y: textY })\n\n // Create arrow markers\n const markerId1 = `dim-angular-arrow-start-${Date.now()}`\n const markerId2 = `dim-angular-arrow-end-${Date.now()}`\n markers.push(\n createArrowMarker(markerId1, arrowSize, dimLineColor),\n createArrowMarker(markerId2, arrowSize, dimLineColor),\n )\n\n // Draw extension lines from center to definition points\n elements.push(\n `<line x1=\"${centerX}\" y1=\"${centerY}\" x2=\"${x1}\" y2=\"${y1}\" stroke=\"${extLineColor}\" stroke-width=\"${extLineWeight}\" />`,\n `<line x1=\"${centerX}\" y1=\"${centerY}\" x2=\"${x2}\" y2=\"${y2}\" stroke=\"${extLineColor}\" stroke-width=\"${extLineWeight}\" />`,\n )\n\n // Calculate arc radius (distance from center to text midpoint)\n const radius = Math.hypot(textX - centerX, textY - centerY)\n const startAngle = Math.atan2(y1 - centerY, x1 - centerX)\n const endAngle = Math.atan2(y2 - centerY, x2 - centerX)\n\n // Draw arc for angular dimension\n const largeArcFlag = Math.abs(endAngle - startAngle) > Math.PI ? 1 : 0\n const arcStartX = centerX + radius * Math.cos(startAngle)\n const arcStartY = centerY + radius * Math.sin(startAngle)\n const arcEndX = centerX + radius * Math.cos(endAngle)\n const arcEndY = centerY + radius * Math.sin(endAngle)\n\n elements.push(\n `<path d=\"M ${arcStartX} ${arcStartY} A ${radius} ${radius} 0 ${largeArcFlag} 1 ${arcEndX} ${arcEndY}\" fill=\"none\" stroke=\"${dimLineColor}\" stroke-width=\"${dimLineWeight}\" marker-start=\"url(#${markerId1})\" marker-end=\"url(#${markerId2})\" />`,\n )\n\n // Add dimension text\n if (entity.text) {\n const midAngle = (startAngle + endAngle) / 2\n const textRotation = (midAngle * 180) / Math.PI\n\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"${textHeight}\" fill=\"${textColor}\" text-anchor=\"middle\" transform=\"rotate(${-textRotation} ${textX} ${textY}) scale(1,-1) translate(0 ${-2 * textY})\">${entity.text}</text>`,\n )\n }\n\n return {\n bbox,\n element: `<defs>${markers.join('')}</defs><g>${elements.join('')}</g>`,\n }\n}\n\n/**\n * Render diameter dimension\n */\nfunction renderDiameterDimension(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n const markers: string[] = []\n\n // Get dimension style properties\n const arrowSize = dimStyle?.dimAsz ?? 2.5\n const textHeight = dimStyle?.dimTxt ?? 2.5\n const { dimLineColor, textColor, dimLineWeight } = getDimensionColors(dimStyle)\n\n // Extract geometry\n const x1 = entity.measureStart?.x ?? 0\n const y1 = entity.measureStart?.y ?? 0\n const x2 = entity.measureEnd?.x ?? 0\n const y2 = entity.measureEnd?.y ?? 0\n const textX = entity.textMidpoint?.x ?? (x1 + x2) / 2\n const textY = entity.textMidpoint?.y ?? (y1 + y2) / 2\n\n bbox.expandByPoint({ x: x1, y: y1 })\n bbox.expandByPoint({ x: x2, y: y2 })\n bbox.expandByPoint({ x: textX, y: textY })\n\n // Create arrow markers\n const markerId = `dim-diameter-arrow-${Date.now()}`\n markers.push(createArrowMarker(markerId, arrowSize, dimLineColor))\n\n // Create diameter line with arrow at the end\n elements.push(\n `<line x1=\"${x1}\" y1=\"${y1}\" x2=\"${x2}\" y2=\"${y2}\" stroke=\"${dimLineColor}\" stroke-width=\"${dimLineWeight}\" marker-end=\"url(#${markerId})\" />`,\n )\n\n // Add dimension text with diameter symbol\n const diameterText = entity.text ? `\u2300${entity.text}` : '\u2300'\n const angle = Math.atan2(y2 - y1, x2 - x1)\n const textRotation = (angle * 180) / Math.PI\n\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"${textHeight}\" fill=\"${textColor}\" text-anchor=\"middle\" transform=\"rotate(${-textRotation} ${textX} ${textY}) scale(1,-1) translate(0 ${-2 * textY})\">${diameterText}</text>`,\n )\n\n return {\n bbox,\n element: `<defs>${markers.join('')}</defs><g>${elements.join('')}</g>`,\n }\n}\n\n/**\n * Render radial dimension\n */\nfunction renderRadialDimension(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n const markers: string[] = []\n\n // Get dimension style properties\n const arrowSize = dimStyle?.dimAsz ?? 2.5\n const textHeight = dimStyle?.dimTxt ?? 2.5\n const { dimLineColor, textColor, dimLineWeight } = getDimensionColors(dimStyle)\n\n // Extract geometry\n const x1 = entity.measureStart?.x ?? 0\n const y1 = entity.measureStart?.y ?? 0\n const x2 = entity.measureEnd?.x ?? 0\n const y2 = entity.measureEnd?.y ?? 0\n const textX = entity.textMidpoint?.x ?? (x1 + x2) / 2\n const textY = entity.textMidpoint?.y ?? (y1 + y2) / 2\n\n bbox.expandByPoint({ x: x1, y: y1 })\n bbox.expandByPoint({ x: x2, y: y2 })\n bbox.expandByPoint({ x: textX, y: textY })\n\n // Create arrow markers\n const markerId = `dim-radius-arrow-${Date.now()}`\n markers.push(createArrowMarker(markerId, arrowSize, dimLineColor))\n\n // Create radius line with arrow at the end\n elements.push(\n `<line x1=\"${x1}\" y1=\"${y1}\" x2=\"${x2}\" y2=\"${y2}\" stroke=\"${dimLineColor}\" stroke-width=\"${dimLineWeight}\" marker-end=\"url(#${markerId})\" />`,\n )\n\n // Add dimension text with radius symbol\n const radiusText = entity.text ? `R${entity.text}` : 'R'\n const angle = Math.atan2(y2 - y1, x2 - x1)\n const textRotation = (angle * 180) / Math.PI\n\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"${textHeight}\" fill=\"${textColor}\" text-anchor=\"middle\" transform=\"rotate(${-textRotation} ${textX} ${textY}) scale(1,-1) translate(0 ${-2 * textY})\">${radiusText}</text>`,\n )\n\n return {\n bbox,\n element: `<defs>${markers.join('')}</defs><g>${elements.join('')}</g>`,\n }\n}\n\n/**\n * Render ordinate dimension\n */\nfunction renderOrdinateDimension(\n entity: DimensionEntity,\n dimStyle?: DimStyleTable,\n): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n\n // Get dimension style properties\n const textHeight = dimStyle?.dimTxt ?? 2.5\n const { dimLineColor, textColor, dimLineWeight } = getDimensionColors(dimStyle)\n\n // Extract geometry\n const x1 = entity.measureStart?.x ?? 0\n const y1 = entity.measureStart?.y ?? 0\n const x2 = entity.start?.x ?? 0\n const y2 = entity.start?.y ?? 0\n const textX = entity.textMidpoint?.x ?? x2\n const textY = entity.textMidpoint?.y ?? y2\n\n bbox.expandByPoint({ x: x1, y: y1 })\n bbox.expandByPoint({ x: x2, y: y2 })\n bbox.expandByPoint({ x: textX, y: textY })\n\n // Create leader line (no arrow for ordinate dimensions)\n elements.push(\n `<line x1=\"${x1}\" y1=\"${y1}\" x2=\"${x2}\" y2=\"${y2}\" stroke=\"${dimLineColor}\" stroke-width=\"${dimLineWeight}\" />`,\n )\n\n // Add dimension text\n if (entity.text) {\n const angle = Math.atan2(y2 - y1, x2 - x1)\n const textRotation = (angle * 180) / Math.PI\n\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"${textHeight}\" fill=\"${textColor}\" text-anchor=\"middle\" transform=\"rotate(${-textRotation} ${textX} ${textY}) scale(1,-1) translate(0 ${-2 * textY})\">${entity.text}</text>`,\n )\n }\n\n return {\n bbox,\n element: `<g>${elements.join('')}</g>`,\n }\n}\n\n/**\n * Fallback renderer for unsupported dimension types\n */\nfunction renderFallbackDimension(entity: DimensionEntity): BoundsAndElement {\n const bbox = new Box2()\n const elements: string[] = []\n\n // Just render text at midpoint\n if (entity.textMidpoint) {\n const textX = entity.textMidpoint.x ?? 0\n const textY = entity.textMidpoint.y ?? 0\n bbox.expandByPoint({ x: textX, y: textY })\n\n if (entity.text) {\n elements.push(\n `<text x=\"${textX}\" y=\"${textY}\" font-size=\"2.5\" text-anchor=\"middle\" transform=\"scale(1,-1) translate(0 ${-2 * textY})\">${entity.text}</text>`,\n )\n }\n }\n\n return {\n bbox,\n element: `<g>${elements.join('')}</g>`,\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,248 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var entityToPolyline_exports = {};
30
+ __export(entityToPolyline_exports, {
31
+ default: () => entityToPolyline,
32
+ interpolateBSpline: () => interpolateBSpline,
33
+ polyfaceOutline: () => polyfaceOutline
34
+ });
35
+ module.exports = __toCommonJS(entityToPolyline_exports);
36
+ var import_bSpline = __toESM(require("./util/bSpline"), 1);
37
+ var import_createArcForLWPolyline = __toESM(require("./util/createArcForLWPolyline"), 1);
38
+ var import_logger = __toESM(require("./util/logger"), 1);
39
+ const rotate = (points, angle) => {
40
+ return points.map(function(p) {
41
+ return [
42
+ p[0] * Math.cos(angle) - p[1] * Math.sin(angle),
43
+ p[1] * Math.cos(angle) + p[0] * Math.sin(angle)
44
+ ];
45
+ });
46
+ };
47
+ const interpolateEllipse = (cx, cy, rx, ry, start, end, rotationAngle) => {
48
+ if (end < start) {
49
+ end += Math.PI * 2;
50
+ }
51
+ let points = [];
52
+ const dTheta = Math.PI * 2 / 72;
53
+ const EPS = 1e-6;
54
+ for (let theta = start; theta < end - EPS; theta += dTheta) {
55
+ points.push([Math.cos(theta) * rx, Math.sin(theta) * ry]);
56
+ }
57
+ points.push([Math.cos(end) * rx, Math.sin(end) * ry]);
58
+ if (rotationAngle) {
59
+ points = rotate(points, rotationAngle);
60
+ }
61
+ points = points.map(function(p) {
62
+ return [cx + p[0], cy + p[1]];
63
+ });
64
+ return points;
65
+ };
66
+ const interpolateBSpline = (controlPoints, degree, knots, interpolationsPerSplineSegment, weights) => {
67
+ const polyline = [];
68
+ const controlPointsForLib = controlPoints.map(function(p) {
69
+ return [p.x, p.y];
70
+ });
71
+ const segmentTs = [knots[degree]];
72
+ const domain = [knots[degree], knots[knots.length - 1 - degree]];
73
+ for (let k = degree + 1; k < knots.length - degree; ++k) {
74
+ if (segmentTs[segmentTs.length - 1] !== knots[k]) {
75
+ segmentTs.push(knots[k]);
76
+ }
77
+ }
78
+ interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25;
79
+ for (let i = 1; i < segmentTs.length; ++i) {
80
+ const uMin = segmentTs[i - 1];
81
+ const uMax = segmentTs[i];
82
+ for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {
83
+ const u = k / interpolationsPerSplineSegment * (uMax - uMin) + uMin;
84
+ let t = (u - domain[0]) / (domain[1] - domain[0]);
85
+ t = Math.max(t, 0);
86
+ t = Math.min(t, 1);
87
+ const p = (0, import_bSpline.default)(t, degree, controlPointsForLib, knots, weights);
88
+ polyline.push([p[0], p[1]]);
89
+ }
90
+ }
91
+ return polyline;
92
+ };
93
+ const polyfaceOutline = (entity) => {
94
+ const vertices = [];
95
+ const faces = [];
96
+ for (const v of entity.vertices) {
97
+ if (v.faces) {
98
+ const face = {
99
+ indices: [],
100
+ hiddens: []
101
+ };
102
+ for (const i of v.faces) {
103
+ if (i === 0) {
104
+ break;
105
+ }
106
+ face.indices.push(i < 0 ? -i - 1 : i - 1);
107
+ face.hiddens.push(i < 0);
108
+ }
109
+ if ([3, 4].includes(face.indices.length)) faces.push(face);
110
+ } else {
111
+ vertices.push({ x: v.x, y: v.y });
112
+ }
113
+ }
114
+ const polylines = [];
115
+ const segment = (a, b) => {
116
+ for (const prev of polylines) {
117
+ if (prev.slice(-1)[0] === a) {
118
+ prev.push(b);
119
+ return;
120
+ }
121
+ }
122
+ polylines.push([a, b]);
123
+ };
124
+ for (const face of faces) {
125
+ for (let beg = 0; beg < face.indices.length; beg++) {
126
+ if (face.hiddens[beg]) {
127
+ continue;
128
+ }
129
+ const end = (beg + 1) % face.indices.length;
130
+ segment(face.indices[beg], face.indices[end]);
131
+ }
132
+ }
133
+ for (const a of polylines) {
134
+ for (const b of polylines) {
135
+ if (a !== b && a[0] === b.slice(-1)[0]) {
136
+ b.push(...a.slice(1));
137
+ a.splice(0, a.length);
138
+ break;
139
+ }
140
+ }
141
+ }
142
+ return polylines.filter((l) => l.length).map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]));
143
+ };
144
+ function entityToPolyline(entity, options) {
145
+ options = options || {};
146
+ let polyline;
147
+ if (entity.type === "LINE") {
148
+ polyline = [
149
+ [entity.start.x, entity.start.y],
150
+ [entity.end.x, entity.end.y]
151
+ ];
152
+ }
153
+ if (entity.type === "LWPOLYLINE" || entity.type === "POLYLINE") {
154
+ polyline = [];
155
+ if (entity.polyfaceMesh) {
156
+ polyline.push(...polyfaceOutline(entity)[0]);
157
+ } else if (entity.polygonMesh) {
158
+ } else if (entity.vertices.length) {
159
+ if (entity.closed) {
160
+ entity.vertices = entity.vertices.concat(entity.vertices[0]);
161
+ }
162
+ for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {
163
+ const from = [entity.vertices[i].x, entity.vertices[i].y];
164
+ const to = [entity.vertices[i + 1].x, entity.vertices[i + 1].y];
165
+ polyline.push(from);
166
+ if (entity.vertices[i].bulge) {
167
+ polyline = polyline.concat(
168
+ (0, import_createArcForLWPolyline.default)(from, to, entity.vertices[i].bulge)
169
+ );
170
+ }
171
+ if (i === il - 2) {
172
+ polyline.push(to);
173
+ }
174
+ }
175
+ } else {
176
+ import_logger.default.warn("Polyline entity with no vertices");
177
+ }
178
+ }
179
+ if (entity.type === "CIRCLE") {
180
+ polyline = interpolateEllipse(
181
+ entity.x,
182
+ entity.y,
183
+ entity.r,
184
+ entity.r,
185
+ 0,
186
+ Math.PI * 2
187
+ );
188
+ if (entity.extrusionZ === -1) {
189
+ polyline = polyline.map(function(p) {
190
+ return [-p[0], p[1]];
191
+ });
192
+ }
193
+ }
194
+ if (entity.type === "ELLIPSE") {
195
+ const rx = Math.hypot(entity.majorX, entity.majorY);
196
+ const ry = entity.axisRatio * rx;
197
+ const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX);
198
+ polyline = interpolateEllipse(
199
+ entity.x,
200
+ entity.y,
201
+ rx,
202
+ ry,
203
+ entity.startAngle,
204
+ entity.endAngle,
205
+ majorAxisRotation
206
+ );
207
+ if (entity.extrusionZ === -1) {
208
+ polyline = polyline.map(function(p) {
209
+ return [-p[0], p[1]];
210
+ });
211
+ }
212
+ }
213
+ if (entity.type === "ARC") {
214
+ polyline = interpolateEllipse(
215
+ entity.x,
216
+ entity.y,
217
+ entity.r,
218
+ entity.r,
219
+ entity.startAngle,
220
+ entity.endAngle
221
+ );
222
+ if (entity.extrusionZ === -1) {
223
+ polyline = polyline.map(function(p) {
224
+ return [-p[0], p[1]];
225
+ });
226
+ }
227
+ }
228
+ if (entity.type === "SPLINE") {
229
+ polyline = interpolateBSpline(
230
+ entity.controlPoints,
231
+ entity.degree,
232
+ entity.knots,
233
+ options.interpolationsPerSplineSegment,
234
+ entity.weights
235
+ );
236
+ }
237
+ if (!polyline) {
238
+ import_logger.default.warn("unsupported entity for converting to polyline:", entity.type);
239
+ return [];
240
+ }
241
+ return polyline;
242
+ }
243
+ // Annotate the CommonJS export names for ESM import in node:
244
+ 0 && (module.exports = {
245
+ interpolateBSpline,
246
+ polyfaceOutline
247
+ });
248
+ //# sourceMappingURL=entityToPolyline.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/entityToPolyline.ts"],
4
+ "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LineEntity,\n SplineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => {\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline(\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["bSpline", "createArcForLWPolyine", "logger"]
7
+ }
@@ -0,0 +1,213 @@
1
+ import bSpline from "./util/bSpline";
2
+ import createArcForLWPolyine from "./util/createArcForLWPolyline";
3
+ import logger from "./util/logger";
4
+ const rotate = (points, angle) => {
5
+ return points.map(function(p) {
6
+ return [
7
+ p[0] * Math.cos(angle) - p[1] * Math.sin(angle),
8
+ p[1] * Math.cos(angle) + p[0] * Math.sin(angle)
9
+ ];
10
+ });
11
+ };
12
+ const interpolateEllipse = (cx, cy, rx, ry, start, end, rotationAngle) => {
13
+ if (end < start) {
14
+ end += Math.PI * 2;
15
+ }
16
+ let points = [];
17
+ const dTheta = Math.PI * 2 / 72;
18
+ const EPS = 1e-6;
19
+ for (let theta = start; theta < end - EPS; theta += dTheta) {
20
+ points.push([Math.cos(theta) * rx, Math.sin(theta) * ry]);
21
+ }
22
+ points.push([Math.cos(end) * rx, Math.sin(end) * ry]);
23
+ if (rotationAngle) {
24
+ points = rotate(points, rotationAngle);
25
+ }
26
+ points = points.map(function(p) {
27
+ return [cx + p[0], cy + p[1]];
28
+ });
29
+ return points;
30
+ };
31
+ const interpolateBSpline = (controlPoints, degree, knots, interpolationsPerSplineSegment, weights) => {
32
+ const polyline = [];
33
+ const controlPointsForLib = controlPoints.map(function(p) {
34
+ return [p.x, p.y];
35
+ });
36
+ const segmentTs = [knots[degree]];
37
+ const domain = [knots[degree], knots[knots.length - 1 - degree]];
38
+ for (let k = degree + 1; k < knots.length - degree; ++k) {
39
+ if (segmentTs[segmentTs.length - 1] !== knots[k]) {
40
+ segmentTs.push(knots[k]);
41
+ }
42
+ }
43
+ interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25;
44
+ for (let i = 1; i < segmentTs.length; ++i) {
45
+ const uMin = segmentTs[i - 1];
46
+ const uMax = segmentTs[i];
47
+ for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {
48
+ const u = k / interpolationsPerSplineSegment * (uMax - uMin) + uMin;
49
+ let t = (u - domain[0]) / (domain[1] - domain[0]);
50
+ t = Math.max(t, 0);
51
+ t = Math.min(t, 1);
52
+ const p = bSpline(t, degree, controlPointsForLib, knots, weights);
53
+ polyline.push([p[0], p[1]]);
54
+ }
55
+ }
56
+ return polyline;
57
+ };
58
+ const polyfaceOutline = (entity) => {
59
+ const vertices = [];
60
+ const faces = [];
61
+ for (const v of entity.vertices) {
62
+ if (v.faces) {
63
+ const face = {
64
+ indices: [],
65
+ hiddens: []
66
+ };
67
+ for (const i of v.faces) {
68
+ if (i === 0) {
69
+ break;
70
+ }
71
+ face.indices.push(i < 0 ? -i - 1 : i - 1);
72
+ face.hiddens.push(i < 0);
73
+ }
74
+ if ([3, 4].includes(face.indices.length)) faces.push(face);
75
+ } else {
76
+ vertices.push({ x: v.x, y: v.y });
77
+ }
78
+ }
79
+ const polylines = [];
80
+ const segment = (a, b) => {
81
+ for (const prev of polylines) {
82
+ if (prev.slice(-1)[0] === a) {
83
+ prev.push(b);
84
+ return;
85
+ }
86
+ }
87
+ polylines.push([a, b]);
88
+ };
89
+ for (const face of faces) {
90
+ for (let beg = 0; beg < face.indices.length; beg++) {
91
+ if (face.hiddens[beg]) {
92
+ continue;
93
+ }
94
+ const end = (beg + 1) % face.indices.length;
95
+ segment(face.indices[beg], face.indices[end]);
96
+ }
97
+ }
98
+ for (const a of polylines) {
99
+ for (const b of polylines) {
100
+ if (a !== b && a[0] === b.slice(-1)[0]) {
101
+ b.push(...a.slice(1));
102
+ a.splice(0, a.length);
103
+ break;
104
+ }
105
+ }
106
+ }
107
+ return polylines.filter((l) => l.length).map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]));
108
+ };
109
+ function entityToPolyline(entity, options) {
110
+ options = options || {};
111
+ let polyline;
112
+ if (entity.type === "LINE") {
113
+ polyline = [
114
+ [entity.start.x, entity.start.y],
115
+ [entity.end.x, entity.end.y]
116
+ ];
117
+ }
118
+ if (entity.type === "LWPOLYLINE" || entity.type === "POLYLINE") {
119
+ polyline = [];
120
+ if (entity.polyfaceMesh) {
121
+ polyline.push(...polyfaceOutline(entity)[0]);
122
+ } else if (entity.polygonMesh) {
123
+ } else if (entity.vertices.length) {
124
+ if (entity.closed) {
125
+ entity.vertices = entity.vertices.concat(entity.vertices[0]);
126
+ }
127
+ for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {
128
+ const from = [entity.vertices[i].x, entity.vertices[i].y];
129
+ const to = [entity.vertices[i + 1].x, entity.vertices[i + 1].y];
130
+ polyline.push(from);
131
+ if (entity.vertices[i].bulge) {
132
+ polyline = polyline.concat(
133
+ createArcForLWPolyine(from, to, entity.vertices[i].bulge)
134
+ );
135
+ }
136
+ if (i === il - 2) {
137
+ polyline.push(to);
138
+ }
139
+ }
140
+ } else {
141
+ logger.warn("Polyline entity with no vertices");
142
+ }
143
+ }
144
+ if (entity.type === "CIRCLE") {
145
+ polyline = interpolateEllipse(
146
+ entity.x,
147
+ entity.y,
148
+ entity.r,
149
+ entity.r,
150
+ 0,
151
+ Math.PI * 2
152
+ );
153
+ if (entity.extrusionZ === -1) {
154
+ polyline = polyline.map(function(p) {
155
+ return [-p[0], p[1]];
156
+ });
157
+ }
158
+ }
159
+ if (entity.type === "ELLIPSE") {
160
+ const rx = Math.hypot(entity.majorX, entity.majorY);
161
+ const ry = entity.axisRatio * rx;
162
+ const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX);
163
+ polyline = interpolateEllipse(
164
+ entity.x,
165
+ entity.y,
166
+ rx,
167
+ ry,
168
+ entity.startAngle,
169
+ entity.endAngle,
170
+ majorAxisRotation
171
+ );
172
+ if (entity.extrusionZ === -1) {
173
+ polyline = polyline.map(function(p) {
174
+ return [-p[0], p[1]];
175
+ });
176
+ }
177
+ }
178
+ if (entity.type === "ARC") {
179
+ polyline = interpolateEllipse(
180
+ entity.x,
181
+ entity.y,
182
+ entity.r,
183
+ entity.r,
184
+ entity.startAngle,
185
+ entity.endAngle
186
+ );
187
+ if (entity.extrusionZ === -1) {
188
+ polyline = polyline.map(function(p) {
189
+ return [-p[0], p[1]];
190
+ });
191
+ }
192
+ }
193
+ if (entity.type === "SPLINE") {
194
+ polyline = interpolateBSpline(
195
+ entity.controlPoints,
196
+ entity.degree,
197
+ entity.knots,
198
+ options.interpolationsPerSplineSegment,
199
+ entity.weights
200
+ );
201
+ }
202
+ if (!polyline) {
203
+ logger.warn("unsupported entity for converting to polyline:", entity.type);
204
+ return [];
205
+ }
206
+ return polyline;
207
+ }
208
+ export {
209
+ entityToPolyline as default,
210
+ interpolateBSpline,
211
+ polyfaceOutline
212
+ };
213
+ //# sourceMappingURL=entityToPolyline.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/entityToPolyline.ts"],
4
+ "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LineEntity,\n SplineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => {\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline(\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var getRGBForEntity_exports = {};
30
+ __export(getRGBForEntity_exports, {
31
+ default: () => getRGBForEntity
32
+ });
33
+ module.exports = __toCommonJS(getRGBForEntity_exports);
34
+ var import_colors = __toESM(require("./util/colors"), 1);
35
+ var import_logger = __toESM(require("./util/logger"), 1);
36
+ function getRGBForEntity(layers, entity) {
37
+ const layerTable = layers[entity.layer ?? "0"];
38
+ if (layerTable) {
39
+ const colorDefinedInEntity = "colorNumber" in entity && entity.colorNumber !== 256;
40
+ const colorNumber = colorDefinedInEntity ? entity.colorNumber : layerTable.colorNumber;
41
+ const rgb = import_colors.default[colorNumber ?? 0];
42
+ if (rgb) {
43
+ return rgb;
44
+ } else {
45
+ import_logger.default.warn("Color index", colorNumber, "invalid, defaulting to black");
46
+ return [0, 0, 0];
47
+ }
48
+ } else {
49
+ import_logger.default.warn("no layer table for layer:" + entity.layer);
50
+ return [0, 0, 0];
51
+ }
52
+ }
53
+ //# sourceMappingURL=getRGBForEntity.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/getRGBForEntity.ts"],
4
+ "sourcesContent": ["import colors from './util/colors'\nimport logger from './util/logger'\n\nimport type { ColorRGB, Entity, LayerTable } from './types'\n\nexport default function getRGBForEntity(\n layers: { [layerName: string]: LayerTable },\n entity: Entity,\n): ColorRGB {\n const layerTable = layers[entity.layer ?? '0']\n if (layerTable) {\n const colorDefinedInEntity =\n 'colorNumber' in entity && entity.colorNumber !== 256\n const colorNumber = colorDefinedInEntity\n ? entity.colorNumber\n : layerTable.colorNumber\n const rgb = colors[colorNumber ?? 0]\n if (rgb) {\n return rgb\n } else {\n logger.warn('Color index', colorNumber, 'invalid, defaulting to black')\n return [0, 0, 0]\n }\n } else {\n logger.warn('no layer table for layer:' + entity.layer)\n return [0, 0, 0]\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAmB;AACnB,oBAAmB;AAIJ,SAAR,gBACL,QACA,QACU;AACV,QAAM,aAAa,OAAO,OAAO,SAAS,GAAG;AAC7C,MAAI,YAAY;AACd,UAAM,uBACJ,iBAAiB,UAAU,OAAO,gBAAgB;AACpD,UAAM,cAAc,uBAChB,OAAO,cACP,WAAW;AACf,UAAM,MAAM,cAAAA,QAAO,eAAe,CAAC;AACnC,QAAI,KAAK;AACP,aAAO;AAAA,IACT,OAAO;AACL,oBAAAC,QAAO,KAAK,eAAe,aAAa,8BAA8B;AACtE,aAAO,CAAC,GAAG,GAAG,CAAC;AAAA,IACjB;AAAA,EACF,OAAO;AACL,kBAAAA,QAAO,KAAK,8BAA8B,OAAO,KAAK;AACtD,WAAO,CAAC,GAAG,GAAG,CAAC;AAAA,EACjB;AACF;",
6
+ "names": ["colors", "logger"]
7
+ }