@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,636 @@
1
+ import { NS_THREE, Externals } from '../stage/externals';
2
+ import { Element, ElementFrameContext } from './element';
3
+ import { EventHub } from '../utils/event-hub';
4
+ import { Events, OwllyEvents } from '../utils/events';
5
+ import { View } from '../view';
6
+ import { DeviceUtils } from '../utils/device-utils';
7
+ import { TilePlane, TilePlaneUtil } from './tile-plane';
8
+ import { CubeFaceConfig, TileTextureInfo, TileUtil } from '../utils/tile-util';
9
+
10
+ interface TilePanoramaViewConfiguration {
11
+ targetView: View;
12
+ showBorder?: boolean;
13
+ showSkyBox?: boolean;
14
+ }
15
+
16
+ let sphereInstance: NS_THREE.Mesh;
17
+
18
+ const TILE_PANORAMA_SIZE = 2;
19
+ /**
20
+ * 全景图对象
21
+ * @noInheritDoc
22
+ */
23
+ class TilePanorama extends Element {
24
+ private initialized: boolean;
25
+
26
+ private needsUpdate: boolean;
27
+
28
+ private level = 0;
29
+
30
+ /** @ignore */
31
+ public levelMax = 0;
32
+
33
+ private sphereMesh: NS_THREE.Mesh | null;
34
+
35
+ private isPlayingVideo: boolean;
36
+
37
+ private video: HTMLVideoElement | null;
38
+
39
+ private wireFrame: NS_THREE.LineSegments;
40
+
41
+ /** @ignore */
42
+ public tilePlanes: TilePlane[];
43
+
44
+ public pid: number;
45
+
46
+ /** @ignore */
47
+ public seqID: number;
48
+
49
+ /** @ignore */
50
+ public neighborPanoramaIDs: number[];
51
+
52
+ /** @ignore */
53
+ public highTextureURLs: string[];
54
+
55
+ /** @ignore */
56
+ public textureURLs: string[];
57
+
58
+ /** @ignore */
59
+ public offLinTextureUrls: string[];
60
+
61
+ /** @ignore */
62
+ public offLineTextureLevel = -1;
63
+
64
+ /** @ignore */
65
+ public useLowTextureURLsOnly: boolean;
66
+
67
+ /** @ignore */
68
+ public tiledTextureURLRoot: string | undefined;
69
+
70
+ private baseQuaternion: NS_THREE.Quaternion;
71
+
72
+ private additionalQuaternion: NS_THREE.Quaternion;
73
+
74
+ private panoramaLoaded: boolean;
75
+
76
+ private eventListeners: {
77
+ onPanoramaSelected: Function;
78
+ onEnded: ((video?: HTMLVideoElement) => void) | null;
79
+ };
80
+
81
+ private isSelected: boolean;
82
+
83
+ private videoCanvas: HTMLCanvasElement | null;
84
+
85
+ private mpegVideoPlayer: any; // eslint-disable-line
86
+
87
+ private videoContentType: 'mp4' | 'ts';
88
+
89
+ private mounted: boolean;
90
+
91
+ /**
92
+ * @param textureURLs 低清立方体贴图六张图的URL数组(本地相对路径或网络URL均可),按右左上下前后的顺序
93
+ * @param highTextureURLs 高清立方体贴图六张图的URL数组(本地相对路径或网络URL均可),按右左上下前后的顺序
94
+ * @param useLowTextureURLsOnly 可选,设置后则(如果没有提供瓦片贴图)只使用低清立方体贴图
95
+ * @param tiledTextureURLRoot 可选,瓦片贴图URL的前缀部分,若没有则用highTextureURLs和lowTextureURLs作为贴图源
96
+ */
97
+ constructor(
98
+ pid: number,
99
+ seqID: number,
100
+ textureURLs: string[],
101
+ neighborPanoramaIDs: number[] = [],
102
+ levelMax: number,
103
+ offLinTextureUrls?: string[],
104
+ offLineTextureLevel?: number,
105
+ position?: NS_THREE.Vector3,
106
+ quaternion?: NS_THREE.Quaternion,
107
+ ) {
108
+ super();
109
+ this.pid = pid;
110
+ this.seqID = seqID;
111
+ this.textureURLs = textureURLs;
112
+ this.levelMax = levelMax;
113
+ this.neighborPanoramaIDs = neighborPanoramaIDs;
114
+ this.offLinTextureUrls = offLinTextureUrls || [];
115
+ if (offLineTextureLevel != null) {
116
+ this.offLineTextureLevel = offLineTextureLevel;
117
+ }
118
+ this.initialized = false;
119
+ this.mounted = false;
120
+ this.needsUpdate = false;
121
+ this.tilePlanes = [];
122
+ this.isPlayingVideo = false;
123
+ this.videoCanvas = null;
124
+ this.videoContentType = 'mp4';
125
+ this.setTransform(position, quaternion);
126
+ }
127
+
128
+ /**
129
+ * 关联包围框
130
+ * @param size
131
+ */
132
+ private linkLineBox(size: number): void {
133
+ const { THREE } = Externals.getInstance();
134
+ const boxGeometry = new THREE.BoxBufferGeometry(size, size, size);
135
+
136
+ this.wireFrame = new THREE.LineSegments(
137
+ new THREE.EdgesGeometry(boxGeometry),
138
+ new THREE.LineBasicMaterial({ color: 0xff0000 }),
139
+ );
140
+ (this.wireFrame.material as NS_THREE.Material).visible = false;
141
+ this.wireFrame.renderOrder = 100;
142
+ this.add(this.wireFrame);
143
+ }
144
+
145
+ /**
146
+ * 关联球
147
+ * @returns
148
+ */
149
+ private linkShere(): NS_THREE.Mesh {
150
+ const { THREE } = Externals.getInstance();
151
+ if (!sphereInstance) {
152
+ const sphereGeometry = new THREE.SphereBufferGeometry(1, 60, 40);
153
+ sphereGeometry.scale(1, -1, 1);
154
+ sphereGeometry.rotateY(-90 * Math.PI / 180.0);
155
+ sphereInstance = new THREE.Mesh(sphereGeometry);
156
+ sphereInstance.visible = false;
157
+ sphereInstance.renderOrder = 150;
158
+ } else {
159
+ // sphereInstance.matrix.identity();
160
+ }
161
+ // sphereInstance.applyMatrix4(matrix);
162
+ return sphereInstance;
163
+ }
164
+
165
+ /**
166
+ * 挂载
167
+ * @ignore
168
+ */
169
+ public mount(): void {
170
+ TilePlaneUtil.setPlanesVisible(true);
171
+ this.tilePlanes = TilePlaneUtil.getPlanesByMatrix(
172
+ this.pid, this.level, this.textureURLs, this.offLineTextureLevel, this.offLinTextureUrls,
173
+ );
174
+ this.tilePlanes.forEach((plane) => {
175
+ this.add(plane);
176
+ plane.visible = true;
177
+ // plane.renderOnce();
178
+ });
179
+ this.sphereMesh = this.linkShere();
180
+ this.linkLineBox(TILE_PANORAMA_SIZE);
181
+ this.add(this.sphereMesh);
182
+ this.mounted = true;
183
+ this.emit(Events.DID_LOAD_PANORAMA, this.pid);
184
+ }
185
+
186
+ /**
187
+ * 卸载
188
+ */
189
+ public unMount(): void {
190
+ TilePlaneUtil.setPlanesVisible(false);
191
+ this.tilePlanes.forEach((plane) => {
192
+ // plane.visible = false;
193
+ this.remove(plane);
194
+ });
195
+ this.tilePlanes = [];
196
+ if (this.sphereMesh) {
197
+ this.remove();
198
+ this.sphereMesh = null;
199
+ }
200
+
201
+ this.mounted = false;
202
+ }
203
+
204
+ /**
205
+ * 更新等级
206
+ * @param level
207
+ */
208
+ public updateLevel(level: number): void {
209
+ const tLevel = Math.min(level, this.levelMax);
210
+ if (this.level !== tLevel) {
211
+ this.level = tLevel;
212
+ if (this.tilePlanes) {
213
+ this.tilePlanes.forEach((plane) => {
214
+ plane.level = tLevel;
215
+ });
216
+ }
217
+ }
218
+ }
219
+
220
+ /**
221
+ * 获取预处理纹理信息
222
+ * @returns
223
+ */
224
+ public getPreTextureInfos(): TileTextureInfo[] {
225
+ const ref = [] as TileTextureInfo[];
226
+ CubeFaceConfig.forEach((config, index) => {
227
+ const {
228
+ face,
229
+ } = config;
230
+ const {
231
+ level, textureURLs, offLineTextureLevel, offLinTextureUrls,
232
+ } = this;
233
+ const pPid = this.pid + (face + 1) / 10;
234
+ const count = TileUtil.getCount(this.level);
235
+ for (let i = 0; i < count; i++) {
236
+ const info = new TileTextureInfo(
237
+ pPid, 0, level, i, textureURLs[index], offLineTextureLevel, offLinTextureUrls[index],
238
+ );
239
+ if (level === 0) {
240
+ info.frize = true;
241
+ }
242
+ ref.push(info);
243
+ }
244
+ });
245
+ return ref;
246
+ }
247
+
248
+ /**
249
+ * 设置位移
250
+ * @param position
251
+ * @param quaternion
252
+ */
253
+ private setTransform(position: NS_THREE.Vector3 | undefined, quaternion: NS_THREE.Quaternion | undefined): void {
254
+ if (position) {
255
+ this.position.copy(position);
256
+ }
257
+ if (quaternion) {
258
+ this.quaternion.copy(quaternion);
259
+ }
260
+ const { THREE } = Externals.getInstance();
261
+ this.baseQuaternion = new THREE.Quaternion().copy(this.quaternion);
262
+ this.additionalQuaternion = new THREE.Quaternion();
263
+
264
+ /* eslint-disable no-underscore-dangle */
265
+ const onQuaternionChangeCallback = this.quaternion._onChangeCallback;
266
+ this.quaternion._onChange(() => {
267
+ onQuaternionChangeCallback();
268
+ const targetQuaternion = new THREE.Quaternion()
269
+ .multiplyQuaternions(this.baseQuaternion, this.additionalQuaternion);
270
+ if (targetQuaternion.equals(this.quaternion)) return;
271
+ this.baseQuaternion = this.quaternion.clone();
272
+ const {
273
+ x, y, z, w,
274
+ } = new THREE.Quaternion().multiplyQuaternions(this.baseQuaternion, this.additionalQuaternion);
275
+ this.quaternion.set(x, y, z, w);
276
+ this.needsUpdate = true;
277
+ });
278
+ const onRotationChangeCallback = this.rotation._onChangeCallback;
279
+ this.rotation._onChange(() => {
280
+ onRotationChangeCallback();
281
+ const reverse = this.additionalQuaternion.clone().invert();
282
+ this.baseQuaternion = this.quaternion.clone().multiply(reverse);
283
+ });
284
+ this.eventListeners = {
285
+ onPanoramaSelected: (panorama: Element): void => {
286
+ this.isSelected = panorama === this;
287
+ if (!this.isSelected) return;
288
+ this.emit(Events.PANORAMA_SELECTED, this.pid);
289
+ },
290
+ onEnded: (): void => { },
291
+ };
292
+ EventHub.on(OwllyEvents.ELEMENT_SELECTED, this.eventListeners.onPanoramaSelected);
293
+ }
294
+
295
+ // /**
296
+ // * 为全景图对象设置立方体贴图
297
+ // * @param cubeTexture 立方体贴图对象
298
+ // */
299
+ // public setTexture(): void {
300
+ // this.needsUpdate = true;
301
+ // if (!this.panoramaLoaded) {
302
+ // this.emit(Events.DID_LOAD_PANORAMA, this.pid);
303
+ // }
304
+ // this.panoramaLoaded = true;
305
+ // }
306
+
307
+ /**
308
+ * 暂停视频播放
309
+ */
310
+ public pauseVideo(): void {
311
+ if (this.videoContentType === 'ts') {
312
+ if (this.mpegVideoPlayer) this.mpegVideoPlayer.pause();
313
+ } else {
314
+ const videoElementID = `pano_vid_${this.pid}`;
315
+ this.video = this.video || document.getElementById(videoElementID) as HTMLVideoElement;
316
+
317
+ if (!this.video) {
318
+ return;
319
+ }
320
+ this.video.pause();
321
+ }
322
+ }
323
+
324
+ /**
325
+ * 恢复视频播放
326
+ */
327
+ public async resumeVideo(): Promise<void> {
328
+ if (this.videoContentType === 'ts') {
329
+ if (this.mpegVideoPlayer) this.mpegVideoPlayer.play();
330
+ } else {
331
+ const videoElementID = `pano_vid_${this.pid}`;
332
+ this.video = this.video || document.getElementById(videoElementID) as HTMLVideoElement;
333
+
334
+ if (!this.video) {
335
+ return;
336
+ }
337
+ await this.video.play();
338
+ }
339
+ }
340
+
341
+ /**
342
+ * 停止视频播放,并释放视频相关资源
343
+ */
344
+ public stopVideo(): void {
345
+ if (!this.sphereMesh) {
346
+ return;
347
+ }
348
+ this.sphereMesh.visible = false;
349
+
350
+ if (this.videoContentType === 'ts') {
351
+ if (this.mpegVideoPlayer) {
352
+ this.mpegVideoPlayer.stop();
353
+ this.mpegVideoPlayer.destroy();
354
+ this.mpegVideoPlayer = null;
355
+ }
356
+
357
+ const canvasTexture = (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).map as NS_THREE.Texture | null;
358
+ if (canvasTexture) canvasTexture.dispose();
359
+ (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).dispose();
360
+
361
+ this.videoCanvas = null;
362
+ } else {
363
+ const videoElementID = `pano_vid_${this.pid}`;
364
+ this.video = this.video || document.getElementById(videoElementID) as HTMLVideoElement;
365
+
366
+ const videoTexture = (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).map as NS_THREE.Texture | null;
367
+ if (videoTexture) {
368
+ videoTexture.dispose();
369
+ }
370
+ (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).dispose();
371
+ if (this.video) {
372
+ this.video.pause();
373
+ this.video.removeAttribute('src');
374
+ this.video.load();
375
+ this.video = null;
376
+ }
377
+ }
378
+
379
+ if (this.eventListeners.onEnded) this.eventListeners.onEnded();
380
+
381
+ this.isPlayingVideo = false;
382
+ this.needsUpdate = true;
383
+ }
384
+
385
+ /**
386
+ * 开始视频播放
387
+ * @param videoURL 视频地址
388
+ * @param loop 是否循环播放
389
+ * @param callbacks 回调函数集合,可选
390
+ */
391
+ public playVideo(
392
+ videoURL: string,
393
+ loop: boolean,
394
+ callbacks?: {
395
+ onPrepareToPlay?: (video?: HTMLVideoElement) => void;
396
+ onReadyToPlay?: (video?: HTMLVideoElement) => void;
397
+ onEnded?: (video?: HTMLVideoElement) => void;
398
+ },
399
+ contentType: 'mp4' | 'ts' = 'mp4',
400
+ canvasSize: [number, number] = [2048, 2048],
401
+ ): HTMLVideoElement | null {
402
+ if (!this.sphereMesh) {
403
+ return null;
404
+ }
405
+ const { THREE } = Externals.getInstance();
406
+ const { onReadyToPlay, onEnded, onPrepareToPlay } = callbacks || {};
407
+ this.videoContentType = contentType;
408
+
409
+ this.eventListeners.onEnded = onEnded || ((): void => { });
410
+
411
+ if (this.videoContentType === 'ts') {
412
+ if (!JSMpeg || !JSMpeg.Player) throw new Error('JSMpeg is needed. Please get JSMpeg from https://github.com/phoboslab/jsmpeg');
413
+ if (!this.videoCanvas) {
414
+ this.videoCanvas = document.createElement('canvas');
415
+ [this.videoCanvas.width, this.videoCanvas.height] = canvasSize;
416
+ }
417
+ this.mpegVideoPlayer = new JSMpeg.Player(
418
+ videoURL,
419
+ {
420
+ canvas: this.videoCanvas,
421
+ loop,
422
+ autoplay: false,
423
+ disableGl: false,
424
+ onSourceEstablished: (): void => {
425
+ this.needsUpdate = true;
426
+ if (onPrepareToPlay) onPrepareToPlay();
427
+ },
428
+ onPlay: (): void => {
429
+ if (this.sphereMesh) { this.sphereMesh.visible = true; }
430
+ this.needsUpdate = true;
431
+ if (onReadyToPlay) onReadyToPlay();
432
+ this.isPlayingVideo = true;
433
+ },
434
+ onPause: (): void => { },
435
+ onStalled: (): void => { },
436
+ onEnded: (): void => {
437
+ this.stopVideo();
438
+ },
439
+ chunkSize: 8 * 1024 * 1024,
440
+ videoBufferSize: 8 * 512 * 1024,
441
+ decodeFirstFrame: false,
442
+ preserveDrawingBuffer: false,
443
+ },
444
+ );
445
+ const texture = new THREE.CanvasTexture(this.videoCanvas);
446
+ texture.needsUpdate = true;
447
+ if (DeviceUtils.DetectIOS()) texture.flipY = false;
448
+ this.sphereMesh.material = new THREE.MeshBasicMaterial({
449
+ map: texture,
450
+ // side: DoubleSide,
451
+ transparent: false,
452
+ depthTest: false,
453
+ depthWrite: false,
454
+ });
455
+ this.mpegVideoPlayer.source.established = false;
456
+ this.mpegVideoPlayer.source.loadedSize = 0;
457
+ this.mpegVideoPlayer.demuxer.startTime = 0;
458
+ this.mpegVideoPlayer.demuxer.currentTime = 0;
459
+ this.mpegVideoPlayer.demuxer.bits = null;
460
+ this.mpegVideoPlayer.demuxer.leftoverBytes = null;
461
+ this.mpegVideoPlayer.audioOut.resetEnqueuedTime();
462
+ this.mpegVideoPlayer.audioOut.unlock();
463
+ this.mpegVideoPlayer.seek(0);
464
+ this.mpegVideoPlayer.play();
465
+ } else {
466
+ const videoElementID = `pano_vid_${this.pid}`;
467
+ this.video = document.getElementById(videoElementID) as HTMLVideoElement;
468
+ if (!this.video) {
469
+ this.video = document.createElement('video');
470
+ this.video.id = videoElementID;
471
+ this.video.setAttribute('webkit-playsinline', 'true');
472
+ this.video.setAttribute('x5-playsinline', 'true');
473
+ this.video.setAttribute('playsinline', 'true');
474
+ this.video.setAttribute('crossorigin', 'anonymous');
475
+ // console.info('#Video# video', video);
476
+ }
477
+
478
+ this.video.src = videoURL;
479
+ this.video.loop = !!loop;
480
+ this.video.addEventListener('playing', () => {
481
+ // console.info('#Video# playing', ev);
482
+ if (this.sphereMesh) { this.sphereMesh.visible = true; }
483
+ this.needsUpdate = true;
484
+ if (onReadyToPlay) {
485
+ onReadyToPlay(this.video!);
486
+ }
487
+ this.isPlayingVideo = true;
488
+ });
489
+ this.video.addEventListener('ended', () => {
490
+ this.stopVideo();
491
+ });
492
+ this.video.addEventListener('play', () => {
493
+ // console.info('#Video# play', ev);
494
+ this.needsUpdate = true;
495
+ if (onPrepareToPlay) {
496
+ onPrepareToPlay(this.video!);
497
+ }
498
+ });
499
+ this.video.play();
500
+ const texture = new THREE.VideoTexture(this.video);
501
+ texture.needsUpdate = true;
502
+ this.sphereMesh.material = new THREE.MeshBasicMaterial({
503
+ map: texture,
504
+ // side: DoubleSide,
505
+ transparent: false,
506
+ depthTest: false,
507
+ depthWrite: false,
508
+ });
509
+ return this.video;
510
+ }
511
+
512
+ return null;
513
+ }
514
+
515
+ /**
516
+ * 设置是否只使用低分辨率贴图
517
+ * @param useLowTexturesOnly 是否只使用低分辨率贴图
518
+ */
519
+ public setUseLowTexturesOnly(useLowTexturesOnly: boolean): void {
520
+ this.useLowTextureURLsOnly = useLowTexturesOnly;
521
+ }
522
+
523
+ /**
524
+ * 是否使用地分辨率贴图
525
+ * @returns
526
+ */
527
+ public isUseLowTexturesOnly(): boolean {
528
+ return this.useLowTextureURLsOnly;
529
+ }
530
+
531
+ /**
532
+ * 清理
533
+ */
534
+ public dispose(): void {
535
+ super.dispose();
536
+ if (this.mounted) {
537
+ this.unMount();
538
+ }
539
+ this.initialized = false;
540
+ EventHub.off(OwllyEvents.ELEMENT_SELECTED, this.eventListeners.onPanoramaSelected);
541
+ }
542
+
543
+ /**
544
+ * @ignore
545
+ */
546
+ public update(): ElementFrameContext {
547
+ const frameContext = new ElementFrameContext(this);
548
+ if (!this.initialized) {
549
+ this.initialized = true;
550
+ frameContext.needUpdate = true;
551
+ } else if (this.needsUpdate || this.isPlayingVideo) {
552
+ frameContext.needUpdate = true;
553
+ if (
554
+ this.sphereMesh
555
+ && this.isPlayingVideo
556
+ && this.videoCanvas
557
+ && (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).map
558
+ ) {
559
+ (this.sphereMesh.material as NS_THREE.MeshBasicMaterial).map!.needsUpdate = true;
560
+ }
561
+ this.needsUpdate = false;
562
+ }
563
+ if (this.initialized && !this.parent) {
564
+ frameContext.shouldPlaceElement = true;
565
+ }
566
+ return frameContext;
567
+ }
568
+
569
+ /**
570
+ * 使用欧拉角模式设置矫正
571
+ * @param roll 横滚角, 坐标轴为x
572
+ * @param pitch 俯仰角, 坐标轴为y
573
+ * @param yaw 偏航角, 坐标轴为z
574
+ */
575
+ public setAdditionalRotationInEuler(
576
+ roll: number,
577
+ pitch: number,
578
+ yaw: number,
579
+ ): NS_THREE.Quaternion {
580
+ const { THREE } = Externals.getInstance();
581
+ this.additionalQuaternion.setFromEuler(new THREE.Euler(roll, pitch, yaw));
582
+ const {
583
+ x, y, z, w,
584
+ } = this.baseQuaternion.clone().multiply(this.additionalQuaternion);
585
+ this.quaternion.set(x, y, z, w);
586
+ this.needsUpdate = true;
587
+ return this.additionalQuaternion.clone();
588
+ }
589
+
590
+ /**
591
+ * 使用四元数模式设置矫正
592
+ * @param x 四元数的x值
593
+ * @param y 四元数的y值
594
+ * @param z 四元数的y值
595
+ * @param w 四元数的w值
596
+ */
597
+ public setAdditionalRotationInQuaternion(
598
+ x: number,
599
+ y: number,
600
+ z: number,
601
+ w: number,
602
+ ): NS_THREE.Euler {
603
+ const { THREE } = Externals.getInstance();
604
+ this.additionalQuaternion.set(x, y, z, w);
605
+ const {
606
+ x: tx, y: ty, z: tz, w: tw,
607
+ } = this.baseQuaternion.clone().multiply(this.additionalQuaternion);
608
+ this.quaternion.set(tx, ty, tz, tw);
609
+ this.needsUpdate = true;
610
+ return new THREE.Euler().setFromQuaternion(this.additionalQuaternion);
611
+ }
612
+
613
+ // /**
614
+ // * @ignore
615
+ // * @param view
616
+ // * @returns
617
+ // */
618
+ // public renderingViewChanged(view: View): void {
619
+ // if (!view.camera) return;
620
+ // super.renderingViewChanged(view);
621
+ // this.tilePlanes.forEach((tilePlane) => {
622
+ // tilePlane.renderingViewChanged(view);
623
+ // });
624
+ // }
625
+
626
+ /**
627
+ * 获取盒子
628
+ * @ignore
629
+ * @returns
630
+ */
631
+ public getBox(): { size: number; matrix: NS_THREE.Matrix4 } {
632
+ return { size: 2, matrix: this.matrix };
633
+ }
634
+ }
635
+
636
+ export { TilePanorama, TilePanoramaViewConfiguration };