@needle-tools/engine 4.4.0-beta.7 → 4.4.0-beta.9

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 (1043) hide show
  1. package/CHANGELOG.md +3618 -3616
  2. package/LICENSE.md +10 -10
  3. package/README.md +64 -64
  4. package/components.needle.json +1 -1
  5. package/dist/needle-engine.bundle.js +5029 -4950
  6. package/dist/needle-engine.bundle.light.js +5030 -4951
  7. package/dist/needle-engine.bundle.light.min.js +146 -116
  8. package/dist/needle-engine.bundle.light.umd.cjs +148 -118
  9. package/dist/needle-engine.bundle.min.js +146 -116
  10. package/dist/needle-engine.bundle.umd.cjs +148 -118
  11. package/dist/needle-engine.d.ts +129 -130
  12. package/dist/needle-engine.light.d.ts +129 -130
  13. package/lib/asap/needle-asap.d.ts +1 -1
  14. package/lib/asap/needle-asap.js +95 -95
  15. package/lib/asap/sessiongranted.d.ts +3 -3
  16. package/lib/asap/sessiongranted.js +65 -65
  17. package/lib/asap/utils.d.ts +1 -1
  18. package/lib/asap/utils.js +3 -3
  19. package/lib/engine/analytics/index.d.ts +6 -6
  20. package/lib/engine/analytics/index.js +12 -12
  21. package/lib/engine/analytics/lcp.d.ts +3 -3
  22. package/lib/engine/analytics/lcp.js +34 -34
  23. package/lib/engine/api.d.ts +81 -81
  24. package/lib/engine/api.js +80 -80
  25. package/lib/engine/assets/index.d.ts +11 -11
  26. package/lib/engine/assets/index.js +47 -47
  27. package/lib/engine/assets/static.d.ts +1 -1
  28. package/lib/engine/assets/static.js +4 -4
  29. package/lib/engine/codegen/register_types.d.ts +1 -1
  30. package/lib/engine/codegen/register_types.js +300 -300
  31. package/lib/engine/debug/debug.d.ts +15 -15
  32. package/lib/engine/debug/debug.js +44 -44
  33. package/lib/engine/debug/debug_console.d.ts +2 -2
  34. package/lib/engine/debug/debug_console.js +307 -307
  35. package/lib/engine/debug/debug_overlay.d.ts +22 -22
  36. package/lib/engine/debug/debug_overlay.js +316 -316
  37. package/lib/engine/debug/debug_spatial_console.d.ts +2 -2
  38. package/lib/engine/debug/debug_spatial_console.js +390 -390
  39. package/lib/engine/debug/index.d.ts +2 -2
  40. package/lib/engine/debug/index.js +2 -2
  41. package/lib/engine/engine.d.ts +4 -0
  42. package/lib/engine/engine.js +12 -0
  43. package/lib/engine/engine.js.map +1 -0
  44. package/lib/engine/engine_addressables.d.ts +166 -166
  45. package/lib/engine/engine_addressables.js +608 -608
  46. package/lib/engine/engine_animation.d.ts +43 -43
  47. package/lib/engine/engine_animation.js +133 -133
  48. package/lib/engine/engine_application.d.ts +40 -40
  49. package/lib/engine/engine_application.js +104 -104
  50. package/lib/engine/engine_assetdatabase.d.ts +25 -25
  51. package/lib/engine/engine_assetdatabase.js +344 -344
  52. package/lib/engine/engine_audio.d.ts +4 -4
  53. package/lib/engine/engine_audio.js +23 -23
  54. package/lib/engine/engine_camera.d.ts +13 -13
  55. package/lib/engine/engine_camera.js +30 -30
  56. package/lib/engine/engine_components.d.ts +110 -110
  57. package/lib/engine/engine_components.js +382 -382
  58. package/lib/engine/engine_components_internal.d.ts +9 -9
  59. package/lib/engine/engine_components_internal.js +36 -36
  60. package/lib/engine/engine_constants.d.ts +10 -10
  61. package/lib/engine/engine_constants.js +41 -41
  62. package/lib/engine/engine_context.d.ts +354 -354
  63. package/lib/engine/engine_context.js +1536 -1536
  64. package/lib/engine/engine_context_registry.d.ts +71 -71
  65. package/lib/engine/engine_context_registry.js +117 -117
  66. package/lib/engine/engine_coroutine.d.ts +35 -35
  67. package/lib/engine/engine_coroutine.js +52 -52
  68. package/lib/engine/engine_create_objects.d.ts +118 -118
  69. package/lib/engine/engine_create_objects.js +308 -308
  70. package/lib/engine/engine_default_parameters.d.ts +2 -2
  71. package/lib/engine/engine_default_parameters.js +3 -3
  72. package/lib/engine/engine_editor-sync.d.ts +21 -21
  73. package/lib/engine/engine_editor-sync.js +4 -4
  74. package/lib/engine/engine_element.d.ts +113 -113
  75. package/lib/engine/engine_element.js +832 -829
  76. package/lib/engine/engine_element.js.map +1 -1
  77. package/lib/engine/engine_element_attributes.d.ts +72 -72
  78. package/lib/engine/engine_element_attributes.js +1 -1
  79. package/lib/engine/engine_element_extras.d.ts +6 -6
  80. package/lib/engine/engine_element_extras.js +13 -13
  81. package/lib/engine/engine_element_loading.d.ts +44 -44
  82. package/lib/engine/engine_element_loading.js +349 -349
  83. package/lib/engine/engine_element_overlay.d.ts +21 -21
  84. package/lib/engine/engine_element_overlay.js +166 -166
  85. package/lib/engine/engine_fileloader.d.ts +2 -2
  86. package/lib/engine/engine_fileloader.js +8 -8
  87. package/lib/engine/engine_gameobject.d.ts +68 -68
  88. package/lib/engine/engine_gameobject.js +591 -591
  89. package/lib/engine/engine_generic_utils.d.ts +1 -1
  90. package/lib/engine/engine_generic_utils.js +13 -13
  91. package/lib/engine/engine_gizmos.d.ts +149 -149
  92. package/lib/engine/engine_gizmos.js +530 -530
  93. package/lib/engine/engine_gltf.d.ts +12 -12
  94. package/lib/engine/engine_gltf.js +15 -15
  95. package/lib/engine/engine_gltf_builtin_components.d.ts +7 -7
  96. package/lib/engine/engine_gltf_builtin_components.js +341 -341
  97. package/lib/engine/engine_hot_reload.d.ts +7 -7
  98. package/lib/engine/engine_hot_reload.js +184 -184
  99. package/lib/engine/engine_input.d.ts +352 -352
  100. package/lib/engine/engine_input.js +1265 -1265
  101. package/lib/engine/engine_input_utils.d.ts +2 -2
  102. package/lib/engine/engine_input_utils.js +22 -22
  103. package/lib/engine/engine_instancing.d.ts +19 -19
  104. package/lib/engine/engine_instancing.js +39 -39
  105. package/lib/engine/engine_license.d.ts +11 -9
  106. package/lib/engine/engine_license.js +361 -320
  107. package/lib/engine/engine_license.js.map +1 -1
  108. package/lib/engine/engine_lifecycle_api.d.ts +76 -76
  109. package/lib/engine/engine_lifecycle_api.js +99 -99
  110. package/lib/engine/engine_lifecycle_functions_internal.d.ts +32 -32
  111. package/lib/engine/engine_lifecycle_functions_internal.js +146 -146
  112. package/lib/engine/engine_lightdata.d.ts +23 -23
  113. package/lib/engine/engine_lightdata.js +91 -91
  114. package/lib/engine/engine_loaders.d.ts +13 -13
  115. package/lib/engine/engine_loaders.js +62 -62
  116. package/lib/engine/engine_lods.d.ts +31 -31
  117. package/lib/engine/engine_lods.js +146 -146
  118. package/lib/engine/engine_mainloop_utils.d.ts +32 -32
  119. package/lib/engine/engine_mainloop_utils.js +466 -466
  120. package/lib/engine/engine_math.d.ts +114 -114
  121. package/lib/engine/engine_math.js +247 -247
  122. package/lib/engine/engine_modules.d.ts +36 -36
  123. package/lib/engine/engine_modules.js +85 -85
  124. package/lib/engine/engine_networking.d.ts +252 -252
  125. package/lib/engine/engine_networking.js +743 -743
  126. package/lib/engine/engine_networking_auto.d.ts +24 -24
  127. package/lib/engine/engine_networking_auto.js +310 -310
  128. package/lib/engine/engine_networking_blob.d.ts +48 -48
  129. package/lib/engine/engine_networking_blob.js +212 -212
  130. package/lib/engine/engine_networking_files.d.ts +35 -35
  131. package/lib/engine/engine_networking_files.js +172 -172
  132. package/lib/engine/engine_networking_files_default_components.d.ts +6 -6
  133. package/lib/engine/engine_networking_files_default_components.js +42 -42
  134. package/lib/engine/engine_networking_instantiate.d.ts +100 -100
  135. package/lib/engine/engine_networking_instantiate.js +345 -345
  136. package/lib/engine/engine_networking_peer.d.ts +15 -15
  137. package/lib/engine/engine_networking_peer.js +132 -132
  138. package/lib/engine/engine_networking_streams.d.ts +123 -123
  139. package/lib/engine/engine_networking_streams.js +645 -645
  140. package/lib/engine/engine_networking_types.d.ts +22 -22
  141. package/lib/engine/engine_networking_types.js +7 -7
  142. package/lib/engine/engine_networking_utils.d.ts +2 -2
  143. package/lib/engine/engine_networking_utils.js +20 -20
  144. package/lib/engine/engine_networking_websocket.d.ts +1 -1
  145. package/lib/engine/engine_networking_websocket.js +2 -2
  146. package/lib/engine/engine_patcher.d.ts +10 -10
  147. package/lib/engine/engine_patcher.js +142 -142
  148. package/lib/engine/engine_physics.d.ts +152 -152
  149. package/lib/engine/engine_physics.js +645 -645
  150. package/lib/engine/engine_physics.types.d.ts +40 -40
  151. package/lib/engine/engine_physics.types.js +33 -33
  152. package/lib/engine/engine_physics_rapier.d.ts +147 -147
  153. package/lib/engine/engine_physics_rapier.js +1432 -1432
  154. package/lib/engine/engine_playerview.d.ts +26 -26
  155. package/lib/engine/engine_playerview.js +64 -64
  156. package/lib/engine/engine_scenelighting.d.ts +71 -71
  157. package/lib/engine/engine_scenelighting.js +226 -226
  158. package/lib/engine/engine_scenetools.d.ts +50 -50
  159. package/lib/engine/engine_scenetools.js +321 -321
  160. package/lib/engine/engine_serialization.d.ts +3 -3
  161. package/lib/engine/engine_serialization.js +3 -3
  162. package/lib/engine/engine_serialization_builtin_serializer.d.ts +72 -72
  163. package/lib/engine/engine_serialization_builtin_serializer.js +403 -403
  164. package/lib/engine/engine_serialization_core.d.ts +85 -85
  165. package/lib/engine/engine_serialization_core.js +602 -602
  166. package/lib/engine/engine_serialization_decorator.d.ts +23 -23
  167. package/lib/engine/engine_serialization_decorator.js +66 -66
  168. package/lib/engine/engine_setup.d.ts +1 -1
  169. package/lib/engine/engine_setup.js +2 -2
  170. package/lib/engine/engine_shaders.d.ts +53 -53
  171. package/lib/engine/engine_shaders.js +252 -252
  172. package/lib/engine/engine_shims.d.ts +4 -4
  173. package/lib/engine/engine_shims.js +24 -24
  174. package/lib/engine/engine_test_utils.d.ts +39 -39
  175. package/lib/engine/engine_test_utils.js +83 -83
  176. package/lib/engine/engine_texture.d.ts +28 -28
  177. package/lib/engine/engine_texture.js +64 -64
  178. package/lib/engine/engine_three_utils.d.ts +201 -201
  179. package/lib/engine/engine_three_utils.js +731 -731
  180. package/lib/engine/engine_time.d.ts +51 -51
  181. package/lib/engine/engine_time.js +82 -82
  182. package/lib/engine/engine_time_utils.d.ts +88 -88
  183. package/lib/engine/engine_time_utils.js +215 -215
  184. package/lib/engine/engine_tonemapping.d.ts +2 -2
  185. package/lib/engine/engine_tonemapping.js +194 -194
  186. package/lib/engine/engine_types.d.ts +572 -572
  187. package/lib/engine/engine_types.js +88 -88
  188. package/lib/engine/engine_typestore.d.ts +28 -28
  189. package/lib/engine/engine_typestore.js +55 -55
  190. package/lib/engine/engine_util_decorator.d.ts +13 -13
  191. package/lib/engine/engine_util_decorator.js +116 -116
  192. package/lib/engine/engine_utils.d.ts +266 -266
  193. package/lib/engine/engine_utils.js +878 -878
  194. package/lib/engine/engine_utils_format.d.ts +21 -21
  195. package/lib/engine/engine_utils_format.js +193 -193
  196. package/lib/engine/engine_utils_screenshot.d.ts +159 -159
  197. package/lib/engine/engine_utils_screenshot.js +513 -513
  198. package/lib/engine/engine_utils_screenshot.xr.d.ts +5 -5
  199. package/lib/engine/engine_utils_screenshot.xr.js +90 -90
  200. package/lib/engine/engine_web_api.d.ts +12 -0
  201. package/lib/engine/engine_web_api.js +113 -0
  202. package/lib/engine/engine_web_api.js.map +1 -0
  203. package/lib/engine/engine_xr.d.ts +1 -1
  204. package/lib/engine/engine_xr.js +1 -1
  205. package/lib/engine/export/gltf/Writers.d.ts +19 -19
  206. package/lib/engine/export/gltf/Writers.js +24 -24
  207. package/lib/engine/export/gltf/index.d.ts +11 -11
  208. package/lib/engine/export/gltf/index.js +123 -123
  209. package/lib/engine/export/index.d.ts +2 -2
  210. package/lib/engine/export/index.js +2 -2
  211. package/lib/engine/export/state.d.ts +7 -7
  212. package/lib/engine/export/state.js +17 -17
  213. package/lib/engine/export/utils.d.ts +2 -2
  214. package/lib/engine/export/utils.js +7 -7
  215. package/lib/engine/extensions/EXT_texture_exr.d.ts +8 -8
  216. package/lib/engine/extensions/EXT_texture_exr.js +32 -32
  217. package/lib/engine/extensions/NEEDLE_animator_controller_model.d.ts +122 -122
  218. package/lib/engine/extensions/NEEDLE_animator_controller_model.js +95 -95
  219. package/lib/engine/extensions/NEEDLE_components.d.ts +35 -35
  220. package/lib/engine/extensions/NEEDLE_components.js +220 -220
  221. package/lib/engine/extensions/NEEDLE_gameobject_data.d.ts +10 -10
  222. package/lib/engine/extensions/NEEDLE_gameobject_data.js +57 -57
  223. package/lib/engine/extensions/NEEDLE_lighting_settings.d.ts +37 -37
  224. package/lib/engine/extensions/NEEDLE_lighting_settings.js +157 -157
  225. package/lib/engine/extensions/NEEDLE_lightmaps.d.ts +18 -18
  226. package/lib/engine/extensions/NEEDLE_lightmaps.js +99 -99
  227. package/lib/engine/extensions/NEEDLE_persistent_assets.d.ts +11 -11
  228. package/lib/engine/extensions/NEEDLE_persistent_assets.js +63 -63
  229. package/lib/engine/extensions/NEEDLE_progressive.d.ts +1 -1
  230. package/lib/engine/extensions/NEEDLE_progressive.js +1 -1
  231. package/lib/engine/extensions/NEEDLE_render_objects.d.ts +13 -13
  232. package/lib/engine/extensions/NEEDLE_render_objects.js +159 -159
  233. package/lib/engine/extensions/NEEDLE_techniques_webgl.d.ts +38 -38
  234. package/lib/engine/extensions/NEEDLE_techniques_webgl.js +564 -564
  235. package/lib/engine/extensions/extension_resolver.d.ts +4 -4
  236. package/lib/engine/extensions/extension_resolver.js +1 -1
  237. package/lib/engine/extensions/extension_utils.d.ts +12 -12
  238. package/lib/engine/extensions/extension_utils.js +152 -152
  239. package/lib/engine/extensions/extensions.d.ts +31 -31
  240. package/lib/engine/extensions/extensions.js +103 -103
  241. package/lib/engine/extensions/index.d.ts +6 -6
  242. package/lib/engine/extensions/index.js +6 -6
  243. package/lib/engine/extensions/usage_tracker.d.ts +13 -13
  244. package/lib/engine/extensions/usage_tracker.js +65 -65
  245. package/lib/engine/js-extensions/Camera.d.ts +1 -1
  246. package/lib/engine/js-extensions/Camera.js +39 -39
  247. package/lib/engine/js-extensions/ExtensionUtils.d.ts +9 -9
  248. package/lib/engine/js-extensions/ExtensionUtils.js +67 -67
  249. package/lib/engine/js-extensions/Layers.d.ts +6 -6
  250. package/lib/engine/js-extensions/Layers.js +22 -22
  251. package/lib/engine/js-extensions/Object3D.d.ts +120 -120
  252. package/lib/engine/js-extensions/Object3D.js +136 -136
  253. package/lib/engine/js-extensions/RGBAColor.d.ts +23 -23
  254. package/lib/engine/js-extensions/RGBAColor.js +110 -110
  255. package/lib/engine/js-extensions/Vector.d.ts +3 -3
  256. package/lib/engine/js-extensions/Vector.js +13 -13
  257. package/lib/engine/js-extensions/index.d.ts +5 -5
  258. package/lib/engine/js-extensions/index.js +5 -5
  259. package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.d.ts +4 -4
  260. package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +76 -76
  261. package/lib/engine/shaders/shaderData.d.ts +55 -55
  262. package/lib/engine/shaders/shaderData.js +58 -58
  263. package/lib/engine/tests/test_utils.d.ts +2 -2
  264. package/lib/engine/tests/test_utils.js +53 -53
  265. package/lib/engine/webcomponents/WebXRButtons.d.ts +56 -56
  266. package/lib/engine/webcomponents/WebXRButtons.js +230 -230
  267. package/lib/engine/webcomponents/api.d.ts +5 -5
  268. package/lib/engine/webcomponents/api.js +4 -4
  269. package/lib/engine/webcomponents/buttons.d.ts +39 -39
  270. package/lib/engine/webcomponents/buttons.js +237 -237
  271. package/lib/engine/webcomponents/fonts.d.ts +9 -9
  272. package/lib/engine/webcomponents/fonts.js +32 -32
  273. package/lib/engine/webcomponents/icons.d.ts +9 -9
  274. package/lib/engine/webcomponents/icons.js +52 -52
  275. package/lib/engine/webcomponents/index.d.ts +1 -1
  276. package/lib/engine/webcomponents/index.js +1 -1
  277. package/lib/engine/webcomponents/logo-element.d.ts +10 -10
  278. package/lib/engine/webcomponents/logo-element.js +67 -67
  279. package/lib/engine/webcomponents/needle menu/needle-menu-spatial.d.ts +37 -37
  280. package/lib/engine/webcomponents/needle menu/needle-menu-spatial.js +513 -513
  281. package/lib/engine/webcomponents/needle menu/needle-menu.d.ts +155 -151
  282. package/lib/engine/webcomponents/needle menu/needle-menu.js +1029 -1018
  283. package/lib/engine/webcomponents/needle menu/needle-menu.js.map +1 -1
  284. package/lib/engine/webcomponents/needle-button.d.ts +34 -34
  285. package/lib/engine/webcomponents/needle-button.js +161 -161
  286. package/lib/engine/xr/NeedleXRController.d.ts +313 -313
  287. package/lib/engine/xr/NeedleXRController.js +1007 -1007
  288. package/lib/engine/xr/NeedleXRSession.d.ts +339 -339
  289. package/lib/engine/xr/NeedleXRSession.js +1427 -1427
  290. package/lib/engine/xr/NeedleXRSync.d.ts +22 -22
  291. package/lib/engine/xr/NeedleXRSync.js +188 -188
  292. package/lib/engine/xr/SceneTransition.d.ts +18 -18
  293. package/lib/engine/xr/SceneTransition.js +69 -69
  294. package/lib/engine/xr/TempXRContext.d.ts +34 -34
  295. package/lib/engine/xr/TempXRContext.js +187 -187
  296. package/lib/engine/xr/XRRig.d.ts +7 -7
  297. package/lib/engine/xr/XRRig.js +1 -1
  298. package/lib/engine/xr/api.d.ts +6 -6
  299. package/lib/engine/xr/api.js +6 -6
  300. package/lib/engine/xr/events.d.ts +66 -66
  301. package/lib/engine/xr/events.js +93 -93
  302. package/lib/engine/xr/internal.d.ts +12 -12
  303. package/lib/engine/xr/internal.js +25 -25
  304. package/lib/engine/xr/usdz.d.ts +12 -12
  305. package/lib/engine/xr/usdz.js +29 -29
  306. package/lib/engine/xr/utils.d.ts +11 -11
  307. package/lib/engine/xr/utils.js +34 -34
  308. package/lib/engine-components/AlignmentConstraint.d.ts +10 -10
  309. package/lib/engine-components/AlignmentConstraint.js +39 -39
  310. package/lib/engine-components/Animation.d.ts +156 -156
  311. package/lib/engine-components/Animation.js +508 -508
  312. package/lib/engine-components/AnimationCurve.d.ts +40 -40
  313. package/lib/engine-components/AnimationCurve.js +159 -159
  314. package/lib/engine-components/AnimationUtils.d.ts +8 -8
  315. package/lib/engine-components/AnimationUtils.js +27 -27
  316. package/lib/engine-components/AnimationUtilsAutoplay.d.ts +1 -1
  317. package/lib/engine-components/AnimationUtilsAutoplay.js +39 -39
  318. package/lib/engine-components/Animator.d.ts +217 -217
  319. package/lib/engine-components/Animator.js +354 -354
  320. package/lib/engine-components/AnimatorController.d.ts +227 -227
  321. package/lib/engine-components/AnimatorController.js +1152 -1152
  322. package/lib/engine-components/AudioListener.d.ts +33 -33
  323. package/lib/engine-components/AudioListener.js +86 -86
  324. package/lib/engine-components/AudioSource.d.ts +217 -217
  325. package/lib/engine-components/AudioSource.js +627 -627
  326. package/lib/engine-components/AvatarLoader.d.ts +80 -80
  327. package/lib/engine-components/AvatarLoader.js +231 -231
  328. package/lib/engine-components/AxesHelper.d.ts +32 -32
  329. package/lib/engine-components/AxesHelper.js +67 -67
  330. package/lib/engine-components/BasicIKConstraint.d.ts +9 -9
  331. package/lib/engine-components/BasicIKConstraint.js +43 -43
  332. package/lib/engine-components/BoxCollider.d.ts +2 -2
  333. package/lib/engine-components/BoxCollider.js +2 -2
  334. package/lib/engine-components/BoxHelperComponent.d.ts +47 -47
  335. package/lib/engine-components/BoxHelperComponent.js +102 -102
  336. package/lib/engine-components/Camera.d.ts +231 -231
  337. package/lib/engine-components/Camera.js +700 -700
  338. package/lib/engine-components/CameraUtils.d.ts +1 -1
  339. package/lib/engine-components/CameraUtils.js +121 -121
  340. package/lib/engine-components/CharacterController.d.ts +55 -55
  341. package/lib/engine-components/CharacterController.js +236 -236
  342. package/lib/engine-components/Collider.d.ts +188 -188
  343. package/lib/engine-components/Collider.js +369 -369
  344. package/lib/engine-components/Component.d.ts +792 -792
  345. package/lib/engine-components/Component.js +915 -915
  346. package/lib/engine-components/ContactShadows.d.ts +82 -82
  347. package/lib/engine-components/ContactShadows.js +430 -430
  348. package/lib/engine-components/DeleteBox.d.ts +19 -19
  349. package/lib/engine-components/DeleteBox.js +58 -58
  350. package/lib/engine-components/DeviceFlag.d.ts +16 -16
  351. package/lib/engine-components/DeviceFlag.js +47 -47
  352. package/lib/engine-components/DragControls.d.ts +170 -170
  353. package/lib/engine-components/DragControls.js +1421 -1421
  354. package/lib/engine-components/DropListener.d.ts +215 -215
  355. package/lib/engine-components/DropListener.js +630 -630
  356. package/lib/engine-components/Duplicatable.d.ts +35 -35
  357. package/lib/engine-components/Duplicatable.js +202 -202
  358. package/lib/engine-components/EventList.d.ts +54 -54
  359. package/lib/engine-components/EventList.js +232 -232
  360. package/lib/engine-components/EventTrigger.d.ts +33 -33
  361. package/lib/engine-components/EventTrigger.js +75 -75
  362. package/lib/engine-components/EventType.d.ts +22 -22
  363. package/lib/engine-components/EventType.js +23 -23
  364. package/lib/engine-components/FlyControls.d.ts +10 -0
  365. package/lib/engine-components/FlyControls.js +29 -0
  366. package/lib/engine-components/FlyControls.js.map +1 -0
  367. package/lib/engine-components/Fog.d.ts +22 -22
  368. package/lib/engine-components/Fog.js +61 -61
  369. package/lib/engine-components/Gizmos.d.ts +17 -17
  370. package/lib/engine-components/Gizmos.js +64 -64
  371. package/lib/engine-components/GridHelper.d.ts +20 -20
  372. package/lib/engine-components/GridHelper.js +54 -54
  373. package/lib/engine-components/GroundProjection.d.ts +67 -67
  374. package/lib/engine-components/GroundProjection.js +343 -343
  375. package/lib/engine-components/Interactable.d.ts +12 -12
  376. package/lib/engine-components/Interactable.js +12 -12
  377. package/lib/engine-components/Joints.d.ts +19 -19
  378. package/lib/engine-components/Joints.js +51 -51
  379. package/lib/engine-components/LODGroup.d.ts +35 -35
  380. package/lib/engine-components/LODGroup.js +152 -152
  381. package/lib/engine-components/Light.d.ts +180 -180
  382. package/lib/engine-components/Light.js +535 -535
  383. package/lib/engine-components/LookAtConstraint.d.ts +19 -19
  384. package/lib/engine-components/LookAtConstraint.js +35 -35
  385. package/lib/engine-components/NeedleMenu.d.ts +50 -50
  386. package/lib/engine-components/NeedleMenu.js +92 -92
  387. package/lib/engine-components/NeedleMenu.js.map +1 -1
  388. package/lib/engine-components/NestedGltf.d.ts +25 -25
  389. package/lib/engine-components/NestedGltf.js +88 -88
  390. package/lib/engine-components/Networking.d.ts +54 -54
  391. package/lib/engine-components/Networking.js +112 -112
  392. package/lib/engine-components/OffsetConstraint.d.ts +14 -14
  393. package/lib/engine-components/OffsetConstraint.js +65 -65
  394. package/lib/engine-components/OrbitControls.d.ts +266 -266
  395. package/lib/engine-components/OrbitControls.js +1009 -1009
  396. package/lib/engine-components/PlayerColor.d.ts +19 -19
  397. package/lib/engine-components/PlayerColor.js +94 -94
  398. package/lib/engine-components/ReflectionProbe.d.ts +27 -27
  399. package/lib/engine-components/ReflectionProbe.js +201 -201
  400. package/lib/engine-components/ReflectionProbe.js.map +1 -1
  401. package/lib/engine-components/Renderer.d.ts +153 -153
  402. package/lib/engine-components/Renderer.js +830 -830
  403. package/lib/engine-components/RendererInstancing.d.ts +140 -140
  404. package/lib/engine-components/RendererInstancing.js +744 -744
  405. package/lib/engine-components/RendererLightmap.d.ts +24 -24
  406. package/lib/engine-components/RendererLightmap.js +182 -182
  407. package/lib/engine-components/RigidBody.d.ts +155 -155
  408. package/lib/engine-components/RigidBody.js +517 -517
  409. package/lib/engine-components/SceneSwitcher.d.ts +263 -263
  410. package/lib/engine-components/SceneSwitcher.js +951 -951
  411. package/lib/engine-components/ScreenCapture.d.ts +144 -144
  412. package/lib/engine-components/ScreenCapture.js +547 -547
  413. package/lib/engine-components/ShadowCatcher.d.ts +33 -33
  414. package/lib/engine-components/ShadowCatcher.js +166 -166
  415. package/lib/engine-components/Skybox.d.ts +82 -82
  416. package/lib/engine-components/Skybox.js +448 -448
  417. package/lib/engine-components/SmoothFollow.d.ts +34 -34
  418. package/lib/engine-components/SmoothFollow.js +82 -82
  419. package/lib/engine-components/SpatialTrigger.d.ts +102 -102
  420. package/lib/engine-components/SpatialTrigger.js +225 -225
  421. package/lib/engine-components/SpectatorCamera.d.ts +111 -111
  422. package/lib/engine-components/SpectatorCamera.js +715 -715
  423. package/lib/engine-components/SphereCollider.d.ts +2 -2
  424. package/lib/engine-components/SphereCollider.js +2 -2
  425. package/lib/engine-components/SpriteRenderer.d.ts +132 -132
  426. package/lib/engine-components/SpriteRenderer.js +472 -472
  427. package/lib/engine-components/SyncedCamera.d.ts +41 -41
  428. package/lib/engine-components/SyncedCamera.js +199 -199
  429. package/lib/engine-components/SyncedRoom.d.ts +106 -106
  430. package/lib/engine-components/SyncedRoom.js +371 -371
  431. package/lib/engine-components/SyncedTransform.d.ts +94 -94
  432. package/lib/engine-components/SyncedTransform.js +331 -331
  433. package/lib/engine-components/TestRunner.d.ts +16 -16
  434. package/lib/engine-components/TestRunner.js +102 -102
  435. package/lib/engine-components/TransformGizmo.d.ts +75 -75
  436. package/lib/engine-components/TransformGizmo.js +209 -209
  437. package/lib/engine-components/VideoPlayer.d.ts +184 -184
  438. package/lib/engine-components/VideoPlayer.js +978 -978
  439. package/lib/engine-components/Voip.d.ts +67 -67
  440. package/lib/engine-components/Voip.js +360 -360
  441. package/lib/engine-components/api.d.ts +51 -51
  442. package/lib/engine-components/api.js +50 -50
  443. package/lib/engine-components/avatar/AvatarBlink_Simple.d.ts +11 -11
  444. package/lib/engine-components/avatar/AvatarBlink_Simple.js +76 -76
  445. package/lib/engine-components/avatar/AvatarEyeLook_Rotation.d.ts +14 -14
  446. package/lib/engine-components/avatar/AvatarEyeLook_Rotation.js +68 -68
  447. package/lib/engine-components/avatar/Avatar_Brain_LookAt.d.ts +29 -29
  448. package/lib/engine-components/avatar/Avatar_Brain_LookAt.js +121 -121
  449. package/lib/engine-components/avatar/Avatar_MouthShapes.d.ts +15 -15
  450. package/lib/engine-components/avatar/Avatar_MouthShapes.js +79 -79
  451. package/lib/engine-components/avatar/Avatar_MustacheShake.d.ts +9 -9
  452. package/lib/engine-components/avatar/Avatar_MustacheShake.js +29 -29
  453. package/lib/engine-components/codegen/components.d.ts +216 -216
  454. package/lib/engine-components/codegen/components.js +218 -218
  455. package/lib/engine-components/debug/LogStats.d.ts +5 -5
  456. package/lib/engine-components/debug/LogStats.js +18 -18
  457. package/lib/engine-components/export/gltf/GltfExport.d.ts +30 -30
  458. package/lib/engine-components/export/gltf/GltfExport.js +246 -246
  459. package/lib/engine-components/export/gltf/index.d.ts +1 -1
  460. package/lib/engine-components/export/gltf/index.js +1 -1
  461. package/lib/engine-components/export/index.d.ts +1 -1
  462. package/lib/engine-components/export/index.js +1 -1
  463. package/lib/engine-components/export/usdz/Extension.d.ts +22 -22
  464. package/lib/engine-components/export/usdz/Extension.js +1 -1
  465. package/lib/engine-components/export/usdz/ThreeUSDZExporter.d.ts +160 -160
  466. package/lib/engine-components/export/usdz/ThreeUSDZExporter.js +1782 -1782
  467. package/lib/engine-components/export/usdz/USDZExporter.d.ts +130 -130
  468. package/lib/engine-components/export/usdz/USDZExporter.js +663 -663
  469. package/lib/engine-components/export/usdz/extensions/Animation.d.ts +106 -106
  470. package/lib/engine-components/export/usdz/extensions/Animation.js +1071 -1071
  471. package/lib/engine-components/export/usdz/extensions/DocumentExtension.d.ts +5 -5
  472. package/lib/engine-components/export/usdz/extensions/DocumentExtension.js +6 -6
  473. package/lib/engine-components/export/usdz/extensions/USDZText.d.ts +54 -54
  474. package/lib/engine-components/export/usdz/extensions/USDZText.js +203 -203
  475. package/lib/engine-components/export/usdz/extensions/USDZUI.d.ts +8 -8
  476. package/lib/engine-components/export/usdz/extensions/USDZUI.js +157 -157
  477. package/lib/engine-components/export/usdz/extensions/behavior/Actions.d.ts +30 -30
  478. package/lib/engine-components/export/usdz/extensions/behavior/Actions.js +88 -88
  479. package/lib/engine-components/export/usdz/extensions/behavior/AudioExtension.d.ts +10 -10
  480. package/lib/engine-components/export/usdz/extensions/behavior/AudioExtension.js +86 -86
  481. package/lib/engine-components/export/usdz/extensions/behavior/Behaviour.d.ts +28 -28
  482. package/lib/engine-components/export/usdz/extensions/behavior/Behaviour.js +290 -290
  483. package/lib/engine-components/export/usdz/extensions/behavior/BehaviourComponents.d.ts +190 -190
  484. package/lib/engine-components/export/usdz/extensions/behavior/BehaviourComponents.js +1060 -1060
  485. package/lib/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.d.ts +135 -135
  486. package/lib/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.js +548 -548
  487. package/lib/engine-components/export/usdz/extensions/behavior/PhysicsExtension.d.ts +7 -7
  488. package/lib/engine-components/export/usdz/extensions/behavior/PhysicsExtension.js +115 -115
  489. package/lib/engine-components/export/usdz/index.d.ts +3 -3
  490. package/lib/engine-components/export/usdz/index.js +2 -2
  491. package/lib/engine-components/export/usdz/utils/animationutils.d.ts +7 -7
  492. package/lib/engine-components/export/usdz/utils/animationutils.js +163 -163
  493. package/lib/engine-components/export/usdz/utils/quicklook.d.ts +2 -2
  494. package/lib/engine-components/export/usdz/utils/quicklook.js +43 -43
  495. package/lib/engine-components/particlesystem/ParticleSystem.d.ts +177 -177
  496. package/lib/engine-components/particlesystem/ParticleSystem.js +1176 -1176
  497. package/lib/engine-components/particlesystem/ParticleSystemModules.d.ts +526 -526
  498. package/lib/engine-components/particlesystem/ParticleSystemModules.js +1930 -1930
  499. package/lib/engine-components/particlesystem/ParticleSystemSubEmitter.d.ts +25 -25
  500. package/lib/engine-components/particlesystem/ParticleSystemSubEmitter.js +87 -87
  501. package/lib/engine-components/particlesystem/api.d.ts +2 -2
  502. package/lib/engine-components/particlesystem/api.js +2 -2
  503. package/lib/engine-components/postprocessing/Effects/Antialiasing.d.ts +17 -17
  504. package/lib/engine-components/postprocessing/Effects/Antialiasing.js +50 -50
  505. package/lib/engine-components/postprocessing/Effects/BloomEffect.d.ts +46 -46
  506. package/lib/engine-components/postprocessing/Effects/BloomEffect.js +113 -113
  507. package/lib/engine-components/postprocessing/Effects/ChromaticAberration.d.ts +11 -11
  508. package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js +39 -39
  509. package/lib/engine-components/postprocessing/Effects/ColorAdjustments.d.ts +15 -15
  510. package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js +92 -92
  511. package/lib/engine-components/postprocessing/Effects/DepthOfField.d.ts +25 -25
  512. package/lib/engine-components/postprocessing/Effects/DepthOfField.js +104 -104
  513. package/lib/engine-components/postprocessing/Effects/EffectWrapper.d.ts +12 -12
  514. package/lib/engine-components/postprocessing/Effects/EffectWrapper.js +18 -18
  515. package/lib/engine-components/postprocessing/Effects/Pixelation.d.ts +11 -11
  516. package/lib/engine-components/postprocessing/Effects/Pixelation.js +32 -32
  517. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.d.ts +18 -18
  518. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js +91 -91
  519. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.d.ts +70 -70
  520. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.js +175 -175
  521. package/lib/engine-components/postprocessing/Effects/Sharpening.d.ts +17 -17
  522. package/lib/engine-components/postprocessing/Effects/Sharpening.js +123 -123
  523. package/lib/engine-components/postprocessing/Effects/TiltShiftEffect.d.ts +17 -17
  524. package/lib/engine-components/postprocessing/Effects/TiltShiftEffect.js +70 -70
  525. package/lib/engine-components/postprocessing/Effects/Tonemapping.d.ts +26 -26
  526. package/lib/engine-components/postprocessing/Effects/Tonemapping.js +138 -138
  527. package/lib/engine-components/postprocessing/Effects/Vignette.d.ts +15 -15
  528. package/lib/engine-components/postprocessing/Effects/Vignette.js +60 -60
  529. package/lib/engine-components/postprocessing/PostProcessingEffect.d.ts +72 -72
  530. package/lib/engine-components/postprocessing/PostProcessingEffect.js +149 -149
  531. package/lib/engine-components/postprocessing/PostProcessingHandler.d.ts +25 -25
  532. package/lib/engine-components/postprocessing/PostProcessingHandler.js +350 -350
  533. package/lib/engine-components/postprocessing/Volume.d.ts +89 -89
  534. package/lib/engine-components/postprocessing/Volume.js +367 -367
  535. package/lib/engine-components/postprocessing/VolumeParameter.d.ts +26 -26
  536. package/lib/engine-components/postprocessing/VolumeParameter.js +136 -136
  537. package/lib/engine-components/postprocessing/VolumeProfile.d.ts +15 -15
  538. package/lib/engine-components/postprocessing/VolumeProfile.js +60 -60
  539. package/lib/engine-components/postprocessing/index.d.ts +5 -5
  540. package/lib/engine-components/postprocessing/index.js +5 -5
  541. package/lib/engine-components/postprocessing/utils.d.ts +11 -11
  542. package/lib/engine-components/postprocessing/utils.js +37 -37
  543. package/lib/engine-components/timeline/PlayableDirector.d.ts +163 -163
  544. package/lib/engine-components/timeline/PlayableDirector.js +686 -686
  545. package/lib/engine-components/timeline/SignalAsset.d.ts +24 -24
  546. package/lib/engine-components/timeline/SignalAsset.js +130 -130
  547. package/lib/engine-components/timeline/TimelineModels.d.ts +89 -89
  548. package/lib/engine-components/timeline/TimelineModels.js +22 -22
  549. package/lib/engine-components/timeline/TimelineTracks.d.ts +110 -110
  550. package/lib/engine-components/timeline/TimelineTracks.js +879 -879
  551. package/lib/engine-components/timeline/index.d.ts +4 -4
  552. package/lib/engine-components/timeline/index.js +3 -3
  553. package/lib/engine-components/ui/BaseUIComponent.d.ts +49 -49
  554. package/lib/engine-components/ui/BaseUIComponent.js +170 -170
  555. package/lib/engine-components/ui/Button.d.ts +64 -64
  556. package/lib/engine-components/ui/Button.js +315 -315
  557. package/lib/engine-components/ui/Canvas.d.ts +74 -74
  558. package/lib/engine-components/ui/Canvas.js +407 -407
  559. package/lib/engine-components/ui/CanvasGroup.d.ts +19 -19
  560. package/lib/engine-components/ui/CanvasGroup.js +58 -58
  561. package/lib/engine-components/ui/EventSystem.d.ts +125 -125
  562. package/lib/engine-components/ui/EventSystem.js +764 -764
  563. package/lib/engine-components/ui/Graphic.d.ts +55 -55
  564. package/lib/engine-components/ui/Graphic.js +254 -254
  565. package/lib/engine-components/ui/Image.d.ts +35 -35
  566. package/lib/engine-components/ui/Image.js +116 -116
  567. package/lib/engine-components/ui/InputField.d.ts +42 -42
  568. package/lib/engine-components/ui/InputField.js +268 -268
  569. package/lib/engine-components/ui/Interfaces.d.ts +38 -38
  570. package/lib/engine-components/ui/Interfaces.js +12 -12
  571. package/lib/engine-components/ui/Layout.d.ts +84 -84
  572. package/lib/engine-components/ui/Layout.js +330 -330
  573. package/lib/engine-components/ui/Outline.d.ts +7 -7
  574. package/lib/engine-components/ui/Outline.js +20 -20
  575. package/lib/engine-components/ui/PointerEvents.d.ts +115 -115
  576. package/lib/engine-components/ui/PointerEvents.js +145 -145
  577. package/lib/engine-components/ui/RaycastUtils.d.ts +11 -11
  578. package/lib/engine-components/ui/RaycastUtils.js +67 -67
  579. package/lib/engine-components/ui/Raycaster.d.ts +30 -30
  580. package/lib/engine-components/ui/Raycaster.js +95 -95
  581. package/lib/engine-components/ui/RectTransform.d.ts +61 -61
  582. package/lib/engine-components/ui/RectTransform.js +353 -353
  583. package/lib/engine-components/ui/SpatialHtml.d.ts +8 -8
  584. package/lib/engine-components/ui/SpatialHtml.js +79 -79
  585. package/lib/engine-components/ui/Text.d.ts +78 -78
  586. package/lib/engine-components/ui/Text.js +539 -539
  587. package/lib/engine-components/ui/Utils.d.ts +24 -24
  588. package/lib/engine-components/ui/Utils.js +90 -90
  589. package/lib/engine-components/ui/index.d.ts +1 -1
  590. package/lib/engine-components/ui/index.js +1 -1
  591. package/lib/engine-components/utils/EnvironmentScene.d.ts +5 -5
  592. package/lib/engine-components/utils/EnvironmentScene.js +205 -205
  593. package/lib/engine-components/utils/LookAt.d.ts +31 -31
  594. package/lib/engine-components/utils/LookAt.js +82 -82
  595. package/lib/engine-components/utils/OpenURL.d.ts +42 -42
  596. package/lib/engine-components/utils/OpenURL.js +119 -119
  597. package/lib/engine-components/webxr/Avatar.d.ts +25 -25
  598. package/lib/engine-components/webxr/Avatar.js +255 -255
  599. package/lib/engine-components/webxr/TeleportTarget.d.ts +7 -7
  600. package/lib/engine-components/webxr/TeleportTarget.js +7 -7
  601. package/lib/engine-components/webxr/WebARCameraBackground.d.ts +30 -30
  602. package/lib/engine-components/webxr/WebARCameraBackground.js +155 -155
  603. package/lib/engine-components/webxr/WebARSessionRoot.d.ts +98 -98
  604. package/lib/engine-components/webxr/WebARSessionRoot.js +770 -770
  605. package/lib/engine-components/webxr/WebXR.d.ts +232 -232
  606. package/lib/engine-components/webxr/WebXR.js +561 -561
  607. package/lib/engine-components/webxr/WebXRAvatar.d.ts +27 -27
  608. package/lib/engine-components/webxr/WebXRAvatar.js +44 -44
  609. package/lib/engine-components/webxr/WebXRImageTracking.d.ts +86 -86
  610. package/lib/engine-components/webxr/WebXRImageTracking.js +470 -470
  611. package/lib/engine-components/webxr/WebXRPlaneTracking.d.ts +92 -92
  612. package/lib/engine-components/webxr/WebXRPlaneTracking.js +500 -500
  613. package/lib/engine-components/webxr/WebXRRig.d.ts +32 -32
  614. package/lib/engine-components/webxr/WebXRRig.js +72 -72
  615. package/lib/engine-components/webxr/XRFlag.d.ts +38 -38
  616. package/lib/engine-components/webxr/XRFlag.js +139 -139
  617. package/lib/engine-components/webxr/controllers/XRControllerFollow.d.ts +47 -47
  618. package/lib/engine-components/webxr/controllers/XRControllerFollow.js +120 -120
  619. package/lib/engine-components/webxr/controllers/XRControllerModel.d.ts +43 -43
  620. package/lib/engine-components/webxr/controllers/XRControllerModel.js +351 -351
  621. package/lib/engine-components/webxr/controllers/XRControllerMovement.d.ts +78 -78
  622. package/lib/engine-components/webxr/controllers/XRControllerMovement.js +506 -506
  623. package/lib/engine-components/webxr/index.d.ts +3 -3
  624. package/lib/engine-components/webxr/index.js +3 -3
  625. package/lib/engine-components/webxr/types.d.ts +3 -3
  626. package/lib/engine-components/webxr/types.js +1 -1
  627. package/lib/engine-components-experimental/Presentation.d.ts +6 -6
  628. package/lib/engine-components-experimental/Presentation.js +9 -9
  629. package/lib/engine-components-experimental/api.d.ts +4 -4
  630. package/lib/engine-components-experimental/api.js +4 -4
  631. package/lib/engine-components-experimental/networking/PlayerSync.d.ts +156 -156
  632. package/lib/engine-components-experimental/networking/PlayerSync.js +377 -377
  633. package/lib/engine-schemes/api.d.ts +12 -12
  634. package/lib/engine-schemes/api.js +12 -12
  635. package/lib/engine-schemes/schemes.d.ts +7 -7
  636. package/lib/engine-schemes/schemes.js +19 -19
  637. package/lib/engine-schemes/synced-camera-model.d.ts +25 -25
  638. package/lib/engine-schemes/synced-camera-model.js +67 -67
  639. package/lib/engine-schemes/synced-transform-model.d.ts +31 -31
  640. package/lib/engine-schemes/synced-transform-model.js +66 -66
  641. package/lib/engine-schemes/transform.d.ts +12 -12
  642. package/lib/engine-schemes/transform.js +39 -39
  643. package/lib/engine-schemes/vec2.d.ts +10 -10
  644. package/lib/engine-schemes/vec2.js +25 -25
  645. package/lib/engine-schemes/vec3.d.ts +11 -11
  646. package/lib/engine-schemes/vec3.js +29 -29
  647. package/lib/engine-schemes/vec4.d.ts +12 -12
  648. package/lib/engine-schemes/vec4.js +33 -33
  649. package/lib/engine-schemes/vr-user-state-buffer.d.ts +37 -37
  650. package/lib/engine-schemes/vr-user-state-buffer.js +110 -110
  651. package/lib/include/three/EXT_mesh_gpu_instancing_exporter.d.ts +6 -6
  652. package/lib/include/three/EXT_mesh_gpu_instancing_exporter.js +45 -45
  653. package/lib/needle-engine.d.ts +7 -7
  654. package/lib/needle-engine.js +64 -64
  655. package/package.json +2 -2
  656. package/plugins/common/buildinfo.js +64 -64
  657. package/plugins/common/cloud.js +1 -1
  658. package/plugins/common/config.cjs +31 -31
  659. package/plugins/common/config.js +35 -35
  660. package/plugins/common/files.js +31 -31
  661. package/plugins/common/generator.js +10 -10
  662. package/plugins/common/license.js +355 -341
  663. package/plugins/common/npm.js +15 -15
  664. package/plugins/common/timers.js +7 -7
  665. package/plugins/common/version.js +37 -37
  666. package/plugins/gltf-packer.mjs +1 -1
  667. package/plugins/next/alias.cjs +39 -39
  668. package/plugins/next/license.cjs +18 -18
  669. package/plugins/next/meshbvhworker.cjs +18 -18
  670. package/plugins/next/next.js +128 -128
  671. package/plugins/types/index.d.ts +2 -2
  672. package/plugins/types/license.d.ts +24 -24
  673. package/plugins/types/needleConfig.d.ts +27 -27
  674. package/plugins/types/userconfig.d.ts +108 -108
  675. package/plugins/types/webmanifest.d.ts +32 -32
  676. package/plugins/vite/alias.js +174 -174
  677. package/plugins/vite/asap.js +245 -245
  678. package/plugins/vite/build-pipeline.js +355 -355
  679. package/plugins/vite/build.js +19 -19
  680. package/plugins/vite/buildinfo.js +41 -41
  681. package/plugins/vite/config.js +106 -106
  682. package/plugins/vite/copyfiles.js +138 -138
  683. package/plugins/vite/defines.js +66 -66
  684. package/plugins/vite/dependencies.js +223 -223
  685. package/plugins/vite/dependency-watcher.js +231 -231
  686. package/plugins/vite/drop-client.js +76 -76
  687. package/plugins/vite/drop.js +87 -87
  688. package/plugins/vite/editor-connection.js +124 -124
  689. package/plugins/vite/facebook-instant-games.js +99 -99
  690. package/plugins/vite/gzip.js +5 -5
  691. package/plugins/vite/imports-logger.js +143 -143
  692. package/plugins/vite/index.js +139 -139
  693. package/plugins/vite/license.js +55 -55
  694. package/plugins/vite/meta.js +163 -163
  695. package/plugins/vite/npm.js +7 -7
  696. package/plugins/vite/peer.js +29 -29
  697. package/plugins/vite/poster-client.js +73 -73
  698. package/plugins/vite/poster.js +79 -79
  699. package/plugins/vite/pwa.js +604 -604
  700. package/plugins/vite/reload-client.js +15 -15
  701. package/plugins/vite/reload.js +363 -363
  702. package/plugins/vite/server.js +66 -66
  703. package/plugins/vite/transform-codegen.js +55 -55
  704. package/plugins/vite/transform.js +31 -31
  705. package/plugins/vite/vite-4.4-hack.js +31 -31
  706. package/src/asap/needle-asap.ts +111 -111
  707. package/src/asap/sessiongranted.ts +75 -75
  708. package/src/asap/utils.ts +4 -4
  709. package/src/engine/analytics/index.ts +10 -10
  710. package/src/engine/analytics/lcp.ts +35 -35
  711. package/src/engine/api.ts +81 -81
  712. package/src/engine/assets/index.ts +59 -59
  713. package/src/engine/assets/static.js +5 -5
  714. package/src/engine/codegen/register_types.ts +300 -300
  715. package/src/engine/debug/debug.ts +51 -51
  716. package/src/engine/debug/debug_console.ts +333 -333
  717. package/src/engine/debug/debug_overlay.ts +332 -332
  718. package/src/engine/debug/debug_spatial_console.ts +429 -429
  719. package/src/engine/debug/index.ts +1 -1
  720. package/src/engine/engine_addressables.ts +679 -679
  721. package/src/engine/engine_animation.ts +145 -145
  722. package/src/engine/engine_application.ts +113 -113
  723. package/src/engine/engine_assetdatabase.ts +387 -387
  724. package/src/engine/engine_audio.ts +24 -24
  725. package/src/engine/engine_camera.ts +39 -39
  726. package/src/engine/engine_components.ts +374 -374
  727. package/src/engine/engine_components_internal.ts +40 -40
  728. package/src/engine/engine_constants.ts +52 -52
  729. package/src/engine/engine_context.ts +1686 -1686
  730. package/src/engine/engine_context_registry.ts +129 -129
  731. package/src/engine/engine_coroutine.ts +54 -54
  732. package/src/engine/engine_create_objects.ts +398 -398
  733. package/src/engine/engine_default_parameters.ts +3 -3
  734. package/src/engine/engine_editor-sync.ts +28 -28
  735. package/src/engine/engine_element.ts +872 -869
  736. package/src/engine/engine_element_attributes.ts +85 -85
  737. package/src/engine/engine_element_extras.ts +16 -16
  738. package/src/engine/engine_element_loading.ts +381 -381
  739. package/src/engine/engine_element_overlay.ts +186 -186
  740. package/src/engine/engine_fileloader.js +9 -9
  741. package/src/engine/engine_gameobject.ts +684 -684
  742. package/src/engine/engine_generic_utils.js +13 -13
  743. package/src/engine/engine_gizmos.ts +577 -577
  744. package/src/engine/engine_gltf.ts +29 -29
  745. package/src/engine/engine_gltf_builtin_components.ts +403 -403
  746. package/src/engine/engine_hot_reload.ts +198 -198
  747. package/src/engine/engine_input.ts +1460 -1460
  748. package/src/engine/engine_input_utils.ts +23 -23
  749. package/src/engine/engine_instancing.ts +45 -45
  750. package/src/engine/engine_license.ts +378 -329
  751. package/src/engine/engine_lifecycle_api.ts +106 -106
  752. package/src/engine/engine_lifecycle_functions_internal.ts +193 -193
  753. package/src/engine/engine_lightdata.ts +117 -117
  754. package/src/engine/engine_loaders.ts +82 -82
  755. package/src/engine/engine_lods.ts +168 -168
  756. package/src/engine/engine_mainloop_utils.ts +472 -472
  757. package/src/engine/engine_math.ts +282 -282
  758. package/src/engine/engine_modules.ts +83 -83
  759. package/src/engine/engine_networking.ts +841 -841
  760. package/src/engine/engine_networking_auto.ts +352 -352
  761. package/src/engine/engine_networking_blob.ts +254 -254
  762. package/src/engine/engine_networking_files.ts +217 -217
  763. package/src/engine/engine_networking_files_default_components.ts +58 -58
  764. package/src/engine/engine_networking_instantiate.ts +419 -419
  765. package/src/engine/engine_networking_peer.ts +159 -159
  766. package/src/engine/engine_networking_streams.ts +713 -713
  767. package/src/engine/engine_networking_types.ts +24 -24
  768. package/src/engine/engine_networking_utils.ts +23 -23
  769. package/src/engine/engine_networking_websocket.ts +2 -2
  770. package/src/engine/engine_patcher.ts +199 -199
  771. package/src/engine/engine_physics.ts +783 -783
  772. package/src/engine/engine_physics.types.ts +46 -46
  773. package/src/engine/engine_physics_rapier.ts +1579 -1579
  774. package/src/engine/engine_playerview.ts +80 -80
  775. package/src/engine/engine_scenelighting.ts +294 -294
  776. package/src/engine/engine_scenetools.ts +365 -365
  777. package/src/engine/engine_serialization.ts +2 -2
  778. package/src/engine/engine_serialization_builtin_serializer.ts +473 -473
  779. package/src/engine/engine_serialization_core.ts +705 -705
  780. package/src/engine/engine_serialization_decorator.ts +80 -80
  781. package/src/engine/engine_setup.ts +1 -1
  782. package/src/engine/engine_shaders.ts +267 -267
  783. package/src/engine/engine_shims.ts +32 -32
  784. package/src/engine/engine_test_utils.ts +109 -109
  785. package/src/engine/engine_texture.ts +82 -82
  786. package/src/engine/engine_three_utils.ts +849 -849
  787. package/src/engine/engine_time.ts +94 -94
  788. package/src/engine/engine_time_utils.ts +237 -237
  789. package/src/engine/engine_tonemapping.ts +210 -210
  790. package/src/engine/engine_types.ts +714 -714
  791. package/src/engine/engine_typestore.ts +63 -63
  792. package/src/engine/engine_util_decorator.ts +136 -136
  793. package/src/engine/engine_utils.ts +972 -972
  794. package/src/engine/engine_utils_format.ts +212 -212
  795. package/src/engine/engine_utils_screenshot.ts +698 -698
  796. package/src/engine/engine_utils_screenshot.xr.ts +103 -103
  797. package/src/engine/export/gltf/Writers.ts +34 -34
  798. package/src/engine/export/gltf/index.ts +158 -158
  799. package/src/engine/export/index.ts +2 -2
  800. package/src/engine/export/state.ts +19 -19
  801. package/src/engine/export/utils.ts +9 -9
  802. package/src/engine/extensions/EXT_texture_exr.ts +50 -50
  803. package/src/engine/extensions/NEEDLE_animator_controller_model.ts +195 -195
  804. package/src/engine/extensions/NEEDLE_components.ts +268 -268
  805. package/src/engine/extensions/NEEDLE_gameobject_data.ts +81 -81
  806. package/src/engine/extensions/NEEDLE_lighting_settings.ts +185 -185
  807. package/src/engine/extensions/NEEDLE_lightmaps.ts +119 -119
  808. package/src/engine/extensions/NEEDLE_persistent_assets.ts +76 -76
  809. package/src/engine/extensions/NEEDLE_render_objects.ts +209 -209
  810. package/src/engine/extensions/NEEDLE_techniques_webgl.ts +640 -640
  811. package/src/engine/extensions/extension_resolver.ts +4 -4
  812. package/src/engine/extensions/extension_utils.ts +166 -166
  813. package/src/engine/extensions/extensions.ts +135 -135
  814. package/src/engine/extensions/index.ts +5 -5
  815. package/src/engine/extensions/usage_tracker.ts +100 -100
  816. package/src/engine/js-extensions/Camera.ts +37 -37
  817. package/src/engine/js-extensions/ExtensionUtils.ts +85 -85
  818. package/src/engine/js-extensions/Layers.ts +23 -23
  819. package/src/engine/js-extensions/Object3D.ts +296 -296
  820. package/src/engine/js-extensions/RGBAColor.ts +125 -125
  821. package/src/engine/js-extensions/Vector.ts +18 -18
  822. package/src/engine/js-extensions/index.ts +4 -4
  823. package/src/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +122 -122
  824. package/src/engine/shaders/shaderData.ts +67 -67
  825. package/src/engine/tests/test_utils.ts +63 -63
  826. package/src/engine/webcomponents/WebXRButtons.ts +260 -260
  827. package/src/engine/webcomponents/api.ts +6 -6
  828. package/src/engine/webcomponents/buttons.ts +262 -262
  829. package/src/engine/webcomponents/fonts.ts +41 -41
  830. package/src/engine/webcomponents/icons.ts +57 -57
  831. package/src/engine/webcomponents/index.ts +1 -1
  832. package/src/engine/webcomponents/logo-element.ts +78 -78
  833. package/src/engine/webcomponents/needle menu/needle-menu-spatial.ts +573 -573
  834. package/src/engine/webcomponents/needle menu/needle-menu.ts +1118 -1107
  835. package/src/engine/webcomponents/needle-button.ts +181 -181
  836. package/src/engine/xr/NeedleXRController.ts +1125 -1125
  837. package/src/engine/xr/NeedleXRSession.ts +1585 -1585
  838. package/src/engine/xr/NeedleXRSync.ts +220 -220
  839. package/src/engine/xr/SceneTransition.ts +78 -78
  840. package/src/engine/xr/TempXRContext.ts +216 -216
  841. package/src/engine/xr/XRRig.ts +9 -9
  842. package/src/engine/xr/api.ts +5 -5
  843. package/src/engine/xr/events.ts +102 -102
  844. package/src/engine/xr/internal.ts +34 -34
  845. package/src/engine/xr/usdz.ts +30 -30
  846. package/src/engine/xr/utils.ts +39 -39
  847. package/src/engine-components/AlignmentConstraint.ts +36 -36
  848. package/src/engine-components/Animation.ts +557 -557
  849. package/src/engine-components/AnimationCurve.ts +150 -150
  850. package/src/engine-components/AnimationUtils.ts +28 -28
  851. package/src/engine-components/AnimationUtilsAutoplay.ts +43 -43
  852. package/src/engine-components/Animator.ts +397 -397
  853. package/src/engine-components/AnimatorController.ts +1293 -1293
  854. package/src/engine-components/AudioListener.ts +92 -92
  855. package/src/engine-components/AudioSource.ts +639 -639
  856. package/src/engine-components/AvatarLoader.ts +263 -263
  857. package/src/engine-components/AxesHelper.ts +59 -59
  858. package/src/engine-components/BasicIKConstraint.ts +54 -54
  859. package/src/engine-components/BoxCollider.ts +1 -1
  860. package/src/engine-components/BoxHelperComponent.ts +114 -114
  861. package/src/engine-components/Camera.ts +719 -719
  862. package/src/engine-components/CameraUtils.ts +136 -136
  863. package/src/engine-components/CharacterController.ts +253 -253
  864. package/src/engine-components/Collider.ts +374 -374
  865. package/src/engine-components/Component.ts +1294 -1294
  866. package/src/engine-components/ContactShadows.ts +482 -482
  867. package/src/engine-components/DeleteBox.ts +62 -62
  868. package/src/engine-components/DeviceFlag.ts +46 -46
  869. package/src/engine-components/DragControls.ts +1623 -1623
  870. package/src/engine-components/DropListener.ts +698 -698
  871. package/src/engine-components/Duplicatable.ts +198 -198
  872. package/src/engine-components/EventList.ts +266 -266
  873. package/src/engine-components/EventTrigger.ts +74 -74
  874. package/src/engine-components/EventType.ts +22 -22
  875. package/src/engine-components/Fog.ts +60 -60
  876. package/src/engine-components/Gizmos.ts +56 -56
  877. package/src/engine-components/GridHelper.ts +48 -48
  878. package/src/engine-components/GroundProjection.ts +356 -356
  879. package/src/engine-components/Interactable.ts +14 -14
  880. package/src/engine-components/Joints.ts +52 -52
  881. package/src/engine-components/LODGroup.ts +153 -153
  882. package/src/engine-components/Light.ts +558 -558
  883. package/src/engine-components/LookAtConstraint.ts +25 -25
  884. package/src/engine-components/NeedleMenu.ts +84 -84
  885. package/src/engine-components/NestedGltf.ts +86 -86
  886. package/src/engine-components/Networking.ts +114 -114
  887. package/src/engine-components/OffsetConstraint.ts +60 -60
  888. package/src/engine-components/OrbitControls.ts +1068 -1068
  889. package/src/engine-components/PlayerColor.ts +103 -103
  890. package/src/engine-components/ReflectionProbe.ts +216 -216
  891. package/src/engine-components/Renderer.ts +900 -900
  892. package/src/engine-components/RendererInstancing.ts +855 -855
  893. package/src/engine-components/RendererLightmap.ts +198 -198
  894. package/src/engine-components/RigidBody.ts +526 -526
  895. package/src/engine-components/SceneSwitcher.ts +1013 -1013
  896. package/src/engine-components/ScreenCapture.ts +592 -592
  897. package/src/engine-components/ShadowCatcher.ts +172 -172
  898. package/src/engine-components/Skybox.ts +455 -455
  899. package/src/engine-components/SmoothFollow.ts +76 -76
  900. package/src/engine-components/SpatialTrigger.ts +229 -229
  901. package/src/engine-components/SpectatorCamera.ts +787 -787
  902. package/src/engine-components/SphereCollider.ts +1 -1
  903. package/src/engine-components/SpriteRenderer.ts +468 -468
  904. package/src/engine-components/SyncedCamera.ts +220 -220
  905. package/src/engine-components/SyncedRoom.ts +380 -380
  906. package/src/engine-components/SyncedTransform.ts +383 -383
  907. package/src/engine-components/TestRunner.ts +118 -118
  908. package/src/engine-components/TransformGizmo.ts +219 -219
  909. package/src/engine-components/VideoPlayer.ts +1025 -1025
  910. package/src/engine-components/Voip.ts +363 -363
  911. package/src/engine-components/api.ts +60 -60
  912. package/src/engine-components/avatar/AvatarBlink_Simple.ts +69 -69
  913. package/src/engine-components/avatar/AvatarEyeLook_Rotation.ts +63 -63
  914. package/src/engine-components/avatar/Avatar_Brain_LookAt.ts +139 -139
  915. package/src/engine-components/avatar/Avatar_MouthShapes.ts +83 -83
  916. package/src/engine-components/avatar/Avatar_MustacheShake.ts +31 -31
  917. package/src/engine-components/codegen/components.ts +217 -217
  918. package/src/engine-components/debug/LogStats.ts +21 -21
  919. package/src/engine-components/export/gltf/GltfExport.ts +265 -265
  920. package/src/engine-components/export/usdz/Extension.ts +24 -24
  921. package/src/engine-components/export/usdz/ThreeUSDZExporter.ts +2413 -2413
  922. package/src/engine-components/export/usdz/USDZExporter.ts +705 -705
  923. package/src/engine-components/export/usdz/extensions/Animation.ts +1204 -1204
  924. package/src/engine-components/export/usdz/extensions/DocumentExtension.ts +9 -9
  925. package/src/engine-components/export/usdz/extensions/USDZText.ts +240 -240
  926. package/src/engine-components/export/usdz/extensions/USDZUI.ts +189 -189
  927. package/src/engine-components/export/usdz/extensions/behavior/Actions.ts +99 -99
  928. package/src/engine-components/export/usdz/extensions/behavior/AudioExtension.ts +102 -102
  929. package/src/engine-components/export/usdz/extensions/behavior/Behaviour.ts +320 -320
  930. package/src/engine-components/export/usdz/extensions/behavior/BehaviourComponents.ts +1225 -1225
  931. package/src/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.ts +646 -646
  932. package/src/engine-components/export/usdz/extensions/behavior/PhysicsExtension.ts +132 -132
  933. package/src/engine-components/export/usdz/index.ts +2 -2
  934. package/src/engine-components/export/usdz/utils/animationutils.ts +191 -191
  935. package/src/engine-components/export/usdz/utils/quicklook.ts +50 -50
  936. package/src/engine-components/particlesystem/ParticleSystem.ts +1287 -1287
  937. package/src/engine-components/particlesystem/ParticleSystemModules.ts +1765 -1765
  938. package/src/engine-components/particlesystem/ParticleSystemSubEmitter.ts +111 -111
  939. package/src/engine-components/particlesystem/api.ts +1 -1
  940. package/src/engine-components/postprocessing/Effects/Antialiasing.ts +55 -55
  941. package/src/engine-components/postprocessing/Effects/BloomEffect.ts +116 -116
  942. package/src/engine-components/postprocessing/Effects/ChromaticAberration.ts +37 -37
  943. package/src/engine-components/postprocessing/Effects/ColorAdjustments.ts +95 -95
  944. package/src/engine-components/postprocessing/Effects/DepthOfField.ts +103 -103
  945. package/src/engine-components/postprocessing/Effects/EffectWrapper.ts +25 -25
  946. package/src/engine-components/postprocessing/Effects/Pixelation.ts +32 -32
  947. package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.ts +90 -90
  948. package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.ts +191 -191
  949. package/src/engine-components/postprocessing/Effects/Sharpening.ts +138 -138
  950. package/src/engine-components/postprocessing/Effects/TiltShiftEffect.ts +61 -61
  951. package/src/engine-components/postprocessing/Effects/Tonemapping.ts +155 -155
  952. package/src/engine-components/postprocessing/Effects/Vignette.ts +59 -59
  953. package/src/engine-components/postprocessing/PostProcessingEffect.ts +172 -172
  954. package/src/engine-components/postprocessing/PostProcessingHandler.ts +398 -398
  955. package/src/engine-components/postprocessing/Volume.ts +410 -410
  956. package/src/engine-components/postprocessing/VolumeParameter.ts +158 -158
  957. package/src/engine-components/postprocessing/VolumeProfile.ts +61 -61
  958. package/src/engine-components/postprocessing/index.ts +5 -5
  959. package/src/engine-components/postprocessing/utils.ts +52 -52
  960. package/src/engine-components/timeline/PlayableDirector.ts +722 -722
  961. package/src/engine-components/timeline/SignalAsset.ts +144 -144
  962. package/src/engine-components/timeline/TimelineModels.ts +92 -92
  963. package/src/engine-components/timeline/TimelineTracks.ts +967 -967
  964. package/src/engine-components/timeline/index.ts +3 -3
  965. package/src/engine-components/ui/BaseUIComponent.ts +203 -203
  966. package/src/engine-components/ui/Button.ts +307 -307
  967. package/src/engine-components/ui/Canvas.ts +419 -419
  968. package/src/engine-components/ui/CanvasGroup.ts +54 -54
  969. package/src/engine-components/ui/EventSystem.ts +853 -853
  970. package/src/engine-components/ui/Graphic.ts +275 -275
  971. package/src/engine-components/ui/Image.ts +112 -112
  972. package/src/engine-components/ui/InputField.ts +321 -321
  973. package/src/engine-components/ui/Interfaces.ts +57 -57
  974. package/src/engine-components/ui/Layout.ts +334 -334
  975. package/src/engine-components/ui/Outline.ts +13 -13
  976. package/src/engine-components/ui/PointerEvents.ts +206 -206
  977. package/src/engine-components/ui/RaycastUtils.ts +69 -69
  978. package/src/engine-components/ui/Raycaster.ts +102 -102
  979. package/src/engine-components/ui/RectTransform.ts +372 -372
  980. package/src/engine-components/ui/SpatialHtml.ts +79 -79
  981. package/src/engine-components/ui/Text.ts +578 -578
  982. package/src/engine-components/ui/Utils.ts +112 -112
  983. package/src/engine-components/utils/EnvironmentScene.ts +245 -245
  984. package/src/engine-components/utils/LookAt.ts +88 -88
  985. package/src/engine-components/utils/OpenURL.ts +114 -114
  986. package/src/engine-components/webxr/Avatar.ts +265 -265
  987. package/src/engine-components/webxr/TeleportTarget.ts +9 -9
  988. package/src/engine-components/webxr/WebARCameraBackground.ts +175 -175
  989. package/src/engine-components/webxr/WebARSessionRoot.ts +880 -880
  990. package/src/engine-components/webxr/WebXR.ts +585 -585
  991. package/src/engine-components/webxr/WebXRAvatar.ts +66 -66
  992. package/src/engine-components/webxr/WebXRImageTracking.ts +518 -518
  993. package/src/engine-components/webxr/WebXRPlaneTracking.ts +570 -570
  994. package/src/engine-components/webxr/WebXRRig.ts +77 -77
  995. package/src/engine-components/webxr/XRFlag.ts +147 -147
  996. package/src/engine-components/webxr/controllers/XRControllerFollow.ts +118 -118
  997. package/src/engine-components/webxr/controllers/XRControllerModel.ts +374 -374
  998. package/src/engine-components/webxr/controllers/XRControllerMovement.ts +550 -550
  999. package/src/engine-components/webxr/index.ts +2 -2
  1000. package/src/engine-components/webxr/types.ts +3 -3
  1001. package/src/engine-components-experimental/Presentation.ts +12 -12
  1002. package/src/engine-components-experimental/api.ts +4 -4
  1003. package/src/engine-components-experimental/networking/PlayerSync.ts +401 -401
  1004. package/src/engine-schemes/COMPILE_SCHEMES.bat +3 -3
  1005. package/src/engine-schemes/COMPILE_TS.bat +11 -11
  1006. package/src/engine-schemes/README.md +1 -1
  1007. package/src/engine-schemes/api.ts +12 -12
  1008. package/src/engine-schemes/dist/api.js +17 -0
  1009. package/src/engine-schemes/dist/api.js.meta +7 -0
  1010. package/src/engine-schemes/dist/schemes.js +25 -0
  1011. package/src/engine-schemes/dist/schemes.js.meta +7 -0
  1012. package/src/engine-schemes/dist/synced-camera-model.js +74 -0
  1013. package/src/engine-schemes/dist/synced-camera-model.js.meta +7 -0
  1014. package/src/engine-schemes/dist/synced-transform-model.js +73 -0
  1015. package/src/engine-schemes/dist/synced-transform-model.js.meta +7 -0
  1016. package/src/engine-schemes/dist/transform.js +46 -0
  1017. package/src/engine-schemes/dist/transform.js.meta +7 -0
  1018. package/src/engine-schemes/dist/vec2.js +32 -0
  1019. package/src/engine-schemes/dist/vec2.js.meta +7 -0
  1020. package/src/engine-schemes/dist/vec3.js +36 -0
  1021. package/src/engine-schemes/dist/vec3.js.meta +7 -0
  1022. package/src/engine-schemes/dist/vec4.js +40 -0
  1023. package/src/engine-schemes/dist/vec4.js.meta +7 -0
  1024. package/src/engine-schemes/dist/vr-user-state-buffer.js +110 -0
  1025. package/src/engine-schemes/dist/vr-user-state-buffer.js.meta +7 -0
  1026. package/src/engine-schemes/schemes.ts +28 -28
  1027. package/src/engine-schemes/synced-camera-model.ts +92 -92
  1028. package/src/engine-schemes/synced-transform-model.ts +90 -90
  1029. package/src/engine-schemes/syncedCamera.fbs +10 -10
  1030. package/src/engine-schemes/transform.ts +50 -50
  1031. package/src/engine-schemes/transforms.fbs +25 -25
  1032. package/src/engine-schemes/vec.fbs +19 -19
  1033. package/src/engine-schemes/vec2.ts +33 -33
  1034. package/src/engine-schemes/vec3.ts +38 -38
  1035. package/src/engine-schemes/vec4.ts +43 -43
  1036. package/src/engine-schemes/vr-user-state-buffer.ts +145 -145
  1037. package/src/engine-schemes/vrUserStateBuffer.fbs +17 -17
  1038. package/src/include/draco/draco_decoder.js +34 -34
  1039. package/src/include/ktx2/basis_transcoder.js +21 -21
  1040. package/src/include/needle/arial-msdf.json +1471 -1471
  1041. package/src/include/three/DragControls.js +231 -231
  1042. package/src/include/three/EXT_mesh_gpu_instancing_exporter.js +66 -66
  1043. package/src/needle-engine.ts +70 -70
