@needle-tools/engine 4.7.0-alpha → 4.7.0-next.da47826
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.
- package/CHANGELOG.md +3768 -3768
- package/LICENSE.md +10 -10
- package/README.md +64 -64
- package/components.needle.json +1 -1
- package/dist/generateMeshBVH.worker-BaNp_Xtp.js +25 -0
- package/dist/{gltf-progressive-Bm9eEfgu.min.js → gltf-progressive-Bl4okF1b.min.js} +1 -1
- package/dist/{gltf-progressive-GjIqwSG3.js → gltf-progressive-DSpdn0QT.js} +2 -2
- package/dist/{gltf-progressive-Dn6o99rH.umd.cjs → gltf-progressive-P8b8a0qY.umd.cjs} +1 -1
- package/dist/{needle-engine.bundle-CK8cQ3FX.umd.cjs → needle-engine.bundle-Bu88IoKB.umd.cjs} +57 -57
- package/dist/{needle-engine.bundle-CXtflnL6.js → needle-engine.bundle-CO1Ub9sm.js} +638 -638
- package/dist/{needle-engine.bundle-BEUFTdl6.min.js → needle-engine.bundle-D95XN5pP.min.js} +62 -62
- package/dist/needle-engine.d.ts +130 -129
- package/dist/needle-engine.js +4 -4
- package/dist/needle-engine.min.js +1 -1
- package/dist/needle-engine.umd.cjs +1 -1
- package/dist/{postprocessing-8AQTeZsr.umd.cjs → postprocessing-CjW23fio.umd.cjs} +2 -2
- package/dist/{postprocessing-BkxN_08g.js → postprocessing-DYLNOL3W.js} +3 -3
- package/dist/{postprocessing-BDScN9yu.min.js → postprocessing-xYQWCHFu.min.js} +2 -2
- package/dist/{three-DMrv-4ar.umd.cjs → three-B_hneGZr.umd.cjs} +4 -4
- package/dist/{three-Bz6X1mrw.js → three-DrqIzZTH.js} +4198 -4198
- package/dist/{three-Boa-jOq-.min.js → three-DuDKwKB8.min.js} +33 -33
- package/dist/{three-examples-GggCDHv0.js → three-examples-B50TT3Iu.js} +5 -5
- package/dist/{three-examples-DuVhxqft.min.js → three-examples-DaDLBuy6.min.js} +14 -14
- package/dist/{three-examples-C7ryg8vN.umd.cjs → three-examples-X3OadjXB.umd.cjs} +3 -3
- package/dist/{three-mesh-ui-CY6Izc7C.min.js → three-mesh-ui-B3p3gyUz.min.js} +1 -1
- package/dist/{three-mesh-ui-CwlN0FUC.umd.cjs → three-mesh-ui-CQiIQIlA.umd.cjs} +1 -1
- package/dist/{three-mesh-ui-CLNOfsWn.js → three-mesh-ui-CxuWt7m-.js} +1 -1
- package/dist/{vendor-zxXa3Dmr.min.js → vendor-BlSxe9JJ.min.js} +3 -3
- package/dist/{vendor-BSD1RQIh.js → vendor-BmYIgaS1.js} +3 -3
- package/dist/{vendor-DHr4aqIZ.umd.cjs → vendor-Cavtu3CP.umd.cjs} +3 -3
- package/lib/asap/needle-asap.d.ts +1 -1
- package/lib/asap/needle-asap.js +95 -95
- package/lib/asap/sessiongranted.d.ts +3 -3
- package/lib/asap/sessiongranted.js +65 -65
- package/lib/asap/utils.d.ts +1 -1
- package/lib/asap/utils.js +3 -3
- package/lib/engine/analytics/index.d.ts +6 -6
- package/lib/engine/analytics/index.js +12 -12
- package/lib/engine/analytics/lcp.d.ts +3 -3
- package/lib/engine/analytics/lcp.js +34 -34
- package/lib/engine/api.d.ts +82 -82
- package/lib/engine/api.js +81 -81
- package/lib/engine/assets/index.d.ts +11 -11
- package/lib/engine/assets/index.js +47 -47
- package/lib/engine/assets/static.d.ts +1 -1
- package/lib/engine/assets/static.js +4 -4
- package/lib/engine/codegen/register_types.d.ts +1 -1
- package/lib/engine/codegen/register_types.js +300 -300
- package/lib/engine/debug/debug.d.ts +15 -15
- package/lib/engine/debug/debug.js +44 -44
- package/lib/engine/debug/debug_console.d.ts +2 -2
- package/lib/engine/debug/debug_console.js +307 -307
- package/lib/engine/debug/debug_overlay.d.ts +22 -22
- package/lib/engine/debug/debug_overlay.js +316 -316
- package/lib/engine/debug/debug_spatial_console.d.ts +2 -2
- package/lib/engine/debug/debug_spatial_console.js +390 -390
- package/lib/engine/debug/index.d.ts +2 -2
- package/lib/engine/debug/index.js +2 -2
- package/lib/engine/engine_addressables.d.ts +166 -166
- package/lib/engine/engine_addressables.js +608 -608
- package/lib/engine/engine_animation.d.ts +43 -43
- package/lib/engine/engine_animation.js +133 -133
- package/lib/engine/engine_application.d.ts +45 -45
- package/lib/engine/engine_application.js +104 -104
- package/lib/engine/engine_assetdatabase.d.ts +25 -25
- package/lib/engine/engine_assetdatabase.js +346 -346
- package/lib/engine/engine_audio.d.ts +4 -4
- package/lib/engine/engine_audio.js +23 -23
- package/lib/engine/engine_camera.d.ts +13 -13
- package/lib/engine/engine_camera.js +30 -30
- package/lib/engine/engine_components.d.ts +110 -110
- package/lib/engine/engine_components.js +374 -374
- package/lib/engine/engine_components_internal.d.ts +9 -9
- package/lib/engine/engine_components_internal.js +36 -36
- package/lib/engine/engine_constants.d.ts +10 -10
- package/lib/engine/engine_constants.js +41 -41
- package/lib/engine/engine_context.d.ts +475 -475
- package/lib/engine/engine_context.js +1672 -1672
- package/lib/engine/engine_context_registry.d.ts +71 -71
- package/lib/engine/engine_context_registry.js +117 -117
- package/lib/engine/engine_coroutine.d.ts +35 -35
- package/lib/engine/engine_coroutine.js +52 -52
- package/lib/engine/engine_create_objects.d.ts +119 -119
- package/lib/engine/engine_create_objects.js +320 -320
- package/lib/engine/engine_default_parameters.d.ts +2 -2
- package/lib/engine/engine_default_parameters.js +3 -3
- package/lib/engine/engine_editor-sync.d.ts +21 -21
- package/lib/engine/engine_editor-sync.js +4 -4
- package/lib/engine/engine_fileloader.d.ts +2 -2
- package/lib/engine/engine_fileloader.js +8 -8
- package/lib/engine/engine_gameobject.d.ts +68 -68
- package/lib/engine/engine_gameobject.js +619 -619
- package/lib/engine/engine_generic_utils.d.ts +1 -1
- package/lib/engine/engine_generic_utils.js +13 -13
- package/lib/engine/engine_gizmos.d.ts +149 -149
- package/lib/engine/engine_gizmos.js +530 -530
- package/lib/engine/engine_gltf.d.ts +12 -12
- package/lib/engine/engine_gltf.js +15 -15
- package/lib/engine/engine_gltf_builtin_components.d.ts +11 -11
- package/lib/engine/engine_gltf_builtin_components.js +341 -341
- package/lib/engine/engine_hot_reload.d.ts +8 -8
- package/lib/engine/engine_hot_reload.js +197 -197
- package/lib/engine/engine_input.d.ts +362 -362
- package/lib/engine/engine_input.js +1294 -1294
- package/lib/engine/engine_input_utils.d.ts +2 -2
- package/lib/engine/engine_input_utils.js +22 -22
- package/lib/engine/engine_instancing.d.ts +19 -19
- package/lib/engine/engine_instancing.js +39 -39
- package/lib/engine/engine_license.d.ts +11 -11
- package/lib/engine/engine_license.js +369 -369
- package/lib/engine/engine_lifecycle_api.d.ts +83 -83
- package/lib/engine/engine_lifecycle_api.js +106 -106
- package/lib/engine/engine_lifecycle_functions_internal.d.ts +32 -32
- package/lib/engine/engine_lifecycle_functions_internal.js +146 -146
- package/lib/engine/engine_lightdata.d.ts +23 -23
- package/lib/engine/engine_lightdata.js +91 -91
- package/lib/engine/engine_loaders.callbacks.d.ts +97 -97
- package/lib/engine/engine_loaders.callbacks.js +86 -86
- package/lib/engine/engine_loaders.d.ts +48 -48
- package/lib/engine/engine_loaders.gltf.d.ts +13 -13
- package/lib/engine/engine_loaders.gltf.js +62 -62
- package/lib/engine/engine_loaders.js +337 -337
- package/lib/engine/engine_lods.d.ts +31 -31
- package/lib/engine/engine_lods.js +146 -146
- package/lib/engine/engine_mainloop_utils.d.ts +32 -32
- package/lib/engine/engine_mainloop_utils.js +466 -466
- package/lib/engine/engine_math.d.ts +114 -114
- package/lib/engine/engine_math.js +247 -247
- package/lib/engine/engine_modules.d.ts +36 -36
- package/lib/engine/engine_modules.js +85 -85
- package/lib/engine/engine_networking.d.ts +260 -260
- package/lib/engine/engine_networking.js +764 -764
- package/lib/engine/engine_networking_auto.d.ts +24 -24
- package/lib/engine/engine_networking_auto.js +310 -310
- package/lib/engine/engine_networking_blob.d.ts +48 -48
- package/lib/engine/engine_networking_blob.js +228 -228
- package/lib/engine/engine_networking_files.d.ts +35 -35
- package/lib/engine/engine_networking_files.js +172 -172
- package/lib/engine/engine_networking_files_default_components.d.ts +6 -6
- package/lib/engine/engine_networking_files_default_components.js +42 -42
- package/lib/engine/engine_networking_instantiate.d.ts +100 -100
- package/lib/engine/engine_networking_instantiate.js +345 -345
- package/lib/engine/engine_networking_peer.d.ts +15 -15
- package/lib/engine/engine_networking_peer.js +132 -132
- package/lib/engine/engine_networking_streams.d.ts +123 -123
- package/lib/engine/engine_networking_streams.js +645 -645
- package/lib/engine/engine_networking_types.d.ts +22 -22
- package/lib/engine/engine_networking_types.js +7 -7
- package/lib/engine/engine_networking_utils.d.ts +2 -2
- package/lib/engine/engine_networking_utils.js +20 -20
- package/lib/engine/engine_networking_websocket.d.ts +1 -1
- package/lib/engine/engine_networking_websocket.js +2 -2
- package/lib/engine/engine_patcher.d.ts +10 -10
- package/lib/engine/engine_patcher.js +142 -142
- package/lib/engine/engine_physics.d.ts +152 -152
- package/lib/engine/engine_physics.js +645 -645
- package/lib/engine/engine_physics.types.d.ts +40 -40
- package/lib/engine/engine_physics.types.js +33 -33
- package/lib/engine/engine_physics_rapier.d.ts +147 -147
- package/lib/engine/engine_physics_rapier.js +1433 -1433
- package/lib/engine/engine_playerview.d.ts +26 -26
- package/lib/engine/engine_playerview.js +64 -64
- package/lib/engine/engine_scenelighting.d.ts +71 -71
- package/lib/engine/engine_scenelighting.js +226 -226
- package/lib/engine/engine_serialization.d.ts +3 -3
- package/lib/engine/engine_serialization.js +3 -3
- package/lib/engine/engine_serialization_builtin_serializer.d.ts +72 -72
- package/lib/engine/engine_serialization_builtin_serializer.js +403 -403
- package/lib/engine/engine_serialization_core.d.ts +94 -94
- package/lib/engine/engine_serialization_core.js +607 -607
- package/lib/engine/engine_serialization_decorator.d.ts +23 -23
- package/lib/engine/engine_serialization_decorator.js +66 -66
- package/lib/engine/engine_setup.d.ts +1 -1
- package/lib/engine/engine_setup.js +2 -2
- package/lib/engine/engine_shaders.d.ts +53 -53
- package/lib/engine/engine_shaders.js +252 -252
- package/lib/engine/engine_shims.d.ts +4 -4
- package/lib/engine/engine_shims.js +24 -24
- package/lib/engine/engine_test_utils.d.ts +39 -39
- package/lib/engine/engine_test_utils.js +83 -83
- package/lib/engine/engine_texture.d.ts +28 -28
- package/lib/engine/engine_texture.js +64 -64
- package/lib/engine/engine_three_utils.d.ts +204 -204
- package/lib/engine/engine_three_utils.js +784 -784
- package/lib/engine/engine_time.d.ts +51 -51
- package/lib/engine/engine_time.js +82 -82
- package/lib/engine/engine_time_utils.d.ts +88 -88
- package/lib/engine/engine_time_utils.js +215 -215
- package/lib/engine/engine_tonemapping.d.ts +6 -6
- package/lib/engine/engine_tonemapping.js +197 -197
- package/lib/engine/engine_types.d.ts +578 -578
- package/lib/engine/engine_types.js +95 -95
- package/lib/engine/engine_typestore.d.ts +28 -28
- package/lib/engine/engine_typestore.js +55 -55
- package/lib/engine/engine_util_decorator.d.ts +13 -13
- package/lib/engine/engine_util_decorator.js +116 -116
- package/lib/engine/engine_utils.d.ts +248 -248
- package/lib/engine/engine_utils.js +1012 -1012
- package/lib/engine/engine_utils_format.d.ts +24 -24
- package/lib/engine/engine_utils_format.js +239 -239
- package/lib/engine/engine_utils_screenshot.d.ts +159 -159
- package/lib/engine/engine_utils_screenshot.js +522 -522
- package/lib/engine/engine_utils_screenshot.xr.d.ts +5 -5
- package/lib/engine/engine_utils_screenshot.xr.js +90 -90
- package/lib/engine/engine_xr.d.ts +1 -1
- package/lib/engine/engine_xr.js +1 -1
- package/lib/engine/export/gltf/Writers.d.ts +19 -19
- package/lib/engine/export/gltf/Writers.js +24 -24
- package/lib/engine/export/gltf/index.d.ts +11 -11
- package/lib/engine/export/gltf/index.js +123 -123
- package/lib/engine/export/index.d.ts +2 -2
- package/lib/engine/export/index.js +2 -2
- package/lib/engine/export/state.d.ts +7 -7
- package/lib/engine/export/state.js +17 -17
- package/lib/engine/export/utils.d.ts +2 -2
- package/lib/engine/export/utils.js +7 -7
- package/lib/engine/extensions/EXT_texture_exr.d.ts +8 -8
- package/lib/engine/extensions/EXT_texture_exr.js +32 -32
- package/lib/engine/extensions/NEEDLE_animator_controller_model.d.ts +122 -122
- package/lib/engine/extensions/NEEDLE_animator_controller_model.js +95 -95
- package/lib/engine/extensions/NEEDLE_components.d.ts +35 -35
- package/lib/engine/extensions/NEEDLE_components.js +220 -220
- package/lib/engine/extensions/NEEDLE_gameobject_data.d.ts +10 -10
- package/lib/engine/extensions/NEEDLE_gameobject_data.js +57 -57
- package/lib/engine/extensions/NEEDLE_lighting_settings.d.ts +37 -37
- package/lib/engine/extensions/NEEDLE_lighting_settings.js +157 -157
- package/lib/engine/extensions/NEEDLE_lightmaps.d.ts +18 -18
- package/lib/engine/extensions/NEEDLE_lightmaps.js +99 -99
- package/lib/engine/extensions/NEEDLE_persistent_assets.d.ts +11 -11
- package/lib/engine/extensions/NEEDLE_persistent_assets.js +63 -63
- package/lib/engine/extensions/NEEDLE_progressive.d.ts +1 -1
- package/lib/engine/extensions/NEEDLE_progressive.js +1 -1
- package/lib/engine/extensions/NEEDLE_render_objects.d.ts +13 -13
- package/lib/engine/extensions/NEEDLE_render_objects.js +159 -159
- package/lib/engine/extensions/NEEDLE_techniques_webgl.d.ts +38 -38
- package/lib/engine/extensions/NEEDLE_techniques_webgl.js +564 -564
- package/lib/engine/extensions/extension_resolver.d.ts +4 -4
- package/lib/engine/extensions/extension_resolver.js +1 -1
- package/lib/engine/extensions/extension_utils.d.ts +12 -12
- package/lib/engine/extensions/extension_utils.js +152 -152
- package/lib/engine/extensions/extensions.d.ts +32 -32
- package/lib/engine/extensions/extensions.js +107 -107
- package/lib/engine/extensions/index.d.ts +6 -6
- package/lib/engine/extensions/index.js +6 -6
- package/lib/engine/extensions/usage_tracker.d.ts +13 -13
- package/lib/engine/extensions/usage_tracker.js +65 -65
- package/lib/engine/js-extensions/Camera.d.ts +1 -1
- package/lib/engine/js-extensions/Camera.js +39 -39
- package/lib/engine/js-extensions/ExtensionUtils.d.ts +9 -9
- package/lib/engine/js-extensions/ExtensionUtils.js +67 -67
- package/lib/engine/js-extensions/Layers.d.ts +6 -6
- package/lib/engine/js-extensions/Layers.js +22 -22
- package/lib/engine/js-extensions/Object3D.d.ts +120 -120
- package/lib/engine/js-extensions/Object3D.js +136 -136
- package/lib/engine/js-extensions/RGBAColor.d.ts +23 -23
- package/lib/engine/js-extensions/RGBAColor.js +111 -111
- package/lib/engine/js-extensions/Vector.d.ts +3 -3
- package/lib/engine/js-extensions/Vector.js +13 -13
- package/lib/engine/js-extensions/index.d.ts +5 -5
- package/lib/engine/js-extensions/index.js +5 -5
- package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.d.ts +4 -4
- package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +79 -79
- package/lib/engine/shaders/shaderData.d.ts +55 -55
- package/lib/engine/shaders/shaderData.js +58 -58
- package/lib/engine/tests/test_utils.d.ts +2 -2
- package/lib/engine/tests/test_utils.js +53 -53
- package/lib/engine/webcomponents/WebXRButtons.d.ts +56 -56
- package/lib/engine/webcomponents/WebXRButtons.js +230 -230
- package/lib/engine/webcomponents/api.d.ts +5 -5
- package/lib/engine/webcomponents/api.js +4 -4
- package/lib/engine/webcomponents/buttons.d.ts +51 -51
- package/lib/engine/webcomponents/buttons.js +264 -264
- package/lib/engine/webcomponents/fonts.d.ts +9 -9
- package/lib/engine/webcomponents/fonts.js +32 -32
- package/lib/engine/webcomponents/icons.d.ts +9 -9
- package/lib/engine/webcomponents/icons.js +52 -52
- package/lib/engine/webcomponents/index.d.ts +1 -1
- package/lib/engine/webcomponents/index.js +1 -1
- package/lib/engine/webcomponents/logo-element.d.ts +10 -10
- package/lib/engine/webcomponents/logo-element.js +67 -67
- package/lib/engine/webcomponents/needle menu/needle-menu-spatial.d.ts +37 -37
- package/lib/engine/webcomponents/needle menu/needle-menu-spatial.js +513 -513
- package/lib/engine/webcomponents/needle menu/needle-menu.d.ts +155 -155
- package/lib/engine/webcomponents/needle menu/needle-menu.js +1029 -1029
- package/lib/engine/webcomponents/needle-button.d.ts +34 -34
- package/lib/engine/webcomponents/needle-button.js +161 -161
- package/lib/engine/webcomponents/needle-engine.ar-overlay.d.ts +21 -21
- package/lib/engine/webcomponents/needle-engine.ar-overlay.js +166 -166
- package/lib/engine/webcomponents/needle-engine.attributes.d.ts +69 -69
- package/lib/engine/webcomponents/needle-engine.attributes.js +1 -1
- package/lib/engine/webcomponents/needle-engine.d.ts +116 -116
- package/lib/engine/webcomponents/needle-engine.extras.d.ts +6 -6
- package/lib/engine/webcomponents/needle-engine.extras.js +13 -13
- package/lib/engine/webcomponents/needle-engine.js +821 -821
- package/lib/engine/webcomponents/needle-engine.loading.d.ts +44 -44
- package/lib/engine/webcomponents/needle-engine.loading.js +341 -341
- package/lib/engine/xr/NeedleXRController.d.ts +313 -313
- package/lib/engine/xr/NeedleXRController.js +1007 -1007
- package/lib/engine/xr/NeedleXRSession.d.ts +340 -340
- package/lib/engine/xr/NeedleXRSession.js +1463 -1463
- package/lib/engine/xr/NeedleXRSync.d.ts +22 -22
- package/lib/engine/xr/NeedleXRSync.js +188 -188
- package/lib/engine/xr/SceneTransition.d.ts +18 -18
- package/lib/engine/xr/SceneTransition.js +69 -69
- package/lib/engine/xr/TempXRContext.d.ts +34 -34
- package/lib/engine/xr/TempXRContext.js +187 -187
- package/lib/engine/xr/XRRig.d.ts +7 -7
- package/lib/engine/xr/XRRig.js +1 -1
- package/lib/engine/xr/api.d.ts +6 -6
- package/lib/engine/xr/api.js +6 -6
- package/lib/engine/xr/events.d.ts +66 -66
- package/lib/engine/xr/events.js +93 -93
- package/lib/engine/xr/internal.d.ts +12 -12
- package/lib/engine/xr/internal.js +25 -25
- package/lib/engine/xr/usdz.d.ts +12 -12
- package/lib/engine/xr/usdz.js +29 -29
- package/lib/engine/xr/utils.d.ts +11 -11
- package/lib/engine/xr/utils.js +34 -34
- package/lib/engine-components/AlignmentConstraint.d.ts +10 -10
- package/lib/engine-components/AlignmentConstraint.js +39 -39
- package/lib/engine-components/Animation.d.ts +156 -156
- package/lib/engine-components/Animation.js +508 -508
- package/lib/engine-components/AnimationCurve.d.ts +40 -40
- package/lib/engine-components/AnimationCurve.js +159 -159
- package/lib/engine-components/AnimationUtils.d.ts +8 -8
- package/lib/engine-components/AnimationUtils.js +27 -27
- package/lib/engine-components/AnimationUtilsAutoplay.d.ts +1 -1
- package/lib/engine-components/AnimationUtilsAutoplay.js +39 -39
- package/lib/engine-components/Animator.d.ts +217 -217
- package/lib/engine-components/Animator.js +354 -354
- package/lib/engine-components/AnimatorController.d.ts +227 -227
- package/lib/engine-components/AnimatorController.js +1152 -1152
- package/lib/engine-components/AudioListener.d.ts +33 -33
- package/lib/engine-components/AudioListener.js +86 -86
- package/lib/engine-components/AudioSource.d.ts +217 -217
- package/lib/engine-components/AudioSource.js +635 -635
- package/lib/engine-components/AvatarLoader.d.ts +80 -80
- package/lib/engine-components/AvatarLoader.js +231 -231
- package/lib/engine-components/AxesHelper.d.ts +32 -32
- package/lib/engine-components/AxesHelper.js +67 -67
- package/lib/engine-components/BasicIKConstraint.d.ts +9 -9
- package/lib/engine-components/BasicIKConstraint.js +43 -43
- package/lib/engine-components/BoxCollider.d.ts +2 -2
- package/lib/engine-components/BoxCollider.js +2 -2
- package/lib/engine-components/BoxHelperComponent.d.ts +47 -47
- package/lib/engine-components/BoxHelperComponent.js +102 -102
- package/lib/engine-components/Camera.d.ts +231 -231
- package/lib/engine-components/Camera.js +700 -700
- package/lib/engine-components/CameraUtils.d.ts +1 -1
- package/lib/engine-components/CameraUtils.js +121 -121
- package/lib/engine-components/CharacterController.d.ts +55 -55
- package/lib/engine-components/CharacterController.js +236 -236
- package/lib/engine-components/Collider.d.ts +188 -188
- package/lib/engine-components/Collider.js +369 -369
- package/lib/engine-components/Component.d.ts +792 -792
- package/lib/engine-components/Component.js +920 -920
- package/lib/engine-components/ContactShadows.d.ts +94 -94
- package/lib/engine-components/ContactShadows.js +453 -453
- package/lib/engine-components/DeleteBox.d.ts +19 -19
- package/lib/engine-components/DeleteBox.js +58 -58
- package/lib/engine-components/DeviceFlag.d.ts +16 -16
- package/lib/engine-components/DeviceFlag.js +47 -47
- package/lib/engine-components/DragControls.d.ts +170 -170
- package/lib/engine-components/DragControls.js +1421 -1421
- package/lib/engine-components/DropListener.d.ts +215 -215
- package/lib/engine-components/DropListener.js +642 -642
- package/lib/engine-components/Duplicatable.d.ts +35 -35
- package/lib/engine-components/Duplicatable.js +202 -202
- package/lib/engine-components/EventList.d.ts +54 -54
- package/lib/engine-components/EventList.js +232 -232
- package/lib/engine-components/EventTrigger.d.ts +33 -33
- package/lib/engine-components/EventTrigger.js +75 -75
- package/lib/engine-components/EventType.d.ts +22 -22
- package/lib/engine-components/EventType.js +23 -23
- package/lib/engine-components/Fog.d.ts +22 -22
- package/lib/engine-components/Fog.js +61 -61
- package/lib/engine-components/Gizmos.d.ts +17 -17
- package/lib/engine-components/Gizmos.js +64 -64
- package/lib/engine-components/GridHelper.d.ts +20 -20
- package/lib/engine-components/GridHelper.js +54 -54
- package/lib/engine-components/GroundProjection.d.ts +67 -67
- package/lib/engine-components/GroundProjection.js +343 -343
- package/lib/engine-components/Interactable.d.ts +12 -12
- package/lib/engine-components/Interactable.js +12 -12
- package/lib/engine-components/Joints.d.ts +19 -19
- package/lib/engine-components/Joints.js +51 -51
- package/lib/engine-components/LODGroup.d.ts +35 -35
- package/lib/engine-components/LODGroup.js +152 -152
- package/lib/engine-components/Light.d.ts +180 -180
- package/lib/engine-components/Light.js +535 -535
- package/lib/engine-components/LookAtConstraint.d.ts +19 -19
- package/lib/engine-components/LookAtConstraint.js +35 -35
- package/lib/engine-components/NeedleMenu.d.ts +50 -50
- package/lib/engine-components/NeedleMenu.js +92 -92
- package/lib/engine-components/NestedGltf.d.ts +25 -25
- package/lib/engine-components/NestedGltf.js +88 -88
- package/lib/engine-components/Networking.d.ts +54 -54
- package/lib/engine-components/Networking.js +112 -112
- package/lib/engine-components/OffsetConstraint.d.ts +14 -14
- package/lib/engine-components/OffsetConstraint.js +65 -65
- package/lib/engine-components/OrbitControls.d.ts +268 -268
- package/lib/engine-components/OrbitControls.js +1015 -1015
- package/lib/engine-components/PlayerColor.d.ts +19 -19
- package/lib/engine-components/PlayerColor.js +94 -94
- package/lib/engine-components/ReflectionProbe.d.ts +28 -28
- package/lib/engine-components/ReflectionProbe.js +204 -204
- package/lib/engine-components/Renderer.d.ts +153 -153
- package/lib/engine-components/Renderer.js +834 -834
- package/lib/engine-components/RendererInstancing.d.ts +140 -140
- package/lib/engine-components/RendererInstancing.js +744 -744
- package/lib/engine-components/RendererLightmap.d.ts +24 -24
- package/lib/engine-components/RendererLightmap.js +182 -182
- package/lib/engine-components/RigidBody.d.ts +155 -155
- package/lib/engine-components/RigidBody.js +517 -517
- package/lib/engine-components/SceneSwitcher.d.ts +263 -263
- package/lib/engine-components/SceneSwitcher.js +971 -971
- package/lib/engine-components/ScreenCapture.d.ts +144 -144
- package/lib/engine-components/ScreenCapture.js +547 -547
- package/lib/engine-components/ShadowCatcher.d.ts +33 -33
- package/lib/engine-components/ShadowCatcher.js +166 -166
- package/lib/engine-components/Skybox.d.ts +88 -88
- package/lib/engine-components/Skybox.js +469 -469
- package/lib/engine-components/SmoothFollow.d.ts +34 -34
- package/lib/engine-components/SmoothFollow.js +82 -82
- package/lib/engine-components/SpatialTrigger.d.ts +102 -102
- package/lib/engine-components/SpatialTrigger.js +225 -225
- package/lib/engine-components/SpectatorCamera.d.ts +111 -111
- package/lib/engine-components/SpectatorCamera.js +715 -715
- package/lib/engine-components/SphereCollider.d.ts +2 -2
- package/lib/engine-components/SphereCollider.js +2 -2
- package/lib/engine-components/SpriteRenderer.d.ts +132 -132
- package/lib/engine-components/SpriteRenderer.js +472 -472
- package/lib/engine-components/SyncedCamera.d.ts +41 -41
- package/lib/engine-components/SyncedCamera.js +199 -199
- package/lib/engine-components/SyncedRoom.d.ts +106 -106
- package/lib/engine-components/SyncedRoom.js +371 -371
- package/lib/engine-components/SyncedTransform.d.ts +94 -94
- package/lib/engine-components/SyncedTransform.js +331 -331
- package/lib/engine-components/TestRunner.d.ts +16 -16
- package/lib/engine-components/TestRunner.js +102 -102
- package/lib/engine-components/TransformGizmo.d.ts +75 -75
- package/lib/engine-components/TransformGizmo.js +209 -209
- package/lib/engine-components/VideoPlayer.d.ts +184 -184
- package/lib/engine-components/VideoPlayer.js +978 -978
- package/lib/engine-components/Voip.d.ts +67 -67
- package/lib/engine-components/Voip.js +360 -360
- package/lib/engine-components/api.d.ts +51 -51
- package/lib/engine-components/api.js +50 -50
- package/lib/engine-components/avatar/AvatarBlink_Simple.d.ts +11 -11
- package/lib/engine-components/avatar/AvatarBlink_Simple.js +76 -76
- package/lib/engine-components/avatar/AvatarEyeLook_Rotation.d.ts +14 -14
- package/lib/engine-components/avatar/AvatarEyeLook_Rotation.js +68 -68
- package/lib/engine-components/avatar/Avatar_Brain_LookAt.d.ts +29 -29
- package/lib/engine-components/avatar/Avatar_Brain_LookAt.js +121 -121
- package/lib/engine-components/avatar/Avatar_MouthShapes.d.ts +15 -15
- package/lib/engine-components/avatar/Avatar_MouthShapes.js +79 -79
- package/lib/engine-components/avatar/Avatar_MustacheShake.d.ts +9 -9
- package/lib/engine-components/avatar/Avatar_MustacheShake.js +29 -29
- package/lib/engine-components/codegen/components.d.ts +216 -216
- package/lib/engine-components/codegen/components.js +218 -218
- package/lib/engine-components/debug/LogStats.d.ts +5 -5
- package/lib/engine-components/debug/LogStats.js +18 -18
- package/lib/engine-components/export/gltf/GltfExport.d.ts +30 -30
- package/lib/engine-components/export/gltf/GltfExport.js +246 -246
- package/lib/engine-components/export/gltf/index.d.ts +1 -1
- package/lib/engine-components/export/gltf/index.js +1 -1
- package/lib/engine-components/export/index.d.ts +1 -1
- package/lib/engine-components/export/index.js +1 -1
- package/lib/engine-components/export/usdz/Extension.d.ts +22 -22
- package/lib/engine-components/export/usdz/Extension.js +1 -1
- package/lib/engine-components/export/usdz/ThreeUSDZExporter.d.ts +162 -162
- package/lib/engine-components/export/usdz/ThreeUSDZExporter.js +1789 -1789
- package/lib/engine-components/export/usdz/USDZExporter.d.ts +130 -130
- package/lib/engine-components/export/usdz/USDZExporter.js +663 -663
- package/lib/engine-components/export/usdz/extensions/Animation.d.ts +106 -106
- package/lib/engine-components/export/usdz/extensions/Animation.js +1071 -1071
- package/lib/engine-components/export/usdz/extensions/DocumentExtension.d.ts +5 -5
- package/lib/engine-components/export/usdz/extensions/DocumentExtension.js +6 -6
- package/lib/engine-components/export/usdz/extensions/NodeMaterialConverter.d.ts +10 -10
- package/lib/engine-components/export/usdz/extensions/NodeMaterialConverter.js +451 -451
- package/lib/engine-components/export/usdz/extensions/USDZText.d.ts +54 -54
- package/lib/engine-components/export/usdz/extensions/USDZText.js +203 -203
- package/lib/engine-components/export/usdz/extensions/USDZUI.d.ts +8 -8
- package/lib/engine-components/export/usdz/extensions/USDZUI.js +158 -158
- package/lib/engine-components/export/usdz/extensions/behavior/Actions.d.ts +30 -30
- package/lib/engine-components/export/usdz/extensions/behavior/Actions.js +88 -88
- package/lib/engine-components/export/usdz/extensions/behavior/AudioExtension.d.ts +10 -10
- package/lib/engine-components/export/usdz/extensions/behavior/AudioExtension.js +86 -86
- package/lib/engine-components/export/usdz/extensions/behavior/Behaviour.d.ts +28 -28
- package/lib/engine-components/export/usdz/extensions/behavior/Behaviour.js +290 -290
- package/lib/engine-components/export/usdz/extensions/behavior/BehaviourComponents.d.ts +190 -190
- package/lib/engine-components/export/usdz/extensions/behavior/BehaviourComponents.js +1060 -1060
- package/lib/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.d.ts +135 -135
- package/lib/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.js +548 -548
- package/lib/engine-components/export/usdz/extensions/behavior/PhysicsExtension.d.ts +7 -7
- package/lib/engine-components/export/usdz/extensions/behavior/PhysicsExtension.js +115 -115
- package/lib/engine-components/export/usdz/index.d.ts +3 -3
- package/lib/engine-components/export/usdz/index.js +2 -2
- package/lib/engine-components/export/usdz/utils/animationutils.d.ts +7 -7
- package/lib/engine-components/export/usdz/utils/animationutils.js +163 -163
- package/lib/engine-components/export/usdz/utils/quicklook.d.ts +2 -2
- package/lib/engine-components/export/usdz/utils/quicklook.js +43 -43
- package/lib/engine-components/particlesystem/ParticleSystem.d.ts +177 -177
- package/lib/engine-components/particlesystem/ParticleSystem.js +1176 -1176
- package/lib/engine-components/particlesystem/ParticleSystemModules.d.ts +526 -526
- package/lib/engine-components/particlesystem/ParticleSystemModules.js +1930 -1930
- package/lib/engine-components/particlesystem/ParticleSystemSubEmitter.d.ts +25 -25
- package/lib/engine-components/particlesystem/ParticleSystemSubEmitter.js +87 -87
- package/lib/engine-components/particlesystem/api.d.ts +2 -2
- package/lib/engine-components/particlesystem/api.js +2 -2
- package/lib/engine-components/postprocessing/Effects/Antialiasing.d.ts +17 -17
- package/lib/engine-components/postprocessing/Effects/Antialiasing.js +52 -52
- package/lib/engine-components/postprocessing/Effects/BloomEffect.d.ts +46 -46
- package/lib/engine-components/postprocessing/Effects/BloomEffect.js +113 -113
- package/lib/engine-components/postprocessing/Effects/ChromaticAberration.d.ts +11 -11
- package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js +39 -39
- package/lib/engine-components/postprocessing/Effects/ColorAdjustments.d.ts +23 -23
- package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js +111 -111
- package/lib/engine-components/postprocessing/Effects/DepthOfField.d.ts +25 -25
- package/lib/engine-components/postprocessing/Effects/DepthOfField.js +104 -104
- package/lib/engine-components/postprocessing/Effects/EffectWrapper.d.ts +12 -12
- package/lib/engine-components/postprocessing/Effects/EffectWrapper.js +18 -18
- package/lib/engine-components/postprocessing/Effects/Pixelation.d.ts +11 -11
- package/lib/engine-components/postprocessing/Effects/Pixelation.js +32 -32
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.d.ts +18 -18
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js +91 -91
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.d.ts +70 -70
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.js +176 -176
- package/lib/engine-components/postprocessing/Effects/Sharpening.d.ts +18 -18
- package/lib/engine-components/postprocessing/Effects/Sharpening.js +127 -127
- package/lib/engine-components/postprocessing/Effects/TiltShiftEffect.d.ts +17 -17
- package/lib/engine-components/postprocessing/Effects/TiltShiftEffect.js +70 -70
- package/lib/engine-components/postprocessing/Effects/Tonemapping.d.ts +19 -19
- package/lib/engine-components/postprocessing/Effects/Tonemapping.js +94 -94
- package/lib/engine-components/postprocessing/Effects/Tonemapping.utils.d.ts +13 -13
- package/lib/engine-components/postprocessing/Effects/Tonemapping.utils.js +51 -51
- package/lib/engine-components/postprocessing/Effects/Vignette.d.ts +15 -15
- package/lib/engine-components/postprocessing/Effects/Vignette.js +60 -60
- package/lib/engine-components/postprocessing/PostProcessingEffect.d.ts +90 -90
- package/lib/engine-components/postprocessing/PostProcessingEffect.js +168 -168
- package/lib/engine-components/postprocessing/PostProcessingHandler.d.ts +42 -42
- package/lib/engine-components/postprocessing/PostProcessingHandler.js +480 -480
- package/lib/engine-components/postprocessing/Volume.d.ts +90 -90
- package/lib/engine-components/postprocessing/Volume.js +385 -385
- package/lib/engine-components/postprocessing/VolumeParameter.d.ts +26 -26
- package/lib/engine-components/postprocessing/VolumeParameter.js +136 -136
- package/lib/engine-components/postprocessing/VolumeProfile.d.ts +15 -15
- package/lib/engine-components/postprocessing/VolumeProfile.js +60 -60
- package/lib/engine-components/postprocessing/index.d.ts +6 -6
- package/lib/engine-components/postprocessing/index.js +6 -6
- package/lib/engine-components/postprocessing/utils.d.ts +55 -55
- package/lib/engine-components/postprocessing/utils.js +119 -119
- package/lib/engine-components/timeline/PlayableDirector.d.ts +163 -163
- package/lib/engine-components/timeline/PlayableDirector.js +686 -686
- package/lib/engine-components/timeline/SignalAsset.d.ts +24 -24
- package/lib/engine-components/timeline/SignalAsset.js +130 -130
- package/lib/engine-components/timeline/TimelineModels.d.ts +89 -89
- package/lib/engine-components/timeline/TimelineModels.js +22 -22
- package/lib/engine-components/timeline/TimelineTracks.d.ts +110 -110
- package/lib/engine-components/timeline/TimelineTracks.js +879 -879
- package/lib/engine-components/timeline/index.d.ts +4 -4
- package/lib/engine-components/timeline/index.js +3 -3
- package/lib/engine-components/ui/BaseUIComponent.d.ts +48 -48
- package/lib/engine-components/ui/BaseUIComponent.js +170 -170
- package/lib/engine-components/ui/Button.d.ts +64 -64
- package/lib/engine-components/ui/Button.js +315 -315
- package/lib/engine-components/ui/Canvas.d.ts +74 -74
- package/lib/engine-components/ui/Canvas.js +407 -407
- package/lib/engine-components/ui/CanvasGroup.d.ts +19 -19
- package/lib/engine-components/ui/CanvasGroup.js +58 -58
- package/lib/engine-components/ui/EventSystem.d.ts +125 -125
- package/lib/engine-components/ui/EventSystem.js +765 -765
- package/lib/engine-components/ui/Graphic.d.ts +55 -55
- package/lib/engine-components/ui/Graphic.js +255 -255
- package/lib/engine-components/ui/Image.d.ts +35 -35
- package/lib/engine-components/ui/Image.js +116 -116
- package/lib/engine-components/ui/InputField.d.ts +42 -42
- package/lib/engine-components/ui/InputField.js +268 -268
- package/lib/engine-components/ui/Interfaces.d.ts +38 -38
- package/lib/engine-components/ui/Interfaces.js +12 -12
- package/lib/engine-components/ui/Layout.d.ts +84 -84
- package/lib/engine-components/ui/Layout.js +330 -330
- package/lib/engine-components/ui/Outline.d.ts +7 -7
- package/lib/engine-components/ui/Outline.js +20 -20
- package/lib/engine-components/ui/PointerEvents.d.ts +115 -115
- package/lib/engine-components/ui/PointerEvents.js +145 -145
- package/lib/engine-components/ui/RaycastUtils.d.ts +11 -11
- package/lib/engine-components/ui/RaycastUtils.js +67 -67
- package/lib/engine-components/ui/Raycaster.d.ts +30 -30
- package/lib/engine-components/ui/Raycaster.js +95 -95
- package/lib/engine-components/ui/RectTransform.d.ts +61 -61
- package/lib/engine-components/ui/RectTransform.js +356 -356
- package/lib/engine-components/ui/SpatialHtml.d.ts +8 -8
- package/lib/engine-components/ui/SpatialHtml.js +79 -79
- package/lib/engine-components/ui/Symbols.d.ts +1 -1
- package/lib/engine-components/ui/Symbols.js +1 -1
- package/lib/engine-components/ui/Text.d.ts +78 -78
- package/lib/engine-components/ui/Text.js +539 -539
- package/lib/engine-components/ui/Utils.d.ts +24 -24
- package/lib/engine-components/ui/Utils.js +90 -90
- package/lib/engine-components/ui/index.d.ts +1 -1
- package/lib/engine-components/ui/index.js +1 -1
- package/lib/engine-components/utils/EnvironmentScene.d.ts +5 -5
- package/lib/engine-components/utils/EnvironmentScene.js +205 -205
- package/lib/engine-components/utils/LookAt.d.ts +31 -31
- package/lib/engine-components/utils/LookAt.js +82 -82
- package/lib/engine-components/utils/OpenURL.d.ts +42 -42
- package/lib/engine-components/utils/OpenURL.js +119 -119
- package/lib/engine-components/webxr/Avatar.d.ts +25 -25
- package/lib/engine-components/webxr/Avatar.js +255 -255
- package/lib/engine-components/webxr/TeleportTarget.d.ts +7 -7
- package/lib/engine-components/webxr/TeleportTarget.js +7 -7
- package/lib/engine-components/webxr/WebARCameraBackground.d.ts +30 -30
- package/lib/engine-components/webxr/WebARCameraBackground.js +155 -155
- package/lib/engine-components/webxr/WebARSessionRoot.d.ts +98 -98
- package/lib/engine-components/webxr/WebARSessionRoot.js +770 -770
- package/lib/engine-components/webxr/WebXR.d.ts +232 -232
- package/lib/engine-components/webxr/WebXR.js +561 -561
- package/lib/engine-components/webxr/WebXRAvatar.d.ts +27 -27
- package/lib/engine-components/webxr/WebXRAvatar.js +44 -44
- package/lib/engine-components/webxr/WebXRImageTracking.d.ts +86 -86
- package/lib/engine-components/webxr/WebXRImageTracking.js +471 -471
- package/lib/engine-components/webxr/WebXRPlaneTracking.d.ts +92 -92
- package/lib/engine-components/webxr/WebXRPlaneTracking.js +500 -500
- package/lib/engine-components/webxr/WebXRRig.d.ts +32 -32
- package/lib/engine-components/webxr/WebXRRig.js +72 -72
- package/lib/engine-components/webxr/XRFlag.d.ts +38 -38
- package/lib/engine-components/webxr/XRFlag.js +139 -139
- package/lib/engine-components/webxr/controllers/XRControllerFollow.d.ts +47 -47
- package/lib/engine-components/webxr/controllers/XRControllerFollow.js +120 -120
- package/lib/engine-components/webxr/controllers/XRControllerModel.d.ts +43 -43
- package/lib/engine-components/webxr/controllers/XRControllerModel.js +352 -352
- package/lib/engine-components/webxr/controllers/XRControllerMovement.d.ts +78 -78
- package/lib/engine-components/webxr/controllers/XRControllerMovement.js +506 -506
- package/lib/engine-components/webxr/index.d.ts +3 -3
- package/lib/engine-components/webxr/index.js +3 -3
- package/lib/engine-components/webxr/types.d.ts +3 -3
- package/lib/engine-components/webxr/types.js +1 -1
- package/lib/engine-components-experimental/Presentation.d.ts +6 -6
- package/lib/engine-components-experimental/Presentation.js +9 -9
- package/lib/engine-components-experimental/api.d.ts +4 -4
- package/lib/engine-components-experimental/api.js +4 -4
- package/lib/engine-components-experimental/networking/PlayerSync.d.ts +156 -156
- package/lib/engine-components-experimental/networking/PlayerSync.js +377 -377
- package/lib/engine-schemes/api.d.ts +12 -12
- package/lib/engine-schemes/api.js +12 -12
- package/lib/engine-schemes/schemes.d.ts +7 -7
- package/lib/engine-schemes/schemes.js +19 -19
- package/lib/engine-schemes/synced-camera-model.d.ts +25 -25
- package/lib/engine-schemes/synced-camera-model.js +67 -67
- package/lib/engine-schemes/synced-transform-model.d.ts +31 -31
- package/lib/engine-schemes/synced-transform-model.js +66 -66
- package/lib/engine-schemes/transform.d.ts +12 -12
- package/lib/engine-schemes/transform.js +39 -39
- package/lib/engine-schemes/vec2.d.ts +10 -10
- package/lib/engine-schemes/vec2.js +25 -25
- package/lib/engine-schemes/vec3.d.ts +11 -11
- package/lib/engine-schemes/vec3.js +29 -29
- package/lib/engine-schemes/vec4.d.ts +12 -12
- package/lib/engine-schemes/vec4.js +33 -33
- package/lib/engine-schemes/vr-user-state-buffer.d.ts +37 -37
- package/lib/engine-schemes/vr-user-state-buffer.js +110 -110
- package/lib/include/three/EXT_mesh_gpu_instancing_exporter.d.ts +6 -6
- package/lib/include/three/EXT_mesh_gpu_instancing_exporter.js +45 -45
- package/lib/needle-engine.d.ts +7 -7
- package/lib/needle-engine.js +64 -64
- package/package.json +2 -2
- package/plugins/common/buildinfo.js +64 -64
- package/plugins/common/cloud.js +1 -1
- package/plugins/common/config.cjs +31 -31
- package/plugins/common/config.js +35 -35
- package/plugins/common/files.js +31 -31
- package/plugins/common/generator.js +10 -10
- package/plugins/common/license.js +452 -452
- package/plugins/common/npm.js +15 -15
- package/plugins/common/timers.js +7 -7
- package/plugins/common/version.js +37 -37
- package/plugins/gltf-packer.mjs +1 -1
- package/plugins/next/alias.cjs +39 -39
- package/plugins/next/license.cjs +24 -24
- package/plugins/next/meshbvhworker.cjs +18 -18
- package/plugins/next/next.js +141 -141
- package/plugins/types/index.d.ts +2 -2
- package/plugins/types/license.d.ts +24 -24
- package/plugins/types/needleConfig.d.ts +27 -27
- package/plugins/types/next.d.ts +2 -2
- package/plugins/types/userconfig.d.ts +120 -120
- package/plugins/types/vite.d.ts +13 -13
- package/plugins/types/webmanifest.d.ts +32 -32
- package/plugins/vite/alias.js +174 -174
- package/plugins/vite/asap.js +251 -251
- package/plugins/vite/build-pipeline.js +371 -371
- package/plugins/vite/build.js +19 -19
- package/plugins/vite/buildinfo.js +41 -41
- package/plugins/vite/config.js +106 -106
- package/plugins/vite/copyfiles.js +138 -138
- package/plugins/vite/defines.js +70 -70
- package/plugins/vite/dependencies.js +232 -232
- package/plugins/vite/dependency-watcher.js +237 -237
- package/plugins/vite/drop-client.js +76 -76
- package/plugins/vite/drop.js +87 -87
- package/plugins/vite/editor-connection.js +124 -124
- package/plugins/vite/facebook-instant-games.js +102 -102
- package/plugins/vite/gzip.js +5 -5
- package/plugins/vite/imports-logger.js +143 -143
- package/plugins/vite/index.js +143 -143
- package/plugins/vite/license.js +56 -56
- package/plugins/vite/local-files.js +440 -440
- package/plugins/vite/meta.js +163 -163
- package/plugins/vite/npm.js +7 -7
- package/plugins/vite/peer.js +29 -29
- package/plugins/vite/poster-client.js +73 -73
- package/plugins/vite/poster.js +79 -79
- package/plugins/vite/pwa.js +604 -604
- package/plugins/vite/reload-client.js +15 -15
- package/plugins/vite/reload.js +351 -351
- package/plugins/vite/server.js +66 -66
- package/plugins/vite/transform-codegen.js +55 -55
- package/plugins/vite/transform.js +31 -31
- package/plugins/vite/vite-4.4-hack.js +31 -31
- package/src/asap/needle-asap.ts +111 -111
- package/src/asap/sessiongranted.ts +75 -75
- package/src/asap/utils.ts +4 -4
- package/src/engine/analytics/index.ts +10 -10
- package/src/engine/analytics/lcp.ts +35 -35
- package/src/engine/api.ts +82 -82
- package/src/engine/assets/index.ts +59 -59
- package/src/engine/assets/static.js +5 -5
- package/src/engine/codegen/register_types.ts +300 -300
- package/src/engine/debug/debug.ts +51 -51
- package/src/engine/debug/debug_console.ts +333 -333
- package/src/engine/debug/debug_overlay.ts +332 -332
- package/src/engine/debug/debug_spatial_console.ts +429 -429
- package/src/engine/debug/index.ts +1 -1
- package/src/engine/engine_addressables.ts +680 -680
- package/src/engine/engine_animation.ts +145 -145
- package/src/engine/engine_application.ts +113 -113
- package/src/engine/engine_assetdatabase.ts +389 -389
- package/src/engine/engine_audio.ts +24 -24
- package/src/engine/engine_camera.ts +39 -39
- package/src/engine/engine_components.ts +366 -366
- package/src/engine/engine_components_internal.ts +40 -40
- package/src/engine/engine_constants.ts +52 -52
- package/src/engine/engine_context.ts +1823 -1823
- package/src/engine/engine_context_registry.ts +129 -129
- package/src/engine/engine_coroutine.ts +54 -54
- package/src/engine/engine_create_objects.ts +411 -411
- package/src/engine/engine_default_parameters.ts +3 -3
- package/src/engine/engine_editor-sync.ts +28 -28
- package/src/engine/engine_fileloader.js +9 -9
- package/src/engine/engine_gameobject.ts +712 -712
- package/src/engine/engine_generic_utils.js +13 -13
- package/src/engine/engine_gizmos.ts +577 -577
- package/src/engine/engine_gltf.ts +29 -29
- package/src/engine/engine_gltf_builtin_components.ts +403 -403
- package/src/engine/engine_hot_reload.ts +210 -210
- package/src/engine/engine_input.ts +1500 -1500
- package/src/engine/engine_input_utils.ts +23 -23
- package/src/engine/engine_instancing.ts +45 -45
- package/src/engine/engine_license.ts +386 -386
- package/src/engine/engine_lifecycle_api.ts +113 -113
- package/src/engine/engine_lifecycle_functions_internal.ts +193 -193
- package/src/engine/engine_lightdata.ts +117 -117
- package/src/engine/engine_loaders.callbacks.ts +136 -136
- package/src/engine/engine_loaders.gltf.ts +82 -82
- package/src/engine/engine_loaders.ts +378 -378
- package/src/engine/engine_lods.ts +168 -168
- package/src/engine/engine_mainloop_utils.ts +472 -472
- package/src/engine/engine_math.ts +282 -282
- package/src/engine/engine_modules.ts +83 -83
- package/src/engine/engine_networking.ts +862 -862
- package/src/engine/engine_networking_auto.ts +352 -352
- package/src/engine/engine_networking_blob.ts +275 -275
- package/src/engine/engine_networking_files.ts +217 -217
- package/src/engine/engine_networking_files_default_components.ts +58 -58
- package/src/engine/engine_networking_instantiate.ts +419 -419
- package/src/engine/engine_networking_peer.ts +159 -159
- package/src/engine/engine_networking_streams.ts +713 -713
- package/src/engine/engine_networking_types.ts +24 -24
- package/src/engine/engine_networking_utils.ts +23 -23
- package/src/engine/engine_networking_websocket.ts +2 -2
- package/src/engine/engine_patcher.ts +199 -199
- package/src/engine/engine_physics.ts +783 -783
- package/src/engine/engine_physics.types.ts +46 -46
- package/src/engine/engine_physics_rapier.ts +1577 -1577
- package/src/engine/engine_playerview.ts +80 -80
- package/src/engine/engine_scenelighting.ts +294 -294
- package/src/engine/engine_serialization.ts +2 -2
- package/src/engine/engine_serialization_builtin_serializer.ts +473 -473
- package/src/engine/engine_serialization_core.ts +720 -720
- package/src/engine/engine_serialization_decorator.ts +80 -80
- package/src/engine/engine_setup.ts +1 -1
- package/src/engine/engine_shaders.ts +267 -267
- package/src/engine/engine_shims.ts +32 -32
- package/src/engine/engine_test_utils.ts +109 -109
- package/src/engine/engine_texture.ts +82 -82
- package/src/engine/engine_three_utils.ts +925 -925
- package/src/engine/engine_time.ts +94 -94
- package/src/engine/engine_time_utils.ts +237 -237
- package/src/engine/engine_tonemapping.ts +208 -208
- package/src/engine/engine_types.ts +730 -730
- package/src/engine/engine_typestore.ts +63 -63
- package/src/engine/engine_util_decorator.ts +136 -136
- package/src/engine/engine_utils.ts +1115 -1115
- package/src/engine/engine_utils_format.ts +273 -273
- package/src/engine/engine_utils_screenshot.ts +708 -708
- package/src/engine/engine_utils_screenshot.xr.ts +103 -103
- package/src/engine/export/gltf/Writers.ts +34 -34
- package/src/engine/export/gltf/index.ts +158 -158
- package/src/engine/export/index.ts +2 -2
- package/src/engine/export/state.ts +19 -19
- package/src/engine/export/utils.ts +9 -9
- package/src/engine/extensions/EXT_texture_exr.ts +50 -50
- package/src/engine/extensions/NEEDLE_animator_controller_model.ts +195 -195
- package/src/engine/extensions/NEEDLE_components.ts +268 -268
- package/src/engine/extensions/NEEDLE_gameobject_data.ts +81 -81
- package/src/engine/extensions/NEEDLE_lighting_settings.ts +185 -185
- package/src/engine/extensions/NEEDLE_lightmaps.ts +119 -119
- package/src/engine/extensions/NEEDLE_persistent_assets.ts +76 -76
- package/src/engine/extensions/NEEDLE_render_objects.ts +209 -209
- package/src/engine/extensions/NEEDLE_techniques_webgl.ts +640 -640
- package/src/engine/extensions/extension_resolver.ts +4 -4
- package/src/engine/extensions/extension_utils.ts +166 -166
- package/src/engine/extensions/extensions.ts +140 -140
- package/src/engine/extensions/index.ts +5 -5
- package/src/engine/extensions/usage_tracker.ts +100 -100
- package/src/engine/js-extensions/Camera.ts +37 -37
- package/src/engine/js-extensions/ExtensionUtils.ts +85 -85
- package/src/engine/js-extensions/Layers.ts +23 -23
- package/src/engine/js-extensions/Object3D.ts +296 -296
- package/src/engine/js-extensions/RGBAColor.ts +126 -126
- package/src/engine/js-extensions/Vector.ts +18 -18
- package/src/engine/js-extensions/index.ts +4 -4
- package/src/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +125 -125
- package/src/engine/shaders/shaderData.ts +67 -67
- package/src/engine/tests/test_utils.ts +63 -63
- package/src/engine/webcomponents/WebXRButtons.ts +260 -260
- package/src/engine/webcomponents/api.ts +6 -6
- package/src/engine/webcomponents/buttons.ts +292 -292
- package/src/engine/webcomponents/fonts.ts +41 -41
- package/src/engine/webcomponents/icons.ts +57 -57
- package/src/engine/webcomponents/index.ts +1 -1
- package/src/engine/webcomponents/logo-element.ts +78 -78
- package/src/engine/webcomponents/needle menu/needle-menu-spatial.ts +573 -573
- package/src/engine/webcomponents/needle menu/needle-menu.ts +1118 -1118
- package/src/engine/webcomponents/needle-button.ts +181 -181
- package/src/engine/webcomponents/needle-engine.ar-overlay.ts +186 -186
- package/src/engine/webcomponents/needle-engine.attributes.ts +82 -82
- package/src/engine/webcomponents/needle-engine.extras.ts +16 -16
- package/src/engine/webcomponents/needle-engine.loading.ts +373 -373
- package/src/engine/webcomponents/needle-engine.ts +860 -860
- package/src/engine/xr/NeedleXRController.ts +1125 -1125
- package/src/engine/xr/NeedleXRSession.ts +1624 -1624
- package/src/engine/xr/NeedleXRSync.ts +220 -220
- package/src/engine/xr/SceneTransition.ts +78 -78
- package/src/engine/xr/TempXRContext.ts +216 -216
- package/src/engine/xr/XRRig.ts +9 -9
- package/src/engine/xr/api.ts +5 -5
- package/src/engine/xr/events.ts +102 -102
- package/src/engine/xr/internal.ts +34 -34
- package/src/engine/xr/usdz.ts +30 -30
- package/src/engine/xr/utils.ts +39 -39
- package/src/engine-components/AlignmentConstraint.ts +36 -36
- package/src/engine-components/Animation.ts +557 -557
- package/src/engine-components/AnimationCurve.ts +150 -150
- package/src/engine-components/AnimationUtils.ts +28 -28
- package/src/engine-components/AnimationUtilsAutoplay.ts +43 -43
- package/src/engine-components/Animator.ts +397 -397
- package/src/engine-components/AnimatorController.ts +1293 -1293
- package/src/engine-components/AudioListener.ts +92 -92
- package/src/engine-components/AudioSource.ts +644 -644
- package/src/engine-components/AvatarLoader.ts +263 -263
- package/src/engine-components/AxesHelper.ts +59 -59
- package/src/engine-components/BasicIKConstraint.ts +54 -54
- package/src/engine-components/BoxCollider.ts +1 -1
- package/src/engine-components/BoxHelperComponent.ts +114 -114
- package/src/engine-components/Camera.ts +719 -719
- package/src/engine-components/CameraUtils.ts +136 -136
- package/src/engine-components/CharacterController.ts +253 -253
- package/src/engine-components/Collider.ts +374 -374
- package/src/engine-components/Component.ts +1297 -1297
- package/src/engine-components/ContactShadows.ts +506 -506
- package/src/engine-components/DeleteBox.ts +62 -62
- package/src/engine-components/DeviceFlag.ts +46 -46
- package/src/engine-components/DragControls.ts +1623 -1623
- package/src/engine-components/DropListener.ts +713 -713
- package/src/engine-components/Duplicatable.ts +198 -198
- package/src/engine-components/EventList.ts +266 -266
- package/src/engine-components/EventTrigger.ts +74 -74
- package/src/engine-components/EventType.ts +22 -22
- package/src/engine-components/Fog.ts +60 -60
- package/src/engine-components/Gizmos.ts +56 -56
- package/src/engine-components/GridHelper.ts +48 -48
- package/src/engine-components/GroundProjection.ts +356 -356
- package/src/engine-components/Interactable.ts +14 -14
- package/src/engine-components/Joints.ts +52 -52
- package/src/engine-components/LODGroup.ts +153 -153
- package/src/engine-components/Light.ts +558 -558
- package/src/engine-components/LookAtConstraint.ts +25 -25
- package/src/engine-components/NeedleMenu.ts +84 -84
- package/src/engine-components/NestedGltf.ts +86 -86
- package/src/engine-components/Networking.ts +114 -114
- package/src/engine-components/OffsetConstraint.ts +60 -60
- package/src/engine-components/OrbitControls.ts +1074 -1074
- package/src/engine-components/PlayerColor.ts +103 -103
- package/src/engine-components/ReflectionProbe.ts +220 -220
- package/src/engine-components/Renderer.ts +903 -903
- package/src/engine-components/RendererInstancing.ts +855 -855
- package/src/engine-components/RendererLightmap.ts +198 -198
- package/src/engine-components/RigidBody.ts +526 -526
- package/src/engine-components/SceneSwitcher.ts +1030 -1030
- package/src/engine-components/ScreenCapture.ts +592 -592
- package/src/engine-components/ShadowCatcher.ts +172 -172
- package/src/engine-components/Skybox.ts +475 -475
- package/src/engine-components/SmoothFollow.ts +76 -76
- package/src/engine-components/SpatialTrigger.ts +229 -229
- package/src/engine-components/SpectatorCamera.ts +787 -787
- package/src/engine-components/SphereCollider.ts +1 -1
- package/src/engine-components/SpriteRenderer.ts +468 -468
- package/src/engine-components/SyncedCamera.ts +220 -220
- package/src/engine-components/SyncedRoom.ts +380 -380
- package/src/engine-components/SyncedTransform.ts +383 -383
- package/src/engine-components/TestRunner.ts +118 -118
- package/src/engine-components/TransformGizmo.ts +219 -219
- package/src/engine-components/VideoPlayer.ts +1025 -1025
- package/src/engine-components/Voip.ts +363 -363
- package/src/engine-components/api.ts +60 -60
- package/src/engine-components/avatar/AvatarBlink_Simple.ts +69 -69
- package/src/engine-components/avatar/AvatarEyeLook_Rotation.ts +63 -63
- package/src/engine-components/avatar/Avatar_Brain_LookAt.ts +139 -139
- package/src/engine-components/avatar/Avatar_MouthShapes.ts +83 -83
- package/src/engine-components/avatar/Avatar_MustacheShake.ts +31 -31
- package/src/engine-components/codegen/components.ts +217 -217
- package/src/engine-components/debug/LogStats.ts +21 -21
- package/src/engine-components/export/gltf/GltfExport.ts +265 -265
- package/src/engine-components/export/usdz/Extension.ts +24 -24
- package/src/engine-components/export/usdz/ThreeUSDZExporter.ts +2426 -2426
- package/src/engine-components/export/usdz/USDZExporter.ts +705 -705
- package/src/engine-components/export/usdz/extensions/Animation.ts +1204 -1204
- package/src/engine-components/export/usdz/extensions/DocumentExtension.ts +9 -9
- package/src/engine-components/export/usdz/extensions/NodeMaterialConverter.ts +532 -532
- package/src/engine-components/export/usdz/extensions/USDZText.ts +240 -240
- package/src/engine-components/export/usdz/extensions/USDZUI.ts +189 -189
- package/src/engine-components/export/usdz/extensions/behavior/Actions.ts +99 -99
- package/src/engine-components/export/usdz/extensions/behavior/AudioExtension.ts +102 -102
- package/src/engine-components/export/usdz/extensions/behavior/Behaviour.ts +320 -320
- package/src/engine-components/export/usdz/extensions/behavior/BehaviourComponents.ts +1225 -1225
- package/src/engine-components/export/usdz/extensions/behavior/BehavioursBuilder.ts +646 -646
- package/src/engine-components/export/usdz/extensions/behavior/PhysicsExtension.ts +132 -132
- package/src/engine-components/export/usdz/index.ts +2 -2
- package/src/engine-components/export/usdz/utils/animationutils.ts +191 -191
- package/src/engine-components/export/usdz/utils/quicklook.ts +50 -50
- package/src/engine-components/particlesystem/ParticleSystem.ts +1287 -1287
- package/src/engine-components/particlesystem/ParticleSystemModules.ts +1765 -1765
- package/src/engine-components/particlesystem/ParticleSystemSubEmitter.ts +111 -111
- package/src/engine-components/particlesystem/api.ts +1 -1
- package/src/engine-components/postprocessing/Effects/Antialiasing.ts +57 -57
- package/src/engine-components/postprocessing/Effects/BloomEffect.ts +116 -116
- package/src/engine-components/postprocessing/Effects/ChromaticAberration.ts +37 -37
- package/src/engine-components/postprocessing/Effects/ColorAdjustments.ts +106 -106
- package/src/engine-components/postprocessing/Effects/DepthOfField.ts +103 -103
- package/src/engine-components/postprocessing/Effects/EffectWrapper.ts +25 -25
- package/src/engine-components/postprocessing/Effects/Pixelation.ts +32 -32
- package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.ts +90 -90
- package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusionN8.ts +192 -192
- package/src/engine-components/postprocessing/Effects/Sharpening.ts +143 -143
- package/src/engine-components/postprocessing/Effects/TiltShiftEffect.ts +61 -61
- package/src/engine-components/postprocessing/Effects/Tonemapping.ts +103 -103
- package/src/engine-components/postprocessing/Effects/Tonemapping.utils.ts +60 -60
- package/src/engine-components/postprocessing/Effects/Vignette.ts +59 -59
- package/src/engine-components/postprocessing/PostProcessingEffect.ts +192 -192
- package/src/engine-components/postprocessing/PostProcessingHandler.ts +560 -560
- package/src/engine-components/postprocessing/Volume.ts +426 -426
- package/src/engine-components/postprocessing/VolumeParameter.ts +158 -158
- package/src/engine-components/postprocessing/VolumeProfile.ts +61 -61
- package/src/engine-components/postprocessing/index.ts +5 -5
- package/src/engine-components/postprocessing/utils.ts +154 -154
- package/src/engine-components/timeline/PlayableDirector.ts +722 -722
- package/src/engine-components/timeline/SignalAsset.ts +144 -144
- package/src/engine-components/timeline/TimelineModels.ts +92 -92
- package/src/engine-components/timeline/TimelineTracks.ts +967 -967
- package/src/engine-components/timeline/index.ts +3 -3
- package/src/engine-components/ui/BaseUIComponent.ts +203 -203
- package/src/engine-components/ui/Button.ts +307 -307
- package/src/engine-components/ui/Canvas.ts +419 -419
- package/src/engine-components/ui/CanvasGroup.ts +54 -54
- package/src/engine-components/ui/EventSystem.ts +854 -854
- package/src/engine-components/ui/Graphic.ts +275 -275
- package/src/engine-components/ui/Image.ts +112 -112
- package/src/engine-components/ui/InputField.ts +321 -321
- package/src/engine-components/ui/Interfaces.ts +57 -57
- package/src/engine-components/ui/Layout.ts +334 -334
- package/src/engine-components/ui/Outline.ts +13 -13
- package/src/engine-components/ui/PointerEvents.ts +206 -206
- package/src/engine-components/ui/RaycastUtils.ts +69 -69
- package/src/engine-components/ui/Raycaster.ts +102 -102
- package/src/engine-components/ui/RectTransform.ts +375 -375
- package/src/engine-components/ui/SpatialHtml.ts +79 -79
- package/src/engine-components/ui/Symbols.ts +1 -1
- package/src/engine-components/ui/Text.ts +578 -578
- package/src/engine-components/ui/Utils.ts +113 -113
- package/src/engine-components/utils/EnvironmentScene.ts +245 -245
- package/src/engine-components/utils/LookAt.ts +88 -88
- package/src/engine-components/utils/OpenURL.ts +114 -114
- package/src/engine-components/webxr/Avatar.ts +265 -265
- package/src/engine-components/webxr/TeleportTarget.ts +9 -9
- package/src/engine-components/webxr/WebARCameraBackground.ts +175 -175
- package/src/engine-components/webxr/WebARSessionRoot.ts +880 -880
- package/src/engine-components/webxr/WebXR.ts +585 -585
- package/src/engine-components/webxr/WebXRAvatar.ts +66 -66
- package/src/engine-components/webxr/WebXRImageTracking.ts +519 -519
- package/src/engine-components/webxr/WebXRPlaneTracking.ts +570 -570
- package/src/engine-components/webxr/WebXRRig.ts +77 -77
- package/src/engine-components/webxr/XRFlag.ts +147 -147
- package/src/engine-components/webxr/controllers/XRControllerFollow.ts +118 -118
- package/src/engine-components/webxr/controllers/XRControllerModel.ts +373 -373
- package/src/engine-components/webxr/controllers/XRControllerMovement.ts +550 -550
- package/src/engine-components/webxr/index.ts +2 -2
- package/src/engine-components/webxr/types.ts +3 -3
- package/src/engine-components-experimental/Presentation.ts +12 -12
- package/src/engine-components-experimental/api.ts +4 -4
- package/src/engine-components-experimental/networking/PlayerSync.ts +401 -401
- package/src/engine-schemes/COMPILE_SCHEMES.bat +3 -3
- package/src/engine-schemes/COMPILE_TS.bat +11 -11
- package/src/engine-schemes/README.md +1 -1
- package/src/engine-schemes/api.ts +12 -12
- package/src/engine-schemes/schemes.ts +28 -28
- package/src/engine-schemes/synced-camera-model.ts +92 -92
- package/src/engine-schemes/synced-transform-model.ts +90 -90
- package/src/engine-schemes/syncedCamera.fbs +10 -10
- package/src/engine-schemes/transform.ts +50 -50
- package/src/engine-schemes/transforms.fbs +25 -25
- package/src/engine-schemes/vec.fbs +19 -19
- package/src/engine-schemes/vec2.ts +33 -33
- package/src/engine-schemes/vec3.ts +38 -38
- package/src/engine-schemes/vec4.ts +43 -43
- package/src/engine-schemes/vr-user-state-buffer.ts +145 -145
- package/src/engine-schemes/vrUserStateBuffer.fbs +17 -17
- package/src/include/draco/draco_decoder.js +34 -34
- package/src/include/ktx2/basis_transcoder.js +21 -21
- package/src/include/needle/arial-msdf.json +1471 -1471
- package/src/include/three/DragControls.js +231 -231
- package/src/include/three/EXT_mesh_gpu_instancing_exporter.js +66 -66
- package/src/needle-engine.ts +70 -70
- package/dist/generateMeshBVH.worker-Cdfpaq5W.js +0 -25
- package/src/engine-schemes/dist/api.js +0 -17
- package/src/engine-schemes/dist/api.js.meta +0 -7
- package/src/engine-schemes/dist/schemes.js +0 -25
- package/src/engine-schemes/dist/schemes.js.meta +0 -7
- package/src/engine-schemes/dist/synced-camera-model.js +0 -74
- package/src/engine-schemes/dist/synced-camera-model.js.meta +0 -7
- package/src/engine-schemes/dist/synced-transform-model.js +0 -73
- package/src/engine-schemes/dist/synced-transform-model.js.meta +0 -7
- package/src/engine-schemes/dist/transform.js +0 -46
- package/src/engine-schemes/dist/transform.js.meta +0 -7
- package/src/engine-schemes/dist/vec2.js +0 -32
- package/src/engine-schemes/dist/vec2.js.meta +0 -7
- package/src/engine-schemes/dist/vec3.js +0 -36
- package/src/engine-schemes/dist/vec3.js.meta +0 -7
- package/src/engine-schemes/dist/vec4.js +0 -40
- package/src/engine-schemes/dist/vec4.js.meta +0 -7
- package/src/engine-schemes/dist/vr-user-state-buffer.js +0 -110
- package/src/engine-schemes/dist/vr-user-state-buffer.js.meta +0 -7
|
@@ -1,720 +1,720 @@
|
|
|
1
|
-
import { Color, EquirectangularReflectionMapping, Euler, Frustum, Matrix4, OrthographicCamera, PerspectiveCamera, Ray, Vector3 } from "three";
|
|
2
|
-
import { Texture } from "three";
|
|
3
|
-
|
|
4
|
-
import { showBalloonMessage } from "../engine/debug/index.js";
|
|
5
|
-
import { Gizmos } from "../engine/engine_gizmos.js";
|
|
6
|
-
import { serializable } from "../engine/engine_serialization_decorator.js";
|
|
7
|
-
import { Context } from "../engine/engine_setup.js";
|
|
8
|
-
import { RenderTexture } from "../engine/engine_texture.js";
|
|
9
|
-
import { getTempColor, getWorldPosition } from "../engine/engine_three_utils.js";
|
|
10
|
-
import type { ICamera } from "../engine/engine_types.js"
|
|
11
|
-
import { getParam } from "../engine/engine_utils.js";
|
|
12
|
-
import { RGBAColor } from "../engine/js-extensions/index.js";
|
|
13
|
-
import { Behaviour, GameObject } from "./Component.js";
|
|
14
|
-
import { OrbitControls } from "./OrbitControls.js";
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* The ClearFlags enum is used to determine how the camera clears the background
|
|
18
|
-
*/
|
|
19
|
-
export enum ClearFlags {
|
|
20
|
-
/** Don't clear the background */
|
|
21
|
-
None = 0,
|
|
22
|
-
/** Clear the background with a skybox */
|
|
23
|
-
Skybox = 1,
|
|
24
|
-
/** Clear the background with a solid color. The alpha channel of the color determines the transparency */
|
|
25
|
-
SolidColor = 2,
|
|
26
|
-
/** Clear the background with a transparent color */
|
|
27
|
-
Uninitialized = 4,
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const debug = getParam("debugcam");
|
|
31
|
-
const debugscreenpointtoray = getParam("debugscreenpointtoray");
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Camera component that handles rendering from a specific viewpoint in the scene.
|
|
35
|
-
* Supports both perspective and orthographic cameras with various rendering options.
|
|
36
|
-
* Internally, this component uses {@link PerspectiveCamera} and {@link OrthographicCamera} three.js objects.
|
|
37
|
-
*
|
|
38
|
-
* @category Camera Controls
|
|
39
|
-
* @group Components
|
|
40
|
-
*/
|
|
41
|
-
export class Camera extends Behaviour implements ICamera {
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Returns whether this component is a camera
|
|
45
|
-
* @returns {boolean} Always returns true
|
|
46
|
-
*/
|
|
47
|
-
get isCamera() {
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Gets or sets the camera's aspect ratio (width divided by height).
|
|
53
|
-
* For perspective cameras, this directly affects the camera's projection matrix.
|
|
54
|
-
* When set, automatically updates the projection matrix.
|
|
55
|
-
*/
|
|
56
|
-
get aspect(): number {
|
|
57
|
-
if (this._cam instanceof PerspectiveCamera) return this._cam.aspect;
|
|
58
|
-
return (this.context.domWidth / this.context.domHeight);
|
|
59
|
-
}
|
|
60
|
-
@serializable()
|
|
61
|
-
set aspect(value: number) {
|
|
62
|
-
if (this._cam instanceof PerspectiveCamera) {
|
|
63
|
-
if (this._cam.aspect !== value) {
|
|
64
|
-
this._cam.aspect = value;
|
|
65
|
-
this._cam.updateProjectionMatrix();
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Gets or sets the camera's field of view in degrees for perspective cameras.
|
|
72
|
-
* When set, automatically updates the projection matrix.
|
|
73
|
-
*/
|
|
74
|
-
get fieldOfView(): number | undefined {
|
|
75
|
-
if (this._cam instanceof PerspectiveCamera) {
|
|
76
|
-
return this._cam.fov;
|
|
77
|
-
}
|
|
78
|
-
return this._fov;
|
|
79
|
-
}
|
|
80
|
-
@serializable()
|
|
81
|
-
set fieldOfView(val: number | undefined) {
|
|
82
|
-
const changed = this.fieldOfView != val;
|
|
83
|
-
this._fov = val;
|
|
84
|
-
if (changed && this._cam) {
|
|
85
|
-
if (this._cam instanceof PerspectiveCamera) {
|
|
86
|
-
if (this._fov === undefined) {
|
|
87
|
-
console.warn("Can not set undefined fov on PerspectiveCamera");
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
this._cam.fov = this._fov;
|
|
91
|
-
this._cam.updateProjectionMatrix();
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* Gets or sets the camera's near clipping plane distance.
|
|
98
|
-
* Objects closer than this distance won't be rendered.
|
|
99
|
-
* When set, automatically updates the projection matrix.
|
|
100
|
-
*/
|
|
101
|
-
get nearClipPlane(): number { return this._nearClipPlane; }
|
|
102
|
-
@serializable()
|
|
103
|
-
set nearClipPlane(val) {
|
|
104
|
-
const changed = this._nearClipPlane != val;
|
|
105
|
-
this._nearClipPlane = val;
|
|
106
|
-
if (this._cam && (changed || this._cam.near != val)) {
|
|
107
|
-
this._cam.near = val;
|
|
108
|
-
this._cam.updateProjectionMatrix();
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
private _nearClipPlane: number = 0.1;
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Gets or sets the camera's far clipping plane distance.
|
|
115
|
-
* Objects farther than this distance won't be rendered.
|
|
116
|
-
* When set, automatically updates the projection matrix.
|
|
117
|
-
*/
|
|
118
|
-
get farClipPlane(): number { return this._farClipPlane; }
|
|
119
|
-
@serializable()
|
|
120
|
-
set farClipPlane(val) {
|
|
121
|
-
const changed = this._farClipPlane != val;
|
|
122
|
-
this._farClipPlane = val;
|
|
123
|
-
if (this._cam && (changed || this._cam.far != val)) {
|
|
124
|
-
this._cam.far = val;
|
|
125
|
-
this._cam.updateProjectionMatrix();
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
private _farClipPlane: number = 1000;
|
|
129
|
-
|
|
130
|
-
/**
|
|
131
|
-
* Applies both the camera's near and far clipping planes and updates the projection matrix.
|
|
132
|
-
* This ensures rendering occurs only within the specified distance range.
|
|
133
|
-
*/
|
|
134
|
-
applyClippingPlane() {
|
|
135
|
-
if (this._cam) {
|
|
136
|
-
this._cam.near = this._nearClipPlane;
|
|
137
|
-
this._cam.far = this._farClipPlane;
|
|
138
|
-
this._cam.updateProjectionMatrix();
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
/**
|
|
143
|
-
* Gets or sets the camera's clear flags that determine how the background is rendered.
|
|
144
|
-
* Options include skybox, solid color, or transparent background.
|
|
145
|
-
*/
|
|
146
|
-
@serializable()
|
|
147
|
-
public get clearFlags(): ClearFlags {
|
|
148
|
-
return this._clearFlags;
|
|
149
|
-
}
|
|
150
|
-
public set clearFlags(val: ClearFlags | "skybox" | "solidcolor") {
|
|
151
|
-
|
|
152
|
-
if (typeof val === "string") {
|
|
153
|
-
switch (val) {
|
|
154
|
-
case "skybox":
|
|
155
|
-
val = ClearFlags.Skybox;
|
|
156
|
-
break;
|
|
157
|
-
case "solidcolor":
|
|
158
|
-
val = ClearFlags.SolidColor;
|
|
159
|
-
break;
|
|
160
|
-
default:
|
|
161
|
-
val = ClearFlags.None;
|
|
162
|
-
break;
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
if (val === this._clearFlags) return;
|
|
167
|
-
this._clearFlags = val;
|
|
168
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
/**
|
|
172
|
-
* Determines if the camera should use orthographic projection instead of perspective.
|
|
173
|
-
*/
|
|
174
|
-
@serializable()
|
|
175
|
-
public orthographic: boolean = false;
|
|
176
|
-
|
|
177
|
-
/**
|
|
178
|
-
* The size of the orthographic camera's view volume when in orthographic mode.
|
|
179
|
-
* Larger values show more of the scene.
|
|
180
|
-
*/
|
|
181
|
-
@serializable()
|
|
182
|
-
public orthographicSize: number = 5;
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* Controls the transparency level of the camera background in AR mode on supported devices.
|
|
186
|
-
* Value from 0 (fully transparent) to 1 (fully opaque).
|
|
187
|
-
*/
|
|
188
|
-
@serializable()
|
|
189
|
-
public ARBackgroundAlpha: number = 0;
|
|
190
|
-
|
|
191
|
-
/**
|
|
192
|
-
* Gets or sets the layers mask that determines which objects this camera will render.
|
|
193
|
-
* Uses the {@link https://threejs.org/docs/#api/en/core/Layers.mask|three.js layers mask} convention.
|
|
194
|
-
*/
|
|
195
|
-
@serializable()
|
|
196
|
-
public set cullingMask(val: number) {
|
|
197
|
-
this._cullingMask = val;
|
|
198
|
-
if (this._cam) {
|
|
199
|
-
this._cam.layers.mask = val;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
public get cullingMask(): number {
|
|
203
|
-
if (this._cam) return this._cam.layers.mask;
|
|
204
|
-
return this._cullingMask;
|
|
205
|
-
}
|
|
206
|
-
private _cullingMask: number = 0xffffffff;
|
|
207
|
-
|
|
208
|
-
/**
|
|
209
|
-
* Sets only a specific layer to be active for rendering by this camera.
|
|
210
|
-
* This is equivalent to calling `layers.set(val)` on the three.js camera object.
|
|
211
|
-
* @param val The layer index to set active
|
|
212
|
-
*/
|
|
213
|
-
public set cullingLayer(val: number) {
|
|
214
|
-
this.cullingMask = (1 << val | 0) >>> 0;
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
/**
|
|
218
|
-
* Gets or sets the blurriness of the skybox background.
|
|
219
|
-
* Values range from 0 (sharp) to 1 (maximum blur).
|
|
220
|
-
*/
|
|
221
|
-
@serializable()
|
|
222
|
-
public set backgroundBlurriness(val: number | undefined) {
|
|
223
|
-
if (val === this._backgroundBlurriness) return;
|
|
224
|
-
if (val === undefined)
|
|
225
|
-
this._backgroundBlurriness = undefined;
|
|
226
|
-
else
|
|
227
|
-
this._backgroundBlurriness = Math.min(Math.max(val, 0), 1);
|
|
228
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
229
|
-
}
|
|
230
|
-
public get backgroundBlurriness(): number | undefined {
|
|
231
|
-
return this._backgroundBlurriness;
|
|
232
|
-
}
|
|
233
|
-
private _backgroundBlurriness?: number = undefined;
|
|
234
|
-
|
|
235
|
-
/**
|
|
236
|
-
* Gets or sets the intensity of the skybox background.
|
|
237
|
-
* Values range from 0 (dark) to 10 (very bright).
|
|
238
|
-
*/
|
|
239
|
-
@serializable()
|
|
240
|
-
public set backgroundIntensity(val: number | undefined) {
|
|
241
|
-
if (val === this._backgroundIntensity) return;
|
|
242
|
-
if (val === undefined)
|
|
243
|
-
this._backgroundIntensity = undefined;
|
|
244
|
-
else
|
|
245
|
-
this._backgroundIntensity = Math.min(Math.max(val, 0), 10);
|
|
246
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
247
|
-
}
|
|
248
|
-
public get backgroundIntensity(): number | undefined {
|
|
249
|
-
return this._backgroundIntensity;
|
|
250
|
-
}
|
|
251
|
-
private _backgroundIntensity?: number = undefined;
|
|
252
|
-
|
|
253
|
-
/**
|
|
254
|
-
* Gets or sets the rotation of the skybox background.
|
|
255
|
-
* Controls the orientation of the environment map.
|
|
256
|
-
*/
|
|
257
|
-
@serializable(Euler)
|
|
258
|
-
public set backgroundRotation(val: Euler | undefined) {
|
|
259
|
-
if (val === this._backgroundRotation) return;
|
|
260
|
-
if (val === undefined)
|
|
261
|
-
this._backgroundRotation = undefined;
|
|
262
|
-
else
|
|
263
|
-
this._backgroundRotation = val;
|
|
264
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
265
|
-
}
|
|
266
|
-
public get backgroundRotation(): Euler | undefined {
|
|
267
|
-
return this._backgroundRotation;
|
|
268
|
-
}
|
|
269
|
-
private _backgroundRotation?: Euler = undefined;
|
|
270
|
-
|
|
271
|
-
/**
|
|
272
|
-
* Gets or sets the intensity of the environment lighting.
|
|
273
|
-
* Controls how strongly the environment map affects scene lighting.
|
|
274
|
-
*/
|
|
275
|
-
@serializable()
|
|
276
|
-
public set environmentIntensity(val: number | undefined) {
|
|
277
|
-
this._environmentIntensity = val;
|
|
278
|
-
}
|
|
279
|
-
public get environmentIntensity(): number | undefined {
|
|
280
|
-
return this._environmentIntensity;
|
|
281
|
-
}
|
|
282
|
-
private _environmentIntensity?: number = undefined;
|
|
283
|
-
|
|
284
|
-
/**
|
|
285
|
-
* Gets or sets the background color of the camera when {@link ClearFlags} is set to {@link ClearFlags.SolidColor}.
|
|
286
|
-
* The alpha component controls transparency.
|
|
287
|
-
*/
|
|
288
|
-
@serializable(RGBAColor)
|
|
289
|
-
public get backgroundColor(): RGBAColor | null {
|
|
290
|
-
return this._backgroundColor ?? null;
|
|
291
|
-
}
|
|
292
|
-
public set backgroundColor(val: RGBAColor | Color | null) {
|
|
293
|
-
if (!val) return;
|
|
294
|
-
if (!this._backgroundColor) {
|
|
295
|
-
this._backgroundColor = new RGBAColor(1, 1, 1, 1);
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
this._backgroundColor.copy(val);
|
|
299
|
-
|
|
300
|
-
// set background color to solid if provided color doesnt have any alpha channel
|
|
301
|
-
if ((!("alpha" in val) || val.alpha === undefined)) {
|
|
302
|
-
this._backgroundColor.alpha = 1;
|
|
303
|
-
}
|
|
304
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
305
|
-
}
|
|
306
|
-
|
|
307
|
-
/**
|
|
308
|
-
* Gets or sets the texture that the camera should render to instead of the screen.
|
|
309
|
-
* Useful for creating effects like mirrors, portals or custom post processing.
|
|
310
|
-
*/
|
|
311
|
-
@serializable(RenderTexture)
|
|
312
|
-
public set targetTexture(rt: RenderTexture | null) {
|
|
313
|
-
this._targetTexture = rt;
|
|
314
|
-
}
|
|
315
|
-
public get targetTexture(): RenderTexture | null {
|
|
316
|
-
return this._targetTexture;
|
|
317
|
-
}
|
|
318
|
-
private _targetTexture: RenderTexture | null = null;
|
|
319
|
-
|
|
320
|
-
private _backgroundColor?: RGBAColor;
|
|
321
|
-
private _fov?: number;
|
|
322
|
-
private _cam: PerspectiveCamera | OrthographicCamera | null = null;
|
|
323
|
-
private _clearFlags: ClearFlags = ClearFlags.SolidColor;
|
|
324
|
-
private _skybox?: CameraSkybox;
|
|
325
|
-
|
|
326
|
-
/**
|
|
327
|
-
* Gets the three.js camera object. Creates one if it doesn't exist yet.
|
|
328
|
-
* @returns {PerspectiveCamera | OrthographicCamera} The three.js camera object
|
|
329
|
-
* @deprecated Use {@link threeCamera} instead
|
|
330
|
-
*/
|
|
331
|
-
public get cam(): PerspectiveCamera | OrthographicCamera {
|
|
332
|
-
return this.threeCamera;
|
|
333
|
-
}
|
|
334
|
-
|
|
335
|
-
/**
|
|
336
|
-
* Gets the three.js camera object. Creates one if it doesn't exist yet.
|
|
337
|
-
* @returns {PerspectiveCamera | OrthographicCamera} The three.js camera object
|
|
338
|
-
*/
|
|
339
|
-
public get threeCamera(): PerspectiveCamera | OrthographicCamera {
|
|
340
|
-
if (this.activeAndEnabled)
|
|
341
|
-
this.buildCamera();
|
|
342
|
-
return this._cam!;
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
private static _origin: Vector3 = new Vector3();
|
|
346
|
-
private static _direction: Vector3 = new Vector3();
|
|
347
|
-
|
|
348
|
-
/**
|
|
349
|
-
* Converts screen coordinates to a ray in world space.
|
|
350
|
-
* Useful for implementing picking or raycasting from screen to world.
|
|
351
|
-
*
|
|
352
|
-
* @param x The x screen coordinate
|
|
353
|
-
* @param y The y screen coordinate
|
|
354
|
-
* @param ray Optional ray object to reuse instead of creating a new one
|
|
355
|
-
* @returns {Ray} A ray originating from the camera position pointing through the screen point
|
|
356
|
-
*/
|
|
357
|
-
public screenPointToRay(x: number, y: number, ray?: Ray): Ray {
|
|
358
|
-
const cam = this.threeCamera;
|
|
359
|
-
const origin = Camera._origin;
|
|
360
|
-
origin.set(x, y, -1);
|
|
361
|
-
this.context.input.convertScreenspaceToRaycastSpace(origin);
|
|
362
|
-
if (debugscreenpointtoray) console.log("screenPointToRay", x.toFixed(2), y.toFixed(2), "now:", origin.x.toFixed(2), origin.y.toFixed(2), "isInXR:" + this.context.isInXR);
|
|
363
|
-
origin.z = -1;
|
|
364
|
-
origin.unproject(cam);
|
|
365
|
-
const dir = Camera._direction.set(origin.x, origin.y, origin.z);
|
|
366
|
-
const camPosition = getWorldPosition(cam);
|
|
367
|
-
dir.sub(camPosition);
|
|
368
|
-
dir.normalize();
|
|
369
|
-
if (ray) {
|
|
370
|
-
ray.set(camPosition, dir);
|
|
371
|
-
return ray;
|
|
372
|
-
}
|
|
373
|
-
else {
|
|
374
|
-
return new Ray(camPosition.clone(), dir.clone());
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
|
|
378
|
-
private _frustum?: Frustum;
|
|
379
|
-
|
|
380
|
-
/**
|
|
381
|
-
* Gets the camera's view frustum for culling and visibility checks.
|
|
382
|
-
* Creates the frustum if it doesn't exist and returns it.
|
|
383
|
-
*
|
|
384
|
-
* @returns {Frustum} The camera's view frustum
|
|
385
|
-
*/
|
|
386
|
-
public getFrustum(): Frustum {
|
|
387
|
-
if (!this._frustum) {
|
|
388
|
-
this._frustum = new Frustum();
|
|
389
|
-
this.updateFrustum();
|
|
390
|
-
}
|
|
391
|
-
return this._frustum;
|
|
392
|
-
}
|
|
393
|
-
|
|
394
|
-
/**
|
|
395
|
-
* Forces an update of the camera's frustum.
|
|
396
|
-
* This is automatically called every frame in onBeforeRender.
|
|
397
|
-
*/
|
|
398
|
-
public updateFrustum() {
|
|
399
|
-
if (!this._frustum) this._frustum = new Frustum();
|
|
400
|
-
this._frustum.setFromProjectionMatrix(this.getProjectionScreenMatrix(this._projScreenMatrix, true), this.context.renderer.coordinateSystem);
|
|
401
|
-
}
|
|
402
|
-
|
|
403
|
-
/**
|
|
404
|
-
* Gets this camera's projection-screen matrix.
|
|
405
|
-
*
|
|
406
|
-
* @param target Matrix4 object to store the result in
|
|
407
|
-
* @param forceUpdate Whether to force recalculation of the matrix
|
|
408
|
-
* @returns {Matrix4} The requested projection screen matrix
|
|
409
|
-
*/
|
|
410
|
-
public getProjectionScreenMatrix(target: Matrix4, forceUpdate?: boolean) {
|
|
411
|
-
if (forceUpdate) {
|
|
412
|
-
this._projScreenMatrix.multiplyMatrices(this.threeCamera.projectionMatrix, this.threeCamera.matrixWorldInverse);
|
|
413
|
-
}
|
|
414
|
-
if (target === this._projScreenMatrix) return target;
|
|
415
|
-
return target.copy(this._projScreenMatrix);
|
|
416
|
-
}
|
|
417
|
-
private readonly _projScreenMatrix = new Matrix4();
|
|
418
|
-
|
|
419
|
-
/** @internal */
|
|
420
|
-
awake() {
|
|
421
|
-
if (debugscreenpointtoray) {
|
|
422
|
-
window.addEventListener("pointerdown", evt => {
|
|
423
|
-
const px = evt.clientX;
|
|
424
|
-
const py = evt.clientY;
|
|
425
|
-
console.log("touch", px.toFixed(2), py.toFixed(2))
|
|
426
|
-
const ray = this.screenPointToRay(px, py);
|
|
427
|
-
const randomHex = "#" + Math.floor(Math.random() * 16777215).toString(16);
|
|
428
|
-
Gizmos.DrawRay(ray.origin, ray.direction, randomHex, 10);
|
|
429
|
-
});
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
/** @internal */
|
|
434
|
-
onEnable(): void {
|
|
435
|
-
if (debug) console.log(`Camera enabled: \"${this.name}\". ClearFlags=${ClearFlags[this._clearFlags]}`, this);
|
|
436
|
-
this.buildCamera();
|
|
437
|
-
if (this.tag == "MainCamera" || !this.context.mainCameraComponent) {
|
|
438
|
-
this.context.setCurrentCamera(this);
|
|
439
|
-
handleFreeCam(this);
|
|
440
|
-
}
|
|
441
|
-
this.applyClearFlagsIfIsActiveCamera({ applySkybox: true });
|
|
442
|
-
}
|
|
443
|
-
|
|
444
|
-
/** @internal */
|
|
445
|
-
onDisable() {
|
|
446
|
-
this.context.removeCamera(this);
|
|
447
|
-
}
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
/** @internal */
|
|
451
|
-
onBeforeRender() {
|
|
452
|
-
if (this._cam) {
|
|
453
|
-
|
|
454
|
-
if (this._frustum) {
|
|
455
|
-
this.updateFrustum();
|
|
456
|
-
}
|
|
457
|
-
|
|
458
|
-
// because the background color may be animated!
|
|
459
|
-
if (this._clearFlags === ClearFlags.SolidColor)
|
|
460
|
-
this.applyClearFlagsIfIsActiveCamera();
|
|
461
|
-
|
|
462
|
-
if (this._targetTexture) {
|
|
463
|
-
if (this.context.isManagedExternally) {
|
|
464
|
-
// TODO: rendering with r3f renderer does throw an shader error for some reason?
|
|
465
|
-
if (!this["_warnedAboutExternalRenderer"]) {
|
|
466
|
-
this["_warnedAboutExternalRenderer"] = true;
|
|
467
|
-
console.warn("Rendering with external renderer is not supported yet. This may not work or throw errors. Please remove the the target texture from your camera: " + this.name, this.targetTexture)
|
|
468
|
-
}
|
|
469
|
-
}
|
|
470
|
-
|
|
471
|
-
// TODO: optimize to not render twice if this is already the main camera. In that case we just want to blit
|
|
472
|
-
const composer = this.context.composer;
|
|
473
|
-
const useNormalRenderer = true;// this.context.isInXR || !composer;
|
|
474
|
-
const renderer = useNormalRenderer ? this.context.renderer : composer;
|
|
475
|
-
if (renderer) {
|
|
476
|
-
// TODO: we should do this in onBeforeRender for the main camera only
|
|
477
|
-
const mainCam = this.context.mainCameraComponent;
|
|
478
|
-
this.applyClearFlags();
|
|
479
|
-
this._targetTexture.render(this.context.scene, this._cam, renderer);
|
|
480
|
-
mainCam?.applyClearFlags();
|
|
481
|
-
}
|
|
482
|
-
}
|
|
483
|
-
}
|
|
484
|
-
}
|
|
485
|
-
|
|
486
|
-
/**
|
|
487
|
-
* Creates a three.js camera object if it doesn't exist yet and sets its properties.
|
|
488
|
-
* This is called internally when accessing the {@link threeCamera} property.
|
|
489
|
-
*/
|
|
490
|
-
buildCamera() {
|
|
491
|
-
if (this._cam) return;
|
|
492
|
-
|
|
493
|
-
const cameraAlreadyCreated = this.gameObject["isCamera"];
|
|
494
|
-
|
|
495
|
-
// TODO: when exporting from blender we already have a camera in the children
|
|
496
|
-
let cam: PerspectiveCamera | OrthographicCamera | null = null;
|
|
497
|
-
if (cameraAlreadyCreated) {
|
|
498
|
-
cam = this.gameObject as any;
|
|
499
|
-
cam?.layers.enableAll();
|
|
500
|
-
if (cam instanceof PerspectiveCamera)
|
|
501
|
-
this._fov = cam.fov;
|
|
502
|
-
}
|
|
503
|
-
else
|
|
504
|
-
cam = this.gameObject.children[0] as PerspectiveCamera | OrthographicCamera | null;
|
|
505
|
-
if (cam && cam.isCamera) {
|
|
506
|
-
if (cam instanceof PerspectiveCamera) {
|
|
507
|
-
if (this._fov)
|
|
508
|
-
cam.fov = this._fov;
|
|
509
|
-
cam.near = this._nearClipPlane;
|
|
510
|
-
cam.far = this._farClipPlane;
|
|
511
|
-
cam.updateProjectionMatrix();
|
|
512
|
-
}
|
|
513
|
-
}
|
|
514
|
-
else if (!this.orthographic) {
|
|
515
|
-
cam = new PerspectiveCamera(this.fieldOfView, window.innerWidth / window.innerHeight, this._nearClipPlane, this._farClipPlane);
|
|
516
|
-
if (this.fieldOfView)
|
|
517
|
-
cam.fov = this.fieldOfView;
|
|
518
|
-
this.gameObject.add(cam);
|
|
519
|
-
}
|
|
520
|
-
else {
|
|
521
|
-
const factor = this.orthographicSize * 100;
|
|
522
|
-
cam = new OrthographicCamera(window.innerWidth / -factor, window.innerWidth / factor, window.innerHeight / factor, window.innerHeight / -factor, this._nearClipPlane, this._farClipPlane);
|
|
523
|
-
this.gameObject.add(cam);
|
|
524
|
-
}
|
|
525
|
-
this._cam = cam;
|
|
526
|
-
|
|
527
|
-
this._cam.layers.mask = this._cullingMask;
|
|
528
|
-
|
|
529
|
-
if (this.tag == "MainCamera") {
|
|
530
|
-
this.context.setCurrentCamera(this);
|
|
531
|
-
}
|
|
532
|
-
}
|
|
533
|
-
|
|
534
|
-
/**
|
|
535
|
-
* Applies clear flags if this is the active main camera.
|
|
536
|
-
* @param opts Options for applying clear flags
|
|
537
|
-
*/
|
|
538
|
-
applyClearFlagsIfIsActiveCamera(opts?: { applySkybox: boolean }) {
|
|
539
|
-
if (this.context.mainCameraComponent === this) {
|
|
540
|
-
this.applyClearFlags(opts);
|
|
541
|
-
}
|
|
542
|
-
}
|
|
543
|
-
|
|
544
|
-
/**
|
|
545
|
-
* Applies this camera's clear flags and related settings to the renderer.
|
|
546
|
-
* This controls how the background is rendered (skybox, solid color, transparent).
|
|
547
|
-
* @param opts Options for applying clear flags
|
|
548
|
-
*/
|
|
549
|
-
applyClearFlags(opts?: { applySkybox: boolean }) {
|
|
550
|
-
if (!this._cam) {
|
|
551
|
-
if (debug) console.log("Camera does not exist (apply clear flags)")
|
|
552
|
-
return;
|
|
553
|
-
}
|
|
554
|
-
|
|
555
|
-
// restore previous fov (e.g. when user was in VR or AR and the camera's fov has changed)
|
|
556
|
-
this.fieldOfView = this._fov;
|
|
557
|
-
|
|
558
|
-
if (debug) {
|
|
559
|
-
const msg = `[Camera] Apply ClearFlags: ${ClearFlags[this._clearFlags]} - \"${this.name}\"`;
|
|
560
|
-
console.debug(msg);
|
|
561
|
-
}
|
|
562
|
-
|
|
563
|
-
const hasBackgroundImageOrColorAttribute = this.context.domElement.getAttribute("background-image") || this.context.domElement.getAttribute("background-color") || this.context.domElement.getAttribute("skybox-image");
|
|
564
|
-
|
|
565
|
-
switch (this._clearFlags) {
|
|
566
|
-
case ClearFlags.None:
|
|
567
|
-
return;
|
|
568
|
-
|
|
569
|
-
case ClearFlags.Skybox:
|
|
570
|
-
if (Camera.backgroundShouldBeTransparent(this.context)) {
|
|
571
|
-
if (!this.ARBackgroundAlpha || this.ARBackgroundAlpha < 0.001) {
|
|
572
|
-
this.context.scene.background = null;
|
|
573
|
-
this.context.renderer.setClearColor(0x000000, 0);
|
|
574
|
-
return;
|
|
575
|
-
}
|
|
576
|
-
}
|
|
577
|
-
|
|
578
|
-
// apply the skybox only if it is not already set or if it's the first time (e.g. if the _skybox is not set yet)
|
|
579
|
-
if (!this.scene.background || !this._skybox || opts?.applySkybox === true)
|
|
580
|
-
this.applySceneSkybox();
|
|
581
|
-
|
|
582
|
-
// set background blurriness and intensity
|
|
583
|
-
if (this._backgroundBlurriness !== undefined && !this.context.domElement.getAttribute("background-blurriness"))
|
|
584
|
-
this.context.scene.backgroundBlurriness = this._backgroundBlurriness;
|
|
585
|
-
else if (debug) console.warn(`Camera \"${this.name}\" has no background blurriness`)
|
|
586
|
-
|
|
587
|
-
if (this._backgroundIntensity !== undefined && !this.context.domElement.getAttribute("background-intensity"))
|
|
588
|
-
this.context.scene.backgroundIntensity = this._backgroundIntensity;
|
|
589
|
-
|
|
590
|
-
if (this._backgroundRotation !== undefined && !this.context.domElement.getAttribute("background-rotation"))
|
|
591
|
-
this.context.scene.backgroundRotation = this._backgroundRotation;
|
|
592
|
-
|
|
593
|
-
else if (debug) console.warn(`Camera \"${this.name}\" has no background intensity`)
|
|
594
|
-
|
|
595
|
-
break;
|
|
596
|
-
case ClearFlags.SolidColor:
|
|
597
|
-
if (this._backgroundColor && !hasBackgroundImageOrColorAttribute) {
|
|
598
|
-
let alpha = this._backgroundColor.alpha;
|
|
599
|
-
// when in WebXR use ar background alpha override or set to 0
|
|
600
|
-
if (Camera.backgroundShouldBeTransparent(this.context)) {
|
|
601
|
-
alpha = this.ARBackgroundAlpha ?? 0;
|
|
602
|
-
}
|
|
603
|
-
this.context.scene.background = null;
|
|
604
|
-
// In WebXR VR the background colorspace is wrong
|
|
605
|
-
if (this.context.xr?.isVR) {
|
|
606
|
-
this.context.renderer.setClearColor(getTempColor(this._backgroundColor).convertLinearToSRGB());
|
|
607
|
-
} else {
|
|
608
|
-
this.context.renderer.setClearColor(this._backgroundColor, alpha);
|
|
609
|
-
}
|
|
610
|
-
}
|
|
611
|
-
else if (!this._backgroundColor) {
|
|
612
|
-
if (debug) console.warn(`[Camera] has no background color \"${this.name}\" `)
|
|
613
|
-
}
|
|
614
|
-
break;
|
|
615
|
-
case ClearFlags.Uninitialized:
|
|
616
|
-
if (!hasBackgroundImageOrColorAttribute) {
|
|
617
|
-
this.context.scene.background = null
|
|
618
|
-
this.context.renderer.setClearColor(0x000000, 0);
|
|
619
|
-
}
|
|
620
|
-
break;
|
|
621
|
-
}
|
|
622
|
-
}
|
|
623
|
-
|
|
624
|
-
/**
|
|
625
|
-
* Applies the skybox texture to the scene background.
|
|
626
|
-
*/
|
|
627
|
-
applySceneSkybox() {
|
|
628
|
-
if (!this._skybox)
|
|
629
|
-
this._skybox = new CameraSkybox(this);
|
|
630
|
-
this._skybox.apply();
|
|
631
|
-
}
|
|
632
|
-
|
|
633
|
-
/**
|
|
634
|
-
* Determines if the background should be transparent when in passthrough AR mode.
|
|
635
|
-
*
|
|
636
|
-
* @param context The current rendering context
|
|
637
|
-
* @returns {boolean} True when in XR on a pass through device where the background should be invisible
|
|
638
|
-
*/
|
|
639
|
-
static backgroundShouldBeTransparent(context: Context) {
|
|
640
|
-
const session = context.renderer.xr?.getSession();
|
|
641
|
-
if (!session) return false;
|
|
642
|
-
if (typeof session["_transparent"] === "boolean") {
|
|
643
|
-
return session["_transparent"];
|
|
644
|
-
}
|
|
645
|
-
const environmentBlendMode = session.environmentBlendMode;
|
|
646
|
-
if (debug)
|
|
647
|
-
showBalloonMessage("Environment blend mode: " + environmentBlendMode + " on " + navigator.userAgent);
|
|
648
|
-
let transparent = environmentBlendMode === 'additive' || environmentBlendMode === 'alpha-blend';
|
|
649
|
-
if (context.isInAR) {
|
|
650
|
-
if (environmentBlendMode === "opaque") {
|
|
651
|
-
// workaround for Quest 2 returning opaque when it should be alpha-blend
|
|
652
|
-
// check user agent if this is the Quest browser and return true if so
|
|
653
|
-
if (navigator.userAgent?.includes("OculusBrowser")) {
|
|
654
|
-
transparent = true;
|
|
655
|
-
}
|
|
656
|
-
// Mozilla WebXR Viewer
|
|
657
|
-
else if (navigator.userAgent?.includes("Mozilla") && navigator.userAgent?.includes("Mobile WebXRViewer/v2")) {
|
|
658
|
-
transparent = true;
|
|
659
|
-
}
|
|
660
|
-
}
|
|
661
|
-
}
|
|
662
|
-
|
|
663
|
-
session["_transparent"] = transparent;
|
|
664
|
-
return transparent;
|
|
665
|
-
}
|
|
666
|
-
}
|
|
667
|
-
|
|
668
|
-
/**
|
|
669
|
-
* Helper class for managing skybox textures for cameras.
|
|
670
|
-
* Handles retrieving and applying skybox textures to the scene.
|
|
671
|
-
*/
|
|
672
|
-
class CameraSkybox {
|
|
673
|
-
|
|
674
|
-
private _camera: Camera;
|
|
675
|
-
private _skybox?: Texture;
|
|
676
|
-
|
|
677
|
-
get context() { return this._camera?.context; }
|
|
678
|
-
|
|
679
|
-
constructor(camera: Camera) {
|
|
680
|
-
this._camera = camera;
|
|
681
|
-
}
|
|
682
|
-
|
|
683
|
-
/**
|
|
684
|
-
* Applies the skybox texture to the scene background.
|
|
685
|
-
* Retrieves the texture based on the camera's source ID.
|
|
686
|
-
*/
|
|
687
|
-
apply() {
|
|
688
|
-
this._skybox = this.context.lightmaps.tryGetSkybox(this._camera.sourceId) as Texture;
|
|
689
|
-
if (!this._skybox) {
|
|
690
|
-
if (!this["_did_log_failed_to_find_skybox"]) {
|
|
691
|
-
this["_did_log_failed_to_find_skybox"] = true;
|
|
692
|
-
console.warn(`Camera \"${this._camera.name}\" has no skybox texture. ${this._camera.sourceId}`);
|
|
693
|
-
}
|
|
694
|
-
}
|
|
695
|
-
else if (this.context.scene.background !== this._skybox) {
|
|
696
|
-
|
|
697
|
-
const hasBackgroundAttribute = this.context.domElement.getAttribute("background-image") || this.context.domElement.getAttribute("background-color") || this.context.domElement.getAttribute("skybox-image");
|
|
698
|
-
|
|
699
|
-
if (debug) console.debug(`[Camera] Apply Skybox ${this._skybox?.name} ${hasBackgroundAttribute} - \"${this._camera.name}\"`);
|
|
700
|
-
if (!hasBackgroundAttribute?.length) {
|
|
701
|
-
this._skybox.mapping = EquirectangularReflectionMapping;
|
|
702
|
-
this.context.scene.background = this._skybox;
|
|
703
|
-
}
|
|
704
|
-
}
|
|
705
|
-
}
|
|
706
|
-
}
|
|
707
|
-
|
|
708
|
-
/**
|
|
709
|
-
* Adds orbit controls to the camera if the freecam URL parameter is enabled.
|
|
710
|
-
*
|
|
711
|
-
* @param cam The camera to potentially add orbit controls to
|
|
712
|
-
*/
|
|
713
|
-
function handleFreeCam(cam: Camera) {
|
|
714
|
-
const isFreecam = getParam("freecam");
|
|
715
|
-
if (isFreecam) {
|
|
716
|
-
if (cam.context.mainCameraComponent === cam) {
|
|
717
|
-
GameObject.getOrAddComponent(cam.gameObject, OrbitControls);
|
|
718
|
-
}
|
|
719
|
-
}
|
|
1
|
+
import { Color, EquirectangularReflectionMapping, Euler, Frustum, Matrix4, OrthographicCamera, PerspectiveCamera, Ray, Vector3 } from "three";
|
|
2
|
+
import { Texture } from "three";
|
|
3
|
+
|
|
4
|
+
import { showBalloonMessage } from "../engine/debug/index.js";
|
|
5
|
+
import { Gizmos } from "../engine/engine_gizmos.js";
|
|
6
|
+
import { serializable } from "../engine/engine_serialization_decorator.js";
|
|
7
|
+
import { Context } from "../engine/engine_setup.js";
|
|
8
|
+
import { RenderTexture } from "../engine/engine_texture.js";
|
|
9
|
+
import { getTempColor, getWorldPosition } from "../engine/engine_three_utils.js";
|
|
10
|
+
import type { ICamera } from "../engine/engine_types.js"
|
|
11
|
+
import { getParam } from "../engine/engine_utils.js";
|
|
12
|
+
import { RGBAColor } from "../engine/js-extensions/index.js";
|
|
13
|
+
import { Behaviour, GameObject } from "./Component.js";
|
|
14
|
+
import { OrbitControls } from "./OrbitControls.js";
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* The ClearFlags enum is used to determine how the camera clears the background
|
|
18
|
+
*/
|
|
19
|
+
export enum ClearFlags {
|
|
20
|
+
/** Don't clear the background */
|
|
21
|
+
None = 0,
|
|
22
|
+
/** Clear the background with a skybox */
|
|
23
|
+
Skybox = 1,
|
|
24
|
+
/** Clear the background with a solid color. The alpha channel of the color determines the transparency */
|
|
25
|
+
SolidColor = 2,
|
|
26
|
+
/** Clear the background with a transparent color */
|
|
27
|
+
Uninitialized = 4,
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const debug = getParam("debugcam");
|
|
31
|
+
const debugscreenpointtoray = getParam("debugscreenpointtoray");
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Camera component that handles rendering from a specific viewpoint in the scene.
|
|
35
|
+
* Supports both perspective and orthographic cameras with various rendering options.
|
|
36
|
+
* Internally, this component uses {@link PerspectiveCamera} and {@link OrthographicCamera} three.js objects.
|
|
37
|
+
*
|
|
38
|
+
* @category Camera Controls
|
|
39
|
+
* @group Components
|
|
40
|
+
*/
|
|
41
|
+
export class Camera extends Behaviour implements ICamera {
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Returns whether this component is a camera
|
|
45
|
+
* @returns {boolean} Always returns true
|
|
46
|
+
*/
|
|
47
|
+
get isCamera() {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Gets or sets the camera's aspect ratio (width divided by height).
|
|
53
|
+
* For perspective cameras, this directly affects the camera's projection matrix.
|
|
54
|
+
* When set, automatically updates the projection matrix.
|
|
55
|
+
*/
|
|
56
|
+
get aspect(): number {
|
|
57
|
+
if (this._cam instanceof PerspectiveCamera) return this._cam.aspect;
|
|
58
|
+
return (this.context.domWidth / this.context.domHeight);
|
|
59
|
+
}
|
|
60
|
+
@serializable()
|
|
61
|
+
set aspect(value: number) {
|
|
62
|
+
if (this._cam instanceof PerspectiveCamera) {
|
|
63
|
+
if (this._cam.aspect !== value) {
|
|
64
|
+
this._cam.aspect = value;
|
|
65
|
+
this._cam.updateProjectionMatrix();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Gets or sets the camera's field of view in degrees for perspective cameras.
|
|
72
|
+
* When set, automatically updates the projection matrix.
|
|
73
|
+
*/
|
|
74
|
+
get fieldOfView(): number | undefined {
|
|
75
|
+
if (this._cam instanceof PerspectiveCamera) {
|
|
76
|
+
return this._cam.fov;
|
|
77
|
+
}
|
|
78
|
+
return this._fov;
|
|
79
|
+
}
|
|
80
|
+
@serializable()
|
|
81
|
+
set fieldOfView(val: number | undefined) {
|
|
82
|
+
const changed = this.fieldOfView != val;
|
|
83
|
+
this._fov = val;
|
|
84
|
+
if (changed && this._cam) {
|
|
85
|
+
if (this._cam instanceof PerspectiveCamera) {
|
|
86
|
+
if (this._fov === undefined) {
|
|
87
|
+
console.warn("Can not set undefined fov on PerspectiveCamera");
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
this._cam.fov = this._fov;
|
|
91
|
+
this._cam.updateProjectionMatrix();
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Gets or sets the camera's near clipping plane distance.
|
|
98
|
+
* Objects closer than this distance won't be rendered.
|
|
99
|
+
* When set, automatically updates the projection matrix.
|
|
100
|
+
*/
|
|
101
|
+
get nearClipPlane(): number { return this._nearClipPlane; }
|
|
102
|
+
@serializable()
|
|
103
|
+
set nearClipPlane(val) {
|
|
104
|
+
const changed = this._nearClipPlane != val;
|
|
105
|
+
this._nearClipPlane = val;
|
|
106
|
+
if (this._cam && (changed || this._cam.near != val)) {
|
|
107
|
+
this._cam.near = val;
|
|
108
|
+
this._cam.updateProjectionMatrix();
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
private _nearClipPlane: number = 0.1;
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Gets or sets the camera's far clipping plane distance.
|
|
115
|
+
* Objects farther than this distance won't be rendered.
|
|
116
|
+
* When set, automatically updates the projection matrix.
|
|
117
|
+
*/
|
|
118
|
+
get farClipPlane(): number { return this._farClipPlane; }
|
|
119
|
+
@serializable()
|
|
120
|
+
set farClipPlane(val) {
|
|
121
|
+
const changed = this._farClipPlane != val;
|
|
122
|
+
this._farClipPlane = val;
|
|
123
|
+
if (this._cam && (changed || this._cam.far != val)) {
|
|
124
|
+
this._cam.far = val;
|
|
125
|
+
this._cam.updateProjectionMatrix();
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
private _farClipPlane: number = 1000;
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Applies both the camera's near and far clipping planes and updates the projection matrix.
|
|
132
|
+
* This ensures rendering occurs only within the specified distance range.
|
|
133
|
+
*/
|
|
134
|
+
applyClippingPlane() {
|
|
135
|
+
if (this._cam) {
|
|
136
|
+
this._cam.near = this._nearClipPlane;
|
|
137
|
+
this._cam.far = this._farClipPlane;
|
|
138
|
+
this._cam.updateProjectionMatrix();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Gets or sets the camera's clear flags that determine how the background is rendered.
|
|
144
|
+
* Options include skybox, solid color, or transparent background.
|
|
145
|
+
*/
|
|
146
|
+
@serializable()
|
|
147
|
+
public get clearFlags(): ClearFlags {
|
|
148
|
+
return this._clearFlags;
|
|
149
|
+
}
|
|
150
|
+
public set clearFlags(val: ClearFlags | "skybox" | "solidcolor") {
|
|
151
|
+
|
|
152
|
+
if (typeof val === "string") {
|
|
153
|
+
switch (val) {
|
|
154
|
+
case "skybox":
|
|
155
|
+
val = ClearFlags.Skybox;
|
|
156
|
+
break;
|
|
157
|
+
case "solidcolor":
|
|
158
|
+
val = ClearFlags.SolidColor;
|
|
159
|
+
break;
|
|
160
|
+
default:
|
|
161
|
+
val = ClearFlags.None;
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
if (val === this._clearFlags) return;
|
|
167
|
+
this._clearFlags = val;
|
|
168
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
/**
|
|
172
|
+
* Determines if the camera should use orthographic projection instead of perspective.
|
|
173
|
+
*/
|
|
174
|
+
@serializable()
|
|
175
|
+
public orthographic: boolean = false;
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* The size of the orthographic camera's view volume when in orthographic mode.
|
|
179
|
+
* Larger values show more of the scene.
|
|
180
|
+
*/
|
|
181
|
+
@serializable()
|
|
182
|
+
public orthographicSize: number = 5;
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* Controls the transparency level of the camera background in AR mode on supported devices.
|
|
186
|
+
* Value from 0 (fully transparent) to 1 (fully opaque).
|
|
187
|
+
*/
|
|
188
|
+
@serializable()
|
|
189
|
+
public ARBackgroundAlpha: number = 0;
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* Gets or sets the layers mask that determines which objects this camera will render.
|
|
193
|
+
* Uses the {@link https://threejs.org/docs/#api/en/core/Layers.mask|three.js layers mask} convention.
|
|
194
|
+
*/
|
|
195
|
+
@serializable()
|
|
196
|
+
public set cullingMask(val: number) {
|
|
197
|
+
this._cullingMask = val;
|
|
198
|
+
if (this._cam) {
|
|
199
|
+
this._cam.layers.mask = val;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
public get cullingMask(): number {
|
|
203
|
+
if (this._cam) return this._cam.layers.mask;
|
|
204
|
+
return this._cullingMask;
|
|
205
|
+
}
|
|
206
|
+
private _cullingMask: number = 0xffffffff;
|
|
207
|
+
|
|
208
|
+
/**
|
|
209
|
+
* Sets only a specific layer to be active for rendering by this camera.
|
|
210
|
+
* This is equivalent to calling `layers.set(val)` on the three.js camera object.
|
|
211
|
+
* @param val The layer index to set active
|
|
212
|
+
*/
|
|
213
|
+
public set cullingLayer(val: number) {
|
|
214
|
+
this.cullingMask = (1 << val | 0) >>> 0;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* Gets or sets the blurriness of the skybox background.
|
|
219
|
+
* Values range from 0 (sharp) to 1 (maximum blur).
|
|
220
|
+
*/
|
|
221
|
+
@serializable()
|
|
222
|
+
public set backgroundBlurriness(val: number | undefined) {
|
|
223
|
+
if (val === this._backgroundBlurriness) return;
|
|
224
|
+
if (val === undefined)
|
|
225
|
+
this._backgroundBlurriness = undefined;
|
|
226
|
+
else
|
|
227
|
+
this._backgroundBlurriness = Math.min(Math.max(val, 0), 1);
|
|
228
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
229
|
+
}
|
|
230
|
+
public get backgroundBlurriness(): number | undefined {
|
|
231
|
+
return this._backgroundBlurriness;
|
|
232
|
+
}
|
|
233
|
+
private _backgroundBlurriness?: number = undefined;
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Gets or sets the intensity of the skybox background.
|
|
237
|
+
* Values range from 0 (dark) to 10 (very bright).
|
|
238
|
+
*/
|
|
239
|
+
@serializable()
|
|
240
|
+
public set backgroundIntensity(val: number | undefined) {
|
|
241
|
+
if (val === this._backgroundIntensity) return;
|
|
242
|
+
if (val === undefined)
|
|
243
|
+
this._backgroundIntensity = undefined;
|
|
244
|
+
else
|
|
245
|
+
this._backgroundIntensity = Math.min(Math.max(val, 0), 10);
|
|
246
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
247
|
+
}
|
|
248
|
+
public get backgroundIntensity(): number | undefined {
|
|
249
|
+
return this._backgroundIntensity;
|
|
250
|
+
}
|
|
251
|
+
private _backgroundIntensity?: number = undefined;
|
|
252
|
+
|
|
253
|
+
/**
|
|
254
|
+
* Gets or sets the rotation of the skybox background.
|
|
255
|
+
* Controls the orientation of the environment map.
|
|
256
|
+
*/
|
|
257
|
+
@serializable(Euler)
|
|
258
|
+
public set backgroundRotation(val: Euler | undefined) {
|
|
259
|
+
if (val === this._backgroundRotation) return;
|
|
260
|
+
if (val === undefined)
|
|
261
|
+
this._backgroundRotation = undefined;
|
|
262
|
+
else
|
|
263
|
+
this._backgroundRotation = val;
|
|
264
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
265
|
+
}
|
|
266
|
+
public get backgroundRotation(): Euler | undefined {
|
|
267
|
+
return this._backgroundRotation;
|
|
268
|
+
}
|
|
269
|
+
private _backgroundRotation?: Euler = undefined;
|
|
270
|
+
|
|
271
|
+
/**
|
|
272
|
+
* Gets or sets the intensity of the environment lighting.
|
|
273
|
+
* Controls how strongly the environment map affects scene lighting.
|
|
274
|
+
*/
|
|
275
|
+
@serializable()
|
|
276
|
+
public set environmentIntensity(val: number | undefined) {
|
|
277
|
+
this._environmentIntensity = val;
|
|
278
|
+
}
|
|
279
|
+
public get environmentIntensity(): number | undefined {
|
|
280
|
+
return this._environmentIntensity;
|
|
281
|
+
}
|
|
282
|
+
private _environmentIntensity?: number = undefined;
|
|
283
|
+
|
|
284
|
+
/**
|
|
285
|
+
* Gets or sets the background color of the camera when {@link ClearFlags} is set to {@link ClearFlags.SolidColor}.
|
|
286
|
+
* The alpha component controls transparency.
|
|
287
|
+
*/
|
|
288
|
+
@serializable(RGBAColor)
|
|
289
|
+
public get backgroundColor(): RGBAColor | null {
|
|
290
|
+
return this._backgroundColor ?? null;
|
|
291
|
+
}
|
|
292
|
+
public set backgroundColor(val: RGBAColor | Color | null) {
|
|
293
|
+
if (!val) return;
|
|
294
|
+
if (!this._backgroundColor) {
|
|
295
|
+
this._backgroundColor = new RGBAColor(1, 1, 1, 1);
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
this._backgroundColor.copy(val);
|
|
299
|
+
|
|
300
|
+
// set background color to solid if provided color doesnt have any alpha channel
|
|
301
|
+
if ((!("alpha" in val) || val.alpha === undefined)) {
|
|
302
|
+
this._backgroundColor.alpha = 1;
|
|
303
|
+
}
|
|
304
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
/**
|
|
308
|
+
* Gets or sets the texture that the camera should render to instead of the screen.
|
|
309
|
+
* Useful for creating effects like mirrors, portals or custom post processing.
|
|
310
|
+
*/
|
|
311
|
+
@serializable(RenderTexture)
|
|
312
|
+
public set targetTexture(rt: RenderTexture | null) {
|
|
313
|
+
this._targetTexture = rt;
|
|
314
|
+
}
|
|
315
|
+
public get targetTexture(): RenderTexture | null {
|
|
316
|
+
return this._targetTexture;
|
|
317
|
+
}
|
|
318
|
+
private _targetTexture: RenderTexture | null = null;
|
|
319
|
+
|
|
320
|
+
private _backgroundColor?: RGBAColor;
|
|
321
|
+
private _fov?: number;
|
|
322
|
+
private _cam: PerspectiveCamera | OrthographicCamera | null = null;
|
|
323
|
+
private _clearFlags: ClearFlags = ClearFlags.SolidColor;
|
|
324
|
+
private _skybox?: CameraSkybox;
|
|
325
|
+
|
|
326
|
+
/**
|
|
327
|
+
* Gets the three.js camera object. Creates one if it doesn't exist yet.
|
|
328
|
+
* @returns {PerspectiveCamera | OrthographicCamera} The three.js camera object
|
|
329
|
+
* @deprecated Use {@link threeCamera} instead
|
|
330
|
+
*/
|
|
331
|
+
public get cam(): PerspectiveCamera | OrthographicCamera {
|
|
332
|
+
return this.threeCamera;
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
/**
|
|
336
|
+
* Gets the three.js camera object. Creates one if it doesn't exist yet.
|
|
337
|
+
* @returns {PerspectiveCamera | OrthographicCamera} The three.js camera object
|
|
338
|
+
*/
|
|
339
|
+
public get threeCamera(): PerspectiveCamera | OrthographicCamera {
|
|
340
|
+
if (this.activeAndEnabled)
|
|
341
|
+
this.buildCamera();
|
|
342
|
+
return this._cam!;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
private static _origin: Vector3 = new Vector3();
|
|
346
|
+
private static _direction: Vector3 = new Vector3();
|
|
347
|
+
|
|
348
|
+
/**
|
|
349
|
+
* Converts screen coordinates to a ray in world space.
|
|
350
|
+
* Useful for implementing picking or raycasting from screen to world.
|
|
351
|
+
*
|
|
352
|
+
* @param x The x screen coordinate
|
|
353
|
+
* @param y The y screen coordinate
|
|
354
|
+
* @param ray Optional ray object to reuse instead of creating a new one
|
|
355
|
+
* @returns {Ray} A ray originating from the camera position pointing through the screen point
|
|
356
|
+
*/
|
|
357
|
+
public screenPointToRay(x: number, y: number, ray?: Ray): Ray {
|
|
358
|
+
const cam = this.threeCamera;
|
|
359
|
+
const origin = Camera._origin;
|
|
360
|
+
origin.set(x, y, -1);
|
|
361
|
+
this.context.input.convertScreenspaceToRaycastSpace(origin);
|
|
362
|
+
if (debugscreenpointtoray) console.log("screenPointToRay", x.toFixed(2), y.toFixed(2), "now:", origin.x.toFixed(2), origin.y.toFixed(2), "isInXR:" + this.context.isInXR);
|
|
363
|
+
origin.z = -1;
|
|
364
|
+
origin.unproject(cam);
|
|
365
|
+
const dir = Camera._direction.set(origin.x, origin.y, origin.z);
|
|
366
|
+
const camPosition = getWorldPosition(cam);
|
|
367
|
+
dir.sub(camPosition);
|
|
368
|
+
dir.normalize();
|
|
369
|
+
if (ray) {
|
|
370
|
+
ray.set(camPosition, dir);
|
|
371
|
+
return ray;
|
|
372
|
+
}
|
|
373
|
+
else {
|
|
374
|
+
return new Ray(camPosition.clone(), dir.clone());
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
private _frustum?: Frustum;
|
|
379
|
+
|
|
380
|
+
/**
|
|
381
|
+
* Gets the camera's view frustum for culling and visibility checks.
|
|
382
|
+
* Creates the frustum if it doesn't exist and returns it.
|
|
383
|
+
*
|
|
384
|
+
* @returns {Frustum} The camera's view frustum
|
|
385
|
+
*/
|
|
386
|
+
public getFrustum(): Frustum {
|
|
387
|
+
if (!this._frustum) {
|
|
388
|
+
this._frustum = new Frustum();
|
|
389
|
+
this.updateFrustum();
|
|
390
|
+
}
|
|
391
|
+
return this._frustum;
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
/**
|
|
395
|
+
* Forces an update of the camera's frustum.
|
|
396
|
+
* This is automatically called every frame in onBeforeRender.
|
|
397
|
+
*/
|
|
398
|
+
public updateFrustum() {
|
|
399
|
+
if (!this._frustum) this._frustum = new Frustum();
|
|
400
|
+
this._frustum.setFromProjectionMatrix(this.getProjectionScreenMatrix(this._projScreenMatrix, true), this.context.renderer.coordinateSystem);
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
/**
|
|
404
|
+
* Gets this camera's projection-screen matrix.
|
|
405
|
+
*
|
|
406
|
+
* @param target Matrix4 object to store the result in
|
|
407
|
+
* @param forceUpdate Whether to force recalculation of the matrix
|
|
408
|
+
* @returns {Matrix4} The requested projection screen matrix
|
|
409
|
+
*/
|
|
410
|
+
public getProjectionScreenMatrix(target: Matrix4, forceUpdate?: boolean) {
|
|
411
|
+
if (forceUpdate) {
|
|
412
|
+
this._projScreenMatrix.multiplyMatrices(this.threeCamera.projectionMatrix, this.threeCamera.matrixWorldInverse);
|
|
413
|
+
}
|
|
414
|
+
if (target === this._projScreenMatrix) return target;
|
|
415
|
+
return target.copy(this._projScreenMatrix);
|
|
416
|
+
}
|
|
417
|
+
private readonly _projScreenMatrix = new Matrix4();
|
|
418
|
+
|
|
419
|
+
/** @internal */
|
|
420
|
+
awake() {
|
|
421
|
+
if (debugscreenpointtoray) {
|
|
422
|
+
window.addEventListener("pointerdown", evt => {
|
|
423
|
+
const px = evt.clientX;
|
|
424
|
+
const py = evt.clientY;
|
|
425
|
+
console.log("touch", px.toFixed(2), py.toFixed(2))
|
|
426
|
+
const ray = this.screenPointToRay(px, py);
|
|
427
|
+
const randomHex = "#" + Math.floor(Math.random() * 16777215).toString(16);
|
|
428
|
+
Gizmos.DrawRay(ray.origin, ray.direction, randomHex, 10);
|
|
429
|
+
});
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
/** @internal */
|
|
434
|
+
onEnable(): void {
|
|
435
|
+
if (debug) console.log(`Camera enabled: \"${this.name}\". ClearFlags=${ClearFlags[this._clearFlags]}`, this);
|
|
436
|
+
this.buildCamera();
|
|
437
|
+
if (this.tag == "MainCamera" || !this.context.mainCameraComponent) {
|
|
438
|
+
this.context.setCurrentCamera(this);
|
|
439
|
+
handleFreeCam(this);
|
|
440
|
+
}
|
|
441
|
+
this.applyClearFlagsIfIsActiveCamera({ applySkybox: true });
|
|
442
|
+
}
|
|
443
|
+
|
|
444
|
+
/** @internal */
|
|
445
|
+
onDisable() {
|
|
446
|
+
this.context.removeCamera(this);
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
|
|
450
|
+
/** @internal */
|
|
451
|
+
onBeforeRender() {
|
|
452
|
+
if (this._cam) {
|
|
453
|
+
|
|
454
|
+
if (this._frustum) {
|
|
455
|
+
this.updateFrustum();
|
|
456
|
+
}
|
|
457
|
+
|
|
458
|
+
// because the background color may be animated!
|
|
459
|
+
if (this._clearFlags === ClearFlags.SolidColor)
|
|
460
|
+
this.applyClearFlagsIfIsActiveCamera();
|
|
461
|
+
|
|
462
|
+
if (this._targetTexture) {
|
|
463
|
+
if (this.context.isManagedExternally) {
|
|
464
|
+
// TODO: rendering with r3f renderer does throw an shader error for some reason?
|
|
465
|
+
if (!this["_warnedAboutExternalRenderer"]) {
|
|
466
|
+
this["_warnedAboutExternalRenderer"] = true;
|
|
467
|
+
console.warn("Rendering with external renderer is not supported yet. This may not work or throw errors. Please remove the the target texture from your camera: " + this.name, this.targetTexture)
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
|
|
471
|
+
// TODO: optimize to not render twice if this is already the main camera. In that case we just want to blit
|
|
472
|
+
const composer = this.context.composer;
|
|
473
|
+
const useNormalRenderer = true;// this.context.isInXR || !composer;
|
|
474
|
+
const renderer = useNormalRenderer ? this.context.renderer : composer;
|
|
475
|
+
if (renderer) {
|
|
476
|
+
// TODO: we should do this in onBeforeRender for the main camera only
|
|
477
|
+
const mainCam = this.context.mainCameraComponent;
|
|
478
|
+
this.applyClearFlags();
|
|
479
|
+
this._targetTexture.render(this.context.scene, this._cam, renderer);
|
|
480
|
+
mainCam?.applyClearFlags();
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
|
|
486
|
+
/**
|
|
487
|
+
* Creates a three.js camera object if it doesn't exist yet and sets its properties.
|
|
488
|
+
* This is called internally when accessing the {@link threeCamera} property.
|
|
489
|
+
*/
|
|
490
|
+
buildCamera() {
|
|
491
|
+
if (this._cam) return;
|
|
492
|
+
|
|
493
|
+
const cameraAlreadyCreated = this.gameObject["isCamera"];
|
|
494
|
+
|
|
495
|
+
// TODO: when exporting from blender we already have a camera in the children
|
|
496
|
+
let cam: PerspectiveCamera | OrthographicCamera | null = null;
|
|
497
|
+
if (cameraAlreadyCreated) {
|
|
498
|
+
cam = this.gameObject as any;
|
|
499
|
+
cam?.layers.enableAll();
|
|
500
|
+
if (cam instanceof PerspectiveCamera)
|
|
501
|
+
this._fov = cam.fov;
|
|
502
|
+
}
|
|
503
|
+
else
|
|
504
|
+
cam = this.gameObject.children[0] as PerspectiveCamera | OrthographicCamera | null;
|
|
505
|
+
if (cam && cam.isCamera) {
|
|
506
|
+
if (cam instanceof PerspectiveCamera) {
|
|
507
|
+
if (this._fov)
|
|
508
|
+
cam.fov = this._fov;
|
|
509
|
+
cam.near = this._nearClipPlane;
|
|
510
|
+
cam.far = this._farClipPlane;
|
|
511
|
+
cam.updateProjectionMatrix();
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
else if (!this.orthographic) {
|
|
515
|
+
cam = new PerspectiveCamera(this.fieldOfView, window.innerWidth / window.innerHeight, this._nearClipPlane, this._farClipPlane);
|
|
516
|
+
if (this.fieldOfView)
|
|
517
|
+
cam.fov = this.fieldOfView;
|
|
518
|
+
this.gameObject.add(cam);
|
|
519
|
+
}
|
|
520
|
+
else {
|
|
521
|
+
const factor = this.orthographicSize * 100;
|
|
522
|
+
cam = new OrthographicCamera(window.innerWidth / -factor, window.innerWidth / factor, window.innerHeight / factor, window.innerHeight / -factor, this._nearClipPlane, this._farClipPlane);
|
|
523
|
+
this.gameObject.add(cam);
|
|
524
|
+
}
|
|
525
|
+
this._cam = cam;
|
|
526
|
+
|
|
527
|
+
this._cam.layers.mask = this._cullingMask;
|
|
528
|
+
|
|
529
|
+
if (this.tag == "MainCamera") {
|
|
530
|
+
this.context.setCurrentCamera(this);
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
|
|
534
|
+
/**
|
|
535
|
+
* Applies clear flags if this is the active main camera.
|
|
536
|
+
* @param opts Options for applying clear flags
|
|
537
|
+
*/
|
|
538
|
+
applyClearFlagsIfIsActiveCamera(opts?: { applySkybox: boolean }) {
|
|
539
|
+
if (this.context.mainCameraComponent === this) {
|
|
540
|
+
this.applyClearFlags(opts);
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
/**
|
|
545
|
+
* Applies this camera's clear flags and related settings to the renderer.
|
|
546
|
+
* This controls how the background is rendered (skybox, solid color, transparent).
|
|
547
|
+
* @param opts Options for applying clear flags
|
|
548
|
+
*/
|
|
549
|
+
applyClearFlags(opts?: { applySkybox: boolean }) {
|
|
550
|
+
if (!this._cam) {
|
|
551
|
+
if (debug) console.log("Camera does not exist (apply clear flags)")
|
|
552
|
+
return;
|
|
553
|
+
}
|
|
554
|
+
|
|
555
|
+
// restore previous fov (e.g. when user was in VR or AR and the camera's fov has changed)
|
|
556
|
+
this.fieldOfView = this._fov;
|
|
557
|
+
|
|
558
|
+
if (debug) {
|
|
559
|
+
const msg = `[Camera] Apply ClearFlags: ${ClearFlags[this._clearFlags]} - \"${this.name}\"`;
|
|
560
|
+
console.debug(msg);
|
|
561
|
+
}
|
|
562
|
+
|
|
563
|
+
const hasBackgroundImageOrColorAttribute = this.context.domElement.getAttribute("background-image") || this.context.domElement.getAttribute("background-color") || this.context.domElement.getAttribute("skybox-image");
|
|
564
|
+
|
|
565
|
+
switch (this._clearFlags) {
|
|
566
|
+
case ClearFlags.None:
|
|
567
|
+
return;
|
|
568
|
+
|
|
569
|
+
case ClearFlags.Skybox:
|
|
570
|
+
if (Camera.backgroundShouldBeTransparent(this.context)) {
|
|
571
|
+
if (!this.ARBackgroundAlpha || this.ARBackgroundAlpha < 0.001) {
|
|
572
|
+
this.context.scene.background = null;
|
|
573
|
+
this.context.renderer.setClearColor(0x000000, 0);
|
|
574
|
+
return;
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
// apply the skybox only if it is not already set or if it's the first time (e.g. if the _skybox is not set yet)
|
|
579
|
+
if (!this.scene.background || !this._skybox || opts?.applySkybox === true)
|
|
580
|
+
this.applySceneSkybox();
|
|
581
|
+
|
|
582
|
+
// set background blurriness and intensity
|
|
583
|
+
if (this._backgroundBlurriness !== undefined && !this.context.domElement.getAttribute("background-blurriness"))
|
|
584
|
+
this.context.scene.backgroundBlurriness = this._backgroundBlurriness;
|
|
585
|
+
else if (debug) console.warn(`Camera \"${this.name}\" has no background blurriness`)
|
|
586
|
+
|
|
587
|
+
if (this._backgroundIntensity !== undefined && !this.context.domElement.getAttribute("background-intensity"))
|
|
588
|
+
this.context.scene.backgroundIntensity = this._backgroundIntensity;
|
|
589
|
+
|
|
590
|
+
if (this._backgroundRotation !== undefined && !this.context.domElement.getAttribute("background-rotation"))
|
|
591
|
+
this.context.scene.backgroundRotation = this._backgroundRotation;
|
|
592
|
+
|
|
593
|
+
else if (debug) console.warn(`Camera \"${this.name}\" has no background intensity`)
|
|
594
|
+
|
|
595
|
+
break;
|
|
596
|
+
case ClearFlags.SolidColor:
|
|
597
|
+
if (this._backgroundColor && !hasBackgroundImageOrColorAttribute) {
|
|
598
|
+
let alpha = this._backgroundColor.alpha;
|
|
599
|
+
// when in WebXR use ar background alpha override or set to 0
|
|
600
|
+
if (Camera.backgroundShouldBeTransparent(this.context)) {
|
|
601
|
+
alpha = this.ARBackgroundAlpha ?? 0;
|
|
602
|
+
}
|
|
603
|
+
this.context.scene.background = null;
|
|
604
|
+
// In WebXR VR the background colorspace is wrong
|
|
605
|
+
if (this.context.xr?.isVR) {
|
|
606
|
+
this.context.renderer.setClearColor(getTempColor(this._backgroundColor).convertLinearToSRGB());
|
|
607
|
+
} else {
|
|
608
|
+
this.context.renderer.setClearColor(this._backgroundColor, alpha);
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
else if (!this._backgroundColor) {
|
|
612
|
+
if (debug) console.warn(`[Camera] has no background color \"${this.name}\" `)
|
|
613
|
+
}
|
|
614
|
+
break;
|
|
615
|
+
case ClearFlags.Uninitialized:
|
|
616
|
+
if (!hasBackgroundImageOrColorAttribute) {
|
|
617
|
+
this.context.scene.background = null
|
|
618
|
+
this.context.renderer.setClearColor(0x000000, 0);
|
|
619
|
+
}
|
|
620
|
+
break;
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
/**
|
|
625
|
+
* Applies the skybox texture to the scene background.
|
|
626
|
+
*/
|
|
627
|
+
applySceneSkybox() {
|
|
628
|
+
if (!this._skybox)
|
|
629
|
+
this._skybox = new CameraSkybox(this);
|
|
630
|
+
this._skybox.apply();
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
/**
|
|
634
|
+
* Determines if the background should be transparent when in passthrough AR mode.
|
|
635
|
+
*
|
|
636
|
+
* @param context The current rendering context
|
|
637
|
+
* @returns {boolean} True when in XR on a pass through device where the background should be invisible
|
|
638
|
+
*/
|
|
639
|
+
static backgroundShouldBeTransparent(context: Context) {
|
|
640
|
+
const session = context.renderer.xr?.getSession();
|
|
641
|
+
if (!session) return false;
|
|
642
|
+
if (typeof session["_transparent"] === "boolean") {
|
|
643
|
+
return session["_transparent"];
|
|
644
|
+
}
|
|
645
|
+
const environmentBlendMode = session.environmentBlendMode;
|
|
646
|
+
if (debug)
|
|
647
|
+
showBalloonMessage("Environment blend mode: " + environmentBlendMode + " on " + navigator.userAgent);
|
|
648
|
+
let transparent = environmentBlendMode === 'additive' || environmentBlendMode === 'alpha-blend';
|
|
649
|
+
if (context.isInAR) {
|
|
650
|
+
if (environmentBlendMode === "opaque") {
|
|
651
|
+
// workaround for Quest 2 returning opaque when it should be alpha-blend
|
|
652
|
+
// check user agent if this is the Quest browser and return true if so
|
|
653
|
+
if (navigator.userAgent?.includes("OculusBrowser")) {
|
|
654
|
+
transparent = true;
|
|
655
|
+
}
|
|
656
|
+
// Mozilla WebXR Viewer
|
|
657
|
+
else if (navigator.userAgent?.includes("Mozilla") && navigator.userAgent?.includes("Mobile WebXRViewer/v2")) {
|
|
658
|
+
transparent = true;
|
|
659
|
+
}
|
|
660
|
+
}
|
|
661
|
+
}
|
|
662
|
+
|
|
663
|
+
session["_transparent"] = transparent;
|
|
664
|
+
return transparent;
|
|
665
|
+
}
|
|
666
|
+
}
|
|
667
|
+
|
|
668
|
+
/**
|
|
669
|
+
* Helper class for managing skybox textures for cameras.
|
|
670
|
+
* Handles retrieving and applying skybox textures to the scene.
|
|
671
|
+
*/
|
|
672
|
+
class CameraSkybox {
|
|
673
|
+
|
|
674
|
+
private _camera: Camera;
|
|
675
|
+
private _skybox?: Texture;
|
|
676
|
+
|
|
677
|
+
get context() { return this._camera?.context; }
|
|
678
|
+
|
|
679
|
+
constructor(camera: Camera) {
|
|
680
|
+
this._camera = camera;
|
|
681
|
+
}
|
|
682
|
+
|
|
683
|
+
/**
|
|
684
|
+
* Applies the skybox texture to the scene background.
|
|
685
|
+
* Retrieves the texture based on the camera's source ID.
|
|
686
|
+
*/
|
|
687
|
+
apply() {
|
|
688
|
+
this._skybox = this.context.lightmaps.tryGetSkybox(this._camera.sourceId) as Texture;
|
|
689
|
+
if (!this._skybox) {
|
|
690
|
+
if (!this["_did_log_failed_to_find_skybox"]) {
|
|
691
|
+
this["_did_log_failed_to_find_skybox"] = true;
|
|
692
|
+
console.warn(`Camera \"${this._camera.name}\" has no skybox texture. ${this._camera.sourceId}`);
|
|
693
|
+
}
|
|
694
|
+
}
|
|
695
|
+
else if (this.context.scene.background !== this._skybox) {
|
|
696
|
+
|
|
697
|
+
const hasBackgroundAttribute = this.context.domElement.getAttribute("background-image") || this.context.domElement.getAttribute("background-color") || this.context.domElement.getAttribute("skybox-image");
|
|
698
|
+
|
|
699
|
+
if (debug) console.debug(`[Camera] Apply Skybox ${this._skybox?.name} ${hasBackgroundAttribute} - \"${this._camera.name}\"`);
|
|
700
|
+
if (!hasBackgroundAttribute?.length) {
|
|
701
|
+
this._skybox.mapping = EquirectangularReflectionMapping;
|
|
702
|
+
this.context.scene.background = this._skybox;
|
|
703
|
+
}
|
|
704
|
+
}
|
|
705
|
+
}
|
|
706
|
+
}
|
|
707
|
+
|
|
708
|
+
/**
|
|
709
|
+
* Adds orbit controls to the camera if the freecam URL parameter is enabled.
|
|
710
|
+
*
|
|
711
|
+
* @param cam The camera to potentially add orbit controls to
|
|
712
|
+
*/
|
|
713
|
+
function handleFreeCam(cam: Camera) {
|
|
714
|
+
const isFreecam = getParam("freecam");
|
|
715
|
+
if (isFreecam) {
|
|
716
|
+
if (cam.context.mainCameraComponent === cam) {
|
|
717
|
+
GameObject.getOrAddComponent(cam.gameObject, OrbitControls);
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
720
|
}
|