@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,50 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+ import { CSS3DRenderer } from '../../external/renderers/css-3d-renderer';
3
+ import { Overlay } from './overlay';
4
+ import { View } from '../view/view';
5
+
6
+ class CSS3DOverlay extends Overlay {
7
+ private container: HTMLElement;
8
+
9
+ private parent: View;
10
+
11
+ renderer: CSS3DRenderer | null;
12
+
13
+ init(parent: View, container = new HTMLElement()): void {
14
+ this.container = container;
15
+ this.parent = parent;
16
+ const { clientWidth, clientHeight } = this.container;
17
+ this.renderer = new CSS3DRenderer();
18
+ this.renderer.setSize(clientWidth, clientHeight);
19
+ this.renderer.domElement.style.position = 'absolute';
20
+ this.renderer.domElement.style.top = '0';
21
+ this.renderer.domElement.style.left = '0';
22
+ this.renderer.domElement.style.userSelect = 'none';
23
+ // this.renderer.domElement.style.pointerEvents = 'none';
24
+ this.container.appendChild(this.renderer.domElement);
25
+ }
26
+
27
+ resize(containerWidth: number, containerHeight: number): void {
28
+ this.renderer!.setSize(containerWidth, containerHeight);
29
+ }
30
+
31
+ setRenderOrder(order: number): void {
32
+ this.renderer!.domElement.style.setProperty('z-index', `${order}`);
33
+ }
34
+
35
+ update(): boolean {
36
+ return false;
37
+ }
38
+
39
+ render(scene: NS_THREE.Scene): void {
40
+ if (!this.parent.camera) return;
41
+ this.renderer!.render(scene, this.parent.camera);
42
+ }
43
+
44
+ dispose(): void {
45
+ this.container.removeChild(this.renderer!.domElement);
46
+ this.renderer = null;
47
+ }
48
+ }
49
+
50
+ export { CSS3DOverlay };
@@ -0,0 +1,11 @@
1
+ // #if WEB_ONLY
2
+ export * from './overlay';
3
+ // #endif
4
+ // export * from './path-overlay';
5
+ export * from './path-overlay2';
6
+ // export * from './label-overlay';
7
+ export * from './css-2d-overlay';
8
+ // export * from './css-3d-overlay';
9
+ export * from './poi-overlay';
10
+ export * from './canvas-overlay';
11
+ export * from './poi-overlay-3d';
@@ -0,0 +1,419 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+ import { Overlay } from './overlay';
3
+ import { View } from '../view/view';
4
+ import { Events } from '../utils/events';
5
+
6
+ interface LabelPoint {
7
+ element: HTMLElement;
8
+ labelElement: HTMLElement;
9
+ pointElement: HTMLElement;
10
+ guidelineElement?: HTMLElement;
11
+ position: NS_THREE.Vector3;
12
+ name: string;
13
+ size: [number, number];
14
+ ready: boolean;
15
+ id: string;
16
+ priority: number;
17
+ alwaysShow: boolean;
18
+ }
19
+
20
+ /**
21
+ * 该文件应被舍弃, 不再使用
22
+ * @deprecated
23
+ */
24
+ class LabelOverlay extends Overlay {
25
+ private container: HTMLElement;
26
+
27
+ private parent: View;
28
+
29
+ private overlay: HTMLDivElement;
30
+
31
+ private iconPoints: { element: HTMLImageElement; position: NS_THREE.Vector3; offsetX: number; offsetY: number }[];
32
+
33
+ private labelPoints: LabelPoint[];
34
+
35
+ private bubblePoint: {
36
+ element: HTMLElement;
37
+ imageElement: HTMLImageElement;
38
+ messageElement: HTMLDivElement;
39
+ position: NS_THREE.Vector3;
40
+ message: string;
41
+ };
42
+
43
+ private renderThisFrame: boolean;
44
+
45
+ init(parent: View, container = new HTMLElement()): void {
46
+ this.container = container;
47
+ this.parent = parent;
48
+ if (!this.parent.camera) {
49
+ throw new Error('Parent view should have a camera to rely on');
50
+ }
51
+ this.iconPoints = [];
52
+ this.labelPoints = [];
53
+ this.renderThisFrame = false;
54
+ this.overlay = document.createElement('div');
55
+ this.overlay.style.cssText = `
56
+ pointer-events: none;
57
+ position: absolute;
58
+ top: 0;
59
+ left: 0;
60
+ width: 100%;
61
+ height: 100%;
62
+ `;
63
+ this.container.appendChild(this.overlay);
64
+ }
65
+
66
+ update(): boolean {
67
+ this.labelPoints.forEach(({ labelElement, ready }, i) => {
68
+ if (ready) return;
69
+ const { width, height } = labelElement.getBoundingClientRect();
70
+ labelElement.style.setProperty('left', `${-width * 0.5}px`);
71
+ labelElement.style.setProperty('top', `${-height - 4}px`);
72
+ this.labelPoints[i].ready = true;
73
+ });
74
+ if (this.renderThisFrame) {
75
+ this.renderThisFrame = false;
76
+ return true;
77
+ }
78
+ return false;
79
+ }
80
+
81
+ render(): void {
82
+ const { clientWidth, clientHeight } = this.container;
83
+ const widthHalf = clientWidth / 2;
84
+ const heightHalf = clientHeight / 2;
85
+ this.iconPoints.forEach(({
86
+ element, position, offsetX, offsetY,
87
+ }) => {
88
+ if (!this.parent.camera) return;
89
+ const p = position.clone();
90
+ p.project(this.parent.camera);
91
+ element.style.setProperty('left', `${(p.x + 1) * widthHalf - 20 + offsetX}px`);
92
+ element.style.setProperty('top', `${(1 - p.y) * heightHalf - 40 + offsetY}px`);
93
+ });
94
+ this.emit(Events.LABEL_ICONS_POSITION_UPDATED, this.iconPoints.map((p) => (p.element)));
95
+ if (
96
+ this.bubblePoint
97
+ && this.bubblePoint.message
98
+ && this.bubblePoint.message.length
99
+ && this.parent.camera
100
+ ) {
101
+ const p = this.bubblePoint.position.clone();
102
+ p.project(this.parent.camera);
103
+ this.bubblePoint.element.style.setProperty('left', `${(p.x + 1) * widthHalf}px`);
104
+ this.bubblePoint.element.style.setProperty('top', `${(1 - p.y) * heightHalf}px`);
105
+ }
106
+ const range: number[][] = [];
107
+ this.labelPoints.forEach(({
108
+ element, labelElement, position, pointElement, alwaysShow,
109
+ }, i) => {
110
+ if (!this.parent.camera) return;
111
+ const p = position.clone();
112
+ p.project(this.parent.camera);
113
+ if (!Number.isFinite(p.x) || !Number.isFinite(p.y)) return;
114
+ const posX = (p.x + 1) * widthHalf;
115
+ const posY = (1 - p.y) * heightHalf;
116
+ element.style.setProperty('left', `${posX}px`);
117
+ element.style.setProperty('top', `${posY}px`);
118
+ const { width, height } = labelElement.getBoundingClientRect();
119
+ const leftX = posX - width / 2 - 8;
120
+ const rightX = posX + width / 2 + 8;
121
+ const topY = posY - height - 4 - 8;
122
+ const bottomY = posY - 4 + 8;
123
+
124
+ if (i === 0) {
125
+ range.push([leftX, rightX, topY, bottomY]);
126
+ return;
127
+ }
128
+
129
+ const valid = alwaysShow || !range.some(([lx, rx, ty, by]) => {
130
+ if (leftX >= lx && leftX >= rx) return false;
131
+ if (leftX <= rx && rightX <= lx) return false;
132
+ if (topY >= ty && topY >= by) return false;
133
+ if (topY <= by && bottomY <= ty) return false;
134
+ return true;
135
+ });
136
+
137
+ if (valid) {
138
+ range.push([leftX, rightX, topY, bottomY]);
139
+ labelElement.style.setProperty('opacity', '1');
140
+ pointElement.style.setProperty('opacity', '1');
141
+ } else {
142
+ labelElement.style.setProperty('opacity', '0');
143
+ pointElement.style.setProperty('opacity', '0');
144
+ }
145
+ });
146
+ }
147
+
148
+ setRenderOrder(order: number): void {
149
+ this.overlay.style.setProperty('z-index', `${order}`);
150
+ }
151
+
152
+ dispose(): void {
153
+ if (this.container) this.container.removeChild(this.overlay);
154
+ delete (this as any).overlay; // eslint-disable-line
155
+ }
156
+
157
+ static getBiggerPos(arr: number[][], target: number, index: number): number {
158
+ let i = 0;
159
+ let j = arr.length - 1;
160
+ while (i !== j) {
161
+ const p = Math.ceil((i + j) / 2);
162
+ const v = arr[p][index];
163
+ if (target >= v) {
164
+ i = p;
165
+ } else {
166
+ j = p - 1;
167
+ }
168
+ }
169
+ return i;
170
+ }
171
+
172
+ static getSmallerPos(arr: number[][], target: number, index: number): number {
173
+ let i = 0;
174
+ let j = arr.length - 1;
175
+ while (i !== j) {
176
+ const p = Math.floor((i + j) / 2);
177
+ const v = arr[p][index];
178
+ if (target >= v) {
179
+ i = p + 1;
180
+ } else {
181
+ j = p;
182
+ }
183
+ }
184
+ return i;
185
+ }
186
+
187
+ public setBubble(
188
+ {
189
+ position, message, imageStyle, messageStyle, fontSize,
190
+ }: {
191
+ position: NS_THREE.Vector3;
192
+ message: string | null;
193
+ fontSize: number;
194
+ imageStyle: {
195
+ left: number;
196
+ top: number;
197
+ width: number;
198
+ height: number;
199
+ };
200
+ messageStyle: {
201
+ left: number;
202
+ top: number;
203
+ width: number;
204
+ height: number;
205
+ };
206
+ },
207
+ ): void {
208
+ if (
209
+ this.bubblePoint
210
+ && this.bubblePoint.message
211
+ && this.bubblePoint.message.length
212
+ ) {
213
+ this.overlay.removeChild(this.bubblePoint.element);
214
+ this.bubblePoint.message = '';
215
+ }
216
+ if (!message || !message.length) return;
217
+ this.bubblePoint = {
218
+ element: document.createElement('div'),
219
+ imageElement: document.createElement('img'),
220
+ messageElement: document.createElement('div'),
221
+ position,
222
+ message,
223
+ };
224
+ this.bubblePoint.element.style.cssText = `
225
+ pointer-events: none;
226
+ position: absolute;
227
+ top: 0;
228
+ left: 0;
229
+ width: 0;
230
+ height: 0;
231
+ z-index: 2;
232
+ `;
233
+ this.bubblePoint.imageElement.src = 'imgs/bubble.png';
234
+ this.bubblePoint.imageElement.style.cssText = `
235
+ pointer-events: none;
236
+ position: absolute;
237
+ top: ${imageStyle.top || -110}px;
238
+ left: ${imageStyle.left || -103.5}px;
239
+ width: ${imageStyle.width || 207}px;
240
+ height: ${imageStyle.height || 85}px;
241
+ object-fit: contain;
242
+ z-index: 2;
243
+ `;
244
+ this.bubblePoint.messageElement.innerHTML = `
245
+ <span style="text-align: center;">
246
+ ${message}
247
+ </span>
248
+ `;
249
+ this.bubblePoint.messageElement.style.cssText = `
250
+ display: flex;
251
+ align-items: center;
252
+ justify-content: center;
253
+ position: absolute;
254
+ top: ${messageStyle.top || -104}px;
255
+ left: ${messageStyle.left || -82}px;
256
+ width: ${messageStyle.width || 164}px;
257
+ height: ${messageStyle.height || 42}px;
258
+ color: #000;
259
+ font-size: ${fontSize}px;
260
+ z-index: 3;
261
+ `;
262
+ this.bubblePoint.element.appendChild(this.bubblePoint.imageElement);
263
+ this.bubblePoint.element.appendChild(this.bubblePoint.messageElement);
264
+ this.overlay.appendChild(this.bubblePoint.element);
265
+ this.renderThisFrame = true;
266
+ }
267
+
268
+ public setIconPoints(
269
+ points: {
270
+ position: NS_THREE.Vector3;
271
+ src: string;
272
+ width: number;
273
+ height: number;
274
+ offsetX: number;
275
+ offsetY: number;
276
+ }[],
277
+ ): void {
278
+ const srcSet = new Set<string>();
279
+ const srcMap = new Map<
280
+ string,
281
+ { element: HTMLImageElement; position: NS_THREE.Vector3; offsetX: number; offsetY: number }
282
+ >();
283
+ points.forEach(({ src }) => { srcSet.add(src); });
284
+ while (this.iconPoints.length) {
285
+ const p = this.iconPoints.pop();
286
+ if (p) {
287
+ const s = p.element.src;
288
+ if (srcSet.has(s)) srcMap.set(s, p);
289
+ else this.overlay.removeChild(p.element);
290
+ }
291
+ }
292
+ this.iconPoints.push(...srcMap.values());
293
+ points.forEach(({
294
+ position, src, width, height, offsetX, offsetY,
295
+ }) => {
296
+ if (srcMap.has(src)) {
297
+ srcMap.get(src)!.position = position;
298
+ return;
299
+ }
300
+ const point = {
301
+ element: document.createElement('img'), position, offsetX, offsetY,
302
+ };
303
+ point.element.src = src;
304
+ point.element.style.cssText = `
305
+ pointer-events: none;
306
+ position: absolute;
307
+ top: 0;
308
+ left: 0;
309
+ width: ${width || 40}px;
310
+ height: ${height || 40}px;
311
+ object-fit: contain;
312
+ z-index: 2;
313
+ `;
314
+ this.iconPoints.push(point);
315
+ this.overlay.appendChild(point.element);
316
+ });
317
+ this.renderThisFrame = true;
318
+ }
319
+
320
+ public setLabelPoints(
321
+ points: {
322
+ position: NS_THREE.Vector3;
323
+ name: string;
324
+ nodeId: string;
325
+ color?: string;
326
+ pointSize?: number;
327
+ offsetX?: number;
328
+ offsetY?: number;
329
+ showGuideline?: boolean;
330
+ fontSize?: number;
331
+ alwaysShow?: boolean;
332
+ }[],
333
+ ): void {
334
+ while (this.labelPoints.length) {
335
+ const p = this.labelPoints.pop();
336
+ if (p) this.overlay.removeChild(p.element);
337
+ }
338
+ points.forEach(({
339
+ position, name, nodeId, color, pointSize,
340
+ offsetX, offsetY, showGuideline, fontSize, alwaysShow,
341
+ }) => {
342
+ const pSize = pointSize || 4;
343
+ const offX = offsetX || 0;
344
+ const offY = offsetY || 0;
345
+ const point = {
346
+ element: document.createElement('div'),
347
+ labelElement: document.createElement('div'),
348
+ pointElement: document.createElement('div'),
349
+ position,
350
+ name,
351
+ size: [0, 0] as [number, number],
352
+ ready: false,
353
+ id: nodeId,
354
+ priority: 0,
355
+ alwaysShow: !!alwaysShow,
356
+ } as LabelPoint;
357
+ point.element.style.cssText = `
358
+ pointer-events: none;
359
+ position: absolute;
360
+ top: 0;
361
+ left: 0;
362
+ width: auto;
363
+ height: auto;
364
+ z-index: 1;
365
+ `;
366
+ point.labelElement.innerHTML = name;
367
+ // TODO(jyfang): Free color settings.
368
+ point.labelElement.style.cssText = `
369
+ position: absolute;
370
+ font-size: ${fontSize || 16}px;
371
+ white-space: nowrap;
372
+ color: ${color || '#A57D50'};
373
+ font-weight: 500;
374
+ text-shadow: 0 1px white, 1px 0 white, -1px 0 white, 0 -1px white;
375
+ transform: translate(${offX}px, ${offY}px);
376
+ `;
377
+ point.pointElement.style.cssText = `
378
+ display: inline-block;
379
+ position: absolute;
380
+ top: -${pSize / 2}px;
381
+ left: -${pSize / 2}px;
382
+ height: ${pSize}px;
383
+ width: ${pSize}px;
384
+ background-color: ${color || '#A57D50'};
385
+ border-radius: 50%;
386
+ box-shadow: 0 0 1px 2px #fff;
387
+ `;
388
+ point.element.appendChild(point.labelElement);
389
+ point.element.appendChild(point.pointElement);
390
+ if (showGuideline) {
391
+ point.guidelineElement = document.createElement('div');
392
+ point.guidelineElement.style.cssText = `
393
+ position: absolute;
394
+ width: 2px;
395
+ height: ${Math.abs(offY) - 20}px;
396
+ top: ${Math.sign(offY) * (Math.abs(offY) - 20)}px;
397
+ left: -1px;
398
+ background-color: #fff;
399
+ `;
400
+ point.element.appendChild(point.guidelineElement);
401
+ }
402
+ this.labelPoints.push(point);
403
+ this.overlay.appendChild(point.element);
404
+ });
405
+ this.renderThisFrame = true;
406
+ }
407
+
408
+ public setPriorLabelPoints(ids: string[]): void {
409
+ const idSet = new Set<string>();
410
+ ids.forEach((id) => { idSet.add(id); });
411
+ this.labelPoints.forEach((p) => {
412
+ if (idSet.has(p.id)) p.priority = 999;
413
+ else p.priority = 0;
414
+ });
415
+ this.labelPoints.sort((a, b) => b.priority - a.priority);
416
+ }
417
+ }
418
+
419
+ export { LabelOverlay };
@@ -0,0 +1,17 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+
3
+ import { View } from '../view/view';
4
+ import { EventHubClassic } from '../utils/event-hub';
5
+
6
+ class Overlay extends EventHubClassic { }
7
+
8
+ interface Overlay {
9
+ init(parent: View): void;
10
+ update(): boolean;
11
+ render(scene?: NS_THREE.Scene): void;
12
+ setRenderOrder(order: number): void;
13
+ resize?(containerWidth: number, containerHeight: number): void;
14
+ dispose(): void;
15
+ }
16
+
17
+ export { Overlay };
@@ -0,0 +1,170 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+ import { Overlay } from './overlay';
3
+ import { View } from '../view/view';
4
+
5
+ /**
6
+ * 该类应该被舍弃, 不再使用
7
+ * @deprecated
8
+ */
9
+ class PathOverlay extends Overlay {
10
+ private container: HTMLElement;
11
+
12
+ private parent: View;
13
+
14
+ private canvas: HTMLCanvasElement;
15
+
16
+ private context: CanvasRenderingContext2D | null;
17
+
18
+ private devicePixelRatio: number;
19
+
20
+ // private forceRender: boolean;
21
+ private path: NS_THREE.Vector3[];
22
+
23
+ private showEndPoints: boolean;
24
+
25
+ private startColor: { r: number; g: number; b: number };
26
+
27
+ private endColor: { r: number; g: number; b: number };
28
+
29
+ private lineWidth: number;
30
+
31
+ private setCanvasHeight(
32
+ containerWidth: number,
33
+ containerHeight: number,
34
+ ): void {
35
+ this.canvas.width = containerWidth * this.devicePixelRatio;
36
+ this.canvas.height = containerHeight * this.devicePixelRatio;
37
+ this.canvas.style.width = `${containerWidth}px`;
38
+ this.canvas.style.height = `${containerHeight}px`;
39
+ }
40
+
41
+ init(parent: View, container = new HTMLElement()): void {
42
+ this.container = container;
43
+ this.parent = parent;
44
+ this.devicePixelRatio = window.devicePixelRatio;
45
+ this.canvas = document.createElement('canvas');
46
+ this.path = [];
47
+ this.context = this.canvas.getContext('2d');
48
+ this.showEndPoints = true;
49
+ // this.forceRender = false;
50
+ this.canvas.style.cssText = `
51
+ pointer-events: none;
52
+ position: absolute;
53
+ top: 0;
54
+ left: 0;
55
+ `;
56
+ const { clientWidth, clientHeight } = this.container;
57
+ this.setCanvasHeight(clientWidth, clientHeight);
58
+ this.container.appendChild(this.canvas);
59
+ this.startColor = { r: 109, g: 150, b: 253 };
60
+ this.endColor = { r: 109, g: 150, b: 253 };
61
+ this.lineWidth = 9;
62
+ }
63
+
64
+ resize(containerWidth: number, containerHeight: number): void {
65
+ this.setCanvasHeight(containerWidth, containerHeight);
66
+ }
67
+
68
+ update(): boolean {
69
+ return false;
70
+ }
71
+
72
+ render(): void {
73
+ if (!this.context) return;
74
+ const widthHalf = this.canvas.width / 2;
75
+ const heightHalf = this.canvas.height / 2;
76
+ const renderPath: [number, number][] = [];
77
+ this.path.forEach((v) => {
78
+ if (!this.parent.camera) return;
79
+ const p = v.clone();
80
+ p.project(this.parent.camera);
81
+ renderPath.push([(p.x + 1) * widthHalf, (1 - p.y) * heightHalf]);
82
+ });
83
+ this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
84
+ if (!renderPath.length) return;
85
+ this.context.lineCap = 'round';
86
+ this.context.lineJoin = 'round';
87
+ const diff = {
88
+ r: this.endColor.r - this.startColor.r,
89
+ g: this.endColor.g - this.startColor.g,
90
+ b: this.endColor.b - this.startColor.b,
91
+ };
92
+ diff.r /= (renderPath.length - 1);
93
+ diff.g /= (renderPath.length - 1);
94
+ diff.b /= (renderPath.length - 1);
95
+ const currentColor = { ...this.startColor };
96
+ this.context.lineWidth = this.lineWidth;
97
+ this.context.beginPath();
98
+ renderPath.forEach((p: [number, number], i: number) => {
99
+ if (!this.context) return;
100
+ if (i === 0) {
101
+ this.context.moveTo(...p);
102
+ } else {
103
+ this.context.lineTo(...p);
104
+ currentColor.r += diff.r;
105
+ currentColor.g += diff.g;
106
+ currentColor.b += diff.b;
107
+ this.context.strokeStyle = `rgb(${currentColor.r}, ${currentColor.g}, ${currentColor.b})`;
108
+ this.context.stroke();
109
+ this.context.beginPath();
110
+ this.context.moveTo(...p);
111
+ }
112
+ });
113
+ if (!this.showEndPoints) return;
114
+ this.context.fillStyle = '#6F8DFF';
115
+ this.context.beginPath();
116
+ this.context.arc(renderPath[0][0], renderPath[0][1], 16, 0, Math.PI * 2);
117
+ this.context.arc(
118
+ renderPath[renderPath.length - 1][0],
119
+ renderPath[renderPath.length - 1][1],
120
+ 16,
121
+ 0,
122
+ Math.PI * 2,
123
+ );
124
+ this.context.fill();
125
+ this.context.fillStyle = '#FFFFFF';
126
+ this.context.strokeStyle = 'none';
127
+ this.context.beginPath();
128
+ this.context.arc(renderPath[0][0], renderPath[0][1], 8, 0, Math.PI * 2);
129
+ this.context.arc(
130
+ renderPath[renderPath.length - 1][0],
131
+ renderPath[renderPath.length - 1][1],
132
+ 8,
133
+ 0,
134
+ Math.PI * 2,
135
+ );
136
+ this.context.fill();
137
+ }
138
+
139
+ setRenderOrder(order: number): void {
140
+ this.canvas.style.setProperty('z-index', `${order}`);
141
+ }
142
+
143
+ dispose(): void {
144
+ if (this.container) this.container.removeChild(this.canvas);
145
+ delete (this as any).canvas; // eslint-disable-line
146
+ }
147
+
148
+ public setPath3D(path: NS_THREE.Vector3[]): void {
149
+ this.path = path;
150
+ this.render();
151
+ }
152
+
153
+ public setEndPointsVisible(value: boolean): void {
154
+ this.showEndPoints = value;
155
+ }
156
+
157
+ public setColors(
158
+ start: { r: number; g: number; b: number },
159
+ end: { r: number; g: number; b: number },
160
+ ): void {
161
+ this.startColor = start;
162
+ this.endColor = end;
163
+ }
164
+
165
+ public setLineWidth(lineWidth: number): void {
166
+ this.lineWidth = lineWidth;
167
+ }
168
+ }
169
+
170
+ export { PathOverlay };