@aibee/owlly 1.0.25

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 (500) hide show
  1. package/README.external.md +75 -0
  2. package/README.md +28 -0
  3. package/lib/src/external/lines/line-geometry.d.ts +9 -0
  4. package/lib/src/external/lines/line-geometry.js +52 -0
  5. package/lib/src/external/lines/line-geometry.js.map +1 -0
  6. package/lib/src/external/lines/line-material.d.ts +10 -0
  7. package/lib/src/external/lines/line-material.js +377 -0
  8. package/lib/src/external/lines/line-material.js.map +1 -0
  9. package/lib/src/external/lines/line-segments-2.d.ts +7 -0
  10. package/lib/src/external/lines/line-segments-2.js +144 -0
  11. package/lib/src/external/lines/line-segments-2.js.map +1 -0
  12. package/lib/src/external/lines/line-segments-geometry.d.ts +15 -0
  13. package/lib/src/external/lines/line-segments-geometry.js +141 -0
  14. package/lib/src/external/lines/line-segments-geometry.js.map +1 -0
  15. package/lib/src/external/loaders/gltf-loader.d.ts +77 -0
  16. package/lib/src/external/loaders/gltf-loader.js +2319 -0
  17. package/lib/src/external/loaders/gltf-loader.js.map +1 -0
  18. package/lib/src/external/orbit-controls.d.ts +44 -0
  19. package/lib/src/external/orbit-controls.js +746 -0
  20. package/lib/src/external/orbit-controls.js.map +1 -0
  21. package/lib/src/external/renderers/css-2d-renderer.d.ts +16 -0
  22. package/lib/src/external/renderers/css-2d-renderer.js +122 -0
  23. package/lib/src/external/renderers/css-2d-renderer.js.map +1 -0
  24. package/lib/src/external/renderers/css-3d-renderer.d.ts +18 -0
  25. package/lib/src/external/renderers/css-3d-renderer.js +139 -0
  26. package/lib/src/external/renderers/css-3d-renderer.js.map +1 -0
  27. package/lib/src/external/transform-controls.d.ts +106 -0
  28. package/lib/src/external/transform-controls.js +1113 -0
  29. package/lib/src/external/transform-controls.js.map +1 -0
  30. package/lib/src/external/util/buffer-geometry-utils.d.ts +45 -0
  31. package/lib/src/external/util/buffer-geometry-utils.js +569 -0
  32. package/lib/src/external/util/buffer-geometry-utils.js.map +1 -0
  33. package/lib/src/owlly/controller/aerial-element-controller.d.ts +65 -0
  34. package/lib/src/owlly/controller/aerial-element-controller.js +236 -0
  35. package/lib/src/owlly/controller/aerial-element-controller.js.map +1 -0
  36. package/lib/src/owlly/controller/basic-controller.d.ts +324 -0
  37. package/lib/src/owlly/controller/basic-controller.js +1239 -0
  38. package/lib/src/owlly/controller/basic-controller.js.map +1 -0
  39. package/lib/src/owlly/controller/camera-controller.d.ts +37 -0
  40. package/lib/src/owlly/controller/camera-controller.js +138 -0
  41. package/lib/src/owlly/controller/camera-controller.js.map +1 -0
  42. package/lib/src/owlly/controller/controller.d.ts +61 -0
  43. package/lib/src/owlly/controller/controller.js +24 -0
  44. package/lib/src/owlly/controller/controller.js.map +1 -0
  45. package/lib/src/owlly/controller/index.d.ts +2 -0
  46. package/lib/src/owlly/controller/index.js +14 -0
  47. package/lib/src/owlly/controller/index.js.map +1 -0
  48. package/lib/src/owlly/controller/mouse-indicator-controller.d.ts +34 -0
  49. package/lib/src/owlly/controller/mouse-indicator-controller.js +119 -0
  50. package/lib/src/owlly/controller/mouse-indicator-controller.js.map +1 -0
  51. package/lib/src/owlly/controller/orbit-control.d.ts +147 -0
  52. package/lib/src/owlly/controller/orbit-control.js +265 -0
  53. package/lib/src/owlly/controller/orbit-control.js.map +1 -0
  54. package/lib/src/owlly/controller/panorama-adjust-controller.d.ts +45 -0
  55. package/lib/src/owlly/controller/panorama-adjust-controller.js +158 -0
  56. package/lib/src/owlly/controller/panorama-adjust-controller.js.map +1 -0
  57. package/lib/src/owlly/controller/panorama-controller.d.ts +441 -0
  58. package/lib/src/owlly/controller/panorama-controller.js +1944 -0
  59. package/lib/src/owlly/controller/panorama-controller.js.map +1 -0
  60. package/lib/src/owlly/controller/panorama-transform-controller.d.ts +66 -0
  61. package/lib/src/owlly/controller/panorama-transform-controller.js +137 -0
  62. package/lib/src/owlly/controller/panorama-transform-controller.js.map +1 -0
  63. package/lib/src/owlly/controller/plane-controller.d.ts +43 -0
  64. package/lib/src/owlly/controller/plane-controller.js +174 -0
  65. package/lib/src/owlly/controller/plane-controller.js.map +1 -0
  66. package/lib/src/owlly/controller/texture-controller.d.ts +181 -0
  67. package/lib/src/owlly/controller/texture-controller.js +876 -0
  68. package/lib/src/owlly/controller/texture-controller.js.map +1 -0
  69. package/lib/src/owlly/controller/tile-panorama-controller.d.ts +308 -0
  70. package/lib/src/owlly/controller/tile-panorama-controller.js +1354 -0
  71. package/lib/src/owlly/controller/tile-panorama-controller.js.map +1 -0
  72. package/lib/src/owlly/controller/transform-controller.d.ts +106 -0
  73. package/lib/src/owlly/controller/transform-controller.js +546 -0
  74. package/lib/src/owlly/controller/transform-controller.js.map +1 -0
  75. package/lib/src/owlly/element/bottom-nav-element.d.ts +65 -0
  76. package/lib/src/owlly/element/bottom-nav-element.js +258 -0
  77. package/lib/src/owlly/element/bottom-nav-element.js.map +1 -0
  78. package/lib/src/owlly/element/camera.d.ts +82 -0
  79. package/lib/src/owlly/element/camera.js +284 -0
  80. package/lib/src/owlly/element/camera.js.map +1 -0
  81. package/lib/src/owlly/element/dom-2d-element.d.ts +35 -0
  82. package/lib/src/owlly/element/dom-2d-element.js +49 -0
  83. package/lib/src/owlly/element/dom-2d-element.js.map +1 -0
  84. package/lib/src/owlly/element/dom-3d-element.d.ts +27 -0
  85. package/lib/src/owlly/element/dom-3d-element.js +34 -0
  86. package/lib/src/owlly/element/dom-3d-element.js.map +1 -0
  87. package/lib/src/owlly/element/dom-label-2d.d.ts +116 -0
  88. package/lib/src/owlly/element/dom-label-2d.js +383 -0
  89. package/lib/src/owlly/element/dom-label-2d.js.map +1 -0
  90. package/lib/src/owlly/element/element.d.ts +53 -0
  91. package/lib/src/owlly/element/element.js +76 -0
  92. package/lib/src/owlly/element/element.js.map +1 -0
  93. package/lib/src/owlly/element/floor-model.d.ts +83 -0
  94. package/lib/src/owlly/element/floor-model.js +228 -0
  95. package/lib/src/owlly/element/floor-model.js.map +1 -0
  96. package/lib/src/owlly/element/gif-kit/Gif.d.ts +96 -0
  97. package/lib/src/owlly/element/gif-kit/Gif.js +433 -0
  98. package/lib/src/owlly/element/gif-kit/Gif.js.map +1 -0
  99. package/lib/src/owlly/element/gif-kit/GifColor.d.ts +21 -0
  100. package/lib/src/owlly/element/gif-kit/GifColor.js +38 -0
  101. package/lib/src/owlly/element/gif-kit/GifColor.js.map +1 -0
  102. package/lib/src/owlly/element/gif-kit/GifCompressedCodesToByteArrayConverter.d.ts +20 -0
  103. package/lib/src/owlly/element/gif-kit/GifCompressedCodesToByteArrayConverter.js +51 -0
  104. package/lib/src/owlly/element/gif-kit/GifCompressedCodesToByteArrayConverter.js.map +1 -0
  105. package/lib/src/owlly/element/gif-kit/GifFrame.d.ts +31 -0
  106. package/lib/src/owlly/element/gif-kit/GifFrame.js +97 -0
  107. package/lib/src/owlly/element/gif-kit/GifFrame.js.map +1 -0
  108. package/lib/src/owlly/element/gif-kit/GifImage.d.ts +23 -0
  109. package/lib/src/owlly/element/gif-kit/GifImage.js +8 -0
  110. package/lib/src/owlly/element/gif-kit/GifImage.js.map +1 -0
  111. package/lib/src/owlly/element/gif-kit/GifParser.d.ts +17 -0
  112. package/lib/src/owlly/element/gif-kit/GifParser.js +197 -0
  113. package/lib/src/owlly/element/gif-kit/GifParser.js.map +1 -0
  114. package/lib/src/owlly/element/gif-kit/GifPresenter.d.ts +20 -0
  115. package/lib/src/owlly/element/gif-kit/GifPresenter.js +44 -0
  116. package/lib/src/owlly/element/gif-kit/GifPresenter.js.map +1 -0
  117. package/lib/src/owlly/element/gif-kit/GifVersion.d.ts +10 -0
  118. package/lib/src/owlly/element/gif-kit/GifVersion.js +13 -0
  119. package/lib/src/owlly/element/gif-kit/GifVersion.js.map +1 -0
  120. package/lib/src/owlly/element/gltf-mesh-element.d.ts +31 -0
  121. package/lib/src/owlly/element/gltf-mesh-element.js +137 -0
  122. package/lib/src/owlly/element/gltf-mesh-element.js.map +1 -0
  123. package/lib/src/owlly/element/index.d.ts +20 -0
  124. package/lib/src/owlly/element/index.js +25 -0
  125. package/lib/src/owlly/element/index.js.map +1 -0
  126. package/lib/src/owlly/element/map-kit/area.d.ts +24 -0
  127. package/lib/src/owlly/element/map-kit/area.js +218 -0
  128. package/lib/src/owlly/element/map-kit/area.js.map +1 -0
  129. package/lib/src/owlly/element/map-kit/block-set.d.ts +39 -0
  130. package/lib/src/owlly/element/map-kit/block-set.js +91 -0
  131. package/lib/src/owlly/element/map-kit/block-set.js.map +1 -0
  132. package/lib/src/owlly/element/map-kit/block.d.ts +77 -0
  133. package/lib/src/owlly/element/map-kit/block.js +339 -0
  134. package/lib/src/owlly/element/map-kit/block.js.map +1 -0
  135. package/lib/src/owlly/element/map-kit/index.d.ts +4 -0
  136. package/lib/src/owlly/element/map-kit/index.js +7 -0
  137. package/lib/src/owlly/element/map-kit/index.js.map +1 -0
  138. package/lib/src/owlly/element/map-kit/shape.d.ts +131 -0
  139. package/lib/src/owlly/element/map-kit/shape.js +190 -0
  140. package/lib/src/owlly/element/map-kit/shape.js.map +1 -0
  141. package/lib/src/owlly/element/mesh-element.d.ts +22 -0
  142. package/lib/src/owlly/element/mesh-element.js +64 -0
  143. package/lib/src/owlly/element/mesh-element.js.map +1 -0
  144. package/lib/src/owlly/element/mesh-line-2d.d.ts +82 -0
  145. package/lib/src/owlly/element/mesh-line-2d.js +888 -0
  146. package/lib/src/owlly/element/mesh-line-2d.js.map +1 -0
  147. package/lib/src/owlly/element/meshline-o.d.ts +64 -0
  148. package/lib/src/owlly/element/meshline-o.js +679 -0
  149. package/lib/src/owlly/element/meshline-o.js.map +1 -0
  150. package/lib/src/owlly/element/panorama-group.d.ts +241 -0
  151. package/lib/src/owlly/element/panorama-group.js +967 -0
  152. package/lib/src/owlly/element/panorama-group.js.map +1 -0
  153. package/lib/src/owlly/element/panorama.d.ts +132 -0
  154. package/lib/src/owlly/element/panorama.js +813 -0
  155. package/lib/src/owlly/element/panorama.js.map +1 -0
  156. package/lib/src/owlly/element/path-group.d.ts +69 -0
  157. package/lib/src/owlly/element/path-group.js +172 -0
  158. package/lib/src/owlly/element/path-group.js.map +1 -0
  159. package/lib/src/owlly/element/path.d.ts +99 -0
  160. package/lib/src/owlly/element/path.js +532 -0
  161. package/lib/src/owlly/element/path.js.map +1 -0
  162. package/lib/src/owlly/element/placeable-2d.d.ts +158 -0
  163. package/lib/src/owlly/element/placeable-2d.js +471 -0
  164. package/lib/src/owlly/element/placeable-2d.js.map +1 -0
  165. package/lib/src/owlly/element/polygon-mesh.d.ts +107 -0
  166. package/lib/src/owlly/element/polygon-mesh.js +308 -0
  167. package/lib/src/owlly/element/polygon-mesh.js.map +1 -0
  168. package/lib/src/owlly/element/ring-element.d.ts +79 -0
  169. package/lib/src/owlly/element/ring-element.js +384 -0
  170. package/lib/src/owlly/element/ring-element.js.map +1 -0
  171. package/lib/src/owlly/element/sphere-mesh.d.ts +28 -0
  172. package/lib/src/owlly/element/sphere-mesh.js +70 -0
  173. package/lib/src/owlly/element/sphere-mesh.js.map +1 -0
  174. package/lib/src/owlly/element/svg-floor-model.d.ts +22 -0
  175. package/lib/src/owlly/element/svg-floor-model.js +185 -0
  176. package/lib/src/owlly/element/svg-floor-model.js.map +1 -0
  177. package/lib/src/owlly/element/svg-floors.d.ts +27 -0
  178. package/lib/src/owlly/element/svg-floors.js +110 -0
  179. package/lib/src/owlly/element/svg-floors.js.map +1 -0
  180. package/lib/src/owlly/element/tile-panorama-group.d.ts +335 -0
  181. package/lib/src/owlly/element/tile-panorama-group.js +1007 -0
  182. package/lib/src/owlly/element/tile-panorama-group.js.map +1 -0
  183. package/lib/src/owlly/element/tile-panorama.d.ts +161 -0
  184. package/lib/src/owlly/element/tile-panorama.js +511 -0
  185. package/lib/src/owlly/element/tile-panorama.js.map +1 -0
  186. package/lib/src/owlly/element/tile-plane.d.ts +105 -0
  187. package/lib/src/owlly/element/tile-plane.js +361 -0
  188. package/lib/src/owlly/element/tile-plane.js.map +1 -0
  189. package/lib/src/owlly/element/video-element.d.ts +33 -0
  190. package/lib/src/owlly/element/video-element.js +160 -0
  191. package/lib/src/owlly/element/video-element.js.map +1 -0
  192. package/lib/src/owlly/geometries/ExtrudeGeometry2.d.ts +15 -0
  193. package/lib/src/owlly/geometries/ExtrudeGeometry2.js +211 -0
  194. package/lib/src/owlly/geometries/ExtrudeGeometry2.js.map +1 -0
  195. package/lib/src/owlly/index.d.ts +13 -0
  196. package/lib/src/owlly/index.js +17 -0
  197. package/lib/src/owlly/index.js.map +1 -0
  198. package/lib/src/owlly/overlay/canvas-overlay.d.ts +96 -0
  199. package/lib/src/owlly/overlay/canvas-overlay.js +511 -0
  200. package/lib/src/owlly/overlay/canvas-overlay.js.map +1 -0
  201. package/lib/src/owlly/overlay/css-2d-overlay.d.ts +14 -0
  202. package/lib/src/owlly/overlay/css-2d-overlay.js +36 -0
  203. package/lib/src/owlly/overlay/css-2d-overlay.js.map +1 -0
  204. package/lib/src/owlly/overlay/css-3d-overlay.d.ts +16 -0
  205. package/lib/src/owlly/overlay/css-3d-overlay.js +37 -0
  206. package/lib/src/owlly/overlay/css-3d-overlay.js.map +1 -0
  207. package/lib/src/owlly/overlay/index.d.ts +6 -0
  208. package/lib/src/owlly/overlay/index.js +12 -0
  209. package/lib/src/owlly/overlay/index.js.map +1 -0
  210. package/lib/src/owlly/overlay/label-overlay.d.ts +62 -0
  211. package/lib/src/owlly/overlay/label-overlay.js +329 -0
  212. package/lib/src/owlly/overlay/label-overlay.js.map +1 -0
  213. package/lib/src/owlly/overlay/overlay.d.ts +14 -0
  214. package/lib/src/owlly/overlay/overlay.js +5 -0
  215. package/lib/src/owlly/overlay/overlay.js.map +1 -0
  216. package/lib/src/owlly/overlay/path-overlay.d.ts +39 -0
  217. package/lib/src/owlly/overlay/path-overlay.js +125 -0
  218. package/lib/src/owlly/overlay/path-overlay.js.map +1 -0
  219. package/lib/src/owlly/overlay/path-overlay2.d.ts +35 -0
  220. package/lib/src/owlly/overlay/path-overlay2.js +119 -0
  221. package/lib/src/owlly/overlay/path-overlay2.js.map +1 -0
  222. package/lib/src/owlly/overlay/poi-overlay-3d.d.ts +278 -0
  223. package/lib/src/owlly/overlay/poi-overlay-3d.js +1433 -0
  224. package/lib/src/owlly/overlay/poi-overlay-3d.js.map +1 -0
  225. package/lib/src/owlly/overlay/poi-overlay.d.ts +277 -0
  226. package/lib/src/owlly/overlay/poi-overlay.js +1412 -0
  227. package/lib/src/owlly/overlay/poi-overlay.js.map +1 -0
  228. package/lib/src/owlly/owlly-2d/index.d.ts +28 -0
  229. package/lib/src/owlly/owlly-2d/index.js +93 -0
  230. package/lib/src/owlly/owlly-2d/index.js.map +1 -0
  231. package/lib/src/owlly/screen/index.d.ts +1 -0
  232. package/lib/src/owlly/screen/index.js +2 -0
  233. package/lib/src/owlly/screen/index.js.map +1 -0
  234. package/lib/src/owlly/screen/screen.d.ts +73 -0
  235. package/lib/src/owlly/screen/screen.js +237 -0
  236. package/lib/src/owlly/screen/screen.js.map +1 -0
  237. package/lib/src/owlly/stage/__test__/stage.spec.d.ts +1 -0
  238. package/lib/src/owlly/stage/__test__/stage.spec.js +15 -0
  239. package/lib/src/owlly/stage/__test__/stage.spec.js.map +1 -0
  240. package/lib/src/owlly/stage/externals.d.ts +19 -0
  241. package/lib/src/owlly/stage/externals.js +25 -0
  242. package/lib/src/owlly/stage/externals.js.map +1 -0
  243. package/lib/src/owlly/stage/index.d.ts +4 -0
  244. package/lib/src/owlly/stage/index.js +7 -0
  245. package/lib/src/owlly/stage/index.js.map +1 -0
  246. package/lib/src/owlly/stage/owlly.d.ts +38 -0
  247. package/lib/src/owlly/stage/owlly.js +168 -0
  248. package/lib/src/owlly/stage/owlly.js.map +1 -0
  249. package/lib/src/owlly/stage/stage.d.ts +108 -0
  250. package/lib/src/owlly/stage/stage.js +235 -0
  251. package/lib/src/owlly/stage/stage.js.map +1 -0
  252. package/lib/src/owlly/utils/alignment-utils.d.ts +20 -0
  253. package/lib/src/owlly/utils/alignment-utils.js +64 -0
  254. package/lib/src/owlly/utils/alignment-utils.js.map +1 -0
  255. package/lib/src/owlly/utils/basic-calc.d.ts +18 -0
  256. package/lib/src/owlly/utils/basic-calc.js +130 -0
  257. package/lib/src/owlly/utils/basic-calc.js.map +1 -0
  258. package/lib/src/owlly/utils/basic-tools.d.ts +71 -0
  259. package/lib/src/owlly/utils/basic-tools.js +236 -0
  260. package/lib/src/owlly/utils/basic-tools.js.map +1 -0
  261. package/lib/src/owlly/utils/bvh-tree.d.ts +105 -0
  262. package/lib/src/owlly/utils/bvh-tree.js +540 -0
  263. package/lib/src/owlly/utils/bvh-tree.js.map +1 -0
  264. package/lib/src/owlly/utils/camera.d.ts +37 -0
  265. package/lib/src/owlly/utils/camera.js +51 -0
  266. package/lib/src/owlly/utils/camera.js.map +1 -0
  267. package/lib/src/owlly/utils/cube-texture-cache.d.ts +25 -0
  268. package/lib/src/owlly/utils/cube-texture-cache.js +144 -0
  269. package/lib/src/owlly/utils/cube-texture-cache.js.map +1 -0
  270. package/lib/src/owlly/utils/device-utils.d.ts +18 -0
  271. package/lib/src/owlly/utils/device-utils.js +42 -0
  272. package/lib/src/owlly/utils/device-utils.js.map +1 -0
  273. package/lib/src/owlly/utils/environment-utils.d.ts +37 -0
  274. package/lib/src/owlly/utils/environment-utils.js +74 -0
  275. package/lib/src/owlly/utils/environment-utils.js.map +1 -0
  276. package/lib/src/owlly/utils/event-hub.d.ts +50 -0
  277. package/lib/src/owlly/utils/event-hub.js +107 -0
  278. package/lib/src/owlly/utils/event-hub.js.map +1 -0
  279. package/lib/src/owlly/utils/events.d.ts +219 -0
  280. package/lib/src/owlly/utils/events.js +220 -0
  281. package/lib/src/owlly/utils/events.js.map +1 -0
  282. package/lib/src/owlly/utils/geometry-utils.d.ts +119 -0
  283. package/lib/src/owlly/utils/geometry-utils.js +623 -0
  284. package/lib/src/owlly/utils/geometry-utils.js.map +1 -0
  285. package/lib/src/owlly/utils/helper.d.ts +6 -0
  286. package/lib/src/owlly/utils/helper.js +25 -0
  287. package/lib/src/owlly/utils/helper.js.map +1 -0
  288. package/lib/src/owlly/utils/index.d.ts +14 -0
  289. package/lib/src/owlly/utils/index.js +18 -0
  290. package/lib/src/owlly/utils/index.js.map +1 -0
  291. package/lib/src/owlly/utils/lru-cache.d.ts +26 -0
  292. package/lib/src/owlly/utils/lru-cache.js +110 -0
  293. package/lib/src/owlly/utils/lru-cache.js.map +1 -0
  294. package/lib/src/owlly/utils/map-utils.d.ts +7 -0
  295. package/lib/src/owlly/utils/map-utils.js +53 -0
  296. package/lib/src/owlly/utils/map-utils.js.map +1 -0
  297. package/lib/src/owlly/utils/number-utils.d.ts +8 -0
  298. package/lib/src/owlly/utils/number-utils.js +73 -0
  299. package/lib/src/owlly/utils/number-utils.js.map +1 -0
  300. package/lib/src/owlly/utils/panorama-model-util.d.ts +46 -0
  301. package/lib/src/owlly/utils/panorama-model-util.js +246 -0
  302. package/lib/src/owlly/utils/panorama-model-util.js.map +1 -0
  303. package/lib/src/owlly/utils/path-utils.d.ts +80 -0
  304. package/lib/src/owlly/utils/path-utils.js +729 -0
  305. package/lib/src/owlly/utils/path-utils.js.map +1 -0
  306. package/lib/src/owlly/utils/svgutils.d.ts +138 -0
  307. package/lib/src/owlly/utils/svgutils.js +562 -0
  308. package/lib/src/owlly/utils/svgutils.js.map +1 -0
  309. package/lib/src/owlly/utils/texture-cache.d.ts +29 -0
  310. package/lib/src/owlly/utils/texture-cache.js +116 -0
  311. package/lib/src/owlly/utils/texture-cache.js.map +1 -0
  312. package/lib/src/owlly/utils/tile-util.d.ts +187 -0
  313. package/lib/src/owlly/utils/tile-util.js +457 -0
  314. package/lib/src/owlly/utils/tile-util.js.map +1 -0
  315. package/lib/src/owlly/utils/time-profiler.d.ts +21 -0
  316. package/lib/src/owlly/utils/time-profiler.js +49 -0
  317. package/lib/src/owlly/utils/time-profiler.js.map +1 -0
  318. package/lib/src/owlly/view/__test__/perspective-view.spec.d.ts +0 -0
  319. package/lib/src/owlly/view/__test__/perspective-view.spec.js +22 -0
  320. package/lib/src/owlly/view/__test__/perspective-view.spec.js.map +1 -0
  321. package/lib/src/owlly/view/camera-view.d.ts +35 -0
  322. package/lib/src/owlly/view/camera-view.js +102 -0
  323. package/lib/src/owlly/view/camera-view.js.map +1 -0
  324. package/lib/src/owlly/view/index.d.ts +3 -0
  325. package/lib/src/owlly/view/index.js +6 -0
  326. package/lib/src/owlly/view/index.js.map +1 -0
  327. package/lib/src/owlly/view/orthographic-view.d.ts +40 -0
  328. package/lib/src/owlly/view/orthographic-view.js +95 -0
  329. package/lib/src/owlly/view/orthographic-view.js.map +1 -0
  330. package/lib/src/owlly/view/perspective-view.d.ts +40 -0
  331. package/lib/src/owlly/view/perspective-view.js +96 -0
  332. package/lib/src/owlly/view/perspective-view.js.map +1 -0
  333. package/lib/src/owlly/view/svg-map-view.d.ts +46 -0
  334. package/lib/src/owlly/view/svg-map-view.js +145 -0
  335. package/lib/src/owlly/view/svg-map-view.js.map +1 -0
  336. package/lib/src/owlly/view/view.d.ts +146 -0
  337. package/lib/src/owlly/view/view.js +318 -0
  338. package/lib/src/owlly/view/view.js.map +1 -0
  339. package/lib/src/web/main.centroid.d.ts +0 -0
  340. package/lib/src/web/main.centroid.js +74 -0
  341. package/lib/src/web/main.centroid.js.map +1 -0
  342. package/lib/src/web/main.hyma.meshline2d.d.ts +1 -0
  343. package/lib/src/web/main.hyma.meshline2d.js +76 -0
  344. package/lib/src/web/main.hyma.meshline2d.js.map +1 -0
  345. package/lib/src/web/main.jyfang.sample.d.ts +0 -0
  346. package/lib/src/web/main.jyfang.sample.js +122 -0
  347. package/lib/src/web/main.jyfang.sample.js.map +1 -0
  348. package/lib/src/web/main.rpeng.extrude.d.ts +1 -0
  349. package/lib/src/web/main.rpeng.extrude.js +180 -0
  350. package/lib/src/web/main.rpeng.extrude.js.map +1 -0
  351. package/lib/src/web/main.rpeng.mes.plane.d.ts +1 -0
  352. package/lib/src/web/main.rpeng.mes.plane.js +135 -0
  353. package/lib/src/web/main.rpeng.mes.plane.js.map +1 -0
  354. package/lib/src/web/main.rpeng.sample.d.ts +0 -0
  355. package/lib/src/web/main.rpeng.sample.js +318 -0
  356. package/lib/src/web/main.rpeng.sample.js.map +1 -0
  357. package/lib/src/web/main.rpeng.vr.d.ts +1 -0
  358. package/lib/src/web/main.rpeng.vr.js +141 -0
  359. package/lib/src/web/main.rpeng.vr.js.map +1 -0
  360. package/lib/src/web/main.sample.d.ts +1 -0
  361. package/lib/src/web/main.sample.js +52 -0
  362. package/lib/src/web/main.sample.js.map +1 -0
  363. package/lib/src/web/quattree.hyma.d.ts +0 -0
  364. package/lib/src/web/quattree.hyma.js +150 -0
  365. package/lib/src/web/quattree.hyma.js.map +1 -0
  366. package/lib/src/web/sensor-vr-plugin.d.ts +0 -0
  367. package/lib/src/web/sensor-vr-plugin.js +166 -0
  368. package/lib/src/web/sensor-vr-plugin.js.map +1 -0
  369. package/package.json +142 -0
  370. package/src/@types/SceneUtils.d.ts +9 -0
  371. package/src/@types/chaikin-smooth.d.ts +5 -0
  372. package/src/@types/global.d.ts +3 -0
  373. package/src/@types/snapsvg.d.ts +11 -0
  374. package/src/@types/svgson.d.ts +30 -0
  375. package/src/assets/favicon.ico +0 -0
  376. package/src/external/lines/line-geometry.ts +70 -0
  377. package/src/external/lines/line-material.ts +453 -0
  378. package/src/external/lines/line-segments-2.ts +194 -0
  379. package/src/external/lines/line-segments-geometry.ts +197 -0
  380. package/src/external/loaders/gltf-loader.ts +3004 -0
  381. package/src/external/orbit-controls.ts +1070 -0
  382. package/src/external/renderers/css-2d-renderer.ts +185 -0
  383. package/src/external/renderers/css-3d-renderer.ts +245 -0
  384. package/src/external/transform-controls.ts +1532 -0
  385. package/src/external/util/buffer-geometry-utils.ts +783 -0
  386. package/src/owlly/controller/aerial-element-controller.ts +277 -0
  387. package/src/owlly/controller/basic-controller.ts +1509 -0
  388. package/src/owlly/controller/camera-controller.ts +155 -0
  389. package/src/owlly/controller/controller.ts +76 -0
  390. package/src/owlly/controller/index.ts +15 -0
  391. package/src/owlly/controller/mouse-indicator-controller.ts +157 -0
  392. package/src/owlly/controller/orbit-control.ts +310 -0
  393. package/src/owlly/controller/panorama-adjust-controller.ts +183 -0
  394. package/src/owlly/controller/panorama-controller.ts +2234 -0
  395. package/src/owlly/controller/panorama-transform-controller.ts +151 -0
  396. package/src/owlly/controller/plane-controller.ts +222 -0
  397. package/src/owlly/controller/texture-controller.ts +949 -0
  398. package/src/owlly/controller/tile-panorama-controller.ts +1633 -0
  399. package/src/owlly/controller/transform-controller.ts +684 -0
  400. package/src/owlly/element/bottom-nav-element.ts +352 -0
  401. package/src/owlly/element/camera.ts +389 -0
  402. package/src/owlly/element/dom-2d-element.ts +88 -0
  403. package/src/owlly/element/dom-3d-element.ts +87 -0
  404. package/src/owlly/element/dom-label-2d.ts +497 -0
  405. package/src/owlly/element/element.ts +117 -0
  406. package/src/owlly/element/floor-model.ts +290 -0
  407. package/src/owlly/element/gif-kit/Gif.ts +509 -0
  408. package/src/owlly/element/gif-kit/GifColor.ts +44 -0
  409. package/src/owlly/element/gif-kit/GifCompressedCodesToByteArrayConverter.ts +56 -0
  410. package/src/owlly/element/gif-kit/GifFrame.ts +207 -0
  411. package/src/owlly/element/gif-kit/GifImage.ts +26 -0
  412. package/src/owlly/element/gif-kit/GifParser.ts +254 -0
  413. package/src/owlly/element/gif-kit/GifPresenter.ts +46 -0
  414. package/src/owlly/element/gif-kit/GifVersion.ts +12 -0
  415. package/src/owlly/element/gltf-mesh-element.ts +184 -0
  416. package/src/owlly/element/index.ts +25 -0
  417. package/src/owlly/element/map-kit/area.ts +232 -0
  418. package/src/owlly/element/map-kit/block-set.ts +102 -0
  419. package/src/owlly/element/map-kit/block.ts +417 -0
  420. package/src/owlly/element/map-kit/index.ts +6 -0
  421. package/src/owlly/element/map-kit/shape.ts +285 -0
  422. package/src/owlly/element/mesh-element.ts +94 -0
  423. package/src/owlly/element/mesh-line-2d.ts +1032 -0
  424. package/src/owlly/element/meshline-o.ts +802 -0
  425. package/src/owlly/element/panorama-group.ts +1250 -0
  426. package/src/owlly/element/panorama.ts +1044 -0
  427. package/src/owlly/element/path-group.ts +212 -0
  428. package/src/owlly/element/path.ts +727 -0
  429. package/src/owlly/element/placeable-2d.ts +627 -0
  430. package/src/owlly/element/polygon-mesh.ts +344 -0
  431. package/src/owlly/element/ring-element.ts +517 -0
  432. package/src/owlly/element/sphere-mesh.ts +96 -0
  433. package/src/owlly/element/svg-floor-model.ts +200 -0
  434. package/src/owlly/element/svg-floors.ts +121 -0
  435. package/src/owlly/element/tile-panorama-group.ts +1314 -0
  436. package/src/owlly/element/tile-panorama.ts +636 -0
  437. package/src/owlly/element/tile-plane.ts +430 -0
  438. package/src/owlly/element/video-element.ts +190 -0
  439. package/src/owlly/geometries/ExtrudeGeometry2.ts +255 -0
  440. package/src/owlly/index.ts +19 -0
  441. package/src/owlly/overlay/canvas-overlay.ts +642 -0
  442. package/src/owlly/overlay/css-2d-overlay.ts +48 -0
  443. package/src/owlly/overlay/css-3d-overlay.ts +50 -0
  444. package/src/owlly/overlay/index.ts +11 -0
  445. package/src/owlly/overlay/label-overlay.ts +419 -0
  446. package/src/owlly/overlay/overlay.ts +17 -0
  447. package/src/owlly/overlay/path-overlay.ts +170 -0
  448. package/src/owlly/overlay/path-overlay2.ts +149 -0
  449. package/src/owlly/overlay/poi-overlay-3d.ts +1759 -0
  450. package/src/owlly/overlay/poi-overlay.ts +1739 -0
  451. package/src/owlly/owlly-2d/index.ts +108 -0
  452. package/src/owlly/screen/index.ts +1 -0
  453. package/src/owlly/screen/screen.ts +323 -0
  454. package/src/owlly/stage/__test__/stage.spec.ts +15 -0
  455. package/src/owlly/stage/externals.ts +45 -0
  456. package/src/owlly/stage/index.ts +12 -0
  457. package/src/owlly/stage/owlly.ts +223 -0
  458. package/src/owlly/stage/stage.ts +274 -0
  459. package/src/owlly/utils/alignment-utils.ts +84 -0
  460. package/src/owlly/utils/basic-calc.ts +141 -0
  461. package/src/owlly/utils/basic-tools.ts +286 -0
  462. package/src/owlly/utils/bvh-tree.ts +695 -0
  463. package/src/owlly/utils/camera.ts +72 -0
  464. package/src/owlly/utils/cube-texture-cache.ts +155 -0
  465. package/src/owlly/utils/device-utils.ts +53 -0
  466. package/src/owlly/utils/environment-utils.ts +81 -0
  467. package/src/owlly/utils/event-hub.ts +120 -0
  468. package/src/owlly/utils/events.ts +266 -0
  469. package/src/owlly/utils/geometry-utils.ts +749 -0
  470. package/src/owlly/utils/helper.ts +33 -0
  471. package/src/owlly/utils/index.ts +17 -0
  472. package/src/owlly/utils/lru-cache.ts +126 -0
  473. package/src/owlly/utils/map-utils.ts +55 -0
  474. package/src/owlly/utils/number-utils.ts +75 -0
  475. package/src/owlly/utils/panorama-model-util.ts +255 -0
  476. package/src/owlly/utils/path-utils.ts +837 -0
  477. package/src/owlly/utils/svgutils.ts +732 -0
  478. package/src/owlly/utils/texture-cache.ts +132 -0
  479. package/src/owlly/utils/tile-util.ts +563 -0
  480. package/src/owlly/utils/time-profiler.ts +57 -0
  481. package/src/owlly/view/__test__/perspective-view.spec.ts +23 -0
  482. package/src/owlly/view/camera-view.ts +114 -0
  483. package/src/owlly/view/index.ts +5 -0
  484. package/src/owlly/view/orthographic-view.ts +124 -0
  485. package/src/owlly/view/perspective-view.ts +125 -0
  486. package/src/owlly/view/svg-map-view.ts +187 -0
  487. package/src/owlly/view/view.ts +409 -0
  488. package/src/public/js/jsmpeg.min.js +3129 -0
  489. package/src/web/index.html +52 -0
  490. package/src/web/main.centroid.ts +85 -0
  491. package/src/web/main.hyma.meshline2d.ts +84 -0
  492. package/src/web/main.jyfang.sample.ts +139 -0
  493. package/src/web/main.rpeng.extrude.ts +194 -0
  494. package/src/web/main.rpeng.mes.plane.ts +161 -0
  495. package/src/web/main.rpeng.sample.ts +345 -0
  496. package/src/web/main.rpeng.vr.ts +159 -0
  497. package/src/web/main.sample.ts +59 -0
  498. package/src/web/quattree.hyma.ts +163 -0
  499. package/src/web/sensor-vr-plugin.ts +201 -0
  500. package/src/web/testPixel.png +0 -0
