@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,64 @@
1
+ import { Externals } from '../stage/externals';
2
+ class AlignmentUtils {
3
+ /**
4
+ * 获取2d与3d之间的对齐参数
5
+ * @param view 基准视图
6
+ * @param baseImageScale 底图缩放等级, 绝对值
7
+ * @param offset 底图整体偏移, 结构为 [ number, number ], 对应x, y轴偏移值
8
+ * @param imageSize 底图图片尺寸, 结构为 [ number, number ], 对应宽度, 高度
9
+ * @returns { upTrans: number[]; downTrans: number[]; matrixWorld: number[]; } 三个矩阵,
10
+ * uptrans: 2d转3d, downTrans: 3d转2d, matrixWorld: 相机自身参数, 重设时使用
11
+ */
12
+ static getTransformMatrices(view, baseImageScale, offset, imageSize) {
13
+ if (!view.camera || !view.renderer)
14
+ throw new Error('Cannot find Camera or Renderer object in view');
15
+ const c = view.camera;
16
+ const r = view.renderer;
17
+ const { THREE } = Externals.getInstance();
18
+ const raycaster = new THREE.Raycaster();
19
+ raycaster.setFromCamera({ x: -1, y: -1 }, c);
20
+ const from = raycaster.ray.origin.clone().x;
21
+ raycaster.setFromCamera({ x: 1, y: 1 }, c);
22
+ const to = raycaster.ray.origin.clone().x;
23
+ const ratio = Math.abs(to - from) / r.domElement.clientWidth * baseImageScale; // * r.getPixelRatio()
24
+ const camera = new THREE.Camera();
25
+ const rotation = new THREE.Euler().setFromQuaternion(c.quaternion.clone()).z;
26
+ const offsetX = ratio * (offset[0] * Math.cos(rotation) + offset[1] * Math.sin(rotation));
27
+ const offsetY = ratio * (-offset[0] * Math.sin(rotation) + offset[1] * Math.cos(rotation));
28
+ camera.copy(c);
29
+ camera.position.add(new THREE.Vector3(offsetX, -offsetY, 0));
30
+ camera.updateMatrixWorld();
31
+ const preScaleMatrix = new THREE.Matrix4();
32
+ const preScaleArray = new Array(16).fill(0);
33
+ preScaleArray[0] = 1 / baseImageScale;
34
+ preScaleArray[5] = 1 / baseImageScale;
35
+ preScaleArray[10] = 1;
36
+ preScaleArray[15] = 1;
37
+ preScaleMatrix.fromArray(preScaleArray);
38
+ const postTransformMatrix = new THREE.Matrix4();
39
+ const postTransformArray = new Array(16).fill(0);
40
+ postTransformArray[0] = imageSize[0] / 2;
41
+ postTransformArray[5] = -imageSize[1] / 2;
42
+ postTransformArray[10] = 1;
43
+ postTransformArray[12] = imageSize[0] / 2;
44
+ postTransformArray[13] = imageSize[1] / 2;
45
+ postTransformArray[15] = 1;
46
+ postTransformMatrix.fromArray(postTransformArray);
47
+ const downTransOrigin = camera.projectionMatrix.clone()
48
+ .multiply(preScaleMatrix)
49
+ .multiply(camera.matrixWorldInverse);
50
+ const upTransOrigin = downTransOrigin.clone().invert();
51
+ const downTrans = postTransformMatrix.clone().multiply(downTransOrigin);
52
+ const upTrans = downTrans.clone().invert();
53
+ const matrixWorld = camera.matrixWorld.elements.slice();
54
+ return {
55
+ upTransOrigin: upTransOrigin.elements.slice(),
56
+ downTransOrigin: downTransOrigin.elements.slice(),
57
+ upTrans: upTrans.elements.slice(),
58
+ downTrans: downTrans.elements.slice(),
59
+ matrixWorld,
60
+ };
61
+ }
62
+ }
63
+ export { AlignmentUtils };
64
+ //# sourceMappingURL=alignment-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alignment-utils.js","sourceRoot":"","sources":["../../../../src/owlly/utils/alignment-utils.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ interface Coord2d {
2
+ x: number;
3
+ y: number;
4
+ }
5
+ interface TurningInfo {
6
+ point: number[];
7
+ angle: number;
8
+ startTPoint: number[];
9
+ endTPoint: number[];
10
+ startIndex: number;
11
+ endIndex: number;
12
+ }
13
+ declare class BasicCalcTool {
14
+ static getLineCross(line1_p1: Coord2d, line1_p2: Coord2d, line2_p1: Coord2d, line2_p2: Coord2d): boolean;
15
+ static calcTurning(linePoints: [number, number][], turningStandard?: number[]): TurningInfo[];
16
+ static chunk(items: any[], size: number): any[][];
17
+ }
18
+ export { BasicCalcTool, TurningInfo };
@@ -0,0 +1,130 @@
1
+ /* eslint-disable @typescript-eslint/camelcase */
2
+ class BasicCalcTool {
3
+ static getLineCross(line1_p1, line1_p2, line2_p1, line2_p2) {
4
+ // step1 利用投影快速排斥
5
+ const ifL2R = Math.min(line2_p1.x, line2_p2.x) > Math.max(line1_p1.x, line1_p2.x);
6
+ const ifL2T = Math.min(line2_p1.y, line2_p2.y) > Math.max(line1_p1.y, line1_p2.y);
7
+ const ifL1R = Math.min(line1_p1.x, line1_p2.x) > Math.max(line2_p1.x, line2_p2.x);
8
+ const ifL1T = Math.min(line1_p1.y, line1_p2.y) > Math.max(line2_p1.y, line2_p2.y);
9
+ if (ifL2R || ifL2T || ifL1R || ifL1T)
10
+ return false;
11
+ // step2 投影快速排斥不成立 证明两个点分别在一条直线的两边
12
+ const crossMul = (v1, v2) => v1.x * v2.y - v1.y * v2.x;
13
+ // eslint-disable-next-line no-shadow
14
+ const checkCross = (line1_p1, line1_p2, line2_p1, line2_p2) => {
15
+ let v1 = { x: line1_p1.x - line2_p1.x, y: line2_p1.y - line1_p1.y };
16
+ let v2 = { x: line1_p2.x - line2_p1.x, y: line1_p2.y - line2_p1.y };
17
+ let v3 = { x: line2_p2.x - line2_p1.x, y: line2_p2.y - line2_p1.y };
18
+ const v = crossMul(v1, v3) * crossMul(v2, v3);
19
+ v1 = { x: line2_p1.x - line1_p1.x, y: line2_p1.y - line1_p1.y };
20
+ v2 = { x: line2_p2.x - line1_p1.x, y: line2_p2.y - line1_p1.y };
21
+ v3 = { x: line1_p2.x - line1_p1.x, y: line1_p2.y - line1_p1.y };
22
+ return !!((v <= 0 && crossMul(v1, v3) * crossMul(v2, v3) <= 0));
23
+ };
24
+ const ifCross = checkCross(line1_p1, line1_p2, line2_p1, line2_p2);
25
+ return ifCross;
26
+ }
27
+ // 拐角范围内的判定为 [2, 20] [340, 358] 平滑后的路径角度在此范围内, 未经平滑的路径返回 []
28
+ static calcTurning(linePoints, turningStandard = [2, 20]) {
29
+ const len = linePoints.length;
30
+ if (len < 2)
31
+ return [];
32
+ const crds = [];
33
+ const getAngle = (p1, p2) => {
34
+ const { x: x1, y: y1 } = p1;
35
+ const { x: x2, y: y2 } = p2;
36
+ const dot = x1 * x2 + y1 * y2;
37
+ const det = x1 * y2 - y1 * x2;
38
+ const angle = Math.atan2(det, dot) / Math.PI * 180;
39
+ return Math.round(angle + 360) % 360;
40
+ };
41
+ let isCrossing = false;
42
+ let curAngle = 0;
43
+ let curPoint = [0, 0];
44
+ let startTPoint = [0, 0];
45
+ let endTPoint = [0, 0];
46
+ let startIndex = 0;
47
+ let endIndex = 0;
48
+ // 经过平滑处理的线, 一个夹角90度可能由n个小夹角组成
49
+ for (let i = 1; i < len - 1; i++) {
50
+ const prev = linePoints[i - 1];
51
+ const cur = linePoints[i];
52
+ const next = linePoints[i + 1];
53
+ const angle = getAngle({
54
+ x: next[0] - cur[0],
55
+ y: next[1] - cur[1],
56
+ }, {
57
+ x: cur[0] - prev[0],
58
+ y: cur[1] - prev[1],
59
+ });
60
+ const isAngleWithinStand = (angle >= turningStandard[0] && angle <= turningStandard[1])
61
+ || (angle >= (360 - turningStandard[1]) && angle <= (360 - turningStandard[0]));
62
+ if (!isCrossing && isAngleWithinStand) { // 首次进入夹角
63
+ isCrossing = true;
64
+ startTPoint = cur;
65
+ curAngle += angle;
66
+ startIndex = i;
67
+ }
68
+ else if (isCrossing && isAngleWithinStand) { // 夹角中并夹角依然在增大
69
+ curAngle += angle;
70
+ }
71
+ else if (isCrossing && !isAngleWithinStand) { // 夹角中并夹角停止增大趋势
72
+ curAngle += angle;
73
+ endIndex = i;
74
+ endTPoint = cur;
75
+ // curPoint 取 夹角范围内最靠近中心的点
76
+ curPoint = [
77
+ (startTPoint[0] + endTPoint[0]) / 2,
78
+ (startTPoint[1] + endTPoint[1]) / 2,
79
+ ];
80
+ crds.push({
81
+ point: curPoint,
82
+ angle: curAngle % 360,
83
+ startTPoint,
84
+ endTPoint,
85
+ startIndex,
86
+ endIndex,
87
+ });
88
+ isCrossing = false;
89
+ }
90
+ else if (!isCrossing && !isAngleWithinStand) { // 直行中
91
+ startIndex = endIndex = 0;
92
+ curAngle = 0;
93
+ curPoint = [0, 0];
94
+ startTPoint = [0, 0];
95
+ endTPoint = [0, 0];
96
+ }
97
+ }
98
+ // 最后一个点依然在拐角内
99
+ if (isCrossing) {
100
+ endTPoint = linePoints[len - 1];
101
+ curPoint = [
102
+ (startTPoint[0] + endTPoint[0]) / 2,
103
+ (startTPoint[1] + endTPoint[1]) / 2,
104
+ ];
105
+ crds.push({
106
+ point: curPoint,
107
+ angle: curAngle % 360,
108
+ startTPoint,
109
+ endTPoint,
110
+ startIndex,
111
+ endIndex,
112
+ });
113
+ isCrossing = false;
114
+ }
115
+ return crds;
116
+ }
117
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
118
+ static chunk(items, size) {
119
+ if (items.length <= 0 || size <= 0) {
120
+ return items;
121
+ }
122
+ const chunks = [];
123
+ for (let i = 0; i < items.length; i += size) {
124
+ chunks.push(items.slice(i, i + size));
125
+ }
126
+ return chunks;
127
+ }
128
+ }
129
+ export { BasicCalcTool };
130
+ //# sourceMappingURL=basic-calc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"basic-calc.js","sourceRoot":"","sources":["../../../../src/owlly/utils/basic-calc.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,71 @@
1
+ import { NS_THREE } from '../stage/externals';
2
+ import { Element } from '../element/element';
3
+ import { View } from '../view/view';
4
+ declare class BasicTools {
5
+ /**
6
+ * 销毁工具
7
+ * @param o 对象
8
+ * @param recursive 递归销毁
9
+ */
10
+ static dispose(o: NS_THREE.Object3D, recursive?: boolean): void;
11
+ /**
12
+ * 鼠标碰撞工具函数
13
+ * @param objects 需要检测碰撞的 Element
14
+ * @param param1 鼠标点击坐标
15
+ * @param camera 使用的相机
16
+ * @param candidates 候选者, candidate 存在于 object 中
17
+ * @param maxWorldDistance 世界中点击时的距离
18
+ * @returns 碰撞对象
19
+ */
20
+ static getMouseIntersection(objects: Element[], { x, y }: {
21
+ x: number;
22
+ y: number;
23
+ }, camera: NS_THREE.Camera, candidates?: Element[], maxWorldDistance?: number): NS_THREE.Intersection | null;
24
+ /**
25
+ * 获取屏幕空间的点击碰撞
26
+ * @param objects 需要检查的对象
27
+ * @param param1 点击坐标
28
+ * @param param2 屏幕尺寸
29
+ * @param maxDistance 最大检测距离
30
+ * @param camera 相机
31
+ * @param candidates 候选对象, 可能在 object 内
32
+ * @param maxWorldDistance 最大世界空间坐标检测距离
33
+ * @param boundingBoxes 候选的碰撞盒, 可选
34
+ * @returns 碰撞到的对象
35
+ */
36
+ static getMouseIntersectionOnScreen(objects: NS_THREE.Object3D[] | Element[], { x, y }: {
37
+ x: number;
38
+ y: number;
39
+ }, { screenWidth, screenHeight }: {
40
+ screenWidth: number;
41
+ screenHeight: number;
42
+ }, maxDistance: number, camera: NS_THREE.Camera, candidates?: NS_THREE.Object3D[] | Element[], maxWorldDistance?: number, boundingBoxes?: Map<NS_THREE.Object3D | Element, [number, number]>): NS_THREE.Object3D | Element | null;
43
+ /**
44
+ * 转换俯视图屏幕坐标为三维坐标
45
+ * @param {x, y} 屏幕坐标
46
+ * @param view 视图
47
+ * @param camera 相机
48
+ */
49
+ static getHorizontalPlaneCoordinate({ x, y }: {
50
+ x: number;
51
+ y: number;
52
+ }, view: View, camera: NS_THREE.Camera | undefined): NS_THREE.Vector2 | null;
53
+ static getHorizontalPlaneCoordinate3({ x, y }: {
54
+ x: number;
55
+ y: number;
56
+ }, view: View, camera: NS_THREE.Camera | undefined): NS_THREE.Vector3 | null;
57
+ /**
58
+ * 将坐标投影到屏幕空间
59
+ * @param position 世界坐标
60
+ * @param view 视图
61
+ * @param camera 相机
62
+ * @returns 转换后的屏幕坐标
63
+ */
64
+ static projectToScreenCoordinate(position: NS_THREE.Vector3, view: View, camera: NS_THREE.Camera | undefined): {
65
+ x: number;
66
+ y: number;
67
+ } | null;
68
+ private static getMesh;
69
+ static debounce(fn: Function, delay: number): Function;
70
+ }
71
+ export { BasicTools };
@@ -0,0 +1,236 @@
1
+ import { Externals } from '../stage/externals';
2
+ import { Element } from '../element/element';
3
+ class BasicTools {
4
+ /**
5
+ * 销毁工具
6
+ * @param o 对象
7
+ * @param recursive 递归销毁
8
+ */
9
+ static dispose(o, recursive) {
10
+ if (recursive && o.children && o.children.length) {
11
+ o.children.forEach((child) => {
12
+ BasicTools.dispose(child, recursive);
13
+ });
14
+ }
15
+ if (o.isMesh) {
16
+ const m = o;
17
+ if (m.geometry)
18
+ m.geometry.dispose();
19
+ if (m.material) {
20
+ if (Array.isArray(m.material)) {
21
+ m.material.forEach((mat) => {
22
+ mat.dispose();
23
+ });
24
+ }
25
+ else {
26
+ m.material.dispose();
27
+ }
28
+ }
29
+ }
30
+ }
31
+ /**
32
+ * 鼠标碰撞工具函数
33
+ * @param objects 需要检测碰撞的 Element
34
+ * @param param1 鼠标点击坐标
35
+ * @param camera 使用的相机
36
+ * @param candidates 候选者, candidate 存在于 object 中
37
+ * @param maxWorldDistance 世界中点击时的距离
38
+ * @returns 碰撞对象
39
+ */
40
+ static getMouseIntersection(objects, { x, y }, camera, candidates, maxWorldDistance = -1) {
41
+ const { THREE } = Externals.getInstance();
42
+ const maxWorldDistanceSquared = maxWorldDistance < 0 ? Number.MAX_SAFE_INTEGER : Math.pow(maxWorldDistance, 2);
43
+ const rayCaster = new THREE.Raycaster();
44
+ rayCaster.setFromCamera({ x, y }, camera);
45
+ const cameraPosition = camera.position.clone();
46
+ const filteredObjects = objects.filter((o) => o.visible
47
+ && cameraPosition.distanceToSquared(o.getWorldPosition(new THREE.Vector3())) < maxWorldDistanceSquared);
48
+ const intersections = rayCaster.intersectObjects(filteredObjects, true).filter((i) => (!!i.face));
49
+ const candidateSet = new Set(candidates);
50
+ for (let i = 0; i < intersections.length; i++) {
51
+ let target = intersections[i].object;
52
+ const parentElements = [];
53
+ while (!(target instanceof Element) && target.parent)
54
+ target = target.parent;
55
+ while (target) {
56
+ if (target instanceof Element) {
57
+ parentElements.push(target);
58
+ }
59
+ if (!target.parent)
60
+ break;
61
+ target = target.parent;
62
+ }
63
+ for (let j = 0; j < parentElements.length; j++) {
64
+ if (parentElements[j] instanceof Element) {
65
+ if (candidates) {
66
+ if (candidateSet.has(parentElements[j])) {
67
+ const ret = intersections[i];
68
+ ret.object = parentElements[j];
69
+ return ret;
70
+ }
71
+ }
72
+ else {
73
+ const ret = intersections[i];
74
+ ret.object = parentElements[j];
75
+ return ret;
76
+ }
77
+ }
78
+ }
79
+ }
80
+ return null;
81
+ }
82
+ /**
83
+ * 获取屏幕空间的点击碰撞
84
+ * @param objects 需要检查的对象
85
+ * @param param1 点击坐标
86
+ * @param param2 屏幕尺寸
87
+ * @param maxDistance 最大检测距离
88
+ * @param camera 相机
89
+ * @param candidates 候选对象, 可能在 object 内
90
+ * @param maxWorldDistance 最大世界空间坐标检测距离
91
+ * @param boundingBoxes 候选的碰撞盒, 可选
92
+ * @returns 碰撞到的对象
93
+ */
94
+ static getMouseIntersectionOnScreen(objects, { x, y }, { screenWidth, screenHeight }, maxDistance, camera, candidates, maxWorldDistance = 13, boundingBoxes) {
95
+ const { THREE } = Externals.getInstance();
96
+ const intersections = [];
97
+ const screenPoint = new THREE.Vector2(x, y);
98
+ const frustum = new THREE.Frustum();
99
+ frustum.setFromProjectionMatrix(new THREE.Matrix4().multiplyMatrices(camera.projectionMatrix, camera.matrixWorldInverse));
100
+ const cameraPos = camera.position.clone();
101
+ const maxWorldDistanceSquared = maxWorldDistance < 0 ? Number.MAX_SAFE_INTEGER : Math.pow(maxWorldDistance, 2);
102
+ objects.forEach((obj) => {
103
+ const v3 = obj.position.clone().project(camera);
104
+ const dist = new THREE.Vector2((v3.x + 1) / 2 * screenWidth, (1 - v3.y) / 2 * screenHeight).distanceTo(screenPoint);
105
+ const mesh = this.getMesh(obj);
106
+ if (!mesh)
107
+ return;
108
+ let hasBoundingBox = false;
109
+ let bboxCollision = false;
110
+ if (boundingBoxes) {
111
+ const value = boundingBoxes.get(obj);
112
+ if (value) {
113
+ hasBoundingBox = true;
114
+ const center = new THREE.Vector2((v3.x + 1) / 2 * screenWidth, (1 - v3.y) / 2 * screenHeight);
115
+ const leftX = center.x - value[0] / 2;
116
+ const rightX = center.x + value[0] / 2;
117
+ const topY = center.y - value[1] / 2;
118
+ const bottomY = center.y + value[1] / 2;
119
+ if (Math.abs(v3.z) <= 1
120
+ && screenPoint.x <= rightX && screenPoint.x >= leftX
121
+ && screenPoint.y >= topY && screenPoint.y <= bottomY) {
122
+ bboxCollision = true;
123
+ }
124
+ }
125
+ }
126
+ if ((hasBoundingBox ? bboxCollision : dist <= maxDistance)
127
+ && cameraPos.distanceToSquared(mesh.getWorldPosition(new THREE.Vector3())) < maxWorldDistanceSquared
128
+ && frustum.intersectsObject(mesh)
129
+ && mesh.visible
130
+ && obj.visible) {
131
+ intersections.push({
132
+ e: obj,
133
+ d: dist,
134
+ });
135
+ }
136
+ });
137
+ intersections.sort((a, b) => a.d - b.d);
138
+ const candidateSet = new Set(candidates);
139
+ for (let i = 0; i < intersections.length; i++) {
140
+ const target = intersections[i].e;
141
+ if (candidates) {
142
+ if (candidateSet.has(target))
143
+ return target;
144
+ }
145
+ else
146
+ return target;
147
+ }
148
+ return null;
149
+ }
150
+ /**
151
+ * 转换俯视图屏幕坐标为三维坐标
152
+ * @param {x, y} 屏幕坐标
153
+ * @param view 视图
154
+ * @param camera 相机
155
+ */
156
+ static getHorizontalPlaneCoordinate({ x, y }, view, camera) {
157
+ if (!camera) {
158
+ return null;
159
+ }
160
+ const { THREE } = Externals.getInstance();
161
+ const { clientWidth, clientHeight } = view.renderer.domElement;
162
+ if (clientWidth <= 0 || clientHeight <= 0) {
163
+ return null;
164
+ }
165
+ const nx = x / clientWidth * 2 - 1;
166
+ const ny = 1 - y / clientHeight * 2;
167
+ const v = new THREE.Vector3(nx, ny, 0);
168
+ const coordinate3 = v.unproject(camera);
169
+ return new THREE.Vector2(coordinate3.x, coordinate3.y);
170
+ }
171
+ static getHorizontalPlaneCoordinate3({ x, y }, view, camera) {
172
+ if (!camera) {
173
+ return null;
174
+ }
175
+ const { THREE } = Externals.getInstance();
176
+ const { clientWidth, clientHeight } = view.renderer.domElement;
177
+ if (clientWidth <= 0 || clientHeight <= 0) {
178
+ return null;
179
+ }
180
+ const nx = x / clientWidth * 2 - 1;
181
+ const ny = 1 - y / clientHeight * 2;
182
+ const v = new THREE.Vector3(nx, ny, 0);
183
+ const coordinate3 = v.unproject(camera);
184
+ return coordinate3;
185
+ }
186
+ /**
187
+ * 将坐标投影到屏幕空间
188
+ * @param position 世界坐标
189
+ * @param view 视图
190
+ * @param camera 相机
191
+ * @returns 转换后的屏幕坐标
192
+ */
193
+ static projectToScreenCoordinate(position, view, camera) {
194
+ if (!camera) {
195
+ return null;
196
+ }
197
+ const { clientWidth, clientHeight } = view.renderer.domElement;
198
+ if (clientWidth <= 0 || clientHeight <= 0) {
199
+ return null;
200
+ }
201
+ const coordinate2 = position.clone().project(camera);
202
+ const x = (coordinate2.x + 1) * 0.5 * clientWidth;
203
+ const y = (1 - coordinate2.y) * 0.5 * clientHeight;
204
+ return { x, y };
205
+ }
206
+ static getMesh(obj) {
207
+ const { THREE } = Externals.getInstance();
208
+ const target = obj instanceof THREE.Mesh ? obj : null;
209
+ if (!target && obj.children.length) {
210
+ for (let i = 0; i < obj.children.length; i += 1) {
211
+ const t = this.getMesh(obj.children[i]);
212
+ if (t)
213
+ return t;
214
+ }
215
+ }
216
+ return target;
217
+ }
218
+ static debounce(fn, delay) {
219
+ let timer;
220
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
221
+ return function debounceFn(force, ...args) {
222
+ if (force) {
223
+ fn.bind(null, ...args);
224
+ }
225
+ if (timer) {
226
+ clearTimeout(timer);
227
+ timer = setTimeout(fn.bind(null, ...args), delay);
228
+ }
229
+ else {
230
+ timer = setTimeout(fn.bind(null, ...args), delay);
231
+ }
232
+ };
233
+ }
234
+ }
235
+ export { BasicTools };
236
+ //# sourceMappingURL=basic-tools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"basic-tools.js","sourceRoot":"","sources":["../../../../src/owlly/utils/basic-tools.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,105 @@
1
+ /**
2
+ * bvh-tree
3
+ * A Bounding Volume Hierarchy data structure implementation.
4
+ * https://github.com/benraziel/bvh-tree
5
+ *
6
+ * 该文件是外部引入的类, 用于创建 FloorModel 的 BVH 树
7
+ *
8
+ * @author Ben Raziel
9
+ * @ignore
10
+ */
11
+ import { NS_THREE } from '../stage/externals';
12
+ interface IntersectResult {
13
+ triangle?: NS_THREE.Vector3[];
14
+ triangleIndex?: number;
15
+ intersectionPoint: NS_THREE.Vector3;
16
+ }
17
+ /**
18
+ * A node in the [[BVHTree]] structure
19
+ *
20
+ */
21
+ declare class BVHNode {
22
+ extentsMin: NS_THREE.Vector3;
23
+ extentsMax: NS_THREE.Vector3;
24
+ startIndex: number;
25
+ endIndex: number;
26
+ level: number;
27
+ node0: BVHNode | null;
28
+ node1: BVHNode | null;
29
+ /**
30
+ * Constructor of BVHNode
31
+ * @param {Point} extentsMin the min coords of this node's bounding box ({x,y,z})
32
+ * @param {Point} extentsMax the max coords of this node's bounding box ({x,y,z})
33
+ * @param {number} startIndex an index in the bbox array, where the first element of this node is located
34
+ * @param {number} endIndex an index in the bbox array, where the last of this node is located,
35
+ * plus 1 (meaning that its non-inclusive).
36
+ * @param {number} the distance of this node from the root for the bvh tree. root node has level=0,
37
+ * its children have level=1 etc.
38
+ */
39
+ constructor(extentsMin: NS_THREE.Vector3, extentsMax: NS_THREE.Vector3, startIndex: number, endIndex: number, level: number);
40
+ elementCount(): number;
41
+ centerX(): number;
42
+ centerY(): number;
43
+ centerZ(): number;
44
+ clearShapes(): void;
45
+ calcBoundingSphereRadius(extentsMin: NS_THREE.Vector3, extentsMax: NS_THREE.Vector3): number;
46
+ }
47
+ /**
48
+ * BVH树
49
+ */
50
+ declare class BVHTree {
51
+ private static EPSILON;
52
+ private trianglesArray;
53
+ private maxTrianglesPerNode;
54
+ private bboxArray;
55
+ private bboxHelper;
56
+ private rootNode;
57
+ private nodesToSplit;
58
+ /**
59
+ * 创建BVH树对象
60
+ * @param {Vector3[][]} triangles 三角形数组,BVH树基于此构建
61
+ * @param {number} maxTrianglesPerNode 每个树结点包含的最多三角形数量
62
+ */
63
+ constructor(triangles: NS_THREE.Vector3[][], maxTrianglesPerNode: number);
64
+ private vector3SetFromArray;
65
+ /**
66
+ * Returns a list of all the triangles in the BVH which interected a specific node.
67
+ * We use the BVH node structure to first cull out nodes which do not intereset the ray.
68
+ * For rays that did intersect, we test intersection of the ray with each triangle
69
+ * @param {Vector3} rayOrigin the origin position of the ray.
70
+ * @param {Vector3} rayDirection the direction vector of the ray.
71
+ * @param {boolean} backfaceCulling if 'true', only intersections with front-faces of the mesh will be performed.
72
+ * @return {{}[]} IntersectionResult an array of intersection result, one for each triangle which intersected the BVH,
73
+ * each item in the form of:
74
+ * {
75
+ * triangle: Vector3[];
76
+ * triangleIndex: number;
77
+ * intersectionPoint: Vector3;
78
+ * }
79
+ */
80
+ intersectRay(rayOrigin: NS_THREE.Vector3, rayDirection: NS_THREE.Vector3, backfaceCulling?: boolean): IntersectResult[];
81
+ /**
82
+ * 获得与指定射线方向相交的最接近射线起点的相交结果
83
+ * @param rayOrigin 射线起点
84
+ * @param rayDirection 射线方向
85
+ * @param backfaceCulling 可选,是否忽略背面
86
+ */
87
+ nearestIntersection(rayOrigin: NS_THREE.Vector3, rayDirection: NS_THREE.Vector3, backfaceCulling?: boolean): IntersectResult | null;
88
+ private calcBoundingBoxes;
89
+ private setBox;
90
+ private copyBox;
91
+ private calcExtents;
92
+ private splitNode;
93
+ private calcTValues;
94
+ private intersectNodeBox;
95
+ private intersectRayTriangle;
96
+ private static addTriangles;
97
+ /**
98
+ * 构建bvhtree
99
+ * @ignore
100
+ * @param {Object3D} threeObj 需要创建BVH树的Object3D根对象
101
+ * @returns {BVHTree}
102
+ */
103
+ static createBVHTree(threeObj: NS_THREE.Object3D): BVHTree;
104
+ }
105
+ export { BVHTree, BVHNode, IntersectResult };