@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,497 @@
1
+ import { Externals, NS_THREE } from '../stage/externals';
2
+ import { DOM2DElement } from './dom-2d-element';
3
+ import { ElementFrameContext } from './element';
4
+ import { Events } from '../utils/events';
5
+
6
+ type AnchorPosition = 'center'|'left'|'right'|'top'|'bottom'|'topleft'|'topright'|'bottomleft'|'bottomright';
7
+
8
+ type TextAttributes = {
9
+ content?: string;
10
+ visible?: boolean;
11
+ fontSize?: number;
12
+ color?: string;
13
+ padding?: { left?: number; right?: number; top?: number; bottom?: number };
14
+ anchor?: AnchorPosition;
15
+ offset?: { x: number; y: number };
16
+ align?: string;
17
+ borderWidth?: number;
18
+ borderColor?: string;
19
+ borderRadius?: number;
20
+ backgroundColor?: string;
21
+ };
22
+
23
+ type ImageAttributes = {
24
+ src?: string;
25
+ visible?: boolean;
26
+ size?: { width: number; height: number };
27
+ anchor?: AnchorPosition;
28
+ offset?: { x: number; y: number };
29
+ }
30
+
31
+ type LabelAttributes = {
32
+ position?: NS_THREE.Vector3;
33
+ visible?: boolean;
34
+ bBoxVisible?: boolean;
35
+ bBoxBorderWidth?: number;
36
+ bBoxBorderColor?: string;
37
+ };
38
+
39
+ /**
40
+ * 2D DOM 标签, 可展示文字与图片
41
+ */
42
+ class DOMLabel2D extends DOM2DElement {
43
+ private static ANCHOR_MAP = {
44
+ center: { x: '-50%', y: '-50%' },
45
+ left: { x: '0', y: '-50%' },
46
+ right: { x: '-100%', y: '-50%' },
47
+ top: { x: '-50%', y: '0' },
48
+ bottom: { x: '-50%', y: '-100%' },
49
+ topleft: { x: '0', y: '0' },
50
+ topright: { x: '-100%', y: '0' },
51
+ bottomleft: { x: '0', y: '-100%' },
52
+ bottomright: { x: '-100%', y: '-100%' },
53
+ };
54
+
55
+ private boundingBox: HTMLDivElement;
56
+
57
+ private textElement: HTMLDivElement;
58
+
59
+ private textPositionInfo: {
60
+ anchor: AnchorPosition;
61
+ offsetX: number;
62
+ offsetY: number;
63
+ }
64
+
65
+ private imageElement: HTMLImageElement;
66
+
67
+ private imagePositionInfo: {
68
+ anchor: AnchorPosition;
69
+ offsetX: number;
70
+ offsetY: number;
71
+ }
72
+
73
+ private calcBBoxNextFrame: boolean;
74
+
75
+ private needCalcBBox: boolean;
76
+
77
+ private listeners: {
78
+ onTouchStart: (e: TouchEvent) => void;
79
+ onTouchMove: (e: TouchEvent) => void;
80
+ onTouchEnd: (e: TouchEvent) => void;
81
+ onMouseDown: (e: PointerEvent) => void;
82
+ onMouseMove: (e: PointerEvent) => void;
83
+ onMouseUp: (e: PointerEvent) => void;
84
+ /* Image Events */
85
+ onImageLoaded: () => void;
86
+ };
87
+
88
+ private status: 'idle' | 'down' | 'move';
89
+
90
+ private mouseStart: NS_THREE.Vector2;
91
+
92
+ private mouseEnd: NS_THREE.Vector2;
93
+
94
+ labelID: number;
95
+
96
+ constructor() {
97
+ super(document.createElement('div')); // this.domElement === wrapper
98
+ const { THREE } = Externals.getInstance();
99
+
100
+ this.boundingBox = document.createElement('div');
101
+ this.textElement = document.createElement('div');
102
+ this.imageElement = document.createElement('img');
103
+
104
+ this.textPositionInfo = { anchor: 'center', offsetX: 0, offsetY: 0 };
105
+ this.imagePositionInfo = { anchor: 'center', offsetX: 0, offsetY: 0 };
106
+
107
+ this.imageElement.setAttribute('draggable', 'false');
108
+
109
+ this.textElement.style.cssText = `
110
+ position: absolute;
111
+ transform: translate(-50%, -50%);
112
+ white-space: nowrap;
113
+ border-style: solid;
114
+ border-width: 0;
115
+ border-color: white;
116
+ line-height: 1.5;
117
+ `;
118
+
119
+ this.imageElement.style.cssText = `
120
+ position: absolute;
121
+ transform: translate(-50%, -50%);
122
+ `;
123
+
124
+ this.boundingBox.style.cssText = `
125
+ position: absolute;
126
+ transform: translate(-50%, -50%);
127
+ display: none;
128
+ border-style: solid;
129
+ border-width: 2px;
130
+ border-color: red;
131
+ border-radius: 4px;
132
+ pointer-events: none;
133
+ `;
134
+
135
+ this.status = 'idle';
136
+
137
+ this.mouseStart = new THREE.Vector2();
138
+ this.mouseEnd = new THREE.Vector2();
139
+
140
+ this.listeners = {
141
+ onImageLoaded: (): void => { this.onImageLoaded(); },
142
+ onMouseDown: (e: PointerEvent): void => { this.onMouseDown(e); },
143
+ onMouseMove: (e: PointerEvent): void => { this.onMouseMove(e); },
144
+ onMouseUp: (e: PointerEvent): void => { this.onMouseUp(e); },
145
+ onTouchStart: (e: TouchEvent): void => { this.onTouchStart(e); },
146
+ onTouchMove: (e: TouchEvent): void => { this.onTouchMove(e); },
147
+ onTouchEnd: (e: TouchEvent): void => { this.onTouchEnd(e); },
148
+ };
149
+ this.registerListeners();
150
+
151
+ this.domElement.appendChild(this.imageElement);
152
+ this.domElement.appendChild(this.textElement);
153
+ this.domElement.appendChild(this.boundingBox);
154
+ this.calcBBoxNextFrame = true;
155
+ }
156
+
157
+ private updateTextTransform(): void {
158
+ const { offsetX, offsetY, anchor } = this.textPositionInfo;
159
+ const { x, y } = DOMLabel2D.ANCHOR_MAP[anchor];
160
+ this.textElement.style.transform = `translate(${x}, ${y}) translate(${offsetX}px, ${offsetY}px)`;
161
+ }
162
+
163
+ private updateImageTransform(): void {
164
+ const { offsetX, offsetY, anchor } = this.imagePositionInfo;
165
+ const { x, y } = DOMLabel2D.ANCHOR_MAP[anchor];
166
+ this.imageElement.style.transform = `translate(${x}, ${y}) translate(${offsetX}px, ${offsetY}px)`;
167
+ }
168
+
169
+ private calcBBox(): void {
170
+ if (!this.visible || this.boundingBox.style.display === 'none') return;
171
+
172
+ const wrapperBoundingRect = this.domElement.getBoundingClientRect();
173
+ const textBoundingRect = this.textElement.getBoundingClientRect();
174
+ const imageBoundingRect = this.imageElement.getBoundingClientRect();
175
+
176
+ const {
177
+ left: textMinX, right: textMaxX, top: textMinY, bottom: textMaxY,
178
+ } = textBoundingRect;
179
+ const {
180
+ left: imageMinX, right: imageMaxX, top: imageMinY, bottom: imageMaxY,
181
+ } = imageBoundingRect;
182
+
183
+ const points = [];
184
+ const { THREE } = Externals.getInstance();
185
+ if (this.textElement.style.display !== 'none') {
186
+ points.push(new THREE.Vector2(textMinX, textMinY));
187
+ points.push(new THREE.Vector2(textMaxX, textMaxY));
188
+ }
189
+ if (this.imageElement.style.display !== 'none') {
190
+ points.push(new THREE.Vector2(imageMinX, imageMinY));
191
+ points.push(new THREE.Vector2(imageMaxX, imageMaxY));
192
+ }
193
+
194
+ let width = 0;
195
+ let height = 0;
196
+ let offsetX = 0;
197
+ let offsetY = 0;
198
+
199
+ if (points.length) {
200
+ const box2 = new THREE.Box2().setFromPoints(points);
201
+ const { x, y } = wrapperBoundingRect;
202
+ width = box2.max.x - box2.min.x + 12;
203
+ height = box2.max.y - box2.min.y + 12;
204
+ offsetX = box2.min.x - x - 6;
205
+ offsetY = box2.min.y - y - 6;
206
+ }
207
+
208
+ this.boundingBox.style.transform = `translate(${offsetX}px, ${offsetY}px)`;
209
+ this.boundingBox.style.width = `${width}px`;
210
+ this.boundingBox.style.height = `${height}px`;
211
+ }
212
+
213
+ /* EventListeners */
214
+
215
+ private registerListeners(): void {
216
+ this.imageElement.addEventListener('load', this.listeners.onImageLoaded);
217
+ this.imageElement.addEventListener('pointerdown', this.listeners.onMouseDown);
218
+ this.imageElement.addEventListener('touchstart', this.listeners.onTouchStart);
219
+ this.imageElement.addEventListener('touchmove', this.listeners.onTouchMove);
220
+ this.imageElement.addEventListener('touchend', this.listeners.onTouchEnd);
221
+ this.textElement.addEventListener('pointerdown', this.listeners.onMouseDown);
222
+ this.textElement.addEventListener('touchstart', this.listeners.onTouchStart);
223
+ this.textElement.addEventListener('touchmove', this.listeners.onTouchMove);
224
+ this.textElement.addEventListener('touchend', this.listeners.onTouchEnd);
225
+ }
226
+
227
+ private unregisterListeners(): void {
228
+ this.imageElement.removeEventListener('load', this.listeners.onImageLoaded);
229
+ this.imageElement.removeEventListener('pointerdown', this.listeners.onMouseDown);
230
+ this.imageElement.removeEventListener('touchstart', this.listeners.onTouchStart);
231
+ this.imageElement.removeEventListener('touchmove', this.listeners.onTouchMove);
232
+ this.imageElement.removeEventListener('touchend', this.listeners.onTouchEnd);
233
+ this.textElement.removeEventListener('pointerdown', this.listeners.onMouseDown);
234
+ this.textElement.removeEventListener('touchstart', this.listeners.onTouchStart);
235
+ this.textElement.removeEventListener('touchmove', this.listeners.onTouchMove);
236
+ this.textElement.removeEventListener('touchend', this.listeners.onTouchEnd);
237
+ }
238
+
239
+ private onImageLoaded(): void {
240
+ if (this.imageElement.style.width === '') {
241
+ this.imageElement.style.width = `${this.imageElement.width}px`;
242
+ }
243
+ if (this.imageElement.style.height === '') {
244
+ this.imageElement.style.height = `${this.imageElement.height}px`;
245
+ }
246
+ this.calcBBoxNextFrame = true;
247
+ }
248
+
249
+ private onMouseDown(e: PointerEvent): void {
250
+ if (this.status !== 'idle' || e.pointerType !== 'mouse' || e.button !== 0) return;
251
+ this.mouseStart.set(e.clientX, e.clientY);
252
+ this.emit(Events.LABEL_DOWN, this, null, 0);
253
+ this.imageElement.ownerDocument!.addEventListener('pointermove', this.listeners.onMouseMove);
254
+ this.imageElement.ownerDocument!.addEventListener('pointerup', this.listeners.onMouseUp);
255
+ this.status = 'down';
256
+ }
257
+
258
+ private onMouseMove(e: PointerEvent): void {
259
+ if (this.status !== 'down' || e.pointerType !== 'mouse' || e.button !== 0) return;
260
+ this.status = 'move';
261
+ }
262
+
263
+ private onMouseUp(e: PointerEvent): void {
264
+ if (this.status === 'idle' || e.pointerType !== 'mouse') return;
265
+ this.mouseEnd.set(e.clientX, e.clientY);
266
+ if (this.status === 'down' || this.mouseStart.distanceToSquared(this.mouseEnd) < 100) {
267
+ this.emit(Events.ELEMENT_SELECTED, this, null, 0);
268
+ }
269
+ this.imageElement.ownerDocument!.removeEventListener('pointermove', this.listeners.onMouseMove);
270
+ this.imageElement.ownerDocument!.removeEventListener('pointerup', this.listeners.onMouseUp);
271
+ this.status = 'idle';
272
+ }
273
+
274
+ private onTouchStart(e: TouchEvent): void {
275
+ if (this.status !== 'idle' || e.touches.length > 1) return;
276
+ this.mouseStart.set(e.touches[0].pageX, e.touches[0].pageY);
277
+ this.emit(Events.LABEL_DOWN, this, null, 0);
278
+ this.status = 'down';
279
+ }
280
+
281
+ private onTouchMove(e: TouchEvent): void {
282
+ if (this.status !== 'down' || e.touches.length > 1) return;
283
+ this.status = 'move';
284
+ }
285
+
286
+ private onTouchEnd(e: TouchEvent): void {
287
+ if (this.status === 'idle') return;
288
+ this.mouseEnd.set(e.changedTouches[0].pageX, e.changedTouches[0].pageY);
289
+ if (this.status === 'down' || this.mouseStart.distanceToSquared(this.mouseEnd) < 100) {
290
+ this.emit(Events.ELEMENT_SELECTED, this, null, 0);
291
+ }
292
+ this.status = 'idle';
293
+ }
294
+
295
+ /* LABEL WRAPPER */
296
+
297
+ public setAttributes({ labelAttrs, imageAttrs, textAttrs }: {
298
+ labelAttrs: LabelAttributes;
299
+ imageAttrs: ImageAttributes;
300
+ textAttrs: TextAttributes;
301
+ }): void {
302
+ if (labelAttrs !== undefined) this.setLabelAttrs(labelAttrs);
303
+ if (imageAttrs !== undefined) this.setImageAttrs(imageAttrs);
304
+ if (textAttrs !== undefined) this.setTextAttrs(textAttrs);
305
+ }
306
+
307
+ public setLabelAttrs(attrs: LabelAttributes): void {
308
+ if (attrs.position !== undefined) this.setPosition(attrs.position);
309
+ if (attrs.visible !== undefined) this.setVisible(attrs.visible);
310
+ if (attrs.bBoxVisible !== undefined) this.setBBoxVisible(attrs.bBoxVisible);
311
+ if (attrs.bBoxBorderWidth !== undefined) this.setBBoxBorderWidth(attrs.bBoxBorderWidth);
312
+ if (attrs.bBoxBorderColor !== undefined) this.setBBoxBorderColor(attrs.bBoxBorderColor);
313
+ }
314
+
315
+ public setPosition(position: NS_THREE.Vector3): void {
316
+ this.position.copy(position);
317
+ this.needUpdate = true;
318
+ }
319
+
320
+ public setVisible(visible: boolean): void {
321
+ this.visible = visible;
322
+ this.cssObject.visible = visible;
323
+ this.needUpdate = true;
324
+ }
325
+
326
+ public setBBoxVisible(visible: boolean): void {
327
+ this.boundingBox.style.display = visible ? 'block' : 'none';
328
+ if (visible) this.calcBBoxNextFrame = true;
329
+ }
330
+
331
+ public setBBoxBorderWidth(width: number): void {
332
+ this.boundingBox.style.borderWidth = `${width}px`;
333
+ }
334
+
335
+ public setBBoxBorderColor(color: string): void {
336
+ this.boundingBox.style.borderColor = color;
337
+ }
338
+
339
+ /* LABEL IMAGE */
340
+
341
+ public setImageAttrs(attrs: ImageAttributes): void {
342
+ if (attrs.src !== undefined) this.setImageSource(attrs.src);
343
+ if (attrs.visible !== undefined) this.setImageVisible(attrs.visible);
344
+ if (attrs.size !== undefined) this.setImageSize(attrs.size.width, attrs.size.height);
345
+ if (attrs.anchor !== undefined) this.setImageAnchor(attrs.anchor);
346
+ if (attrs.offset !== undefined) this.setImageOffset(attrs.offset.x, attrs.offset.y);
347
+ }
348
+
349
+ public setImageVisible(visible: boolean): void {
350
+ this.imageElement.style.display = visible ? 'block' : 'none';
351
+ }
352
+
353
+ public setImageSource(src: string): void {
354
+ this.imageElement.src = src;
355
+ }
356
+
357
+ public setImageSize(width: number, height: number): void {
358
+ this.imageElement.style.height = `${height}px`;
359
+ this.imageElement.style.width = `${width}px`;
360
+ this.calcBBoxNextFrame = true;
361
+ }
362
+
363
+ public setImageAnchor(anchor: AnchorPosition): void {
364
+ this.imagePositionInfo.anchor = anchor;
365
+ this.updateImageTransform();
366
+ this.calcBBoxNextFrame = true;
367
+ }
368
+
369
+ public setImageOffset(offsetX: number, offsetY: number): void {
370
+ this.imagePositionInfo.offsetX = offsetX;
371
+ this.imagePositionInfo.offsetY = offsetY;
372
+ this.updateImageTransform();
373
+ this.calcBBoxNextFrame = true;
374
+ }
375
+
376
+ /* LABEL TEXT */
377
+
378
+ public setTextAttrs(attrs: TextAttributes): void {
379
+ if (attrs.content !== undefined) this.setTextContent(attrs.content);
380
+ if (attrs.visible !== undefined) this.setTextVisible(attrs.visible);
381
+ if (attrs.fontSize !== undefined) this.setTextFontSize(attrs.fontSize);
382
+ if (attrs.color !== undefined) this.setTextColor(attrs.color);
383
+ if (attrs.padding !== undefined) this.setTextPadding(attrs.padding);
384
+ if (attrs.anchor !== undefined) this.setTextAnchor(attrs.anchor);
385
+ if (attrs.offset !== undefined) this.setTextOffset(attrs.offset.x, attrs.offset.y);
386
+ if (attrs.align !== undefined) this.setTextAlign(attrs.align);
387
+ if (attrs.borderWidth !== undefined) this.setTextBorderWidth(attrs.borderWidth);
388
+ if (attrs.borderColor !== undefined) this.setTextBorderColor(attrs.borderColor);
389
+ if (attrs.borderRadius !== undefined) this.setTextBorderRadius(attrs.borderRadius);
390
+ if (attrs.backgroundColor !== undefined) this.setTextBackgroundColor(attrs.backgroundColor);
391
+ }
392
+
393
+ public setTextVisible(visible: boolean): void {
394
+ this.textElement.style.display = visible ? 'block' : 'none';
395
+ this.calcBBoxNextFrame = true;
396
+ }
397
+
398
+ public setTextContent(text: string): void {
399
+ this.textElement.innerText = text;
400
+ this.calcBBoxNextFrame = true;
401
+ }
402
+
403
+ public setTextFontSize(size: number): void {
404
+ this.textElement.style.fontSize = `${size}px`;
405
+ this.calcBBoxNextFrame = true;
406
+ }
407
+
408
+ public setTextColor(color: string): void {
409
+ this.textElement.style.color = color;
410
+ }
411
+
412
+ public setTextPadding(padding: { left?: number; right?: number; top?: number; bottom?: number }): void {
413
+ const targetPadding = {
414
+ left: 0, right: 0, top: 0, bottom: 0,
415
+ };
416
+
417
+ if (padding.left !== undefined) targetPadding.left = padding.left;
418
+ if (padding.right !== undefined) targetPadding.right = padding.right;
419
+ if (padding.top !== undefined) targetPadding.top = padding.top;
420
+ if (padding.bottom !== undefined) targetPadding.bottom = padding.bottom;
421
+
422
+ const {
423
+ left, right, top, bottom,
424
+ } = targetPadding;
425
+
426
+ this.textElement.style.padding = `${top}px ${right}px ${bottom}px ${left}px`;
427
+ this.calcBBoxNextFrame = true;
428
+ }
429
+
430
+ public setTextAnchor(anchor: AnchorPosition): void {
431
+ this.textPositionInfo.anchor = anchor;
432
+ this.updateTextTransform();
433
+ this.calcBBoxNextFrame = true;
434
+ }
435
+
436
+ public setTextOffset(offsetX: number, offsetY: number): void {
437
+ this.textPositionInfo.offsetX = offsetX;
438
+ this.textPositionInfo.offsetY = offsetY;
439
+ this.updateTextTransform();
440
+ this.calcBBoxNextFrame = true;
441
+ }
442
+
443
+ public setTextBorderWidth(width: number): void {
444
+ this.textElement.style.borderWidth = `${width}px`;
445
+ this.calcBBoxNextFrame = true;
446
+ }
447
+
448
+ public setTextAlign(align: string): void {
449
+ this.textElement.style.textAlign = align;
450
+ }
451
+
452
+ public setTextBorderColor(color: string): void {
453
+ this.textElement.style.borderColor = color;
454
+ }
455
+
456
+ public setTextBorderRadius(radius: number): void {
457
+ this.textElement.style.borderRadius = `${radius}px`;
458
+ }
459
+
460
+ public setTextBackgroundColor(color: string): void {
461
+ this.textElement.style.backgroundColor = color;
462
+ }
463
+
464
+ public setLabelID(labelID: number): void {
465
+ this.labelID = labelID;
466
+ }
467
+
468
+ update(): ElementFrameContext {
469
+ const frameContext = new ElementFrameContext(this);
470
+
471
+ if (this.needCalcBBox) this.calcBBox();
472
+ this.needCalcBBox = false;
473
+
474
+ if (this.calcBBoxNextFrame) this.needCalcBBox = true;
475
+ this.calcBBoxNextFrame = false;
476
+
477
+ if (this.initialzed) {
478
+ frameContext.shouldPlaceElement = true;
479
+ this.initialzed = false;
480
+ }
481
+ if (this.needUpdate) {
482
+ frameContext.needUpdate = true;
483
+ this.needUpdate = false;
484
+ }
485
+ return frameContext;
486
+ }
487
+
488
+ dispose(): void {
489
+ this.unregisterListeners();
490
+ this.domElement.removeChild(this.boundingBox);
491
+ this.domElement.removeChild(this.textElement);
492
+ this.domElement.removeChild(this.imageElement);
493
+ super.dispose();
494
+ }
495
+ }
496
+
497
+ export { DOMLabel2D };
@@ -0,0 +1,117 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+ import { EventHub } from '../utils/event-hub';
3
+ import { OwllyEvents, Events } from '../utils/events';
4
+
5
+ /** @ignore */
6
+ class ElementFrameContext {
7
+ element: Element;
8
+
9
+ needUpdate: boolean;
10
+
11
+ shouldPlaceElement: boolean;
12
+
13
+ constructor(
14
+ element: Element,
15
+ needsUpdate = false,
16
+ ) {
17
+ this.element = element;
18
+ this.needUpdate = needsUpdate;
19
+ this.shouldPlaceElement = false;
20
+ }
21
+ }
22
+
23
+ /** 元素类 */
24
+ abstract class Element extends NS_THREE.Object3D {
25
+ /** @ignore */
26
+ public abstract update(): ElementFrameContext;
27
+
28
+ private universalId?: string;
29
+
30
+ private elementListeners: {
31
+ onElementSelected: Function;
32
+ };
33
+
34
+ protected eventMap: Map<string, Set<Function>>;
35
+
36
+ constructor() {
37
+ super();
38
+ this.elementListeners = {
39
+ onElementSelected: this.onElementSelected.bind(this),
40
+ };
41
+ this.eventMap = new Map<string, Set<Function>>();
42
+ EventHub.on(OwllyEvents.ELEMENT_SELECTED, this.elementListeners.onElementSelected);
43
+ }
44
+
45
+ private onElementSelected(e: Element): void {
46
+ if (e === this) EventHub.emit(Events.ELEMENT_SELECTED, e);
47
+ }
48
+
49
+ /**
50
+ * 获取元素的uuid
51
+ */
52
+ public getUUID(): string | undefined {
53
+ return this.universalId;
54
+ }
55
+
56
+ /**
57
+ * 设置元素的uuid
58
+ * @param uuid 配置的uuid
59
+ */
60
+ public setUUID(uuid: string): void {
61
+ this.universalId = uuid;
62
+ }
63
+
64
+ public dispose(): void {
65
+ EventHub.off(OwllyEvents.ELEMENT_SELECTED, this.elementListeners.onElementSelected);
66
+ }
67
+
68
+ /**
69
+ * 注册事件监听
70
+ * @param event 事件名
71
+ * @param callback 回调函数
72
+ */
73
+ on(event: string, callback: Function): void {
74
+ if (!this.eventMap.has(event)) this.eventMap.set(event, new Set<Function>());
75
+ const callbacks = this.eventMap.get(event);
76
+ if (callbacks) {
77
+ callbacks.add(callback);
78
+ this.eventMap.set(
79
+ event,
80
+ callbacks,
81
+ );
82
+ }
83
+ }
84
+
85
+ protected emit(event: string, ...args: unknown[]): void {
86
+ const callbacks = this.eventMap.get(event);
87
+ if (callbacks) {
88
+ callbacks.forEach((callback) => { callback(...args); });
89
+ }
90
+ EventHub.emit(event, ...args);
91
+ }
92
+
93
+ /**
94
+ * 注销事件监听
95
+ * @param event 事件名
96
+ * @param callback 回调函数
97
+ */
98
+ off(event: string, callback: Function): void {
99
+ const callbacks = this.eventMap.get(event);
100
+ if (!callbacks) throw Error(`Target event '${event}' not found`);
101
+ callbacks.delete(callback);
102
+ }
103
+ }
104
+
105
+ interface Element {
106
+ /** 可碰撞成员元素 */
107
+ intersectables?: NS_THREE.Object3D[];
108
+ /**
109
+ * 加载数据
110
+ * @param args 加载数据所需要的参数
111
+ */
112
+ load?(...args: unknown[]): unknown;
113
+ resize?(width: number, height: number): void;
114
+ render?(): void;
115
+ }
116
+
117
+ export { Element, ElementFrameContext };