@plastic-software/three 0.181.3 → 0.183.0
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/LICENSE +1 -1
- package/README.md +3 -4
- package/build/three.cjs +11330 -10017
- package/build/three.core.js +10011 -9493
- package/build/three.core.min.js +2 -2
- package/build/three.module.js +1414 -631
- package/build/three.module.min.js +2 -2
- package/build/three.tsl.js +21 -13
- package/build/three.tsl.min.js +2 -2
- package/build/three.webgpu.js +8007 -5427
- package/build/three.webgpu.min.js +2 -2
- package/build/three.webgpu.nodes.js +8005 -5426
- package/build/three.webgpu.nodes.min.js +2 -2
- package/examples/jsm/Addons.js +0 -3
- package/examples/jsm/animation/CCDIKSolver.js +2 -2
- package/examples/jsm/controls/ArcballControls.js +3 -3
- package/examples/jsm/controls/MapControls.js +55 -1
- package/examples/jsm/controls/OrbitControls.js +109 -6
- package/examples/jsm/controls/TrackballControls.js +6 -6
- package/examples/jsm/csm/CSM.js +2 -1
- package/examples/jsm/effects/AnaglyphEffect.js +102 -7
- package/examples/jsm/environments/ColorEnvironment.js +59 -0
- package/examples/jsm/environments/RoomEnvironment.js +3 -0
- package/examples/jsm/exporters/EXRExporter.js +1 -1
- package/examples/jsm/exporters/GLTFExporter.js +131 -4
- package/examples/jsm/exporters/USDZExporter.js +22 -3
- package/examples/jsm/geometries/DecalGeometry.js +1 -1
- package/examples/jsm/helpers/AnimationPathHelper.js +302 -0
- package/examples/jsm/helpers/LightProbeHelperGPU.js +1 -1
- package/examples/jsm/helpers/TextureHelperGPU.js +1 -1
- package/examples/jsm/helpers/ViewHelper.js +67 -8
- package/examples/jsm/inspector/Inspector.js +74 -14
- package/examples/jsm/inspector/RendererInspector.js +12 -2
- package/examples/jsm/inspector/tabs/Console.js +41 -7
- package/examples/jsm/inspector/tabs/Parameters.js +18 -2
- package/examples/jsm/inspector/tabs/Performance.js +2 -2
- package/examples/jsm/inspector/tabs/Viewer.js +4 -4
- package/examples/jsm/inspector/ui/Profiler.js +1836 -31
- package/examples/jsm/inspector/ui/Style.js +973 -14
- package/examples/jsm/inspector/ui/Tab.js +188 -1
- package/examples/jsm/inspector/ui/Values.js +17 -1
- package/examples/jsm/libs/meshopt_decoder.module.js +6 -5
- package/examples/jsm/lines/LineMaterial.js +6 -0
- package/examples/jsm/loaders/3DMLoader.js +5 -4
- package/examples/jsm/loaders/3MFLoader.js +2 -2
- package/examples/jsm/loaders/AMFLoader.js +2 -2
- package/examples/jsm/loaders/ColladaLoader.js +24 -4026
- package/examples/jsm/loaders/DRACOLoader.js +5 -5
- package/examples/jsm/loaders/EXRLoader.js +5 -5
- package/examples/jsm/loaders/FBXLoader.js +2 -4
- package/examples/jsm/loaders/GCodeLoader.js +34 -8
- package/examples/jsm/loaders/GLTFLoader.js +122 -171
- package/examples/jsm/loaders/HDRLoader.js +0 -1
- package/examples/jsm/loaders/KMZLoader.js +5 -5
- package/examples/jsm/loaders/KTX2Loader.js +19 -3
- package/examples/jsm/loaders/LDrawLoader.js +2 -3
- package/examples/jsm/loaders/LWOLoader.js +7 -39
- package/examples/jsm/loaders/NRRDLoader.js +2 -2
- package/examples/jsm/loaders/PCDLoader.js +4 -2
- package/examples/jsm/loaders/SVGLoader.js +1 -1
- package/examples/jsm/loaders/TDSLoader.js +0 -2
- package/examples/jsm/loaders/TGALoader.js +0 -2
- package/examples/jsm/loaders/USDLoader.js +100 -40
- package/examples/jsm/loaders/UltraHDRLoader.js +285 -160
- package/examples/jsm/loaders/VOXLoader.js +660 -117
- package/examples/jsm/loaders/VRMLLoader.js +79 -2
- package/examples/jsm/loaders/VTKLoader.js +37 -24
- package/examples/jsm/loaders/collada/ColladaComposer.js +2950 -0
- package/examples/jsm/loaders/collada/ColladaParser.js +1962 -0
- package/examples/jsm/loaders/usd/USDAParser.js +447 -366
- package/examples/jsm/loaders/usd/USDCParser.js +1841 -6
- package/examples/jsm/loaders/usd/USDComposer.js +4041 -0
- package/examples/jsm/materials/LDrawConditionalLineNodeMaterial.js +2 -2
- package/examples/jsm/materials/WoodNodeMaterial.js +11 -11
- package/examples/jsm/math/Octree.js +131 -1
- package/examples/jsm/misc/Volume.js +0 -1
- package/examples/jsm/misc/VolumeSlice.js +0 -1
- package/examples/jsm/objects/LensflareMesh.js +1 -1
- package/examples/jsm/objects/Sky.js +76 -4
- package/examples/jsm/objects/SkyMesh.js +127 -10
- package/examples/jsm/objects/Water.js +4 -3
- package/examples/jsm/objects/Water2.js +5 -3
- package/examples/jsm/objects/WaterMesh.js +5 -7
- package/examples/jsm/physics/AmmoPhysics.js +12 -7
- package/examples/jsm/physics/JoltPhysics.js +10 -6
- package/examples/jsm/physics/RapierPhysics.js +9 -5
- package/examples/jsm/postprocessing/EffectComposer.js +7 -5
- package/examples/jsm/postprocessing/OutputPass.js +9 -0
- package/examples/jsm/postprocessing/RenderPass.js +10 -0
- package/examples/jsm/postprocessing/RenderTransitionPass.js +1 -1
- package/examples/jsm/postprocessing/UnrealBloomPass.js +48 -18
- package/examples/jsm/renderers/CSS3DRenderer.js +1 -1
- package/examples/jsm/renderers/Projector.js +268 -30
- package/examples/jsm/renderers/SVGRenderer.js +193 -60
- package/examples/jsm/shaders/GTAOShader.js +19 -6
- package/examples/jsm/shaders/HalftoneShader.js +12 -1
- package/examples/jsm/shaders/PoissonDenoiseShader.js +6 -2
- package/examples/jsm/shaders/SAOShader.js +17 -4
- package/examples/jsm/shaders/SSAOShader.js +11 -1
- package/examples/jsm/shaders/SSRShader.js +6 -5
- package/examples/jsm/shaders/UnpackDepthRGBAShader.js +2 -4
- package/examples/jsm/shaders/VignetteShader.js +1 -1
- package/examples/jsm/transpiler/AST.js +44 -0
- package/examples/jsm/transpiler/GLSLDecoder.js +61 -4
- package/examples/jsm/transpiler/ShaderToyDecoder.js +2 -0
- package/examples/jsm/transpiler/TSLEncoder.js +46 -3
- package/examples/jsm/transpiler/TranspilerUtils.js +3 -3
- package/examples/jsm/transpiler/WGSLEncoder.js +27 -0
- package/examples/jsm/tsl/display/AfterImageNode.js +1 -1
- package/examples/jsm/tsl/display/AnaglyphPassNode.js +458 -16
- package/examples/jsm/tsl/display/AnamorphicNode.js +1 -1
- package/examples/jsm/tsl/display/BilateralBlurNode.js +364 -0
- package/examples/jsm/tsl/display/BloomNode.js +16 -6
- package/examples/jsm/tsl/display/CRT.js +150 -0
- package/examples/jsm/tsl/display/DenoiseNode.js +1 -1
- package/examples/jsm/tsl/display/DepthOfFieldNode.js +1 -1
- package/examples/jsm/tsl/display/DotScreenNode.js +1 -1
- package/examples/jsm/tsl/display/FXAANode.js +2 -2
- package/examples/jsm/tsl/display/GTAONode.js +5 -4
- package/examples/jsm/tsl/display/GaussianBlurNode.js +11 -2
- package/examples/jsm/tsl/display/GodraysNode.js +624 -0
- package/examples/jsm/tsl/display/LensflareNode.js +1 -1
- package/examples/jsm/tsl/display/Lut3DNode.js +1 -1
- package/examples/jsm/tsl/display/OutlineNode.js +3 -3
- package/examples/jsm/tsl/display/ParallaxBarrierPassNode.js +2 -2
- package/examples/jsm/tsl/display/PixelationPassNode.js +7 -6
- package/examples/jsm/tsl/display/RGBShiftNode.js +2 -2
- package/examples/jsm/tsl/display/RetroPassNode.js +263 -0
- package/examples/jsm/tsl/display/SMAANode.js +2 -2
- package/examples/jsm/tsl/display/SSAAPassNode.js +2 -2
- package/examples/jsm/tsl/display/SSGINode.js +8 -20
- package/examples/jsm/tsl/display/SSRNode.js +8 -8
- package/examples/jsm/tsl/display/SSSNode.js +6 -4
- package/examples/jsm/tsl/display/Shape.js +29 -0
- package/examples/jsm/tsl/display/SobelOperatorNode.js +2 -2
- package/examples/jsm/tsl/display/StereoCompositePassNode.js +8 -1
- package/examples/jsm/tsl/display/StereoPassNode.js +1 -2
- package/examples/jsm/tsl/display/TRAANode.js +273 -125
- package/examples/jsm/tsl/display/TransitionNode.js +1 -1
- package/examples/jsm/tsl/display/depthAwareBlend.js +80 -0
- package/examples/jsm/tsl/display/radialBlur.js +68 -0
- package/examples/jsm/tsl/math/Bayer.js +40 -1
- package/examples/jsm/utils/LDrawUtils.js +1 -1
- package/examples/jsm/utils/ShadowMapViewer.js +24 -10
- package/examples/jsm/utils/ShadowMapViewerGPU.js +1 -1
- package/examples/jsm/utils/WebGPUTextureUtils.js +1 -1
- package/package.json +20 -26
- package/src/Three.Core.js +2 -1
- package/src/Three.TSL.js +19 -11
- package/src/Three.WebGPU.Nodes.js +2 -0
- package/src/Three.WebGPU.js +3 -0
- package/src/Three.js +1 -0
- package/src/animation/AnimationAction.js +1 -1
- package/src/animation/AnimationClip.js +1 -1
- package/src/animation/AnimationMixer.js +6 -0
- package/src/animation/AnimationUtils.js +1 -12
- package/src/animation/KeyframeTrack.js +47 -8
- package/src/animation/PropertyMixer.js +4 -4
- package/src/animation/tracks/BooleanKeyframeTrack.js +1 -1
- package/src/animation/tracks/ColorKeyframeTrack.js +1 -1
- package/src/animation/tracks/NumberKeyframeTrack.js +1 -1
- package/src/animation/tracks/QuaternionKeyframeTrack.js +1 -1
- package/src/animation/tracks/StringKeyframeTrack.js +1 -1
- package/src/animation/tracks/VectorKeyframeTrack.js +1 -1
- package/src/audio/Audio.js +1 -1
- package/src/audio/AudioListener.js +5 -3
- package/src/cameras/Camera.js +32 -2
- package/src/cameras/CubeCamera.js +20 -0
- package/src/constants.js +90 -5
- package/src/core/BufferGeometry.js +14 -2
- package/src/core/Clock.js +7 -0
- package/src/core/Object3D.js +56 -4
- package/src/core/Raycaster.js +2 -2
- package/src/core/RenderTarget.js +3 -4
- package/src/extras/PMREMGenerator.js +7 -18
- package/src/extras/TextureUtils.js +5 -1
- package/src/geometries/ExtrudeGeometry.js +2 -2
- package/src/geometries/PolyhedronGeometry.js +1 -1
- package/src/geometries/TorusGeometry.js +8 -3
- package/src/helpers/CameraHelper.js +3 -0
- package/src/helpers/DirectionalLightHelper.js +4 -1
- package/src/helpers/HemisphereLightHelper.js +3 -0
- package/src/helpers/PointLightHelper.js +1 -25
- package/src/helpers/SpotLightHelper.js +3 -0
- package/src/lights/DirectionalLight.js +13 -0
- package/src/lights/HemisphereLight.js +10 -0
- package/src/lights/Light.js +1 -11
- package/src/lights/LightProbe.js +0 -15
- package/src/lights/LightShadow.js +15 -6
- package/src/lights/PointLight.js +15 -0
- package/src/lights/PointLightShadow.js +0 -86
- package/src/lights/SpotLight.js +22 -1
- package/src/lights/webgpu/IESSpotLight.js +2 -1
- package/src/loaders/Cache.js +28 -0
- package/src/loaders/FileLoader.js +1 -1
- package/src/loaders/ImageBitmapLoader.js +8 -3
- package/src/loaders/Loader.js +6 -0
- package/src/loaders/MaterialLoader.js +2 -1
- package/src/loaders/ObjectLoader.js +21 -2
- package/src/loaders/nodes/NodeLoader.js +2 -2
- package/src/materials/Material.js +2 -0
- package/src/materials/MeshLambertMaterial.js +9 -0
- package/src/materials/MeshPhongMaterial.js +9 -0
- package/src/materials/ShaderMaterial.js +20 -1
- package/src/materials/nodes/Line2NodeMaterial.js +7 -7
- package/src/materials/nodes/MeshPhysicalNodeMaterial.js +5 -2
- package/src/materials/nodes/MeshStandardNodeMaterial.js +5 -4
- package/src/materials/nodes/NodeMaterial.js +72 -25
- package/src/materials/nodes/manager/NodeMaterialObserver.js +10 -4
- package/src/math/Line3.js +3 -5
- package/src/math/MathUtils.js +10 -10
- package/src/math/Matrix4.js +74 -65
- package/src/math/Quaternion.js +3 -29
- package/src/math/Sphere.js +1 -1
- package/src/math/Vector3.js +3 -5
- package/src/math/interpolants/BezierInterpolant.js +108 -0
- package/src/nodes/Nodes.js +87 -68
- package/src/nodes/TSL.js +6 -6
- package/src/nodes/accessors/Arrays.js +1 -1
- package/src/nodes/accessors/BatchNode.js +10 -10
- package/src/nodes/accessors/Bitangent.js +5 -5
- package/src/nodes/accessors/BufferAttributeNode.js +98 -12
- package/src/nodes/accessors/BufferNode.js +29 -2
- package/src/nodes/accessors/Camera.js +149 -28
- package/src/nodes/accessors/ClippingNode.js +4 -4
- package/src/nodes/accessors/CubeTextureNode.js +20 -1
- package/src/nodes/accessors/InstanceNode.js +148 -43
- package/src/nodes/accessors/MaterialNode.js +9 -1
- package/src/nodes/accessors/MaterialReferenceNode.js +1 -2
- package/src/nodes/accessors/ModelNode.js +1 -1
- package/src/nodes/accessors/Normal.js +11 -11
- package/src/nodes/accessors/Position.js +34 -2
- package/src/nodes/accessors/ReferenceBaseNode.js +4 -4
- package/src/nodes/accessors/ReferenceNode.js +4 -4
- package/src/nodes/accessors/RendererReferenceNode.js +1 -2
- package/src/nodes/accessors/SceneProperties.js +53 -0
- package/src/nodes/accessors/SkinningNode.js +27 -26
- package/src/nodes/accessors/StorageBufferNode.js +4 -21
- package/src/nodes/accessors/StorageTextureNode.js +37 -1
- package/src/nodes/accessors/Tangent.js +4 -14
- package/src/nodes/accessors/Texture3DNode.js +32 -35
- package/src/nodes/accessors/TextureNode.js +58 -22
- package/src/nodes/accessors/UniformArrayNode.js +4 -2
- package/src/nodes/accessors/UserDataNode.js +1 -2
- package/src/nodes/accessors/VertexColorNode.js +1 -2
- package/src/nodes/code/FunctionNode.js +1 -2
- package/src/nodes/core/ArrayNode.js +20 -1
- package/src/nodes/core/AssignNode.js +2 -2
- package/src/nodes/core/AttributeNode.js +2 -2
- package/src/nodes/core/ContextNode.js +103 -4
- package/src/nodes/core/MRTNode.js +48 -2
- package/src/nodes/core/Node.js +29 -3
- package/src/nodes/core/NodeBuilder.js +170 -53
- package/src/nodes/core/NodeError.js +28 -0
- package/src/nodes/core/NodeFrame.js +12 -4
- package/src/nodes/core/NodeUtils.js +10 -8
- package/src/nodes/core/OutputStructNode.js +12 -10
- package/src/nodes/core/ParameterNode.js +3 -3
- package/src/nodes/core/PropertyNode.js +19 -3
- package/src/nodes/core/StackNode.js +65 -16
- package/src/nodes/core/StackTrace.js +139 -0
- package/src/nodes/core/StructNode.js +16 -2
- package/src/nodes/core/StructTypeNode.js +11 -17
- package/src/nodes/core/SubBuildNode.js +1 -1
- package/src/nodes/core/UniformNode.js +21 -5
- package/src/nodes/core/VarNode.js +47 -22
- package/src/nodes/core/VaryingNode.js +1 -18
- package/src/nodes/display/BlendModes.js +0 -64
- package/src/nodes/display/ColorAdjustment.js +17 -0
- package/src/nodes/display/ColorSpaceNode.js +3 -3
- package/src/nodes/display/NormalMapNode.js +39 -4
- package/src/nodes/display/PassNode.js +98 -9
- package/src/nodes/display/RenderOutputNode.js +3 -3
- package/src/nodes/display/ScreenNode.js +3 -1
- package/src/nodes/display/ToneMappingNode.js +1 -1
- package/src/nodes/display/ToonOutlinePassNode.js +2 -2
- package/src/nodes/display/ViewportDepthNode.js +52 -4
- package/src/nodes/display/ViewportTextureNode.js +21 -4
- package/src/nodes/fog/Fog.js +18 -35
- package/src/nodes/functions/BSDF/BRDF_GGX_Multiscatter.js +3 -3
- package/src/nodes/functions/BSDF/DFGLUT.js +56 -0
- package/src/nodes/functions/BSDF/EnvironmentBRDF.js +2 -2
- package/src/nodes/functions/BSDF/V_GGX_SmithCorrelated_Anisotropic.js +1 -1
- package/src/nodes/functions/PhysicalLightingModel.js +126 -45
- package/src/nodes/geometry/RangeNode.js +4 -2
- package/src/nodes/gpgpu/ComputeBuiltinNode.js +1 -2
- package/src/nodes/gpgpu/ComputeNode.js +5 -4
- package/src/nodes/gpgpu/SubgroupFunctionNode.js +1 -1
- package/src/nodes/gpgpu/WorkgroupInfoNode.js +4 -4
- package/src/nodes/lighting/AnalyticLightNode.js +53 -0
- package/src/nodes/lighting/EnvironmentNode.js +28 -3
- package/src/nodes/lighting/LightsNode.js +2 -2
- package/src/nodes/lighting/PointShadowNode.js +162 -149
- package/src/nodes/lighting/ShadowFilterNode.js +53 -65
- package/src/nodes/lighting/ShadowNode.js +97 -41
- package/src/nodes/math/BitcountNode.js +433 -0
- package/src/nodes/math/ConditionalNode.js +2 -2
- package/src/nodes/math/MathNode.js +3 -40
- package/src/nodes/math/OperatorNode.js +2 -1
- package/src/nodes/math/PackFloatNode.js +98 -0
- package/src/nodes/math/UnpackFloatNode.js +96 -0
- package/src/nodes/pmrem/PMREMNode.js +1 -1
- package/src/nodes/pmrem/PMREMUtils.js +9 -15
- package/src/nodes/tsl/TSLCore.js +17 -14
- package/src/nodes/utils/ArrayElementNode.js +13 -0
- package/src/nodes/utils/DebugNode.js +11 -11
- package/src/nodes/utils/EventNode.js +1 -2
- package/src/nodes/utils/JoinNode.js +2 -2
- package/src/nodes/utils/LoopNode.js +1 -1
- package/src/nodes/utils/MemberNode.js +1 -1
- package/src/nodes/utils/Packing.js +13 -1
- package/src/nodes/utils/PostProcessingUtils.js +33 -1
- package/src/nodes/utils/RTTNode.js +1 -1
- package/src/nodes/utils/ReflectorNode.js +3 -4
- package/src/nodes/utils/SampleNode.js +1 -1
- package/src/nodes/utils/SpriteSheetUV.js +35 -0
- package/src/nodes/utils/UVUtils.js +28 -0
- package/src/objects/BatchedMesh.js +27 -14
- package/src/objects/InstancedMesh.js +11 -0
- package/src/objects/Line.js +1 -1
- package/src/objects/Mesh.js +1 -1
- package/src/objects/Points.js +1 -1
- package/src/objects/Skeleton.js +9 -0
- package/src/renderers/WebGLRenderer.js +178 -92
- package/src/renderers/common/Backend.js +29 -0
- package/src/renderers/common/Background.js +24 -11
- package/src/renderers/common/BindGroup.js +1 -9
- package/src/renderers/common/Binding.js +11 -0
- package/src/renderers/common/Bindings.js +27 -12
- package/src/renderers/common/BlendMode.js +143 -0
- package/src/renderers/common/Buffer.js +40 -0
- package/src/renderers/common/BundleGroup.js +1 -1
- package/src/renderers/common/ChainMap.js +30 -6
- package/src/renderers/common/CubeRenderTarget.js +50 -6
- package/src/renderers/common/Geometries.js +29 -3
- package/src/renderers/common/Lighting.js +5 -21
- package/src/renderers/common/Pipelines.js +4 -4
- package/src/renderers/common/PostProcessing.js +8 -206
- package/src/renderers/common/RenderBundles.js +2 -1
- package/src/renderers/common/RenderContext.js +16 -0
- package/src/renderers/common/RenderContexts.js +33 -49
- package/src/renderers/common/RenderLists.js +2 -1
- package/src/renderers/common/RenderObject.js +15 -3
- package/src/renderers/common/RenderObjectPipeline.js +40 -0
- package/src/renderers/common/RenderObjects.js +18 -2
- package/src/renderers/common/RenderPipeline.js +203 -17
- package/src/renderers/common/Renderer.js +257 -72
- package/src/renderers/common/Sampler.js +4 -4
- package/src/renderers/common/StorageBuffer.js +13 -1
- package/src/renderers/common/Textures.js +17 -1
- package/src/renderers/common/TimestampQueryPool.js +5 -3
- package/src/renderers/common/Uniform.js +8 -0
- package/src/renderers/common/UniformsGroup.js +61 -0
- package/src/renderers/common/XRManager.js +3 -2
- package/src/renderers/common/extras/PMREMGenerator.js +2 -8
- package/src/renderers/common/nodes/NodeBuilderState.js +1 -1
- package/src/renderers/common/nodes/{Nodes.js → NodeManager.js} +18 -6
- package/src/renderers/common/nodes/NodeStorageBuffer.js +13 -2
- package/src/renderers/common/nodes/NodeUniformBuffer.js +52 -0
- package/src/renderers/shaders/DFGLUTData.js +19 -34
- package/src/renderers/shaders/ShaderChunk/batching_pars_vertex.glsl.js +2 -2
- package/src/renderers/shaders/ShaderChunk/color_fragment.glsl.js +1 -5
- package/src/renderers/shaders/ShaderChunk/color_pars_fragment.glsl.js +1 -5
- package/src/renderers/shaders/ShaderChunk/color_pars_vertex.glsl.js +1 -5
- package/src/renderers/shaders/ShaderChunk/color_vertex.glsl.js +8 -10
- package/src/renderers/shaders/ShaderChunk/envmap_fragment.glsl.js +7 -11
- package/src/renderers/shaders/ShaderChunk/lights_fragment_begin.glsl.js +5 -2
- package/src/renderers/shaders/ShaderChunk/lights_fragment_end.glsl.js +6 -0
- package/src/renderers/shaders/ShaderChunk/lights_fragment_maps.glsl.js +6 -2
- package/src/renderers/shaders/ShaderChunk/lights_physical_fragment.glsl.js +8 -4
- package/src/renderers/shaders/ShaderChunk/lights_physical_pars_fragment.glsl.js +112 -51
- package/src/renderers/shaders/ShaderChunk/packing.glsl.js +20 -4
- package/src/renderers/shaders/ShaderChunk/shadowmap_pars_fragment.glsl.js +225 -186
- package/src/renderers/shaders/ShaderChunk/shadowmask_pars_fragment.glsl.js +1 -1
- package/src/renderers/shaders/ShaderChunk/transmission_fragment.glsl.js +1 -1
- package/src/renderers/shaders/ShaderChunk.js +3 -3
- package/src/renderers/shaders/ShaderLib/depth.glsl.js +3 -0
- package/src/renderers/shaders/ShaderLib/{distanceRGBA.glsl.js → distance.glsl.js} +1 -2
- package/src/renderers/shaders/ShaderLib/meshlambert.glsl.js +2 -1
- package/src/renderers/shaders/ShaderLib/meshnormal.glsl.js +1 -2
- package/src/renderers/shaders/ShaderLib/meshphong.glsl.js +2 -1
- package/src/renderers/shaders/ShaderLib/meshphysical.glsl.js +4 -9
- package/src/renderers/shaders/ShaderLib/meshtoon.glsl.js +0 -1
- package/src/renderers/shaders/ShaderLib/shadow.glsl.js +1 -1
- package/src/renderers/shaders/ShaderLib/vsm.glsl.js +4 -6
- package/src/renderers/shaders/ShaderLib.js +7 -5
- package/src/renderers/shaders/UniformsLib.js +0 -3
- package/src/renderers/webgl/WebGLBackground.js +2 -2
- package/src/renderers/webgl/WebGLBindingStates.js +99 -27
- package/src/renderers/webgl/WebGLCapabilities.js +3 -4
- package/src/renderers/webgl/WebGLEnvironments.js +228 -0
- package/src/renderers/webgl/WebGLGeometries.js +10 -7
- package/src/renderers/webgl/WebGLLights.js +18 -1
- package/src/renderers/webgl/WebGLMaterials.js +12 -0
- package/src/renderers/webgl/WebGLObjects.js +3 -1
- package/src/renderers/webgl/WebGLOutput.js +267 -0
- package/src/renderers/webgl/WebGLProgram.js +45 -109
- package/src/renderers/webgl/WebGLPrograms.js +45 -49
- package/src/renderers/webgl/WebGLRenderLists.js +15 -0
- package/src/renderers/webgl/WebGLShadowMap.js +188 -24
- package/src/renderers/webgl/WebGLState.js +32 -37
- package/src/renderers/webgl/WebGLTextures.js +89 -28
- package/src/renderers/webgl/WebGLUniforms.js +40 -3
- package/src/renderers/webgl/WebGLUtils.js +6 -2
- package/src/renderers/webgl-fallback/WebGLBackend.js +148 -18
- package/src/renderers/webgl-fallback/nodes/GLSLNodeBuilder.js +156 -35
- package/src/renderers/webgl-fallback/utils/WebGLState.js +181 -5
- package/src/renderers/webgl-fallback/utils/WebGLTextureUtils.js +5 -3
- package/src/renderers/webgl-fallback/utils/WebGLTimestampQueryPool.js +9 -9
- package/src/renderers/webgl-fallback/utils/WebGLUtils.js +6 -2
- package/src/renderers/webgpu/WebGPUBackend.js +119 -13
- package/src/renderers/webgpu/WebGPURenderer.js +2 -1
- package/src/renderers/webgpu/nodes/WGSLNodeBuilder.js +322 -68
- package/src/renderers/webgpu/utils/WebGPUAttributeUtils.js +4 -17
- package/src/renderers/webgpu/utils/WebGPUBindingUtils.js +357 -200
- package/src/renderers/webgpu/utils/WebGPUConstants.js +2 -0
- package/src/renderers/webgpu/utils/WebGPUPipelineUtils.js +61 -23
- package/src/renderers/webgpu/utils/WebGPUTexturePassUtils.js +152 -200
- package/src/renderers/webgpu/utils/WebGPUTextureUtils.js +65 -42
- package/src/renderers/webgpu/utils/WebGPUTimestampQueryPool.js +7 -7
- package/src/renderers/webgpu/utils/WebGPUUtils.js +17 -11
- package/src/renderers/webxr/WebXRManager.js +2 -2
- package/src/textures/CubeDepthTexture.js +76 -0
- package/src/textures/Source.js +1 -1
- package/src/textures/Texture.js +3 -3
- package/src/utils.js +258 -3
- package/examples/jsm/materials/MeshGouraudMaterial.js +0 -434
- package/examples/jsm/materials/MeshPostProcessingMaterial.js +0 -167
- package/examples/jsm/shaders/GodRaysShader.js +0 -333
- package/src/nodes/accessors/SceneNode.js +0 -145
- package/src/nodes/code/ScriptableNode.js +0 -726
- package/src/nodes/code/ScriptableValueNode.js +0 -253
- package/src/nodes/display/PosterizeNode.js +0 -65
- package/src/nodes/functions/BSDF/DFGApprox.js +0 -71
- package/src/nodes/utils/SpriteSheetUVNode.js +0 -90
- package/src/renderers/webgl/WebGLCubeMaps.js +0 -99
- package/src/renderers/webgl/WebGLCubeUVMaps.js +0 -134
|
@@ -8,7 +8,29 @@ import { Viewer } from './tabs/Viewer.js';
|
|
|
8
8
|
import { setText, splitPath, splitCamelCase } from './ui/utils.js';
|
|
9
9
|
|
|
10
10
|
import { QuadMesh, NodeMaterial, CanvasTarget, setConsoleFunction, REVISION, NoToneMapping } from 'three/webgpu';
|
|
11
|
-
import { renderOutput, vec3, vec4 } from 'three/tsl';
|
|
11
|
+
import { renderOutput, vec2, vec3, vec4, Fn, screenUV, step, OnMaterialUpdate, uniform } from 'three/tsl';
|
|
12
|
+
|
|
13
|
+
const aspectRatioUV = /*@__PURE__*/ Fn( ( [ uv, textureNode ] ) => {
|
|
14
|
+
|
|
15
|
+
const aspect = uniform( 0 );
|
|
16
|
+
|
|
17
|
+
OnMaterialUpdate( () => {
|
|
18
|
+
|
|
19
|
+
const { width, height } = textureNode.value;
|
|
20
|
+
|
|
21
|
+
aspect.value = width / height;
|
|
22
|
+
|
|
23
|
+
} );
|
|
24
|
+
|
|
25
|
+
const centered = uv.sub( 0.5 );
|
|
26
|
+
const corrected = vec2( centered.x.div( aspect ), centered.y );
|
|
27
|
+
const finalUV = corrected.add( 0.5 );
|
|
28
|
+
|
|
29
|
+
const inBounds = step( 0.0, finalUV.x ).mul( step( finalUV.x, 1.0 ) ).mul( step( 0.0, finalUV.y ) ).mul( step( finalUV.y, 1.0 ) );
|
|
30
|
+
|
|
31
|
+
return vec3( finalUV, inBounds );
|
|
32
|
+
|
|
33
|
+
} );
|
|
12
34
|
|
|
13
35
|
class Inspector extends RendererInspector {
|
|
14
36
|
|
|
@@ -20,7 +42,10 @@ class Inspector extends RendererInspector {
|
|
|
20
42
|
|
|
21
43
|
const profiler = new Profiler();
|
|
22
44
|
|
|
23
|
-
const parameters = new Parameters(
|
|
45
|
+
const parameters = new Parameters( {
|
|
46
|
+
builtin: true,
|
|
47
|
+
icon: '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"/><path d="M14 6m-2 0a2 2 0 1 0 4 0a2 2 0 1 0 -4 0" /><path d="M4 6l8 0" /><path d="M16 6l4 0" /><path d="M8 12m-2 0a2 2 0 1 0 4 0a2 2 0 1 0 -4 0" /><path d="M4 12l2 0" /><path d="M10 12l10 0" /><path d="M17 18m-2 0a2 2 0 1 0 4 0a2 2 0 1 0 -4 0" /><path d="M4 18l11 0" /><path d="M19 18l1 0" /></svg>'
|
|
48
|
+
} );
|
|
24
49
|
parameters.hide();
|
|
25
50
|
profiler.addTab( parameters );
|
|
26
51
|
|
|
@@ -31,18 +56,22 @@ class Inspector extends RendererInspector {
|
|
|
31
56
|
const performance = new Performance();
|
|
32
57
|
profiler.addTab( performance );
|
|
33
58
|
|
|
34
|
-
const
|
|
35
|
-
profiler.addTab(
|
|
59
|
+
const consoleTab = new Console();
|
|
60
|
+
profiler.addTab( consoleTab );
|
|
36
61
|
|
|
37
|
-
profiler.
|
|
62
|
+
profiler.loadLayout();
|
|
38
63
|
|
|
39
|
-
|
|
64
|
+
if ( ! profiler.activeTabId ) {
|
|
65
|
+
|
|
66
|
+
profiler.setActiveTab( performance.id );
|
|
67
|
+
|
|
68
|
+
}
|
|
40
69
|
|
|
41
70
|
this.statsData = new Map();
|
|
42
71
|
this.canvasNodes = new Map();
|
|
43
72
|
this.profiler = profiler;
|
|
44
73
|
this.performance = performance;
|
|
45
|
-
this.console =
|
|
74
|
+
this.console = consoleTab;
|
|
46
75
|
this.parameters = parameters;
|
|
47
76
|
this.viewer = viewer;
|
|
48
77
|
this.once = {};
|
|
@@ -81,7 +110,7 @@ class Inspector extends RendererInspector {
|
|
|
81
110
|
|
|
82
111
|
}
|
|
83
112
|
|
|
84
|
-
resolveConsole( type, message ) {
|
|
113
|
+
resolveConsole( type, message, stackTrace = null ) {
|
|
85
114
|
|
|
86
115
|
switch ( type ) {
|
|
87
116
|
|
|
@@ -97,7 +126,15 @@ class Inspector extends RendererInspector {
|
|
|
97
126
|
|
|
98
127
|
this.console.addMessage( 'warn', message );
|
|
99
128
|
|
|
100
|
-
|
|
129
|
+
if ( stackTrace && stackTrace.isStackTrace ) {
|
|
130
|
+
|
|
131
|
+
console.warn( stackTrace.getError( message ) );
|
|
132
|
+
|
|
133
|
+
} else {
|
|
134
|
+
|
|
135
|
+
console.warn( message );
|
|
136
|
+
|
|
137
|
+
}
|
|
101
138
|
|
|
102
139
|
break;
|
|
103
140
|
|
|
@@ -105,7 +142,15 @@ class Inspector extends RendererInspector {
|
|
|
105
142
|
|
|
106
143
|
this.console.addMessage( 'error', message );
|
|
107
144
|
|
|
108
|
-
|
|
145
|
+
if ( stackTrace && stackTrace.isStackTrace ) {
|
|
146
|
+
|
|
147
|
+
console.error( stackTrace.getError( message ) );
|
|
148
|
+
|
|
149
|
+
} else {
|
|
150
|
+
|
|
151
|
+
console.error( message );
|
|
152
|
+
|
|
153
|
+
}
|
|
109
154
|
|
|
110
155
|
break;
|
|
111
156
|
|
|
@@ -153,10 +198,10 @@ class Inspector extends RendererInspector {
|
|
|
153
198
|
|
|
154
199
|
if ( this.isAvailable ) {
|
|
155
200
|
|
|
156
|
-
renderer.backend.trackTimestamp = true;
|
|
157
|
-
|
|
158
201
|
renderer.init().then( () => {
|
|
159
202
|
|
|
203
|
+
renderer.backend.trackTimestamp = true;
|
|
204
|
+
|
|
160
205
|
if ( renderer.hasFeature( 'timestamp-query' ) !== true ) {
|
|
161
206
|
|
|
162
207
|
this.console.addMessage( 'error', 'THREE.Inspector: GPU Timestamp Queries not available.' );
|
|
@@ -178,7 +223,12 @@ class Inspector extends RendererInspector {
|
|
|
178
223
|
if ( this.parameters.isVisible === false ) {
|
|
179
224
|
|
|
180
225
|
this.parameters.show();
|
|
181
|
-
|
|
226
|
+
|
|
227
|
+
if ( this.parameters.isDetached === false ) {
|
|
228
|
+
|
|
229
|
+
this.profiler.setActiveTab( this.parameters.id );
|
|
230
|
+
|
|
231
|
+
}
|
|
182
232
|
|
|
183
233
|
}
|
|
184
234
|
|
|
@@ -266,7 +316,17 @@ class Inspector extends RendererInspector {
|
|
|
266
316
|
|
|
267
317
|
const { path, name } = splitPath( splitCamelCase( node.getName() || '(unnamed)' ) );
|
|
268
318
|
|
|
269
|
-
|
|
319
|
+
const target = node.context( { getUV: ( textureNode ) => {
|
|
320
|
+
|
|
321
|
+
const uvData = aspectRatioUV( screenUV, textureNode );
|
|
322
|
+
const correctedUV = uvData.xy;
|
|
323
|
+
const mask = uvData.z;
|
|
324
|
+
|
|
325
|
+
return correctedUV.mul( mask );
|
|
326
|
+
|
|
327
|
+
} } );
|
|
328
|
+
|
|
329
|
+
let output = vec4( vec3( target ), 1 );
|
|
270
330
|
output = renderOutput( output, NoToneMapping, renderer.outputColorSpace );
|
|
271
331
|
output = output.context( { inspector: true } );
|
|
272
332
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
import { InspectorBase, TimestampQuery } from 'three/webgpu';
|
|
2
|
+
import { InspectorBase, TimestampQuery, warnOnce } from 'three/webgpu';
|
|
3
3
|
|
|
4
4
|
class ObjectStats {
|
|
5
5
|
|
|
@@ -330,7 +330,17 @@ export class RendererInspector extends InspectorBase {
|
|
|
330
330
|
|
|
331
331
|
inspect( node ) {
|
|
332
332
|
|
|
333
|
-
this.currentNodes
|
|
333
|
+
const currentNodes = this.currentNodes;
|
|
334
|
+
|
|
335
|
+
if ( currentNodes !== null ) {
|
|
336
|
+
|
|
337
|
+
currentNodes.push( node );
|
|
338
|
+
|
|
339
|
+
} else {
|
|
340
|
+
|
|
341
|
+
warnOnce( 'RendererInspector: Unable to inspect node outside of frame scope. Use "renderer.setAnimationLoop()".' );
|
|
342
|
+
|
|
343
|
+
}
|
|
334
344
|
|
|
335
345
|
}
|
|
336
346
|
|
|
@@ -2,9 +2,9 @@ import { Tab } from '../ui/Tab.js';
|
|
|
2
2
|
|
|
3
3
|
class Console extends Tab {
|
|
4
4
|
|
|
5
|
-
constructor() {
|
|
5
|
+
constructor( options = {} ) {
|
|
6
6
|
|
|
7
|
-
super( 'Console' );
|
|
7
|
+
super( 'Console', options );
|
|
8
8
|
|
|
9
9
|
this.filters = { info: true, warn: true, error: true };
|
|
10
10
|
this.filterText = '';
|
|
@@ -33,8 +33,14 @@ class Console extends Tab {
|
|
|
33
33
|
|
|
34
34
|
} );
|
|
35
35
|
|
|
36
|
-
const
|
|
37
|
-
|
|
36
|
+
const copyButton = document.createElement( 'button' );
|
|
37
|
+
copyButton.className = 'console-copy-button';
|
|
38
|
+
copyButton.title = 'Copy all';
|
|
39
|
+
copyButton.innerHTML = '<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="9" y="9" width="13" height="13" rx="2" ry="2"></rect><path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"></path></svg>';
|
|
40
|
+
copyButton.addEventListener( 'click', () => this.copyAll( copyButton ) );
|
|
41
|
+
|
|
42
|
+
const buttonsGroup = document.createElement( 'div' );
|
|
43
|
+
buttonsGroup.className = 'console-buttons-group';
|
|
38
44
|
|
|
39
45
|
Object.keys( this.filters ).forEach( type => {
|
|
40
46
|
|
|
@@ -53,11 +59,11 @@ class Console extends Tab {
|
|
|
53
59
|
label.appendChild( checkbox );
|
|
54
60
|
label.appendChild( checkmark );
|
|
55
61
|
label.append( type.charAt( 0 ).toUpperCase() + type.slice( 1 ) );
|
|
56
|
-
|
|
62
|
+
buttonsGroup.appendChild( label );
|
|
57
63
|
|
|
58
64
|
} );
|
|
59
65
|
|
|
60
|
-
|
|
66
|
+
buttonsGroup.addEventListener( 'change', ( e ) => {
|
|
61
67
|
|
|
62
68
|
const type = e.target.dataset.type;
|
|
63
69
|
if ( type in this.filters ) {
|
|
@@ -69,8 +75,10 @@ class Console extends Tab {
|
|
|
69
75
|
|
|
70
76
|
} );
|
|
71
77
|
|
|
78
|
+
buttonsGroup.appendChild( copyButton );
|
|
79
|
+
|
|
72
80
|
header.appendChild( filterInput );
|
|
73
|
-
header.appendChild(
|
|
81
|
+
header.appendChild( buttonsGroup );
|
|
74
82
|
this.content.appendChild( header );
|
|
75
83
|
|
|
76
84
|
}
|
|
@@ -92,6 +100,32 @@ class Console extends Tab {
|
|
|
92
100
|
|
|
93
101
|
}
|
|
94
102
|
|
|
103
|
+
copyAll( button ) {
|
|
104
|
+
|
|
105
|
+
const win = this.logContainer.ownerDocument.defaultView;
|
|
106
|
+
const selection = win.getSelection();
|
|
107
|
+
const selectedText = selection.toString();
|
|
108
|
+
const textInConsole = selectedText && this.logContainer.contains( selection.anchorNode );
|
|
109
|
+
|
|
110
|
+
let text;
|
|
111
|
+
if ( textInConsole ) {
|
|
112
|
+
|
|
113
|
+
text = selectedText;
|
|
114
|
+
|
|
115
|
+
} else {
|
|
116
|
+
|
|
117
|
+
const messages = this.logContainer.querySelectorAll( '.log-message:not(.hidden)' );
|
|
118
|
+
text = Array.from( messages ).map( msg => msg.dataset.rawText ).join( '\n' );
|
|
119
|
+
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
navigator.clipboard.writeText( text );
|
|
123
|
+
|
|
124
|
+
button.classList.add( 'copied' );
|
|
125
|
+
setTimeout( () => button.classList.remove( 'copied' ), 350 );
|
|
126
|
+
|
|
127
|
+
}
|
|
128
|
+
|
|
95
129
|
_getIcon( type, subType ) {
|
|
96
130
|
|
|
97
131
|
let icon;
|
|
@@ -13,6 +13,8 @@ class ParametersGroup {
|
|
|
13
13
|
|
|
14
14
|
this.paramList = new Item( name );
|
|
15
15
|
|
|
16
|
+
this.objects = [];
|
|
17
|
+
|
|
16
18
|
}
|
|
17
19
|
|
|
18
20
|
close() {
|
|
@@ -93,6 +95,15 @@ class ParametersGroup {
|
|
|
93
95
|
|
|
94
96
|
};
|
|
95
97
|
|
|
98
|
+
|
|
99
|
+
this._registerParameter( object, property, editor, subItem );
|
|
100
|
+
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
_registerParameter( object, property, editor, subItem ) {
|
|
104
|
+
|
|
105
|
+
this.objects.push( { object: object, key: property, editor: editor, subItem: subItem } );
|
|
106
|
+
|
|
96
107
|
}
|
|
97
108
|
|
|
98
109
|
addFolder( name ) {
|
|
@@ -291,6 +302,8 @@ class ParametersGroup {
|
|
|
291
302
|
|
|
292
303
|
};
|
|
293
304
|
|
|
305
|
+
this._registerParameter( object, property, editor, subItem );
|
|
306
|
+
|
|
294
307
|
return editor;
|
|
295
308
|
|
|
296
309
|
}
|
|
@@ -299,9 +312,9 @@ class ParametersGroup {
|
|
|
299
312
|
|
|
300
313
|
class Parameters extends Tab {
|
|
301
314
|
|
|
302
|
-
constructor() {
|
|
315
|
+
constructor( options = {} ) {
|
|
303
316
|
|
|
304
|
-
super( 'Parameters' );
|
|
317
|
+
super( 'Parameters', options );
|
|
305
318
|
|
|
306
319
|
const paramList = new List( 'Property', 'Value' );
|
|
307
320
|
paramList.domElement.classList.add( 'parameters' );
|
|
@@ -315,6 +328,8 @@ class Parameters extends Tab {
|
|
|
315
328
|
|
|
316
329
|
this.paramList = paramList;
|
|
317
330
|
|
|
331
|
+
this.groups = [];
|
|
332
|
+
|
|
318
333
|
}
|
|
319
334
|
|
|
320
335
|
createGroup( name ) {
|
|
@@ -322,6 +337,7 @@ class Parameters extends Tab {
|
|
|
322
337
|
const group = new ParametersGroup( this, name );
|
|
323
338
|
|
|
324
339
|
this.paramList.add( group.paramList );
|
|
340
|
+
this.groups.push( group );
|
|
325
341
|
|
|
326
342
|
return group;
|
|
327
343
|
|
|
@@ -6,9 +6,9 @@ import { createValueSpan, setText } from '../ui/utils.js';
|
|
|
6
6
|
|
|
7
7
|
class Performance extends Tab {
|
|
8
8
|
|
|
9
|
-
constructor() {
|
|
9
|
+
constructor( options = {} ) {
|
|
10
10
|
|
|
11
|
-
super( 'Performance' );
|
|
11
|
+
super( 'Performance', options );
|
|
12
12
|
|
|
13
13
|
const perfList = new List( 'Name', 'CPU', 'GPU', 'Total' );
|
|
14
14
|
perfList.setGridStyle( 'minmax(200px, 2fr) 80px 80px 80px' );
|
|
@@ -6,13 +6,13 @@ import { RendererUtils, NoToneMapping, LinearSRGBColorSpace } from 'three/webgpu
|
|
|
6
6
|
|
|
7
7
|
class Viewer extends Tab {
|
|
8
8
|
|
|
9
|
-
constructor() {
|
|
9
|
+
constructor( options = {} ) {
|
|
10
10
|
|
|
11
|
-
super( 'Viewer' );
|
|
11
|
+
super( 'Viewer', options );
|
|
12
12
|
|
|
13
13
|
const nodeList = new List( 'Viewer', 'Name' );
|
|
14
14
|
nodeList.setGridStyle( '150px minmax(200px, 2fr)' );
|
|
15
|
-
nodeList.domElement.style.minWidth = '
|
|
15
|
+
nodeList.domElement.style.minWidth = '400px';
|
|
16
16
|
|
|
17
17
|
const scrollWrapper = document.createElement( 'div' );
|
|
18
18
|
scrollWrapper.className = 'list-scroll-wrapper';
|
|
@@ -70,7 +70,7 @@ class Viewer extends Tab {
|
|
|
70
70
|
|
|
71
71
|
update( renderer, canvasDataList ) {
|
|
72
72
|
|
|
73
|
-
if ( ! this.isActive ) return;
|
|
73
|
+
if ( ! this.isActive && ! this.isDetached ) return;
|
|
74
74
|
|
|
75
75
|
//
|
|
76
76
|
|