@@ -0,0 +1,732 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { parse } from 'svgson';
3
+ import { vec4, mat4 } from 'gl-matrix';
4
+ import Snap from '@aibee/snapsvg';
5
+ import { Externals, NS_THREE } from '../stage/externals';
6
+ import { Shape } from '../element/map-kit/shape';
7
+
8
+ interface ModelSvgMapping {
9
+ scale: number;
10
+ theta: number;
11
+ offsetRatioX: number;
12
+ offsetRatioY: number;
13
+ imageHeight?: number;
14
+ imageWidth?: number;
15
+ }
16
+
17
+ type ArrayFixed<T, L extends number> = [ T, ...Array<T> ] & { length: L }
18
+
19
+ /** @ignore */
20
+ interface SvgNode {
21
+ name: string;
22
+ type: string;
23
+ value: string;
24
+ // eslint-disable-next-line
25
+ attributes: any;
26
+ children: SvgNode[];
27
+ }
28
+
29
+ /** @ignore */
30
+ interface Command {
31
+ command: CommandChar;
32
+ args: number[];
33
+ }
34
+
35
+ /** @ignore */
36
+ interface CanvasNode {
37
+ id?: string;
38
+ children: CanvasNode[];
39
+ commands: Command[];
40
+ fill?: string;
41
+ fillRule?: string;
42
+ tag?: string;
43
+ }
44
+
45
+ /** @ignore */
46
+ interface SvgTransComps {
47
+ position: NS_THREE.Vector3;
48
+ scale: NS_THREE.Vector3;
49
+ quaternion: NS_THREE.Quaternion;
50
+ }
51
+
52
+ /** @ignore */
53
+ type CommandChar = 'C' | 'M' | 'L' | 'Z';
54
+
55
+ /** 图形标记 */
56
+ class GraphicTag {
57
+ /** 地面 */
58
+ static readonly Ground = 'ground';
59
+
60
+ /** 区域 */
61
+ static readonly Area = 'area';
62
+
63
+ /** 店铺 */
64
+ static readonly Store = 'store';
65
+
66
+ /** 不可逾越 */
67
+ static readonly Impassable = 'impassable';
68
+
69
+ /** 停车位 */
70
+ static readonly ParkingSpace = 'parking-space';
71
+ }
72
+
73
+ class SvgUtils {
74
+ /**
75
+ * @deprecated
76
+ * 将SVG文件解析为Owlly map-kit可用的格式
77
+ * @param url svg地址
78
+ * @param alignMatrix 对齐数组
79
+ * @example
80
+ * ```typescript
81
+ * // 将svg解析为Shape对象数组
82
+ * const shapes = await SvgUtils.parseSVG(
83
+ * <svg url>,
84
+ * [0.02, 0, 0, 0, 0, -0.02, 0, 0, 0, 0, 0, 0, -40, 40, 0, 1], // 对齐矩阵
85
+ * );
86
+ * ```
87
+ */
88
+ static async parseSVG(url: string, alignMatrix: ArrayFixed<number, 16>): Promise<Shape[]> {
89
+ const { THREE } = Externals.getInstance();
90
+ const svg: string = await new Promise((resolve) => {
91
+ const fileLoader = new THREE.FileLoader();
92
+ fileLoader.load(url, (data: string) => {
93
+ resolve(data);
94
+ });
95
+ });
96
+ // const svgNode = await parse(svg) as SvgNode;
97
+ // const canvasNode = this.getCanvasNodeFromSvg(svgNode, alignMatrix);
98
+ // if (!canvasNode) return [];
99
+ // return SvgUtils.getShapesFromCanvasNode(canvasNode);
100
+ return this.parseSVGString(svg, alignMatrix);
101
+ }
102
+
103
+ static async parseSVGString(svgStr: string, alignMatrix: ArrayFixed<number, 16>): Promise<Shape[]> {
104
+ const svgNode = await parse(svgStr) as SvgNode;
105
+ const canvasNode = this.getCanvasNodeFromSvg(svgNode, alignMatrix);
106
+ if (!canvasNode) return [];
107
+ return SvgUtils.getShapesFromCanvasNode(canvasNode);
108
+ }
109
+
110
+ /** @ignore */
111
+ static getShapesFromCanvasNode(canvasNode: CanvasNode): Shape[] {
112
+ const result: Shape[] = [];
113
+ if (canvasNode.children.length) {
114
+ const nodesList = canvasNode.children.map((child) => SvgUtils.getShapesFromCanvasNode(child));
115
+ nodesList.forEach((nodes) => {
116
+ nodes.forEach((n) => { result.push(n); });
117
+ });
118
+ }
119
+ if (canvasNode.commands.length) {
120
+ const pathSteps: string[] = [];
121
+ canvasNode.commands.forEach((command) => {
122
+ pathSteps.push(`${command.command.toLowerCase()}${command.args.join(',')}`);
123
+ });
124
+ let height = 2;
125
+ let zIndex = 0.01;
126
+ let fillOpacity = 0.9;
127
+
128
+ if (canvasNode.tag) {
129
+ if (canvasNode.tag.indexOf(GraphicTag.Ground) > -1) {
130
+ height = 0.00;
131
+ zIndex = 0;
132
+ fillOpacity = 1;
133
+ }
134
+ if (canvasNode.tag.indexOf(GraphicTag.Area) > -1) {
135
+ height = 0.00;
136
+ zIndex = 0.01;
137
+ fillOpacity = 1;
138
+ }
139
+ if (canvasNode.tag.indexOf(GraphicTag.ParkingSpace) > -1) {
140
+ height = 0.00;
141
+ zIndex = 0.02;
142
+ fillOpacity = 1;
143
+ }
144
+ if (canvasNode.tag.indexOf(GraphicTag.Store) > -1) {
145
+ height = 1.8;
146
+ zIndex = 0.03;
147
+ fillOpacity = 1;
148
+ }
149
+ }
150
+
151
+ const data = {
152
+ path: pathSteps.join(''),
153
+ shapeType: 'shape',
154
+ fill: canvasNode.fill,
155
+ fillOpacity,
156
+ strokeOpacity: 0.2,
157
+ height,
158
+ zIndex,
159
+ tag: canvasNode.tag,
160
+ parentName: canvasNode.tag,
161
+ } as any;
162
+ if (canvasNode.id) {
163
+ data.tag = canvasNode.id;
164
+ data.id = canvasNode.id;
165
+ }
166
+ const shape = new Shape(data);
167
+ result.push(shape);
168
+ }
169
+ return result;
170
+ }
171
+
172
+ /** @ignore */
173
+ static planCoordinateToWorldCoordinate(
174
+ planX: number, planY: number, mapping: ModelSvgMapping,
175
+ ): { x: number; y: number } {
176
+ const imageWidth = mapping.imageWidth || 4000;
177
+ const imageHeight = mapping.imageHeight || 4000;
178
+ const ratio = imageWidth / 4000;
179
+ const yOffset = (imageWidth - imageHeight) / 2;
180
+ const s = mapping.scale * (4000 / 1000);
181
+ const t = mapping.theta * (Math.PI / 180);
182
+ const w = 4000;
183
+ const h = 4000;
184
+ const x = (planX / ratio - w * mapping.offsetRatioX) / s;
185
+ const y = ((planY + yOffset) / ratio - h * mapping.offsetRatioY) / s;
186
+ const worldX = x * Math.cos(t) + y * Math.sin(t);
187
+ const worldY = x * Math.sin(t) - y * Math.cos(t);
188
+ return { x: worldX, y: worldY };
189
+ }
190
+
191
+ // TODO(jyfang): set scale, theta, etc. externally
192
+ /** @ignore */
193
+ static getPathCommands(
194
+ path: string,
195
+ translate: number[],
196
+ mapping: ModelSvgMapping,
197
+ ): Command[] {
198
+ const commands: Command[] = [];
199
+ // eslint-disable-next-line max-len
200
+ const regexp = /((?:(?:M|L)(?:(?:[0-9]|[.eE]|-)+,(?:[0-9]|[.-eE]|-)+))|(?:C(?:(?:[0-9]|[.-eE]|-)+,(?:[0-9]|[.-eE]|-)+\s){2}(?:(?:[0-9]|[.-eE]|-)+,(?:[0-9]|[.-eE]|-)+))|(?:Z|z))/gm;
201
+ const matches = path.match(regexp);
202
+ if (matches !== null) {
203
+ matches.forEach((step: string) => {
204
+ const positions: number[][] = [];
205
+ const commandChar: CommandChar = step[0] as CommandChar;
206
+ step.substring(1).split(' ').forEach((pos: string) => {
207
+ positions.push(pos.split(',').map((v: string) => parseFloat(v)));
208
+ });
209
+ const worldPositions: number[] = [];
210
+ positions.forEach((position) => {
211
+ if (position.length < 2) return;
212
+ const [planX, planY] = position;
213
+ const { x, y } = SvgUtils.planCoordinateToWorldCoordinate(
214
+ translate[0] + planX,
215
+ translate[1] + planY,
216
+ mapping,
217
+ );
218
+ worldPositions.push(x);
219
+ worldPositions.push(y);
220
+ });
221
+ if (commandChar !== 'Z') {
222
+ commands.push({
223
+ command: commandChar,
224
+ args: worldPositions,
225
+ } as Command);
226
+ }
227
+ });
228
+ }
229
+ return commands;
230
+ }
231
+
232
+ /** @ignore */
233
+ static svgNode2Canvas(
234
+ node: SvgNode,
235
+ mapping: ModelSvgMapping,
236
+ isRoot = false,
237
+ fill: string | null = null,
238
+ fillRule: string | null = null,
239
+ translate: number[] = [0, 0],
240
+ tag: string | null = null,
241
+ ): CanvasNode | null {
242
+ const nodeTag = node.name === 'g' ? node.attributes.name || node.attributes.id || tag : tag;
243
+ const canvasNode = { children: [], commands: [], tag: nodeTag } as CanvasNode;
244
+ if (node.children && node.children.length) {
245
+ const nodeFill = node.attributes.fill || fill;
246
+ const nodeFillRule = node.attributes['fill-rule'] || fillRule;
247
+ const nodeTranslate = translate.slice();
248
+ if (node.attributes.transform) {
249
+ const regexp = /(?:translate\(((?:[0-9]|[.-eE]|-)+),\s((?:[0-9]|[.-eE]|-)+)\))/g;
250
+ const matches = regexp.exec(node.attributes.transform);
251
+ if (matches && matches.length > 2) {
252
+ nodeTranslate[0] += parseFloat(matches[1]);
253
+ nodeTranslate[1] += parseFloat(matches[2]);
254
+ }
255
+ }
256
+ node.children.forEach((c) => {
257
+ if (isRoot && c.name !== 'g') return;
258
+ const childNode = SvgUtils.svgNode2Canvas(
259
+ c, mapping, false, nodeFill, nodeFillRule, nodeTranslate, nodeTag,
260
+ );
261
+ if (childNode) canvasNode.children.push(childNode);
262
+ });
263
+ }
264
+ if (node.name === 'path') {
265
+ // generate path commands
266
+ const path = node.attributes.d;
267
+ canvasNode.commands = SvgUtils.getPathCommands(path, translate, mapping);
268
+ canvasNode.fill = node.attributes.fill || fill;
269
+ canvasNode.fillRule = node.attributes['fill-rule'] || fillRule || 'nonzero';
270
+ }
271
+ if (node.name === 'polygon') {
272
+ // generate polygon commands
273
+ const flatPoints = node.attributes.points.split(' ');
274
+ for (let i = 0; i < flatPoints.length; i += 2) {
275
+ const { x, y } = SvgUtils.planCoordinateToWorldCoordinate(
276
+ translate[0] + parseFloat(flatPoints[i]),
277
+ translate[1] + parseFloat(flatPoints[i + 1]),
278
+ mapping,
279
+ );
280
+ if (i === 0) {
281
+ canvasNode.commands.push({
282
+ command: 'M',
283
+ args: [x, y],
284
+ } as Command);
285
+ } else {
286
+ canvasNode.commands.push({
287
+ command: 'L',
288
+ args: [x, y],
289
+ } as Command);
290
+ }
291
+ }
292
+ canvasNode.fill = node.attributes.fill || fill;
293
+ canvasNode.fillRule = node.attributes['fill-rule'] || fillRule || 'nonzero';
294
+ }
295
+ return canvasNode;
296
+ }
297
+
298
+ /** @ignore */
299
+ static svg2canvas(svg: SvgNode, mapping: ModelSvgMapping): CanvasNode | null{
300
+ return SvgUtils.svgNode2Canvas(svg, mapping, true);
301
+ }
302
+
303
+ /** @ignore */
304
+ static getPathCommandsWithAlignment(
305
+ path: string,
306
+ translate: number[],
307
+ alignMatrix: ArrayFixed<number, 16>,
308
+ ): Command[] {
309
+ const commands: Command[] = [];
310
+ // eslint-disable-next-line max-len
311
+ // const regexp = /((?:(?:M|L)(?:(?:[0-9]|[.eE]|-)+,(?:[0-9]|[.-eE]|-)+))|(?:C(?:(?:[0-9]|[.-eE]|-)+,(?:[0-9]|[.-eE]|-)+\s){2}(?:(?:[0-9]|[.-eE]|-)+,(?:[0-9]|[.-eE]|-)+))|(?:Z|z))/gm;
312
+ const regexp = /[a-z]|[A-Z](\S*)/gm;
313
+ const matches = path.match(regexp);
314
+ if (matches !== null) {
315
+ matches.forEach((step: string) => {
316
+ const positions: number[][] = [];
317
+ const commandChar: CommandChar = step[0] as CommandChar;
318
+ step.substring(1).split(' ').forEach((pos: string) => {
319
+ positions.push(pos.split(',').map((v: string) => parseFloat(v)));
320
+ });
321
+ const worldPositions: number[] = [];
322
+ const list: any = [];
323
+ positions.forEach((position) => {
324
+ if (position.length < 2) return;
325
+ for (let i = 0; i < position.length;) {
326
+ const a = position.slice(i, i += 2);
327
+ list.push(a);
328
+ }
329
+ });
330
+ list.forEach((e: any) => {
331
+ const [planX, planY] = e;
332
+ const { x, y } = SvgUtils.get3DPositionsFrom2D(
333
+ [translate[0] + planX, translate[1] + planY],
334
+ alignMatrix,
335
+ );
336
+ worldPositions.push(x);
337
+ worldPositions.push(y);
338
+ });
339
+ if (commandChar !== 'Z') {
340
+ commands.push({
341
+ command: commandChar,
342
+ args: worldPositions,
343
+ } as Command);
344
+ }
345
+ });
346
+ }
347
+ return commands;
348
+ }
349
+
350
+ public static get3DPositionsFrom2D(
351
+ [x, y]: [number, number],
352
+ m: ArrayFixed<number, 16>,
353
+ ): { x: number; y: number } {
354
+ const alignMat = mat4.fromValues(
355
+ m[0], m[1], m[2], m[3], m[4], m[5], m[6], m[7], m[8], m[9], m[10], m[11], m[12], m[13], m[14], m[15],
356
+ );
357
+ const v = vec4.create();
358
+ vec4.set(v, x, y, 0, 1);
359
+ const result = vec4.create();
360
+ vec4.transformMat4(result, v, alignMat);
361
+ return { x: result[0], y: result[1] };
362
+ }
363
+
364
+ /**
365
+ * 获取对齐矩阵指向北方转动的弧度
366
+ * @param m 对齐矩阵
367
+ */
368
+ public static getRotateRadiusToNorth(
369
+ m: ArrayFixed<number, 16>,
370
+ ): number {
371
+ const { THREE } = Externals.getInstance();
372
+ const position = new THREE.Vector3();
373
+ const scale = new THREE.Vector3();
374
+ const quaternion = new THREE.Quaternion();
375
+ new THREE.Matrix4().fromArray(m).decompose(position, quaternion, scale);
376
+
377
+ const targetAngle = new THREE.Euler().setFromQuaternion(quaternion).z;
378
+ return -targetAngle;
379
+ }
380
+
381
+ /** @ignore */
382
+ private static generateCanvasNodeFromSvg(
383
+ node: SvgNode,
384
+ alignMatrix: ArrayFixed<number, 16>,
385
+ isRoot = false,
386
+ fill: string | null = null,
387
+ fillRule: string | null = null,
388
+ translate: number[] = [0, 0],
389
+ tag: string | null = null,
390
+ ): CanvasNode | null {
391
+ const nodeTag = node.name === 'g' ? node.attributes.name || node.attributes.id || tag : tag;
392
+ const canvasNode = {
393
+ children: [], commands: [], tag: nodeTag, id: node.attributes.id,
394
+ } as CanvasNode;
395
+ if (node.children && node.children.length) {
396
+ const nodeFill = node.attributes.fill || fill;
397
+ const nodeFillRule = node.attributes['fill-rule'] || fillRule;
398
+ const nodeTranslate = translate.slice();
399
+ if (node.attributes.transform) {
400
+ const regexp = /(?:translate\(((?:[0-9]|[.-eE]|-)+),\s((?:[0-9]|[.-eE]|-)+)\))/g;
401
+ const matches = regexp.exec(node.attributes.transform);
402
+ if (matches && matches.length > 2) {
403
+ nodeTranslate[0] += parseFloat(matches[1]);
404
+ nodeTranslate[1] += parseFloat(matches[2]);
405
+ }
406
+ }
407
+ node.children.forEach((c) => {
408
+ if (isRoot && c.name !== 'g') return;
409
+ const childNode = SvgUtils.generateCanvasNodeFromSvg(
410
+ c, alignMatrix, false, nodeFill, nodeFillRule, nodeTranslate, nodeTag,
411
+ );
412
+ if (childNode) canvasNode.children.push(childNode);
413
+ });
414
+ }
415
+ if (node.name === 'path') {
416
+ // generate path commands
417
+ const path = node.attributes.d;
418
+ canvasNode.commands = SvgUtils.getPathCommandsWithAlignment(path, translate, alignMatrix);
419
+ canvasNode.fill = node.attributes.fill || fill;
420
+ canvasNode.fillRule = node.attributes['fill-rule'] || fillRule || 'nonzero';
421
+ }
422
+ if (node.name === 'polygon') {
423
+ // generate polygon commands
424
+ const flatPoints = node.attributes.points.split(' ');
425
+ for (let i = 0; i < flatPoints.length; i += 2) {
426
+ const { x, y } = SvgUtils.get3DPositionsFrom2D(
427
+ [
428
+ translate[0] + parseFloat(flatPoints[i]),
429
+ translate[1] + parseFloat(flatPoints[i + 1]),
430
+ ],
431
+ alignMatrix,
432
+ );
433
+ if (i === 0) {
434
+ canvasNode.commands.push({
435
+ command: 'M',
436
+ args: [x, y],
437
+ } as Command);
438
+ } else {
439
+ canvasNode.commands.push({
440
+ command: 'L',
441
+ args: [x, y],
442
+ } as Command);
443
+ }
444
+ }
445
+ canvasNode.fill = node.attributes.fill || fill;
446
+ canvasNode.fillRule = node.attributes['fill-rule'] || fillRule || 'nonzero';
447
+ }
448
+ return canvasNode;
449
+ }
450
+
451
+ /** @ignore */
452
+ static getCanvasNodeFromSvg(svg: SvgNode, alignMatrix: ArrayFixed<number, 16>): CanvasNode | null{
453
+ return SvgUtils.generateCanvasNodeFromSvg(svg, alignMatrix, true);
454
+ }
455
+
456
+ /** @ignore */
457
+ static generateNewShape(path: string, id: string, options?: { tag?: string; fill?: string; ownTag?: string }): Shape {
458
+ const { tag, fill, ownTag } = options || {};
459
+
460
+ let height = 2;
461
+ let zIndex = 0.01;
462
+ let fillOpacity = 0.9;
463
+ if (tag === GraphicTag.Ground) {
464
+ height = 0.00;
465
+ zIndex = 0;
466
+ fillOpacity = 1;
467
+ }
468
+ if (tag === GraphicTag.Area) {
469
+ height = 0.00;
470
+ zIndex = 0.01;
471
+ fillOpacity = 1;
472
+ }
473
+ if (tag === GraphicTag.ParkingSpace) {
474
+ height = 0.00;
475
+ zIndex = 0.02;
476
+ fillOpacity = 1;
477
+ }
478
+ if (tag === GraphicTag.Store) {
479
+ height = 1.8;
480
+ zIndex = 0.03;
481
+ fillOpacity = 1;
482
+ }
483
+
484
+ return new Shape({
485
+ id,
486
+ path,
487
+ shapeType: 'shape',
488
+ fill,
489
+ fillOpacity,
490
+ strokeOpacity: 0.2,
491
+ height,
492
+ zIndex,
493
+ tag: ownTag || tag,
494
+ parentName: tag,
495
+ });
496
+ }
497
+
498
+ /** @ignore */
499
+ static parseRectElementToShape(
500
+ node: Snap.Element,
501
+ alignMatrix: ArrayFixed<number, 16>,
502
+ { tag, fill, ownTag }: {
503
+ tag?: string;
504
+ fill?: string;
505
+ ownTag?: string;
506
+ },
507
+ ): Shape {
508
+ const {
509
+ x: xString, y: yString, width: widthString, height: heightString, id,
510
+ } = node.attr();
511
+ const [x, y, width, height] = [xString, yString, widthString, heightString].map(parseFloat);
512
+ const alignedPathCommands: (string|number)[][] = [];
513
+ const matrix = node.transform().totalMatrix;
514
+
515
+ const pointList = [x, y, x + width, y, x + width, y + height, x, y + height, x, y];
516
+
517
+ for (let i = 0; i < pointList.length; i += 2) {
518
+ const step: (string|number)[] = [];
519
+ step.push(i > 0 ? 'L' : 'M');
520
+ const localX = pointList[i];
521
+ const localY = pointList[i + 1];
522
+ const worldX = matrix.x(localX, localY);
523
+ const worldY = matrix.y(localX, localY);
524
+ const { x: xPos, y: yPos } = this.get3DPositionsFrom2D([worldX, worldY], alignMatrix);
525
+ step.push(xPos, yPos);
526
+ alignedPathCommands.push(step);
527
+ }
528
+
529
+ return this.generateNewShape(
530
+ alignedPathCommands.map(([command, ...coords]) => (`${command}${coords.join(',')}`)).join(''),
531
+ id,
532
+ { tag, fill, ownTag },
533
+ );
534
+ }
535
+
536
+ /** @ignore */
537
+ static parsePolygonElementToShape(
538
+ node: Snap.Element,
539
+ alignMatrix: ArrayFixed<number, 16>,
540
+ { tag, fill, ownTag }: {
541
+ tag?: string;
542
+ fill?: string;
543
+ ownTag?: string;
544
+ },
545
+ ): Shape {
546
+ const { points, id } = node.attr();
547
+ const pointList = points.split(' ').map(parseFloat);
548
+ const alignedPathCommands: (string|number)[][] = [];
549
+ const matrix = node.transform().totalMatrix;
550
+
551
+ for (let i = 0; i < pointList.length; i += 2) {
552
+ const step: (string|number)[] = [];
553
+ step.push(i > 0 ? 'L' : 'M');
554
+ const localX = pointList[i];
555
+ const localY = pointList[i + 1];
556
+ const worldX = matrix.x(localX, localY);
557
+ const worldY = matrix.y(localX, localY);
558
+ const { x, y } = this.get3DPositionsFrom2D([worldX, worldY], alignMatrix);
559
+ step.push(x, y);
560
+ alignedPathCommands.push(step);
561
+ }
562
+
563
+ return this.generateNewShape(
564
+ alignedPathCommands.map(([command, ...coords]) => (`${command}${coords.join(',')}`)).join(''),
565
+ id,
566
+ { tag, fill, ownTag },
567
+ );
568
+ }
569
+
570
+ /** @ignore */
571
+ static parsePathElementToShape(
572
+ node: Snap.Element,
573
+ alignMatrix: ArrayFixed<number, 16>,
574
+ { tag, fill, ownTag }: {
575
+ tag?: string;
576
+ fill?: string;
577
+ ownTag?: string;
578
+ },
579
+ ): Shape {
580
+ const { d, id } = node.attr();
581
+ const pathCommands = Snap.parsePathString(d);
582
+ const alignedPathCommands: (string|number)[][] = [];
583
+ const matrix = node.transform().totalMatrix;
584
+
585
+ pathCommands.forEach(([commandChar, ...coords]) => {
586
+ if (commandChar === 'Z') return;
587
+
588
+ const step: (string|number)[] = [];
589
+ step.push((commandChar as string).toLowerCase());
590
+ for (let i = 0; i < coords.length; i += 2) {
591
+ const localX = coords[i];
592
+ const localY = coords[i + 1];
593
+ const worldX = matrix.x(localX, localY);
594
+ const worldY = matrix.y(localX, localY);
595
+ const { x, y } = SvgUtils.get3DPositionsFrom2D([worldX, worldY], alignMatrix);
596
+ step.push(x, y);
597
+ }
598
+
599
+ alignedPathCommands.push(step);
600
+ });
601
+
602
+ return this.generateNewShape(
603
+ alignedPathCommands.map(([command, ...coords]) => (`${command}${coords.join(',')}`)).join(''),
604
+ id,
605
+ { tag, fill, ownTag },
606
+ );
607
+ }
608
+
609
+ /** @ignore */
610
+ static parseSnapSvgToShapes(
611
+ node: Snap.Element,
612
+ alignMatrix: ArrayFixed<number, 16>,
613
+ options?: {
614
+ tag?: string;
615
+ fill?: string;
616
+ },
617
+ ): Shape[] {
618
+ try {
619
+ const { tag, fill } = options || {};
620
+ const { type } = node;
621
+ const result: Shape[] = [];
622
+ const attr = node.attr();
623
+ const nodeTag = type === 'g' ? attr.name || attr.id || tag : tag;
624
+ const nodeOwnTag = attr.name || attr.id;
625
+ const nodeFill = attr.fill || fill || '';
626
+ const children = node.children();
627
+ for (let i = 0; i < children.length; i += 1) {
628
+ const childShapes = this.parseSnapSvgToShapes(children[i], alignMatrix, { tag: nodeTag, fill: nodeFill });
629
+ for (let j = 0; j < childShapes.length; j += 1) {
630
+ result.push(childShapes[j]);
631
+ }
632
+ }
633
+ if (type === 'path') {
634
+ result.push(this.parsePathElementToShape(node, alignMatrix, {
635
+ tag: nodeTag,
636
+ fill: nodeFill,
637
+ ownTag: nodeOwnTag,
638
+ }));
639
+ }
640
+ if (type === 'polygon') {
641
+ result.push(this.parsePolygonElementToShape(node, alignMatrix, {
642
+ tag: nodeTag,
643
+ fill: nodeFill,
644
+ ownTag: nodeOwnTag,
645
+ }));
646
+ }
647
+ if (type === 'rect') {
648
+ result.push(this.parseRectElementToShape(node, alignMatrix, {
649
+ tag: nodeTag,
650
+ fill: nodeFill,
651
+ ownTag: nodeOwnTag,
652
+ }));
653
+ }
654
+ return result;
655
+ } catch (error) {
656
+ // ignore
657
+ // console.log(node.type, node.attr('id'), 'not supported skip');
658
+ }
659
+ return [];
660
+ }
661
+
662
+ /** @ignore */
663
+ static getCompsFromMat4(mat: ArrayFixed<number, 16>): SvgTransComps {
664
+ const { THREE } = Externals.getInstance();
665
+ const position = new THREE.Vector3();
666
+ const scale = new THREE.Vector3();
667
+ const quaternion = new THREE.Quaternion();
668
+ new THREE.Matrix4().fromArray(mat).decompose(position, quaternion, scale);
669
+ return {
670
+ position,
671
+ scale,
672
+ quaternion,
673
+ };
674
+ }
675
+
676
+ /**
677
+ * 将svg解析为Shape对象数组
678
+ * @param url SVG文件url
679
+ * @param alignMatrix 对齐矩阵数组
680
+ * @param coefficient shape高度调整系数
681
+ * @example
682
+ * ```typescript
683
+ * // 将svg解析为Shape对象数组
684
+ * const shapes = await SvgUtils.parseSvgToShapes(
685
+ * <svg url>,
686
+ * [0.02, 0, 0, 0, 0, -0.02, 0, 0, 0, 0, 0, 0, -40, 40, 0, 1], // 对齐矩阵
687
+ * );
688
+ * ```
689
+ */
690
+ static parseSvgToShapes(
691
+ url: string,
692
+ alignMatrix: ArrayFixed<number, 16>,
693
+ coefficient = 1,
694
+ ): Promise<Shape[]> {
695
+ return new Promise((resolve) => {
696
+ // const tagsCounterMap: Map<string, number> = new Map();
697
+ Snap.load(
698
+ url,
699
+ (fragment) => {
700
+ let shapes = this.parseSnapSvgToShapes(fragment.select('svg'), alignMatrix);
701
+ shapes = shapes.map((s: Shape): Shape => {
702
+ const { height } = s.getData();
703
+ // if (parentName && !tagsCounterMap.get(parentName)) {
704
+ // tagsCounterMap.set(parentName, 0);
705
+ // }
706
+ // const count = parentName ? tagsCounterMap.get(parentName) : 0;
707
+ // tagsCounterMap.set(parentName as string, count as number + 1);
708
+ const newH = SvgUtils.calcHeightFromMat(height, alignMatrix);
709
+ // const offset = count as number * 0.01;
710
+ const tHeight = newH * coefficient;
711
+ s.updateData({ height: tHeight });
712
+ return s;
713
+ });
714
+ resolve(shapes);
715
+ },
716
+ );
717
+ });
718
+ }
719
+
720
+ static calcHeightFromMat(height: number, alignMatrix: ArrayFixed<number, 16>): number {
721
+ const { scale } = SvgUtils.getCompsFromMat4(alignMatrix);
722
+ const muliNum = 20 * scale.x;
723
+ return height * muliNum;
724
+ }
725
+ }
726
+
727
+ export {
728
+ CanvasNode,
729
+ SvgNode,
730
+ SvgUtils,
731
+ ModelSvgMapping,
732
+ };