@@ -1,771 +1,771 @@
1
- import { AxesHelper, DoubleSide, Matrix4, Mesh, MeshBasicMaterial, Object3D, Plane, Raycaster, RingGeometry, Scene, Vector3 } from "three";
2
- import { isDevEnvironment, showBalloonWarning } from "../../engine/debug/index.js";
3
- import { destroy, instantiate } from "../../engine/engine_gameobject.js";
4
- import { InputEventQueue } from "../../engine/engine_input.js";
5
- import { getBoundingBox, getTempVector } from "../../engine/engine_three_utils.js";
6
- import { DeviceUtilities, getParam } from "../../engine/engine_utils.js";
7
- import { NeedleXRController, NeedleXRSession } from "../../engine/engine_xr.js";
8
- import { Behaviour, GameObject } from "../Component.js";
9
- // https://github.com/takahirox/takahirox.github.io/blob/master/js.mmdeditor/examples/js/controls/DeviceOrientationControls.js
10
- const debug = getParam("debugwebxr");
11
- const invertForwardMatrix = new Matrix4().makeRotationY(Math.PI);
12
- /**
13
- * The WebARSessionRoot is the root object for a WebAR session and used to place the scene in AR.
14
- * It is also responsible for scaling the user in AR and optionally creating a XR anchor for the scene placement.
15
- * @example
16
- * ```ts
17
- * WebARSessionRoot.onPlaced((args) => {
18
- * console.log("Scene has been placed in AR");
19
- * });
20
- * ```
21
- *
22
- * @category XR
23
- * @group Components
24
- */
25
- export class WebARSessionRoot extends Behaviour {
26
- static _eventListeners = {};
27
- /**
28
- * Event that is called when the scene has been placed in AR.
29
- * @param cb the callback that is called when the scene has been placed
30
- * @returns a function to remove the event listener
31
- */
32
- static onPlaced(cb) {
33
- const event = "placed";
34
- if (!this._eventListeners[event])
35
- this._eventListeners[event] = [];
36
- this._eventListeners[event].push(cb);
37
- return () => {
38
- const index = this._eventListeners[event].indexOf(cb);
39
- if (index >= 0)
40
- this._eventListeners[event].splice(index, 1);
41
- };
42
- }
43
- static _hasPlaced = false;
44
- /**
45
- * @returns true if the scene has been placed in AR by the user or automatic placement
46
- */
47
- static get hasPlaced() {
48
- return this._hasPlaced;
49
- }
50
- /** The scale of the user in AR.
51
- * **NOTE**: a large value makes the scene appear smaller
52
- * @default 1
53
- */
54
- get arScale() {
55
- return this._arScale;
56
- }
57
- set arScale(val) {
58
- this._arScale = Math.max(0.000001, val);
59
- this.onSetScale();
60
- }
61
- _arScale = 1;
62
- /** When enabled the placed scene forward direction will towards the XRRig
63
- * @deprecated
64
- * @default false
65
- */
66
- invertForward = false;
67
- /** When assigned this asset will be loaded and visualize the placement while in AR
68
- * @default null
69
- */
70
- customReticle;
71
- /** Enable touch transform to translate, rotate and scale the scene in AR with multitouch
72
- * @default true
73
- */
74
- arTouchTransform = true;
75
- /** When enabled the scene will be placed automatically when a point in the real world is found
76
- * @default false
77
- */
78
- autoPlace = false;
79
- /** When enabled the scene center will be automatically calculated from the content in the scene */
80
- autoCenter = false;
81
- /** Experimental: When enabled we will create a XR anchor for the scene placement
82
- * and make sure the scene is at that anchored point during a XR session
83
- * @default false
84
- **/
85
- useXRAnchor = false;
86
- /** true if we're currently placing the scene */
87
- _isPlacing = true;
88
- /** This is the world matrix of the ar session root when entering webxr
89
- * it is applied when the scene has been placed (e.g. if the session root is x:10, z:10 we want this position to be the center of the scene)
90
- */
91
- _startOffset = new Matrix4();
92
- _createdPlacementObject = null;
93
- _reparentedComponents = [];
94
- // move objects into a temporary scene while placing (which is not rendered) so that the components won't be disabled during this process
95
- // e.g. we want the avatar to still be updated while placing
96
- // another possibly solution would be to ensure from this component that the Rig is *also* not disabled while placing
97
- _placementScene = new Scene();
98
- /** the reticles used for placement */
99
- _reticle = [];
100
- /** needs to be in sync with the reticles */
101
- _hits = [];
102
- _placementStartTime = -1;
103
- _rigPlacementMatrix;
104
- /** if useAnchor is enabled this is the anchor we have created on placing the scene using the placement hit */
105
- _anchor = null;
106
- /** user input is used for ar touch transform */
107
- userInput;
108
- onEnable() {
109
- this.customReticle?.preload();
110
- }
111
- supportsXR(mode) {
112
- return mode === "immersive-ar";
113
- }
114
- onEnterXR(_args) {
115
- if (debug)
116
- console.log("ENTER WEBXR: SessionRoot start...");
117
- this._anchor = null;
118
- WebARSessionRoot._hasPlaced = false;
119
- // if (_args.xr.session.enabledFeatures?.includes("image-tracking")) {
120
- // console.warn("Image tracking is enabled - will not place scene");
121
- // return;
122
- // }
123
- // save the transform of the session root in the scene to apply it when placing the scene
124
- this.gameObject.updateMatrixWorld();
125
- this._startOffset.copy(this.gameObject.matrixWorld);
126
- // create a new root object for the session placement scripts
127
- // and move all the children in the scene in a temporary scene that is not rendered
128
- const rootObject = new Object3D();
129
- this._createdPlacementObject = rootObject;
130
- rootObject.name = "AR Session Root";
131
- this._placementScene.name = "AR Placement Scene";
132
- this._placementScene.children.length = 0;
133
- for (let i = this.context.scene.children.length - 1; i >= 0; i--) {
134
- const ch = this.context.scene.children[i];
135
- this._placementScene.add(ch);
136
- }
137
- this.context.scene.add(rootObject);
138
- if (this.autoCenter) {
139
- const bounds = getBoundingBox(this._placementScene.children);
140
- const center = bounds.getCenter(new Vector3());
141
- const size = bounds.getSize(new Vector3());
142
- const matrix = new Matrix4();
143
- matrix.makeTranslation(center.x, center.y - size.y * .5, center.z);
144
- this._startOffset.multiply(matrix);
145
- }
146
- // reparent components
147
- // save which gameobject the sessionroot component was previously attached to
148
- this._reparentedComponents.length = 0;
149
- this._reparentedComponents.push({ comp: this, originalObject: this.gameObject });
150
- GameObject.addComponent(rootObject, this);
151
- // const webXR = GameObject.findObjectOfType(WebXR2);
152
- // if (webXR) {
153
- // this._reparentedComponents.push({ comp: webXR, originalObject: webXR.gameObject });
154
- // GameObject.addComponent(rootObject, webXR);
155
- // const playerSync = GameObject.findObjectOfType(XRFlag);
156
- // }
157
- // recreate the reticle every time we enter AR
158
- for (const ret of this._reticle) {
159
- destroy(ret);
160
- }
161
- this._reticle.length = 0;
162
- this._isPlacing = true;
163
- // we want to receive pointer events EARLY and prevent interaction with other objects while placing by stopping the event propagation
164
- this.context.input.addEventListener("pointerup", this.onPlaceScene, { queue: InputEventQueue.Early });
165
- }
166
- onLeaveXR() {
167
- // TODO: WebARSessionRoot doesnt work when we enter passthrough and leave XR without having placed the session!!!
168
- this.context.input.removeEventListener("pointerup", this.onPlaceScene, { queue: InputEventQueue.Early });
169
- this.onRevertSceneChanges();
170
- // this._anchor?.delete();
171
- this._anchor = null;
172
- WebARSessionRoot._hasPlaced = false;
173
- this._rigPlacementMatrix = undefined;
174
- }
175
- onUpdateXR(args) {
176
- // disable session placement while images are being tracked
177
- if (args.xr.isTrackingImages) {
178
- for (const ret of this._reticle)
179
- ret.visible = false;
180
- return;
181
- }
182
- if (this._isPlacing) {
183
- const rigObject = args.xr.rig?.gameObject;
184
- // the rig should be parented to the scene while placing
185
- // since the camera is always parented to the rig this ensures that the camera is always rendering
186
- if (rigObject && rigObject.parent !== this.context.scene) {
187
- this.context.scene.add(rigObject);
188
- }
189
- // in pass through mode we want to place the scene using an XR controller
190
- let controllersDidHit = false;
191
- // when auto placing we just use the user's view
192
- if (args.xr.isPassThrough && args.xr.controllers.length > 0 && !this.autoPlace) {
193
- for (const ctrl of args.xr.controllers) {
194
- // with this we can only place with the left / first controller right now
195
- // we also only have one reticle... this should probably be refactored a bit so we can have multiple reticles
196
- // and then place at the reticle for which the user clicked the place button
197
- const hit = ctrl.getHitTest();
198
- if (hit) {
199
- controllersDidHit = true;
200
- this.updateReticleAndHits(args.xr, ctrl.index, hit, args.xr.rigScale);
201
- }
202
- }
203
- }
204
- // in screen AR mode we use "camera" hit testing (or when using the simulator where controller hit testing is not supported)
205
- if (!controllersDidHit) {
206
- const hit = args.xr.getHitTest();
207
- if (hit) {
208
- this.updateReticleAndHits(args.xr, 0, hit, args.xr.rigScale);
209
- }
210
- }
211
- }
212
- else {
213
- // Update anchors, if any
214
- if (this._anchor && args.xr.referenceSpace) {
215
- const pose = args.xr.frame.getPose(this._anchor.anchorSpace, args.xr.referenceSpace);
216
- if (pose && this.context.time.frame % 20 === 0) {
217
- // apply the anchor pose to one of the reticles
218
- const converted = args.xr.convertSpace(pose.transform);
219
- const reticle = this._reticle[0];
220
- if (reticle) {
221
- reticle.position.copy(converted.position);
222
- reticle.quaternion.copy(converted.quaternion);
223
- this.onApplyPose(reticle);
224
- }
225
- }
226
- }
227
- // Scene has been placed
228
- if (this.arTouchTransform) {
229
- if (!this.userInput)
230
- this.userInput = new WebXRSessionRootUserInput(this.context);
231
- this.userInput?.enable();
232
- }
233
- else
234
- this.userInput?.disable();
235
- if (this.arTouchTransform && this.userInput?.hasChanged) {
236
- if (args.xr.rig) {
237
- const rig = args.xr.rig.gameObject;
238
- this.userInput.applyMatrixTo(rig.matrix, true);
239
- rig.matrix.decompose(rig.position, rig.quaternion, rig.scale);
240
- // if the rig is scaled large we want the drag touch to be faster
241
- this.userInput.factor = rig.scale.x;
242
- }
243
- this.userInput.reset();
244
- }
245
- }
246
- }
247
- updateReticleAndHits(_xr, i, hit, scale) {
248
- // save the hit test
249
- this._hits[i] = hit.hit;
250
- let reticle = this._reticle[i];
251
- if (!reticle) {
252
- if (this.customReticle) {
253
- if (this.customReticle.asset) {
254
- reticle = instantiate(this.customReticle.asset);
255
- }
256
- else {
257
- this.customReticle.loadAssetAsync();
258
- return;
259
- }
260
- }
261
- else {
262
- reticle = new Mesh(new RingGeometry(0.07, 0.09, 32).rotateX(-Math.PI / 2), new MeshBasicMaterial({ side: DoubleSide, depthTest: false, depthWrite: false, transparent: true, opacity: 1, color: 0xeeeeee }));
263
- reticle.name = "AR Placement Reticle";
264
- }
265
- if (debug) {
266
- const axes = new AxesHelper(1);
267
- axes.position.y += .01;
268
- reticle.add(axes);
269
- }
270
- this._reticle[i] = reticle;
271
- reticle.matrixAutoUpdate = false;
272
- reticle.visible = false;
273
- }
274
- reticle["lastPos"] = reticle["lastPos"] || hit.position.clone();
275
- reticle["lastQuat"] = reticle["lastQuat"] || hit.quaternion.clone();
276
- // reticle["targetPos"] = reticle["targetPos"] || hit.position.clone();
277
- // reticle["targetQuat"] = reticle["targetQuat"] || hit.quaternion.clone();
278
- // TODO we likely want the reticle itself to be placed _exactly_ and then the visuals being lerped,
279
- // Right now this leads to a "rotation glitch" when going from a horizontal to a vertical surface
280
- reticle.position.copy(reticle["lastPos"].lerp(hit.position, this.context.time.deltaTime / .1));
281
- reticle["lastPos"].copy(reticle.position);
282
- reticle.quaternion.copy(reticle["lastQuat"].slerp(hit.quaternion, this.context.time.deltaTime / .05));
283
- reticle["lastQuat"].copy(reticle.quaternion);
284
- // TODO make sure original reticle asset scale is respected, or document it should be uniformly scaled
285
- // scale *= this.customReticle?.asset?.scale?.x || 1;
286
- reticle.scale.set(scale, scale, scale);
287
- // if (this.invertForward) {
288
- // reticle.rotateY(Math.PI);
289
- // }
290
- // Workaround: For a custom reticle we apply the view based transform during placement preview
291
- // See NE-4161 for context
292
- if (this.customReticle)
293
- this.applyViewBasedTransform(reticle);
294
- reticle.updateMatrix();
295
- reticle.visible = true;
296
- if (reticle.parent !== this.context.scene)
297
- this.context.scene.add(reticle);
298
- if (this._placementStartTime < 0) {
299
- this._placementStartTime = this.context.time.realtimeSinceStartup;
300
- }
301
- if (this.autoPlace) {
302
- this.upVec.set(0, 1, 0).applyQuaternion(reticle.quaternion);
303
- const isUp = this.upVec.dot(getTempVector(0, 1, 0)) > 0.9;
304
- if (isUp) {
305
- // We want the reticle to be at a suitable spot for a moment before we place the scene (not place it immediately)
306
- let autoplace_timer = reticle["autoplace:timer"] || 0;
307
- if (autoplace_timer >= 1) {
308
- reticle.visible = false;
309
- this.onPlaceScene(null);
310
- }
311
- else {
312
- autoplace_timer += this.context.time.deltaTime;
313
- reticle["autoplace:timer"] = autoplace_timer;
314
- }
315
- }
316
- else {
317
- reticle["autoplace:timer"] = 0;
318
- }
319
- }
320
- }
321
- onPlaceScene = (evt) => {
322
- if (this._isPlacing == false)
323
- return;
324
- if (evt?.used)
325
- return;
326
- let reticle = this._reticle[0];
327
- if (!reticle) {
328
- console.warn("No reticle to place...");
329
- return;
330
- }
331
- if (!reticle.visible && !this.autoPlace) {
332
- console.warn("Reticle is not visible (can not place)");
333
- return;
334
- }
335
- if (NeedleXRSession.active?.isTrackingImages) {
336
- console.warn("Scene Placement is disabled while images are being tracked");
337
- return;
338
- }
339
- let hit = this._hits[0];
340
- if (evt && evt.origin instanceof NeedleXRController) {
341
- // until we can use hit testing for both controllers and have multple reticles we only allow placement with the first controller
342
- const controllerReticle = this._reticle[evt.origin.index];
343
- if (controllerReticle) {
344
- reticle = controllerReticle;
345
- hit = this._hits[evt.origin.index];
346
- }
347
- }
348
- // if we place the scene we don't want this event to be propagated to any sub-objects (via the EventSystem) anymore and trigger e.g. a click on objects for the "place tap" event
349
- if (evt) {
350
- evt.stopImmediatePropagation();
351
- evt.stopPropagation();
352
- evt.use();
353
- }
354
- this._isPlacing = false;
355
- this.context.input.removeEventListener("pointerup", this.onPlaceScene);
356
- this.onRevertSceneChanges();
357
- // TODO: we should probably use the non-lerped position and quaternion here
358
- reticle.position.copy(reticle["lastPos"]);
359
- reticle.quaternion.copy(reticle["lastQuat"]);
360
- this.onApplyPose(reticle);
361
- WebARSessionRoot._hasPlaced = true;
362
- if (this.useXRAnchor) {
363
- this.onCreateAnchor(NeedleXRSession.active, hit);
364
- }
365
- if (this.context.xr) {
366
- for (const ctrl of this.context.xr.controllers) {
367
- ctrl.cancelHitTestSource();
368
- }
369
- }
370
- };
371
- onSetScale() {
372
- if (!WebARSessionRoot._hasPlaced)
373
- return;
374
- const rig = NeedleXRSession.active?.rig?.gameObject;
375
- if (rig) {
376
- const currentScale = NeedleXRSession.active?.rigScale || 1;
377
- const newScale = (1 / this._arScale) * currentScale;
378
- const scaleMatrix = new Matrix4().makeScale(newScale, newScale, newScale).invert();
379
- rig.matrix.premultiply(scaleMatrix);
380
- rig.matrix.decompose(rig.position, rig.quaternion, rig.scale);
381
- }
382
- }
383
- onRevertSceneChanges() {
384
- for (const ret of this._reticle) {
385
- if (!ret)
386
- continue;
387
- ret.visible = false;
388
- ret?.removeFromParent();
389
- }
390
- this._reticle.length = 0;
391
- for (let i = this._placementScene.children.length - 1; i >= 0; i--) {
392
- const ch = this._placementScene.children[i];
393
- this.context.scene.add(ch);
394
- }
395
- this._createdPlacementObject?.removeFromParent();
396
- for (const reparented of this._reparentedComponents) {
397
- GameObject.addComponent(reparented.originalObject, reparented.comp);
398
- }
399
- }
400
- async onCreateAnchor(session, hit) {
401
- if (hit.createAnchor === undefined) {
402
- console.warn("Hit does not support creating an anchor", hit);
403
- if (isDevEnvironment())
404
- showBalloonWarning("Hit does not support creating an anchor");
405
- return;
406
- }
407
- else {
408
- const anchor = await hit.createAnchor(session.viewerPose.transform);
409
- // make sure the session is still active
410
- if (session.running && anchor) {
411
- this._anchor = anchor;
412
- }
413
- }
414
- }
415
- upVec = new Vector3(0, 1, 0);
416
- lookPoint = new Vector3();
417
- worldUpVec = new Vector3(0, 1, 0);
418
- applyViewBasedTransform(reticle) {
419
- // Make reticle face the user to unify the placement experience across devices.
420
- // The pose that we're receiving from the hit test varies between devices:
421
- // - Quest: currently aligned to the mesh that was hit (depends on room setup), has changed a couple times
422
- // - Android WebXR: looking at the camera, but pretty random when on a wall
423
- // - Mozilla WebXR Viewer: aligned to the start of the session
424
- const camGo = this.context.mainCamera;
425
- const reticleGo = reticle;
426
- const camWP = camGo.worldPosition;
427
- const reticleWp = reticleGo.worldPosition;
428
- this.upVec.set(0, 1, 0).applyQuaternion(reticle.quaternion);
429
- // upVec may be pointing AWAY from us, we have to flip it if that's the case
430
- const camPos = camGo.worldPosition;
431
- if (camPos) {
432
- const camToReticle = reticle.position.clone().sub(camPos);
433
- const angle = camToReticle.angleTo(this.upVec);
434
- if (angle < Math.PI / 2) {
435
- this.upVec.negate();
436
- }
437
- }
438
- const upAngle = this.upVec.angleTo(this.worldUpVec) * 180 / Math.PI;
439
- // For debugging look angle for AR placement
440
- // Gizmos.DrawDirection(reticle.position, upVec, "blue", 0.1);
441
- // Gizmos.DrawLabel(reticle.position, upAngle.toFixed(2), 0.1);
442
- const angleForWallPlacement = 30;
443
- if ((upAngle > angleForWallPlacement && upAngle < 180 - angleForWallPlacement) ||
444
- (upAngle < -angleForWallPlacement && upAngle > -180 + angleForWallPlacement)) {
445
- this.lookPoint.copy(reticle.position).add(this.upVec);
446
- this.lookPoint.y = reticle.position.y;
447
- reticle.lookAt(this.lookPoint);
448
- }
449
- else {
450
- camWP.y = reticleWp.y;
451
- reticle.lookAt(camWP);
452
- }
453
- // TODO: ability to scale the reticle so that we can fit the scene depending on the view angle or distance to the reticle.
454
- // Currently, doing this leads to wrong placement of the scene.
455
- /*
456
- const rigScale = NeedleXRSession.active?.rigScale || 1;
457
- const scale = distance * rigScale;
458
- reticle.scale.set(scale, scale, scale);
459
- */
460
- }
461
- onApplyPose(reticle) {
462
- const rigObject = NeedleXRSession.active?.rig?.gameObject;
463
- if (!rigObject) {
464
- console.warn("No rig object to place");
465
- return;
466
- }
467
- // const rigScale = NeedleXRSession.active?.rigScale || 1;
468
- // save the previous rig parent
469
- const previousParent = rigObject.parent || this.context.scene;
470
- // if we have placed this rig before and this is just "replacing" with the anchor
471
- // we need to make sure the XRRig attached to the reticle is at the same position as last time
472
- // since in the following code we move it inside the reticle (relative to the reticle)
473
- if (this._rigPlacementMatrix) {
474
- this._rigPlacementMatrix?.decompose(rigObject.position, rigObject.quaternion, rigObject.scale);
475
- }
476
- else {
477
- this._rigPlacementMatrix = rigObject.matrix.clone();
478
- }
479
- this.applyViewBasedTransform(reticle);
480
- reticle.updateMatrix();
481
- // attach rig to reticle (since the reticle is in rig space it's a easy way to place the rig where we want it relative to the reticle)
482
- this.context.scene.add(reticle);
483
- reticle.attach(rigObject);
484
- reticle.removeFromParent();
485
- // move rig now relative to the reticle
486
- // TODO support scaled reticle
487
- rigObject.scale.set(this.arScale, this.arScale, this.arScale);
488
- rigObject.position.multiplyScalar(this.arScale);
489
- rigObject.updateMatrix();
490
- // if invert forward is disabled we need to invert the forward rotation
491
- // we want to look into positive Z direction (if invertForward is enabled we look into negative Z direction)
492
- if (this.invertForward)
493
- rigObject.matrix.premultiply(invertForwardMatrix);
494
- rigObject.matrix.premultiply(this._startOffset);
495
- // apply the rig modifications and add it back to the previous parent
496
- rigObject.matrix.decompose(rigObject.position, rigObject.quaternion, rigObject.scale);
497
- previousParent.add(rigObject);
498
- }
499
- }
500
- class WebXRSessionRootUserInput {
501
- static up = new Vector3(0, 1, 0);
502
- static zero = new Vector3(0, 0, 0);
503
- static one = new Vector3(1, 1, 1);
504
- oneFingerDrag = true;
505
- twoFingerRotate = true;
506
- twoFingerScale = true;
507
- factor = 1;
508
- context;
509
- offset;
510
- plane;
511
- _scale = 1;
512
- _hasChanged = false;
513
- get scale() {
514
- return this._scale;
515
- }
516
- // readonly translate: Vector3 = new Vector3();
517
- // readonly rotation: Quaternion = new Quaternion();
518
- // readonly scale: Vector3 = new Vector3(1, 1, 1);
519
- constructor(context) {
520
- this.context = context;
521
- this.offset = new Matrix4();
522
- this.plane = new Plane();
523
- this.plane.setFromNormalAndCoplanarPoint(WebXRSessionRootUserInput.up, WebXRSessionRootUserInput.zero);
524
- }
525
- _enabled = false;
526
- reset() {
527
- this._scale = 1;
528
- this.offset.identity();
529
- this._hasChanged = true;
530
- }
531
- get hasChanged() { return this._hasChanged; }
532
- /**
533
- * Applies the matrix to the offset matrix
534
- * @param matrix the matrix to apply the drag offset to
535
- * @param invert if true the offset matrix will be inverted before applying it to the matrix and premultiplied
536
- */
537
- applyMatrixTo(matrix, invert) {
538
- this._hasChanged = false;
539
- if (invert) {
540
- this.offset.invert();
541
- matrix.premultiply(this.offset);
542
- }
543
- else
544
- matrix.multiply(this.offset);
545
- // if (this._needsUpdate)
546
- // this.updateMatrix();
547
- // matrix.premultiply(this._rotationMatrix);
548
- // matrix.premultiply(this.offset).premultiply(this._rotationMatrix)
549
- }
550
- currentlyUsedPointerIds = new Set();
551
- currentlyUnusedPointerIds = new Set();
552
- get isActive() {
553
- return this.currentlyUsedPointerIds.size <= 0 && this.currentlyUnusedPointerIds.size > 0;
554
- }
555
- enable() {
556
- if (this._enabled)
557
- return;
558
- this._enabled = true;
559
- this.context.input.addEventListener("pointerdown", this.onPointerDownEarly, { queue: InputEventQueue.Early });
560
- this.context.input.addEventListener("pointerdown", this.onPointerDownLate, { queue: InputEventQueue.Late });
561
- this.context.input.addEventListener("pointerup", this.onPointerUpEarly, { queue: InputEventQueue.Early });
562
- // TODO: refactor the following events to use the input system
563
- window.addEventListener('touchstart', this.touchStart, { passive: false });
564
- window.addEventListener('touchmove', this.touchMove, { passive: false });
565
- window.addEventListener('touchend', this.touchEnd, { passive: false });
566
- }
567
- disable() {
568
- if (!this._enabled)
569
- return;
570
- this._enabled = false;
571
- this.context.input.removeEventListener("pointerdown", this.onPointerDownEarly, { queue: InputEventQueue.Early });
572
- this.context.input.removeEventListener("pointerdown", this.onPointerDownLate, { queue: InputEventQueue.Late });
573
- this.context.input.removeEventListener("pointerup", this.onPointerUpEarly, { queue: InputEventQueue.Early });
574
- window.removeEventListener('touchstart', this.touchStart);
575
- window.removeEventListener('touchmove', this.touchMove);
576
- window.removeEventListener('touchend', this.touchEnd);
577
- }
578
- onPointerDownEarly = (e) => {
579
- if (this.isActive)
580
- e.stopPropagation();
581
- };
582
- onPointerDownLate = (e) => {
583
- if (e.used)
584
- this.currentlyUsedPointerIds.add(e.pointerId);
585
- else if (this.currentlyUsedPointerIds.size <= 0)
586
- this.currentlyUnusedPointerIds.add(e.pointerId);
587
- };
588
- onPointerUpEarly = (e) => {
589
- this.currentlyUsedPointerIds.delete(e.pointerId);
590
- this.currentlyUnusedPointerIds.delete(e.pointerId);
591
- };
592
- // private _needsUpdate: boolean = true;
593
- // private _rotationMatrix: Matrix4 = new Matrix4();
594
- // private updateMatrix() {
595
- // this._needsUpdate = false;
596
- // this._rotationMatrix.makeRotationFromQuaternion(this.rotation);
597
- // this.offset.compose(this.translate, new Quaternion(), this.scale);
598
- // // const rot = this._tempMatrix.makeRotationY(this.angle);
599
- // // this.translate.applyMatrix4(rot);
600
- // // this.offset.elements[12] = this.translate.x;
601
- // // this.offset.elements[13] = this.translate.y;
602
- // // this.offset.elements[14] = this.translate.z;
603
- // // this.offset.premultiply(rot);
604
- // // const s = this.scale;
605
- // // this.offset.premultiply(this._tempMatrix.makeScale(s, s, s));
606
- // }
607
- prev = new Map();
608
- _didMultitouch = false;
609
- touchStart = (evt) => {
610
- if (evt.defaultPrevented)
611
- return;
612
- // let isValidTouch = true;
613
- // isValidTouch = evt.target === this.context.domElement || evt.target === this.context.renderer.domElement;
614
- // if (!isValidTouch) {
615
- // return;
616
- // }
617
- for (let i = 0; i < evt.changedTouches.length; i++) {
618
- const touch = evt.changedTouches[i];
619
- // if a user starts swiping in the top area of the screen
620
- // which might be a gesture to open the menu
621
- // we ignore it
622
- const ignore = DeviceUtilities.isAndroidDevice() && touch.clientY < window.innerHeight * .1;
623
- if (!this.prev.has(touch.identifier))
624
- this.prev.set(touch.identifier, {
625
- ignore,
626
- x: 0,
627
- z: 0,
628
- screenx: 0,
629
- screeny: 0,
630
- });
631
- const prev = this.prev.get(touch.identifier);
632
- if (prev) {
633
- const pos = this.getPositionOnPlane(touch.clientX, touch.clientY);
634
- prev.x = pos.x;
635
- prev.z = pos.z;
636
- prev.screenx = touch.clientX;
637
- prev.screeny = touch.clientY;
638
- }
639
- }
640
- };
641
- touchEnd = (evt) => {
642
- if (evt.touches.length <= 0) {
643
- this._didMultitouch = false;
644
- }
645
- for (let i = 0; i < evt.changedTouches.length; i++) {
646
- const touch = evt.changedTouches[i];
647
- this.prev.delete(touch.identifier);
648
- }
649
- };
650
- touchMove = (evt) => {
651
- if (evt.defaultPrevented)
652
- return;
653
- if (!this.isActive)
654
- return;
655
- if (evt.touches.length === 1) {
656
- // if we had multiple touches before due to e.g. pinching / rotating
657
- // and stopping one of the touches, we don't want to move the scene suddenly
658
- // this will be resettet when all touches stop
659
- if (this._didMultitouch) {
660
- return;
661
- }
662
- const touch = evt.touches[0];
663
- const prev = this.prev.get(touch.identifier);
664
- if (!prev || prev.ignore)
665
- return;
666
- const pos = this.getPositionOnPlane(touch.clientX, touch.clientY);
667
- const dx = pos.x - prev.x;
668
- const dy = pos.z - prev.z;
669
- if (dx === 0 && dy === 0)
670
- return;
671
- if (this.oneFingerDrag)
672
- this.addMovement(dx, dy);
673
- prev.x = pos.x;
674
- prev.z = pos.z;
675
- prev.screenx = touch.clientX;
676
- prev.screeny = touch.clientY;
677
- return;
678
- }
679
- else if (evt.touches.length === 2) {
680
- this._didMultitouch = true;
681
- const touch1 = evt.touches[0];
682
- const touch2 = evt.touches[1];
683
- const prev1 = this.prev.get(touch1.identifier);
684
- const prev2 = this.prev.get(touch2.identifier);
685
- if (!prev1 || !prev2)
686
- return;
687
- if (this.twoFingerRotate) {
688
- const angle1 = Math.atan2(touch1.clientY - touch2.clientY, touch1.clientX - touch2.clientX);
689
- const lastAngle = Math.atan2(prev1.screeny - prev2.screeny, prev1.screenx - prev2.screenx);
690
- const angleDiff = angle1 - lastAngle;
691
- if (Math.abs(angleDiff) > 0.001) {
692
- this.addRotation(angleDiff);
693
- }
694
- }
695
- if (this.twoFingerScale) {
696
- const distx = touch1.clientX - touch2.clientX;
697
- const disty = touch1.clientY - touch2.clientY;
698
- const dist = Math.sqrt(distx * distx + disty * disty);
699
- const lastDistx = prev1.screenx - prev2.screenx;
700
- const lastDisty = prev1.screeny - prev2.screeny;
701
- const lastDist = Math.sqrt(lastDistx * lastDistx + lastDisty * lastDisty);
702
- const distDiff = dist - lastDist;
703
- if (Math.abs(distDiff) > 2) {
704
- this.addScale(distDiff);
705
- }
706
- }
707
- prev1.screenx = touch1.clientX;
708
- prev1.screeny = touch1.clientY;
709
- prev2.screenx = touch2.clientX;
710
- prev2.screeny = touch2.clientY;
711
- }
712
- };
713
- _raycaster = new Raycaster();
714
- _intersection = new Vector3();
715
- _screenPos = new Vector3();
716
- getPositionOnPlane(tx, ty) {
717
- const camera = this.context.mainCamera;
718
- this._screenPos.x = (tx / window.innerWidth) * 2 - 1;
719
- this._screenPos.y = -(ty / window.innerHeight) * 2 + 1;
720
- this._screenPos.z = 1;
721
- this._screenPos.unproject(camera);
722
- this._raycaster.set(camera.position, this._screenPos.sub(camera.position));
723
- this._raycaster.ray.intersectPlane(this.plane, this._intersection);
724
- return this._intersection;
725
- }
726
- addMovement(dx, dz) {
727
- // this.translate.x -= dx;
728
- // this.translate.z -= dz;
729
- // this._needsUpdate = true;
730
- // return
731
- // increase diff if the scene is scaled small
732
- dx /= this._scale;
733
- dz /= this._scale;
734
- dx *= this.factor;
735
- dz *= this.factor;
736
- // apply it
737
- this.offset.elements[12] += dx;
738
- this.offset.elements[14] += dz;
739
- if (dx !== 0 || dz !== 0)
740
- this._hasChanged = true;
741
- }
742
- ;
743
- _tempMatrix = new Matrix4();
744
- addScale(diff) {
745
- diff /= window.innerWidth;
746
- diff *= -1;
747
- // this.scale.x *= 1 + diff;
748
- // this.scale.y *= 1 + diff;
749
- // this.scale.z *= 1 + diff;
750
- // this._needsUpdate = true;
751
- // return;
752
- // we use this factor to modify the translation factor (in apply movement)
753
- this._scale *= 1 + diff;
754
- // apply the scale
755
- this._tempMatrix.makeScale(1 - diff, 1 - diff, 1 - diff);
756
- this.offset.premultiply(this._tempMatrix);
757
- if (diff !== 0)
758
- this._hasChanged = true;
759
- }
760
- addRotation(rot) {
761
- rot *= -1;
762
- // this.rotation.multiply(new Quaternion().setFromAxisAngle(WebXRSessionRootUserInput.up, rot));
763
- // this._needsUpdate = true;
764
- // return;
765
- this._tempMatrix.makeRotationY(rot);
766
- this.offset.premultiply(this._tempMatrix);
767
- if (rot !== 0)
768
- this._hasChanged = true;
769
- }
770
- }
1
+ import { AxesHelper, DoubleSide, Matrix4, Mesh, MeshBasicMaterial, Object3D, Plane, Raycaster, RingGeometry, Scene, Vector3 } from "three";
2
+ import { isDevEnvironment, showBalloonWarning } from "../../engine/debug/index.js";
3
+ import { destroy, instantiate } from "../../engine/engine_gameobject.js";
4
+ import { InputEventQueue } from "../../engine/engine_input.js";
5
+ import { getBoundingBox, getTempVector } from "../../engine/engine_three_utils.js";
6
+ import { DeviceUtilities, getParam } from "../../engine/engine_utils.js";
7
+ import { NeedleXRController, NeedleXRSession } from "../../engine/engine_xr.js";
8
+ import { Behaviour, GameObject } from "../Component.js";
9
+ // https://github.com/takahirox/takahirox.github.io/blob/master/js.mmdeditor/examples/js/controls/DeviceOrientationControls.js
10
+ const debug = getParam("debugwebxr");
11
+ const invertForwardMatrix = new Matrix4().makeRotationY(Math.PI);
12
+ /**
13
+ * The WebARSessionRoot is the root object for a WebAR session and used to place the scene in AR.
14
+ * It is also responsible for scaling the user in AR and optionally creating a XR anchor for the scene placement.
15
+ * @example
16
+ * ```ts
17
+ * WebARSessionRoot.onPlaced((args) => {
18
+ * console.log("Scene has been placed in AR");
19
+ * });
20
+ * ```
21
+ *
22
+ * @category XR
23
+ * @group Components
24
+ */
25
+ export class WebARSessionRoot extends Behaviour {
26
+ static _eventListeners = {};
27
+ /**
28
+ * Event that is called when the scene has been placed in AR.
29
+ * @param cb the callback that is called when the scene has been placed
30
+ * @returns a function to remove the event listener
31
+ */
32
+ static onPlaced(cb) {
33
+ const event = "placed";
34
+ if (!this._eventListeners[event])
35
+ this._eventListeners[event] = [];
36
+ this._eventListeners[event].push(cb);
37
+ return () => {
38
+ const index = this._eventListeners[event].indexOf(cb);
39
+ if (index >= 0)
40
+ this._eventListeners[event].splice(index, 1);
41
+ };
42
+ }
43
+ static _hasPlaced = false;
44
+ /**
45
+ * @returns true if the scene has been placed in AR by the user or automatic placement
46
+ */
47
+ static get hasPlaced() {
48
+ return this._hasPlaced;
49
+ }
50
+ /** The scale of the user in AR.
51
+ * **NOTE**: a large value makes the scene appear smaller
52
+ * @default 1
53
+ */
54
+ get arScale() {
55
+ return this._arScale;
56
+ }
57
+ set arScale(val) {
58
+ this._arScale = Math.max(0.000001, val);
59
+ this.onSetScale();
60
+ }
61
+ _arScale = 1;
62
+ /** When enabled the placed scene forward direction will towards the XRRig
63
+ * @deprecated
64
+ * @default false
65
+ */
66
+ invertForward = false;
67
+ /** When assigned this asset will be loaded and visualize the placement while in AR
68
+ * @default null
69
+ */
70
+ customReticle;
71
+ /** Enable touch transform to translate, rotate and scale the scene in AR with multitouch
72
+ * @default true
73
+ */
74
+ arTouchTransform = true;
75
+ /** When enabled the scene will be placed automatically when a point in the real world is found
76
+ * @default false
77
+ */
78
+ autoPlace = false;
79
+ /** When enabled the scene center will be automatically calculated from the content in the scene */
80
+ autoCenter = false;
81
+ /** Experimental: When enabled we will create a XR anchor for the scene placement
82
+ * and make sure the scene is at that anchored point during a XR session
83
+ * @default false
84
+ **/
85
+ useXRAnchor = false;
86
+ /** true if we're currently placing the scene */
87
+ _isPlacing = true;
88
+ /** This is the world matrix of the ar session root when entering webxr
89
+ * it is applied when the scene has been placed (e.g. if the session root is x:10, z:10 we want this position to be the center of the scene)
90
+ */
91
+ _startOffset = new Matrix4();
92
+ _createdPlacementObject = null;
93
+ _reparentedComponents = [];
94
+ // move objects into a temporary scene while placing (which is not rendered) so that the components won't be disabled during this process
95
+ // e.g. we want the avatar to still be updated while placing
96
+ // another possibly solution would be to ensure from this component that the Rig is *also* not disabled while placing
97
+ _placementScene = new Scene();
98
+ /** the reticles used for placement */
99
+ _reticle = [];
100
+ /** needs to be in sync with the reticles */
101
+ _hits = [];
102
+ _placementStartTime = -1;
103
+ _rigPlacementMatrix;
104
+ /** if useAnchor is enabled this is the anchor we have created on placing the scene using the placement hit */
105
+ _anchor = null;
106
+ /** user input is used for ar touch transform */
107
+ userInput;
108
+ onEnable() {
109
+ this.customReticle?.preload();
110
+ }
111
+ supportsXR(mode) {
112
+ return mode === "immersive-ar";
113
+ }
114
+ onEnterXR(_args) {
115
+ if (debug)
116
+ console.log("ENTER WEBXR: SessionRoot start...");
117
+ this._anchor = null;
118
+ WebARSessionRoot._hasPlaced = false;
119
+ // if (_args.xr.session.enabledFeatures?.includes("image-tracking")) {
120
+ // console.warn("Image tracking is enabled - will not place scene");
121
+ // return;
122
+ // }
123
+ // save the transform of the session root in the scene to apply it when placing the scene
124
+ this.gameObject.updateMatrixWorld();
125
+ this._startOffset.copy(this.gameObject.matrixWorld);
126
+ // create a new root object for the session placement scripts
127
+ // and move all the children in the scene in a temporary scene that is not rendered
128
+ const rootObject = new Object3D();
129
+ this._createdPlacementObject = rootObject;
130
+ rootObject.name = "AR Session Root";
131
+ this._placementScene.name = "AR Placement Scene";
132
+ this._placementScene.children.length = 0;
133
+ for (let i = this.context.scene.children.length - 1; i >= 0; i--) {
134
+ const ch = this.context.scene.children[i];
135
+ this._placementScene.add(ch);
136
+ }
137
+ this.context.scene.add(rootObject);
138
+ if (this.autoCenter) {
139
+ const bounds = getBoundingBox(this._placementScene.children);
140
+ const center = bounds.getCenter(new Vector3());
141
+ const size = bounds.getSize(new Vector3());
142
+ const matrix = new Matrix4();
143
+ matrix.makeTranslation(center.x, center.y - size.y * .5, center.z);
144
+ this._startOffset.multiply(matrix);
145
+ }
146
+ // reparent components
147
+ // save which gameobject the sessionroot component was previously attached to
148
+ this._reparentedComponents.length = 0;
149
+ this._reparentedComponents.push({ comp: this, originalObject: this.gameObject });
150
+ GameObject.addComponent(rootObject, this);
151
+ // const webXR = GameObject.findObjectOfType(WebXR2);
152
+ // if (webXR) {
153
+ // this._reparentedComponents.push({ comp: webXR, originalObject: webXR.gameObject });
154
+ // GameObject.addComponent(rootObject, webXR);
155
+ // const playerSync = GameObject.findObjectOfType(XRFlag);
156
+ // }
157
+ // recreate the reticle every time we enter AR
158
+ for (const ret of this._reticle) {
159
+ destroy(ret);
160
+ }
161
+ this._reticle.length = 0;
162
+ this._isPlacing = true;
163
+ // we want to receive pointer events EARLY and prevent interaction with other objects while placing by stopping the event propagation
164
+ this.context.input.addEventListener("pointerup", this.onPlaceScene, { queue: InputEventQueue.Early });
165
+ }
166
+ onLeaveXR() {
167
+ // TODO: WebARSessionRoot doesnt work when we enter passthrough and leave XR without having placed the session!!!
168
+ this.context.input.removeEventListener("pointerup", this.onPlaceScene, { queue: InputEventQueue.Early });
169
+ this.onRevertSceneChanges();
170
+ // this._anchor?.delete();
171
+ this._anchor = null;
172
+ WebARSessionRoot._hasPlaced = false;
173
+ this._rigPlacementMatrix = undefined;
174
+ }
175
+ onUpdateXR(args) {
176
+ // disable session placement while images are being tracked
177
+ if (args.xr.isTrackingImages) {
178
+ for (const ret of this._reticle)
179
+ ret.visible = false;
180
+ return;
181
+ }
182
+ if (this._isPlacing) {
183
+ const rigObject = args.xr.rig?.gameObject;
184
+ // the rig should be parented to the scene while placing
185
+ // since the camera is always parented to the rig this ensures that the camera is always rendering
186
+ if (rigObject && rigObject.parent !== this.context.scene) {
187
+ this.context.scene.add(rigObject);
188
+ }
189
+ // in pass through mode we want to place the scene using an XR controller
190
+ let controllersDidHit = false;
191
+ // when auto placing we just use the user's view
192
+ if (args.xr.isPassThrough && args.xr.controllers.length > 0 && !this.autoPlace) {
193
+ for (const ctrl of args.xr.controllers) {
194
+ // with this we can only place with the left / first controller right now
195
+ // we also only have one reticle... this should probably be refactored a bit so we can have multiple reticles
196
+ // and then place at the reticle for which the user clicked the place button
197
+ const hit = ctrl.getHitTest();
198
+ if (hit) {
199
+ controllersDidHit = true;
200
+ this.updateReticleAndHits(args.xr, ctrl.index, hit, args.xr.rigScale);
201
+ }
202
+ }
203
+ }
204
+ // in screen AR mode we use "camera" hit testing (or when using the simulator where controller hit testing is not supported)
205
+ if (!controllersDidHit) {
206
+ const hit = args.xr.getHitTest();
207
+ if (hit) {
208
+ this.updateReticleAndHits(args.xr, 0, hit, args.xr.rigScale);
209
+ }
210
+ }
211
+ }
212
+ else {
213
+ // Update anchors, if any
214
+ if (this._anchor && args.xr.referenceSpace) {
215
+ const pose = args.xr.frame.getPose(this._anchor.anchorSpace, args.xr.referenceSpace);
216
+ if (pose && this.context.time.frame % 20 === 0) {
217
+ // apply the anchor pose to one of the reticles
218
+ const converted = args.xr.convertSpace(pose.transform);
219
+ const reticle = this._reticle[0];
220
+ if (reticle) {
221
+ reticle.position.copy(converted.position);
222
+ reticle.quaternion.copy(converted.quaternion);
223
+ this.onApplyPose(reticle);
224
+ }
225
+ }
226
+ }
227
+ // Scene has been placed
228
+ if (this.arTouchTransform) {
229
+ if (!this.userInput)
230
+ this.userInput = new WebXRSessionRootUserInput(this.context);
231
+ this.userInput?.enable();
232
+ }
233
+ else
234
+ this.userInput?.disable();
235
+ if (this.arTouchTransform && this.userInput?.hasChanged) {
236
+ if (args.xr.rig) {
237
+ const rig = args.xr.rig.gameObject;
238
+ this.userInput.applyMatrixTo(rig.matrix, true);
239
+ rig.matrix.decompose(rig.position, rig.quaternion, rig.scale);
240
+ // if the rig is scaled large we want the drag touch to be faster
241
+ this.userInput.factor = rig.scale.x;
242
+ }
243
+ this.userInput.reset();
244
+ }
245
+ }
246
+ }
247
+ updateReticleAndHits(_xr, i, hit, scale) {
248
+ // save the hit test
249
+ this._hits[i] = hit.hit;
250
+ let reticle = this._reticle[i];
251
+ if (!reticle) {
252
+ if (this.customReticle) {
253
+ if (this.customReticle.asset) {
254
+ reticle = instantiate(this.customReticle.asset);
255
+ }
256
+ else {
257
+ this.customReticle.loadAssetAsync();
258
+ return;
259
+ }
260
+ }
261
+ else {
262
+ reticle = new Mesh(new RingGeometry(0.07, 0.09, 32).rotateX(-Math.PI / 2), new MeshBasicMaterial({ side: DoubleSide, depthTest: false, depthWrite: false, transparent: true, opacity: 1, color: 0xeeeeee }));
263
+ reticle.name = "AR Placement Reticle";
264
+ }
265
+ if (debug) {
266
+ const axes = new AxesHelper(1);
267
+ axes.position.y += .01;
268
+ reticle.add(axes);
269
+ }
270
+ this._reticle[i] = reticle;
271
+ reticle.matrixAutoUpdate = false;
272
+ reticle.visible = false;
273
+ }
274
+ reticle["lastPos"] = reticle["lastPos"] || hit.position.clone();
275
+ reticle["lastQuat"] = reticle["lastQuat"] || hit.quaternion.clone();
276
+ // reticle["targetPos"] = reticle["targetPos"] || hit.position.clone();
277
+ // reticle["targetQuat"] = reticle["targetQuat"] || hit.quaternion.clone();
278
+ // TODO we likely want the reticle itself to be placed _exactly_ and then the visuals being lerped,
279
+ // Right now this leads to a "rotation glitch" when going from a horizontal to a vertical surface
280
+ reticle.position.copy(reticle["lastPos"].lerp(hit.position, this.context.time.deltaTime / .1));
281
+ reticle["lastPos"].copy(reticle.position);
282
+ reticle.quaternion.copy(reticle["lastQuat"].slerp(hit.quaternion, this.context.time.deltaTime / .05));
283
+ reticle["lastQuat"].copy(reticle.quaternion);
284
+ // TODO make sure original reticle asset scale is respected, or document it should be uniformly scaled
285
+ // scale *= this.customReticle?.asset?.scale?.x || 1;
286
+ reticle.scale.set(scale, scale, scale);
287
+ // if (this.invertForward) {
288
+ // reticle.rotateY(Math.PI);
289
+ // }
290
+ // Workaround: For a custom reticle we apply the view based transform during placement preview
291
+ // See NE-4161 for context
292
+ if (this.customReticle)
293
+ this.applyViewBasedTransform(reticle);
294
+ reticle.updateMatrix();
295
+ reticle.visible = true;
296
+ if (reticle.parent !== this.context.scene)
297
+ this.context.scene.add(reticle);
298
+ if (this._placementStartTime < 0) {
299
+ this._placementStartTime = this.context.time.realtimeSinceStartup;
300
+ }
301
+ if (this.autoPlace) {
302
+ this.upVec.set(0, 1, 0).applyQuaternion(reticle.quaternion);
303
+ const isUp = this.upVec.dot(getTempVector(0, 1, 0)) > 0.9;
304
+ if (isUp) {
305
+ // We want the reticle to be at a suitable spot for a moment before we place the scene (not place it immediately)
306
+ let autoplace_timer = reticle["autoplace:timer"] || 0;
307
+ if (autoplace_timer >= 1) {
308
+ reticle.visible = false;
309
+ this.onPlaceScene(null);
310
+ }
311
+ else {
312
+ autoplace_timer += this.context.time.deltaTime;
313
+ reticle["autoplace:timer"] = autoplace_timer;
314
+ }
315
+ }
316
+ else {
317
+ reticle["autoplace:timer"] = 0;
318
+ }
319
+ }
320
+ }
321
+ onPlaceScene = (evt) => {
322
+ if (this._isPlacing == false)
323
+ return;
324
+ if (evt?.used)
325
+ return;
326
+ let reticle = this._reticle[0];
327
+ if (!reticle) {
328
+ console.warn("No reticle to place...");
329
+ return;
330
+ }
331
+ if (!reticle.visible && !this.autoPlace) {
332
+ console.warn("Reticle is not visible (can not place)");
333
+ return;
334
+ }
335
+ if (NeedleXRSession.active?.isTrackingImages) {
336
+ console.warn("Scene Placement is disabled while images are being tracked");
337
+ return;
338
+ }
339
+ let hit = this._hits[0];
340
+ if (evt && evt.origin instanceof NeedleXRController) {
341
+ // until we can use hit testing for both controllers and have multple reticles we only allow placement with the first controller
342
+ const controllerReticle = this._reticle[evt.origin.index];
343
+ if (controllerReticle) {
344
+ reticle = controllerReticle;
345
+ hit = this._hits[evt.origin.index];
346
+ }
347
+ }
348
+ // if we place the scene we don't want this event to be propagated to any sub-objects (via the EventSystem) anymore and trigger e.g. a click on objects for the "place tap" event
349
+ if (evt) {
350
+ evt.stopImmediatePropagation();
351
+ evt.stopPropagation();
352
+ evt.use();
353
+ }
354
+ this._isPlacing = false;
355
+ this.context.input.removeEventListener("pointerup", this.onPlaceScene);
356
+ this.onRevertSceneChanges();
357
+ // TODO: we should probably use the non-lerped position and quaternion here
358
+ reticle.position.copy(reticle["lastPos"]);
359
+ reticle.quaternion.copy(reticle["lastQuat"]);
360
+ this.onApplyPose(reticle);
361
+ WebARSessionRoot._hasPlaced = true;
362
+ if (this.useXRAnchor) {
363
+ this.onCreateAnchor(NeedleXRSession.active, hit);
364
+ }
365
+ if (this.context.xr) {
366
+ for (const ctrl of this.context.xr.controllers) {
367
+ ctrl.cancelHitTestSource();
368
+ }
369
+ }
370
+ };
371
+ onSetScale() {
372
+ if (!WebARSessionRoot._hasPlaced)
373
+ return;
374
+ const rig = NeedleXRSession.active?.rig?.gameObject;
375
+ if (rig) {
376
+ const currentScale = NeedleXRSession.active?.rigScale || 1;
377
+ const newScale = (1 / this._arScale) * currentScale;
378
+ const scaleMatrix = new Matrix4().makeScale(newScale, newScale, newScale).invert();
379
+ rig.matrix.premultiply(scaleMatrix);
380
+ rig.matrix.decompose(rig.position, rig.quaternion, rig.scale);
381
+ }
382
+ }
383
+ onRevertSceneChanges() {
384
+ for (const ret of this._reticle) {
385
+ if (!ret)
386
+ continue;
387
+ ret.visible = false;
388
+ ret?.removeFromParent();
389
+ }
390
+ this._reticle.length = 0;
391
+ for (let i = this._placementScene.children.length - 1; i >= 0; i--) {
392
+ const ch = this._placementScene.children[i];
393
+ this.context.scene.add(ch);
394
+ }
395
+ this._createdPlacementObject?.removeFromParent();
396
+ for (const reparented of this._reparentedComponents) {
397
+ GameObject.addComponent(reparented.originalObject, reparented.comp);
398
+ }
399
+ }
400
+ async onCreateAnchor(session, hit) {
401
+ if (hit.createAnchor === undefined) {
402
+ console.warn("Hit does not support creating an anchor", hit);
403
+ if (isDevEnvironment())
404
+ showBalloonWarning("Hit does not support creating an anchor");
405
+ return;
406
+ }
407
+ else {
408
+ const anchor = await hit.createAnchor(session.viewerPose.transform);
409
+ // make sure the session is still active
410
+ if (session.running && anchor) {
411
+ this._anchor = anchor;
412
+ }
413
+ }
414
+ }
415
+ upVec = new Vector3(0, 1, 0);
416
+ lookPoint = new Vector3();
417
+ worldUpVec = new Vector3(0, 1, 0);
418
+ applyViewBasedTransform(reticle) {
419
+ // Make reticle face the user to unify the placement experience across devices.
420
+ // The pose that we're receiving from the hit test varies between devices:
421
+ // - Quest: currently aligned to the mesh that was hit (depends on room setup), has changed a couple times
422
+ // - Android WebXR: looking at the camera, but pretty random when on a wall
423
+ // - Mozilla WebXR Viewer: aligned to the start of the session
424
+ const camGo = this.context.mainCamera;
425
+ const reticleGo = reticle;
426
+ const camWP = camGo.worldPosition;
427
+ const reticleWp = reticleGo.worldPosition;
428
+ this.upVec.set(0, 1, 0).applyQuaternion(reticle.quaternion);
429
+ // upVec may be pointing AWAY from us, we have to flip it if that's the case
430
+ const camPos = camGo.worldPosition;
431
+ if (camPos) {
432
+ const camToReticle = reticle.position.clone().sub(camPos);
433
+ const angle = camToReticle.angleTo(this.upVec);
434
+ if (angle < Math.PI / 2) {
435
+ this.upVec.negate();
436
+ }
437
+ }
438
+ const upAngle = this.upVec.angleTo(this.worldUpVec) * 180 / Math.PI;
439
+ // For debugging look angle for AR placement
440
+ // Gizmos.DrawDirection(reticle.position, upVec, "blue", 0.1);
441
+ // Gizmos.DrawLabel(reticle.position, upAngle.toFixed(2), 0.1);
442
+ const angleForWallPlacement = 30;
443
+ if ((upAngle > angleForWallPlacement && upAngle < 180 - angleForWallPlacement) ||
444
+ (upAngle < -angleForWallPlacement && upAngle > -180 + angleForWallPlacement)) {
445
+ this.lookPoint.copy(reticle.position).add(this.upVec);
446
+ this.lookPoint.y = reticle.position.y;
447
+ reticle.lookAt(this.lookPoint);
448
+ }
449
+ else {
450
+ camWP.y = reticleWp.y;
451
+ reticle.lookAt(camWP);
452
+ }
453
+ // TODO: ability to scale the reticle so that we can fit the scene depending on the view angle or distance to the reticle.
454
+ // Currently, doing this leads to wrong placement of the scene.
455
+ /*
456
+ const rigScale = NeedleXRSession.active?.rigScale || 1;
457
+ const scale = distance * rigScale;
458
+ reticle.scale.set(scale, scale, scale);
459
+ */
460
+ }
461
+ onApplyPose(reticle) {
462
+ const rigObject = NeedleXRSession.active?.rig?.gameObject;
463
+ if (!rigObject) {
464
+ console.warn("No rig object to place");
465
+ return;
466
+ }
467
+ // const rigScale = NeedleXRSession.active?.rigScale || 1;
468
+ // save the previous rig parent
469
+ const previousParent = rigObject.parent || this.context.scene;
470
+ // if we have placed this rig before and this is just "replacing" with the anchor
471
+ // we need to make sure the XRRig attached to the reticle is at the same position as last time
472
+ // since in the following code we move it inside the reticle (relative to the reticle)
473
+ if (this._rigPlacementMatrix) {
474
+ this._rigPlacementMatrix?.decompose(rigObject.position, rigObject.quaternion, rigObject.scale);
475
+ }
476
+ else {
477
+ this._rigPlacementMatrix = rigObject.matrix.clone();
478
+ }
479
+ this.applyViewBasedTransform(reticle);
480
+ reticle.updateMatrix();
481
+ // attach rig to reticle (since the reticle is in rig space it's a easy way to place the rig where we want it relative to the reticle)
482
+ this.context.scene.add(reticle);
483
+ reticle.attach(rigObject);
484
+ reticle.removeFromParent();
485
+ // move rig now relative to the reticle
486
+ // TODO support scaled reticle
487
+ rigObject.scale.set(this.arScale, this.arScale, this.arScale);
488
+ rigObject.position.multiplyScalar(this.arScale);
489
+ rigObject.updateMatrix();
490
+ // if invert forward is disabled we need to invert the forward rotation
491
+ // we want to look into positive Z direction (if invertForward is enabled we look into negative Z direction)
492
+ if (this.invertForward)
493
+ rigObject.matrix.premultiply(invertForwardMatrix);
494
+ rigObject.matrix.premultiply(this._startOffset);
495
+ // apply the rig modifications and add it back to the previous parent
496
+ rigObject.matrix.decompose(rigObject.position, rigObject.quaternion, rigObject.scale);
497
+ previousParent.add(rigObject);
498
+ }
499
+ }
500
+ class WebXRSessionRootUserInput {
501
+ static up = new Vector3(0, 1, 0);
502
+ static zero = new Vector3(0, 0, 0);
503
+ static one = new Vector3(1, 1, 1);
504
+ oneFingerDrag = true;
505
+ twoFingerRotate = true;
506
+ twoFingerScale = true;
507
+ factor = 1;
508
+ context;
509
+ offset;
510
+ plane;
511
+ _scale = 1;
512
+ _hasChanged = false;
513
+ get scale() {
514
+ return this._scale;
515
+ }
516
+ // readonly translate: Vector3 = new Vector3();
517
+ // readonly rotation: Quaternion = new Quaternion();
518
+ // readonly scale: Vector3 = new Vector3(1, 1, 1);
519
+ constructor(context) {
520
+ this.context = context;
521
+ this.offset = new Matrix4();
522
+ this.plane = new Plane();
523
+ this.plane.setFromNormalAndCoplanarPoint(WebXRSessionRootUserInput.up, WebXRSessionRootUserInput.zero);
524
+ }
525
+ _enabled = false;
526
+ reset() {
527
+ this._scale = 1;
528
+ this.offset.identity();
529
+ this._hasChanged = true;
530
+ }
531
+ get hasChanged() { return this._hasChanged; }
532
+ /**
533
+ * Applies the matrix to the offset matrix
534
+ * @param matrix the matrix to apply the drag offset to
535
+ * @param invert if true the offset matrix will be inverted before applying it to the matrix and premultiplied
536
+ */
537
+ applyMatrixTo(matrix, invert) {
538
+ this._hasChanged = false;
539
+ if (invert) {
540
+ this.offset.invert();
541
+ matrix.premultiply(this.offset);
542
+ }
543
+ else
544
+ matrix.multiply(this.offset);
545
+ // if (this._needsUpdate)
546
+ // this.updateMatrix();
547
+ // matrix.premultiply(this._rotationMatrix);
548
+ // matrix.premultiply(this.offset).premultiply(this._rotationMatrix)
549
+ }
550
+ currentlyUsedPointerIds = new Set();
551
+ currentlyUnusedPointerIds = new Set();
552
+ get isActive() {
553
+ return this.currentlyUsedPointerIds.size <= 0 && this.currentlyUnusedPointerIds.size > 0;
554
+ }
555
+ enable() {
556
+ if (this._enabled)
557
+ return;
558
+ this._enabled = true;
559
+ this.context.input.addEventListener("pointerdown", this.onPointerDownEarly, { queue: InputEventQueue.Early });
560
+ this.context.input.addEventListener("pointerdown", this.onPointerDownLate, { queue: InputEventQueue.Late });
561
+ this.context.input.addEventListener("pointerup", this.onPointerUpEarly, { queue: InputEventQueue.Early });
562
+ // TODO: refactor the following events to use the input system
563
+ window.addEventListener('touchstart', this.touchStart, { passive: false });
564
+ window.addEventListener('touchmove', this.touchMove, { passive: false });
565
+ window.addEventListener('touchend', this.touchEnd, { passive: false });
566
+ }
567
+ disable() {
568
+ if (!this._enabled)
569
+ return;
570
+ this._enabled = false;
571
+ this.context.input.removeEventListener("pointerdown", this.onPointerDownEarly, { queue: InputEventQueue.Early });
572
+ this.context.input.removeEventListener("pointerdown", this.onPointerDownLate, { queue: InputEventQueue.Late });
573
+ this.context.input.removeEventListener("pointerup", this.onPointerUpEarly, { queue: InputEventQueue.Early });
574
+ window.removeEventListener('touchstart', this.touchStart);
575
+ window.removeEventListener('touchmove', this.touchMove);
576
+ window.removeEventListener('touchend', this.touchEnd);
577
+ }
578
+ onPointerDownEarly = (e) => {
579
+ if (this.isActive)
580
+ e.stopPropagation();
581
+ };
582
+ onPointerDownLate = (e) => {
583
+ if (e.used)
584
+ this.currentlyUsedPointerIds.add(e.pointerId);
585
+ else if (this.currentlyUsedPointerIds.size <= 0)
586
+ this.currentlyUnusedPointerIds.add(e.pointerId);
587
+ };
588
+ onPointerUpEarly = (e) => {
589
+ this.currentlyUsedPointerIds.delete(e.pointerId);
590
+ this.currentlyUnusedPointerIds.delete(e.pointerId);
591
+ };
592
+ // private _needsUpdate: boolean = true;
593
+ // private _rotationMatrix: Matrix4 = new Matrix4();
594
+ // private updateMatrix() {
595
+ // this._needsUpdate = false;
596
+ // this._rotationMatrix.makeRotationFromQuaternion(this.rotation);
597
+ // this.offset.compose(this.translate, new Quaternion(), this.scale);
598
+ // // const rot = this._tempMatrix.makeRotationY(this.angle);
599
+ // // this.translate.applyMatrix4(rot);
600
+ // // this.offset.elements[12] = this.translate.x;
601
+ // // this.offset.elements[13] = this.translate.y;
602
+ // // this.offset.elements[14] = this.translate.z;
603
+ // // this.offset.premultiply(rot);
604
+ // // const s = this.scale;
605
+ // // this.offset.premultiply(this._tempMatrix.makeScale(s, s, s));
606
+ // }
607
+ prev = new Map();
608
+ _didMultitouch = false;
609
+ touchStart = (evt) => {
610
+ if (evt.defaultPrevented)
611
+ return;
612
+ // let isValidTouch = true;
613
+ // isValidTouch = evt.target === this.context.domElement || evt.target === this.context.renderer.domElement;
614
+ // if (!isValidTouch) {
615
+ // return;
616
+ // }
617
+ for (let i = 0; i < evt.changedTouches.length; i++) {
618
+ const touch = evt.changedTouches[i];
619
+ // if a user starts swiping in the top area of the screen
620
+ // which might be a gesture to open the menu
621
+ // we ignore it
622
+ const ignore = DeviceUtilities.isAndroidDevice() && touch.clientY < window.innerHeight * .1;
623
+ if (!this.prev.has(touch.identifier))
624
+ this.prev.set(touch.identifier, {
625
+ ignore,
626
+ x: 0,
627
+ z: 0,
628
+ screenx: 0,
629
+ screeny: 0,
630
+ });
631
+ const prev = this.prev.get(touch.identifier);
632
+ if (prev) {
633
+ const pos = this.getPositionOnPlane(touch.clientX, touch.clientY);
634
+ prev.x = pos.x;
635
+ prev.z = pos.z;
636
+ prev.screenx = touch.clientX;
637
+ prev.screeny = touch.clientY;
638
+ }
639
+ }
640
+ };
641
+ touchEnd = (evt) => {
642
+ if (evt.touches.length <= 0) {
643
+ this._didMultitouch = false;
644
+ }
645
+ for (let i = 0; i < evt.changedTouches.length; i++) {
646
+ const touch = evt.changedTouches[i];
647
+ this.prev.delete(touch.identifier);
648
+ }
649
+ };
650
+ touchMove = (evt) => {
651
+ if (evt.defaultPrevented)
652
+ return;
653
+ if (!this.isActive)
654
+ return;
655
+ if (evt.touches.length === 1) {
656
+ // if we had multiple touches before due to e.g. pinching / rotating
657
+ // and stopping one of the touches, we don't want to move the scene suddenly
658
+ // this will be resettet when all touches stop
659
+ if (this._didMultitouch) {
660
+ return;
661
+ }
662
+ const touch = evt.touches[0];
663
+ const prev = this.prev.get(touch.identifier);
664
+ if (!prev || prev.ignore)
665
+ return;
666
+ const pos = this.getPositionOnPlane(touch.clientX, touch.clientY);
667
+ const dx = pos.x - prev.x;
668
+ const dy = pos.z - prev.z;
669
+ if (dx === 0 && dy === 0)
670
+ return;
671
+ if (this.oneFingerDrag)
672
+ this.addMovement(dx, dy);
673
+ prev.x = pos.x;
674
+ prev.z = pos.z;
675
+ prev.screenx = touch.clientX;
676
+ prev.screeny = touch.clientY;
677
+ return;
678
+ }
679
+ else if (evt.touches.length === 2) {
680
+ this._didMultitouch = true;
681
+ const touch1 = evt.touches[0];
682
+ const touch2 = evt.touches[1];
683
+ const prev1 = this.prev.get(touch1.identifier);
684
+ const prev2 = this.prev.get(touch2.identifier);
685
+ if (!prev1 || !prev2)
686
+ return;
687
+ if (this.twoFingerRotate) {
688
+ const angle1 = Math.atan2(touch1.clientY - touch2.clientY, touch1.clientX - touch2.clientX);
689
+ const lastAngle = Math.atan2(prev1.screeny - prev2.screeny, prev1.screenx - prev2.screenx);
690
+ const angleDiff = angle1 - lastAngle;
691
+ if (Math.abs(angleDiff) > 0.001) {
692
+ this.addRotation(angleDiff);
693
+ }
694
+ }
695
+ if (this.twoFingerScale) {
696
+ const distx = touch1.clientX - touch2.clientX;
697
+ const disty = touch1.clientY - touch2.clientY;
698
+ const dist = Math.sqrt(distx * distx + disty * disty);
699
+ const lastDistx = prev1.screenx - prev2.screenx;
700
+ const lastDisty = prev1.screeny - prev2.screeny;
701
+ const lastDist = Math.sqrt(lastDistx * lastDistx + lastDisty * lastDisty);
702
+ const distDiff = dist - lastDist;
703
+ if (Math.abs(distDiff) > 2) {
704
+ this.addScale(distDiff);
705
+ }
706
+ }
707
+ prev1.screenx = touch1.clientX;
708
+ prev1.screeny = touch1.clientY;
709
+ prev2.screenx = touch2.clientX;
710
+ prev2.screeny = touch2.clientY;
711
+ }
712
+ };
713
+ _raycaster = new Raycaster();
714
+ _intersection = new Vector3();
715
+ _screenPos = new Vector3();
716
+ getPositionOnPlane(tx, ty) {
717
+ const camera = this.context.mainCamera;
718
+ this._screenPos.x = (tx / window.innerWidth) * 2 - 1;
719
+ this._screenPos.y = -(ty / window.innerHeight) * 2 + 1;
720
+ this._screenPos.z = 1;
721
+ this._screenPos.unproject(camera);
722
+ this._raycaster.set(camera.position, this._screenPos.sub(camera.position));
723
+ this._raycaster.ray.intersectPlane(this.plane, this._intersection);
724
+ return this._intersection;
725
+ }
726
+ addMovement(dx, dz) {
727
+ // this.translate.x -= dx;
728
+ // this.translate.z -= dz;
729
+ // this._needsUpdate = true;
730
+ // return
731
+ // increase diff if the scene is scaled small
732
+ dx /= this._scale;
733
+ dz /= this._scale;
734
+ dx *= this.factor;
735
+ dz *= this.factor;
736
+ // apply it
737
+ this.offset.elements[12] += dx;
738
+ this.offset.elements[14] += dz;
739
+ if (dx !== 0 || dz !== 0)
740
+ this._hasChanged = true;
741
+ }
742
+ ;
743
+ _tempMatrix = new Matrix4();
744
+ addScale(diff) {
745
+ diff /= window.innerWidth;
746
+ diff *= -1;
747
+ // this.scale.x *= 1 + diff;
748
+ // this.scale.y *= 1 + diff;
749
+ // this.scale.z *= 1 + diff;
750
+ // this._needsUpdate = true;
751
+ // return;
752
+ // we use this factor to modify the translation factor (in apply movement)
753
+ this._scale *= 1 + diff;
754
+ // apply the scale
755
+ this._tempMatrix.makeScale(1 - diff, 1 - diff, 1 - diff);
756
+ this.offset.premultiply(this._tempMatrix);
757
+ if (diff !== 0)
758
+ this._hasChanged = true;
759
+ }
760
+ addRotation(rot) {
761
+ rot *= -1;
762
+ // this.rotation.multiply(new Quaternion().setFromAxisAngle(WebXRSessionRootUserInput.up, rot));
763
+ // this._needsUpdate = true;
764
+ // return;
765
+ this._tempMatrix.makeRotationY(rot);
766
+ this.offset.premultiply(this._tempMatrix);
767
+ if (rot !== 0)
768
+ this._hasChanged = true;
769
+ }
770
+ }
771
771
  //# sourceMappingURL=WebARSessionRoot.js.map