@plastic-software/three 0.179.0 → 0.181.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (430) hide show
  1. package/build/three.cjs +1108 -591
  2. package/build/three.core.js +616 -345
  3. package/build/three.core.min.js +1 -1
  4. package/build/three.module.js +488 -250
  5. package/build/three.module.min.js +1 -1
  6. package/build/three.tsl.js +37 -6
  7. package/build/three.tsl.min.js +1 -1
  8. package/build/three.webgpu.js +6576 -2152
  9. package/build/three.webgpu.min.js +1 -1
  10. package/build/three.webgpu.nodes.js +6575 -2151
  11. package/build/three.webgpu.nodes.min.js +1 -1
  12. package/examples/fonts/MPLUSRounded1c/MPLUSRounded1c-Regular.typeface.json.zip +0 -0
  13. package/examples/fonts/MPLUSRounded1c/OFL.txt +91 -0
  14. package/examples/jsm/Addons.js +1 -1
  15. package/examples/jsm/animation/CCDIKSolver.js +1 -1
  16. package/examples/jsm/controls/ArcballControls.js +8 -8
  17. package/examples/jsm/controls/DragControls.js +7 -57
  18. package/examples/jsm/controls/FirstPersonControls.js +3 -3
  19. package/examples/jsm/controls/FlyControls.js +1 -1
  20. package/examples/jsm/controls/OrbitControls.js +2 -2
  21. package/examples/jsm/controls/PointerLockControls.js +2 -10
  22. package/examples/jsm/controls/TrackballControls.js +1 -1
  23. package/examples/jsm/controls/TransformControls.js +1 -1
  24. package/examples/jsm/effects/AsciiEffect.js +8 -8
  25. package/examples/jsm/exporters/DRACOExporter.js +2 -2
  26. package/examples/jsm/exporters/EXRExporter.js +1 -1
  27. package/examples/jsm/exporters/GLTFExporter.js +33 -25
  28. package/examples/jsm/exporters/KTX2Exporter.js +4 -2
  29. package/examples/jsm/exporters/PLYExporter.js +1 -1
  30. package/examples/jsm/exporters/USDZExporter.js +9 -2
  31. package/examples/jsm/geometries/DecalGeometry.js +2 -2
  32. package/examples/jsm/geometries/ParametricGeometry.js +1 -1
  33. package/examples/jsm/geometries/TeapotGeometry.js +2 -2
  34. package/examples/jsm/geometries/TextGeometry.js +3 -2
  35. package/examples/jsm/gpgpu/BitonicSort.js +715 -0
  36. package/examples/jsm/helpers/ViewHelper.js +43 -5
  37. package/examples/jsm/inspector/Inspector.js +427 -0
  38. package/examples/jsm/inspector/RendererInspector.js +415 -0
  39. package/examples/jsm/inspector/tabs/Console.js +204 -0
  40. package/examples/jsm/inspector/tabs/Parameters.js +332 -0
  41. package/examples/jsm/inspector/tabs/Performance.js +268 -0
  42. package/examples/jsm/inspector/tabs/Viewer.js +166 -0
  43. package/examples/jsm/inspector/ui/Graph.js +95 -0
  44. package/examples/jsm/inspector/ui/Item.js +170 -0
  45. package/examples/jsm/inspector/ui/List.js +75 -0
  46. package/examples/jsm/inspector/ui/Profiler.js +170 -0
  47. package/examples/jsm/inspector/ui/Style.js +654 -0
  48. package/examples/jsm/inspector/ui/Tab.js +46 -0
  49. package/examples/jsm/inspector/ui/Values.js +423 -0
  50. package/examples/jsm/inspector/ui/utils.js +56 -0
  51. package/examples/jsm/interactive/HTMLMesh.js +6 -10
  52. package/examples/jsm/interactive/InteractiveGroup.js +1 -1
  53. package/examples/jsm/interactive/SelectionBox.js +30 -0
  54. package/examples/jsm/libs/ktx-parse.module.js +1 -1
  55. package/examples/jsm/lights/RectAreaLightTexturesLib.js +1 -1
  56. package/examples/jsm/lines/Line2.js +3 -3
  57. package/examples/jsm/lines/LineGeometry.js +1 -1
  58. package/examples/jsm/lines/LineSegments2.js +2 -2
  59. package/examples/jsm/lines/Wireframe.js +2 -2
  60. package/examples/jsm/lines/WireframeGeometry2.js +1 -1
  61. package/examples/jsm/lines/webgpu/LineSegments2.js +1 -1
  62. package/examples/jsm/lines/webgpu/Wireframe.js +1 -1
  63. package/examples/jsm/loaders/3MFLoader.js +1 -1
  64. package/examples/jsm/loaders/ColladaLoader.js +3 -3
  65. package/examples/jsm/loaders/DDSLoader.js +1 -1
  66. package/examples/jsm/loaders/DRACOLoader.js +73 -22
  67. package/examples/jsm/loaders/EXRLoader.js +5 -5
  68. package/examples/jsm/loaders/FBXLoader.js +2 -2
  69. package/examples/jsm/loaders/FontLoader.js +23 -5
  70. package/examples/jsm/loaders/GLTFLoader.js +14 -8
  71. package/examples/jsm/loaders/HDRCubeTextureLoader.js +5 -5
  72. package/examples/jsm/loaders/HDRLoader.js +486 -0
  73. package/examples/jsm/loaders/KTX2Loader.js +136 -49
  74. package/examples/jsm/loaders/KTXLoader.js +2 -2
  75. package/examples/jsm/loaders/LDrawLoader.js +1 -1
  76. package/examples/jsm/loaders/LUT3dlLoader.js +2 -2
  77. package/examples/jsm/loaders/LUTCubeLoader.js +1 -1
  78. package/examples/jsm/loaders/LWOLoader.js +2 -2
  79. package/examples/jsm/loaders/MaterialXLoader.js +22 -5
  80. package/examples/jsm/loaders/OBJLoader.js +1 -1
  81. package/examples/jsm/loaders/PDBLoader.js +1 -1
  82. package/examples/jsm/loaders/RGBELoader.js +7 -473
  83. package/examples/jsm/loaders/SVGLoader.js +2 -2
  84. package/examples/jsm/loaders/TTFLoader.js +4 -4
  85. package/examples/jsm/loaders/UltraHDRLoader.js +2 -2
  86. package/examples/jsm/loaders/lwo/IFFParser.js +1 -1
  87. package/examples/jsm/materials/WoodNodeMaterial.js +533 -0
  88. package/examples/jsm/math/ColorSpaces.js +19 -1
  89. package/examples/jsm/math/ConvexHull.js +3 -3
  90. package/examples/jsm/math/ImprovedNoise.js +1 -1
  91. package/examples/jsm/math/Lut.js +2 -2
  92. package/examples/jsm/math/SimplexNoise.js +1 -1
  93. package/examples/jsm/misc/MD2CharacterComplex.js +1 -1
  94. package/examples/jsm/misc/ProgressiveLightMap.js +9 -3
  95. package/examples/jsm/misc/ProgressiveLightMapGPU.js +7 -1
  96. package/examples/jsm/misc/TubePainter.js +383 -40
  97. package/examples/jsm/misc/Volume.js +1 -1
  98. package/examples/jsm/modifiers/SimplifyModifier.js +1 -1
  99. package/examples/jsm/objects/ReflectorForSSRPass.js +1 -0
  100. package/examples/jsm/objects/Sky.js +1 -1
  101. package/examples/jsm/objects/SkyMesh.js +1 -1
  102. package/examples/jsm/objects/Water.js +3 -3
  103. package/examples/jsm/objects/WaterMesh.js +6 -6
  104. package/examples/jsm/postprocessing/GlitchPass.js +2 -2
  105. package/examples/jsm/postprocessing/OutlinePass.js +1 -1
  106. package/examples/jsm/postprocessing/SSRPass.js +37 -8
  107. package/examples/jsm/postprocessing/UnrealBloomPass.js +8 -6
  108. package/examples/jsm/renderers/CSS2DRenderer.js +16 -5
  109. package/examples/jsm/renderers/CSS3DRenderer.js +7 -6
  110. package/examples/jsm/renderers/SVGRenderer.js +1 -1
  111. package/examples/jsm/shaders/ACESFilmicToneMappingShader.js +1 -1
  112. package/examples/jsm/shaders/AfterimageShader.js +1 -1
  113. package/examples/jsm/shaders/BleachBypassShader.js +1 -1
  114. package/examples/jsm/shaders/BokehShader.js +1 -1
  115. package/examples/jsm/shaders/BokehShader2.js +1 -1
  116. package/examples/jsm/shaders/DotScreenShader.js +1 -1
  117. package/examples/jsm/shaders/FocusShader.js +1 -1
  118. package/examples/jsm/shaders/GTAOShader.js +2 -2
  119. package/examples/jsm/shaders/GodRaysShader.js +1 -1
  120. package/examples/jsm/shaders/KaleidoShader.js +1 -1
  121. package/examples/jsm/shaders/PoissonDenoiseShader.js +2 -2
  122. package/examples/jsm/shaders/SSRShader.js +1 -1
  123. package/examples/jsm/shaders/SepiaShader.js +1 -1
  124. package/examples/jsm/shaders/SubsurfaceScatteringShader.js +1 -1
  125. package/examples/jsm/shaders/TriangleBlurShader.js +1 -1
  126. package/examples/jsm/shaders/UnpackDepthRGBAShader.js +1 -1
  127. package/examples/jsm/shaders/VignetteShader.js +1 -1
  128. package/examples/jsm/transpiler/GLSLDecoder.js +22 -19
  129. package/examples/jsm/transpiler/TSLEncoder.js +9 -10
  130. package/examples/jsm/transpiler/WGSLEncoder.js +24 -0
  131. package/examples/jsm/tsl/display/AfterImageNode.js +26 -24
  132. package/examples/jsm/tsl/display/AnamorphicNode.js +28 -4
  133. package/examples/jsm/tsl/display/BloomNode.js +7 -3
  134. package/examples/jsm/tsl/display/ChromaticAberrationNode.js +2 -1
  135. package/examples/jsm/tsl/display/DenoiseNode.js +2 -0
  136. package/examples/jsm/tsl/display/DepthOfFieldNode.js +446 -90
  137. package/examples/jsm/tsl/display/GTAONode.js +53 -5
  138. package/examples/jsm/tsl/display/GaussianBlurNode.js +49 -35
  139. package/examples/jsm/tsl/display/OutlineNode.js +13 -2
  140. package/examples/jsm/tsl/display/SSGINode.js +654 -0
  141. package/examples/jsm/tsl/display/SSRNode.js +182 -65
  142. package/examples/jsm/tsl/display/SSSNode.js +488 -0
  143. package/examples/jsm/tsl/display/TRAANode.js +124 -7
  144. package/examples/jsm/tsl/display/boxBlur.js +65 -0
  145. package/examples/jsm/tsl/display/hashBlur.js +16 -18
  146. package/examples/jsm/tsl/lighting/TiledLightsNode.js +21 -1
  147. package/examples/jsm/utils/BufferGeometryUtils.js +1 -1
  148. package/examples/jsm/utils/ShadowMapViewerGPU.js +12 -5
  149. package/examples/jsm/webxr/OculusHandModel.js +1 -1
  150. package/examples/jsm/webxr/XRControllerModelFactory.js +1 -1
  151. package/examples/jsm/webxr/XRHandModelFactory.js +2 -6
  152. package/package.json +5 -10
  153. package/src/Three.Core.js +4 -2
  154. package/src/Three.TSL.js +36 -5
  155. package/src/Three.WebGPU.Nodes.js +2 -0
  156. package/src/Three.WebGPU.js +2 -0
  157. package/src/animation/AnimationClip.js +20 -4
  158. package/src/animation/AnimationMixer.js +3 -3
  159. package/src/animation/AnimationObjectGroup.js +2 -1
  160. package/src/animation/KeyframeTrack.js +7 -6
  161. package/src/animation/PropertyBinding.js +12 -11
  162. package/src/audio/Audio.js +10 -9
  163. package/src/audio/PositionalAudio.js +1 -1
  164. package/src/cameras/OrthographicCamera.js +1 -1
  165. package/src/cameras/PerspectiveCamera.js +1 -1
  166. package/src/cameras/StereoCamera.js +2 -2
  167. package/src/constants.js +11 -3
  168. package/src/core/BufferGeometry.js +10 -10
  169. package/src/core/EventDispatcher.js +1 -1
  170. package/src/core/InterleavedBuffer.js +1 -1
  171. package/src/core/InterleavedBufferAttribute.js +3 -2
  172. package/src/core/Object3D.js +3 -2
  173. package/src/core/Raycaster.js +2 -1
  174. package/src/core/RenderTarget.js +10 -1
  175. package/src/extras/Controls.js +5 -4
  176. package/src/extras/DataUtils.js +2 -1
  177. package/src/extras/Earcut.js +6 -0
  178. package/src/extras/ImageUtils.js +2 -2
  179. package/src/extras/PMREMGenerator.js +268 -55
  180. package/src/extras/TextureUtils.js +2 -1
  181. package/src/extras/core/Curve.js +2 -1
  182. package/src/extras/core/Interpolations.js +7 -1
  183. package/src/extras/core/ShapePath.js +4 -4
  184. package/src/extras/lib/earcut.js +8 -8
  185. package/src/geometries/BoxGeometry.js +1 -0
  186. package/src/geometries/CapsuleGeometry.js +1 -0
  187. package/src/geometries/CircleGeometry.js +1 -0
  188. package/src/geometries/ConeGeometry.js +1 -0
  189. package/src/geometries/CylinderGeometry.js +1 -0
  190. package/src/geometries/DodecahedronGeometry.js +1 -0
  191. package/src/geometries/ExtrudeGeometry.js +8 -6
  192. package/src/geometries/IcosahedronGeometry.js +1 -0
  193. package/src/geometries/LatheGeometry.js +1 -0
  194. package/src/geometries/OctahedronGeometry.js +1 -0
  195. package/src/geometries/PlaneGeometry.js +1 -0
  196. package/src/geometries/RingGeometry.js +1 -0
  197. package/src/geometries/ShapeGeometry.js +1 -0
  198. package/src/geometries/SphereGeometry.js +1 -0
  199. package/src/geometries/TetrahedronGeometry.js +1 -0
  200. package/src/geometries/TorusGeometry.js +1 -0
  201. package/src/geometries/TorusKnotGeometry.js +1 -0
  202. package/src/geometries/TubeGeometry.js +1 -0
  203. package/src/helpers/CameraHelper.js +1 -1
  204. package/src/lights/webgpu/ProjectorLight.js +1 -1
  205. package/src/loaders/AnimationLoader.js +2 -1
  206. package/src/loaders/AudioLoader.js +2 -1
  207. package/src/loaders/BufferGeometryLoader.js +2 -2
  208. package/src/loaders/Cache.js +2 -2
  209. package/src/loaders/DataTextureLoader.js +1 -1
  210. package/src/loaders/FileLoader.js +3 -2
  211. package/src/loaders/ImageBitmapLoader.js +5 -4
  212. package/src/loaders/ImageLoader.js +1 -1
  213. package/src/loaders/Loader.js +3 -3
  214. package/src/loaders/LoadingManager.js +25 -3
  215. package/src/loaders/MaterialLoader.js +3 -2
  216. package/src/loaders/ObjectLoader.js +13 -13
  217. package/src/loaders/TextureLoader.js +1 -1
  218. package/src/loaders/nodes/NodeLoader.js +3 -2
  219. package/src/materials/Material.js +16 -3
  220. package/src/materials/MeshBasicMaterial.js +1 -0
  221. package/src/materials/MeshDepthMaterial.js +1 -0
  222. package/src/materials/MeshDistanceMaterial.js +1 -1
  223. package/src/materials/MeshLambertMaterial.js +2 -1
  224. package/src/materials/MeshMatcapMaterial.js +22 -0
  225. package/src/materials/MeshNormalMaterial.js +1 -0
  226. package/src/materials/MeshPhongMaterial.js +2 -1
  227. package/src/materials/MeshPhysicalMaterial.js +2 -1
  228. package/src/materials/MeshStandardMaterial.js +8 -7
  229. package/src/materials/MeshToonMaterial.js +1 -0
  230. package/src/materials/PointsMaterial.js +1 -1
  231. package/src/materials/ShaderMaterial.js +2 -2
  232. package/src/materials/nodes/Line2NodeMaterial.js +2 -2
  233. package/src/materials/nodes/MeshSSSNodeMaterial.js +1 -1
  234. package/src/materials/nodes/NodeMaterial.js +62 -22
  235. package/src/materials/nodes/PointsNodeMaterial.js +81 -28
  236. package/src/materials/nodes/SpriteNodeMaterial.js +3 -15
  237. package/src/materials/nodes/manager/NodeMaterialObserver.js +3 -2
  238. package/src/math/Color.js +6 -5
  239. package/src/math/ColorManagement.js +9 -3
  240. package/src/math/Cylindrical.js +1 -1
  241. package/src/math/Euler.js +2 -1
  242. package/src/math/MathUtils.js +13 -11
  243. package/src/math/Matrix2.js +1 -1
  244. package/src/math/Matrix3.js +2 -2
  245. package/src/math/Matrix4.js +7 -7
  246. package/src/math/Plane.js +1 -1
  247. package/src/math/Quaternion.js +68 -66
  248. package/src/math/Spherical.js +1 -1
  249. package/src/nodes/Nodes.js +4 -1
  250. package/src/nodes/TSL.js +4 -1
  251. package/src/nodes/accessors/BufferNode.js +1 -1
  252. package/src/nodes/accessors/Camera.js +133 -7
  253. package/src/nodes/accessors/ClippingNode.js +6 -5
  254. package/src/nodes/accessors/CubeTextureNode.js +5 -4
  255. package/src/nodes/accessors/InstanceNode.js +25 -5
  256. package/src/nodes/accessors/Lights.js +10 -0
  257. package/src/nodes/accessors/Normal.js +5 -4
  258. package/src/nodes/accessors/Object3DNode.js +1 -1
  259. package/src/nodes/accessors/Position.js +18 -2
  260. package/src/nodes/accessors/ReferenceBaseNode.js +1 -1
  261. package/src/nodes/accessors/ReferenceNode.js +3 -2
  262. package/src/nodes/accessors/SceneNode.js +2 -1
  263. package/src/nodes/accessors/StorageBufferNode.js +2 -1
  264. package/src/nodes/accessors/StorageTextureNode.js +22 -0
  265. package/src/nodes/accessors/Texture3DNode.js +14 -1
  266. package/src/nodes/accessors/TextureNode.js +130 -44
  267. package/src/nodes/code/FunctionCallNode.js +24 -4
  268. package/src/nodes/code/FunctionNode.js +23 -0
  269. package/src/nodes/core/ArrayNode.js +1 -0
  270. package/src/nodes/core/AssignNode.js +4 -3
  271. package/src/nodes/core/AttributeNode.js +2 -1
  272. package/src/nodes/core/ContextNode.js +29 -10
  273. package/src/nodes/core/IndexNode.js +2 -2
  274. package/src/nodes/core/InputNode.js +2 -1
  275. package/src/nodes/core/InspectorNode.js +128 -0
  276. package/src/nodes/core/{CacheNode.js → IsolateNode.js} +40 -7
  277. package/src/nodes/core/Node.js +152 -31
  278. package/src/nodes/core/NodeBuilder.js +183 -35
  279. package/src/nodes/core/NodeFrame.js +21 -21
  280. package/src/nodes/core/NodeFunction.js +2 -1
  281. package/src/nodes/core/NodeParser.js +2 -1
  282. package/src/nodes/core/NodeUniform.js +1 -1
  283. package/src/nodes/core/NodeUtils.js +17 -91
  284. package/src/nodes/core/ParameterNode.js +31 -0
  285. package/src/nodes/core/PropertyNode.js +7 -0
  286. package/src/nodes/core/StackNode.js +43 -16
  287. package/src/nodes/core/StructNode.js +5 -5
  288. package/src/nodes/core/StructTypeNode.js +1 -0
  289. package/src/nodes/core/SubBuildNode.js +2 -2
  290. package/src/nodes/core/UniformNode.js +18 -10
  291. package/src/nodes/core/VarNode.js +70 -33
  292. package/src/nodes/core/VaryingNode.js +3 -2
  293. package/src/nodes/display/BlendModes.js +5 -4
  294. package/src/nodes/display/BumpMapNode.js +1 -1
  295. package/src/nodes/display/ColorAdjustment.js +1 -1
  296. package/src/nodes/display/FrontFacingNode.js +4 -8
  297. package/src/nodes/display/NormalMapNode.js +2 -1
  298. package/src/nodes/display/PassNode.js +52 -11
  299. package/src/nodes/display/RenderOutputNode.js +28 -2
  300. package/src/nodes/display/ScreenNode.js +44 -14
  301. package/src/nodes/display/ToneMappingNode.js +31 -4
  302. package/src/nodes/display/ToonOutlinePassNode.js +8 -0
  303. package/src/nodes/display/ViewportDepthTextureNode.js +16 -4
  304. package/src/nodes/display/ViewportSharedTextureNode.js +12 -0
  305. package/src/nodes/display/ViewportTextureNode.js +42 -12
  306. package/src/nodes/fog/Fog.js +3 -2
  307. package/src/nodes/functions/BSDF/BRDF_GGX_Multiscatter.js +52 -0
  308. package/src/nodes/functions/BSDF/DFGApprox.js +60 -19
  309. package/src/nodes/functions/BasicLightingModel.js +2 -1
  310. package/src/nodes/functions/PhysicalLightingModel.js +3 -2
  311. package/src/nodes/functions/VolumetricLightingModel.js +5 -5
  312. package/src/nodes/geometry/RangeNode.js +40 -4
  313. package/src/nodes/gpgpu/ComputeBuiltinNode.js +2 -1
  314. package/src/nodes/gpgpu/ComputeNode.js +17 -5
  315. package/src/nodes/gpgpu/SubgroupFunctionNode.js +455 -0
  316. package/src/nodes/gpgpu/WorkgroupInfoNode.js +2 -1
  317. package/src/nodes/lighting/EnvironmentNode.js +6 -6
  318. package/src/nodes/lighting/LightsNode.js +3 -4
  319. package/src/nodes/lighting/PointShadowNode.js +6 -0
  320. package/src/nodes/lighting/ShadowFilterNode.js +2 -0
  321. package/src/nodes/lighting/ShadowNode.js +75 -8
  322. package/src/nodes/math/BitcastNode.js +156 -0
  323. package/src/nodes/math/ConditionalNode.js +24 -7
  324. package/src/nodes/math/MathNode.js +25 -19
  325. package/src/nodes/math/OperatorNode.js +7 -5
  326. package/src/nodes/pmrem/PMREMUtils.js +117 -2
  327. package/src/nodes/shapes/Shapes.js +1 -1
  328. package/src/nodes/tsl/TSLBase.js +5 -2
  329. package/src/nodes/tsl/TSLCore.js +460 -159
  330. package/src/nodes/utils/DebugNode.js +2 -1
  331. package/src/nodes/utils/EventNode.js +36 -0
  332. package/src/nodes/utils/FunctionOverloadingNode.js +37 -19
  333. package/src/nodes/utils/JoinNode.js +6 -3
  334. package/src/nodes/utils/LoopNode.js +20 -24
  335. package/src/nodes/utils/MemberNode.js +59 -7
  336. package/src/nodes/utils/PostProcessingUtils.js +28 -1
  337. package/src/nodes/utils/RTTNode.js +13 -3
  338. package/src/nodes/utils/ReflectorNode.js +58 -7
  339. package/src/nodes/utils/SampleNode.js +12 -2
  340. package/src/nodes/utils/SplitNode.js +11 -0
  341. package/src/nodes/utils/Timer.js +0 -47
  342. package/src/objects/BatchedMesh.js +2 -2
  343. package/src/objects/LOD.js +1 -1
  344. package/src/objects/Line.js +2 -1
  345. package/src/objects/LineSegments.js +2 -1
  346. package/src/objects/Skeleton.js +3 -2
  347. package/src/objects/SkinnedMesh.js +3 -1
  348. package/src/objects/Sprite.js +4 -3
  349. package/src/renderers/WebGLRenderer.js +48 -41
  350. package/src/renderers/common/Animation.js +13 -1
  351. package/src/renderers/common/Attributes.js +1 -1
  352. package/src/renderers/common/Backend.js +108 -27
  353. package/src/renderers/common/Background.js +2 -1
  354. package/src/renderers/common/Bindings.js +58 -2
  355. package/src/renderers/common/CanvasTarget.js +341 -0
  356. package/src/renderers/common/ChainMap.js +1 -1
  357. package/src/renderers/common/DataMap.js +1 -1
  358. package/src/renderers/common/Geometries.js +26 -0
  359. package/src/renderers/common/Info.js +4 -2
  360. package/src/renderers/common/InspectorBase.js +146 -0
  361. package/src/renderers/common/Pipelines.js +1 -1
  362. package/src/renderers/common/PostProcessing.js +6 -25
  363. package/src/renderers/common/QuadMesh.js +7 -1
  364. package/src/renderers/common/RenderContext.js +2 -2
  365. package/src/renderers/common/RenderList.js +7 -3
  366. package/src/renderers/common/RenderObject.js +16 -2
  367. package/src/renderers/common/RenderObjects.js +1 -1
  368. package/src/renderers/common/Renderer.js +473 -245
  369. package/src/renderers/common/RendererUtils.js +9 -0
  370. package/src/renderers/common/SampledTexture.js +9 -1
  371. package/src/renderers/common/Sampler.js +50 -12
  372. package/src/renderers/common/StorageTexture.js +9 -1
  373. package/src/renderers/common/Textures.js +121 -45
  374. package/src/renderers/common/TimestampQueryPool.js +65 -3
  375. package/src/renderers/common/UniformsGroup.js +2 -1
  376. package/src/renderers/common/XRManager.js +42 -22
  377. package/src/renderers/common/extras/PMREMGenerator.js +160 -65
  378. package/src/renderers/common/nodes/NodeBuilderState.js +1 -1
  379. package/src/renderers/common/nodes/NodeLibrary.js +9 -7
  380. package/src/renderers/common/nodes/NodeSampler.js +13 -1
  381. package/src/renderers/common/nodes/Nodes.js +38 -16
  382. package/src/renderers/shaders/DFGLUTData.js +64 -0
  383. package/src/renderers/shaders/ShaderChunk/common.glsl.js +0 -12
  384. package/src/renderers/shaders/ShaderChunk/envmap_common_pars_fragment.glsl.js +1 -1
  385. package/src/renderers/shaders/ShaderChunk/envmap_physical_pars_fragment.glsl.js +1 -1
  386. package/src/renderers/shaders/ShaderChunk/lights_physical_pars_fragment.glsl.js +52 -18
  387. package/src/renderers/shaders/ShaderChunk/logdepthbuf_fragment.glsl.js +1 -1
  388. package/src/renderers/shaders/ShaderChunk/logdepthbuf_pars_fragment.glsl.js +1 -1
  389. package/src/renderers/shaders/ShaderChunk/logdepthbuf_pars_vertex.glsl.js +1 -1
  390. package/src/renderers/shaders/ShaderChunk/logdepthbuf_vertex.glsl.js +1 -1
  391. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_fragment.glsl.js +7 -15
  392. package/src/renderers/shaders/ShaderLib/depth.glsl.js +1 -1
  393. package/src/renderers/shaders/UniformsLib.js +1 -0
  394. package/src/renderers/shaders/UniformsUtils.js +25 -4
  395. package/src/renderers/webgl/WebGLCapabilities.js +2 -1
  396. package/src/renderers/webgl/WebGLExtensions.js +2 -25
  397. package/src/renderers/webgl/WebGLInfo.js +3 -1
  398. package/src/renderers/webgl/WebGLProgram.js +15 -14
  399. package/src/renderers/webgl/WebGLPrograms.js +2 -1
  400. package/src/renderers/webgl/WebGLShadowMap.js +3 -2
  401. package/src/renderers/webgl/WebGLState.js +15 -14
  402. package/src/renderers/webgl/WebGLTextures.js +19 -14
  403. package/src/renderers/webgl/WebGLUniformsGroups.js +5 -3
  404. package/src/renderers/webgl/WebGLUtils.js +3 -2
  405. package/src/renderers/webgl-fallback/WebGLBackend.js +199 -167
  406. package/src/renderers/webgl-fallback/nodes/GLSLNodeBuilder.js +181 -25
  407. package/src/renderers/webgl-fallback/utils/WebGLConstants.js +2 -3
  408. package/src/renderers/webgl-fallback/utils/WebGLState.js +7 -6
  409. package/src/renderers/webgl-fallback/utils/WebGLTextureUtils.js +169 -19
  410. package/src/renderers/webgl-fallback/utils/WebGLTimestampQueryPool.js +51 -22
  411. package/src/renderers/webgl-fallback/utils/WebGLUtils.js +3 -2
  412. package/src/renderers/webgpu/WebGPUBackend.js +153 -123
  413. package/src/renderers/webgpu/WebGPURenderer.Nodes.js +2 -1
  414. package/src/renderers/webgpu/WebGPURenderer.js +3 -2
  415. package/src/renderers/webgpu/nodes/WGSLNodeBuilder.js +142 -50
  416. package/src/renderers/webgpu/utils/WebGPUAttributeUtils.js +2 -1
  417. package/src/renderers/webgpu/utils/WebGPUBindingUtils.js +5 -3
  418. package/src/renderers/webgpu/utils/WebGPUConstants.js +7 -2
  419. package/src/renderers/webgpu/utils/WebGPUPipelineUtils.js +53 -34
  420. package/src/renderers/webgpu/utils/WebGPUTexturePassUtils.js +6 -8
  421. package/src/renderers/webgpu/utils/WebGPUTextureUtils.js +260 -99
  422. package/src/renderers/webgpu/utils/WebGPUTimestampQueryPool.js +32 -9
  423. package/src/renderers/webgpu/utils/WebGPUUtils.js +22 -2
  424. package/src/renderers/webxr/WebXRManager.js +42 -26
  425. package/src/textures/ExternalTexture.js +15 -4
  426. package/src/textures/Source.js +3 -2
  427. package/src/textures/Texture.js +3 -2
  428. package/src/textures/VideoTexture.js +2 -3
  429. package/src/utils.js +67 -3
  430. package/examples/jsm/loaders/RGBMLoader.js +0 -1148
@@ -0,0 +1,486 @@
1
+ import {
2
+ DataTextureLoader,
3
+ DataUtils,
4
+ FloatType,
5
+ HalfFloatType,
6
+ LinearFilter,
7
+ LinearSRGBColorSpace
8
+ } from 'three';
9
+
10
+ /**
11
+ * A loader for the RGBE HDR texture format.
12
+ *
13
+ * ```js
14
+ * const loader = new HDRLoader();
15
+ * const envMap = await loader.loadAsync( 'textures/equirectangular/blouberg_sunrise_2_1k.hdr' );
16
+ * envMap.mapping = THREE.EquirectangularReflectionMapping;
17
+ *
18
+ * scene.environment = envMap;
19
+ * ```
20
+ *
21
+ * @augments DataTextureLoader
22
+ * @three_import import { HDRLoader } from 'three/addons/loaders/HDRLoader.js';
23
+ */
24
+ class HDRLoader extends DataTextureLoader {
25
+
26
+ /**
27
+ * Constructs a new RGBE/HDR loader.
28
+ *
29
+ * @param {LoadingManager} [manager] - The loading manager.
30
+ */
31
+ constructor( manager ) {
32
+
33
+ super( manager );
34
+
35
+ /**
36
+ * The texture type.
37
+ *
38
+ * @type {(HalfFloatType|FloatType)}
39
+ * @default HalfFloatType
40
+ */
41
+ this.type = HalfFloatType;
42
+
43
+ }
44
+
45
+ /**
46
+ * Parses the given RGBE texture data.
47
+ *
48
+ * @param {ArrayBuffer} buffer - The raw texture data.
49
+ * @return {DataTextureLoader~TexData} An object representing the parsed texture data.
50
+ */
51
+ parse( buffer ) {
52
+
53
+ // adapted from http://www.graphics.cornell.edu/~bjw/rgbe.html
54
+
55
+ const
56
+ /* default error routine. change this to change error handling */
57
+ rgbe_read_error = 1,
58
+ rgbe_write_error = 2,
59
+ rgbe_format_error = 3,
60
+ rgbe_memory_error = 4,
61
+ rgbe_error = function ( rgbe_error_code, msg ) {
62
+
63
+ switch ( rgbe_error_code ) {
64
+
65
+ case rgbe_read_error: throw new Error( 'THREE.HDRLoader: Read Error: ' + ( msg || '' ) );
66
+ case rgbe_write_error: throw new Error( 'THREE.HDRLoader: Write Error: ' + ( msg || '' ) );
67
+ case rgbe_format_error: throw new Error( 'THREE.HDRLoader: Bad File Format: ' + ( msg || '' ) );
68
+ default:
69
+ case rgbe_memory_error: throw new Error( 'THREE.HDRLoader: Memory Error: ' + ( msg || '' ) );
70
+
71
+ }
72
+
73
+ },
74
+
75
+ /* offsets to red, green, and blue components in a data (float) pixel */
76
+ //RGBE_DATA_RED = 0,
77
+ //RGBE_DATA_GREEN = 1,
78
+ //RGBE_DATA_BLUE = 2,
79
+
80
+ /* number of floats per pixel, use 4 since stored in rgba image format */
81
+ //RGBE_DATA_SIZE = 4,
82
+
83
+ /* flags indicating which fields in an rgbe_header_info are valid */
84
+ RGBE_VALID_PROGRAMTYPE = 1,
85
+ RGBE_VALID_FORMAT = 2,
86
+ RGBE_VALID_DIMENSIONS = 4,
87
+
88
+ NEWLINE = '\n',
89
+
90
+ fgets = function ( buffer, lineLimit, consume ) {
91
+
92
+ const chunkSize = 128;
93
+
94
+ lineLimit = ! lineLimit ? 1024 : lineLimit;
95
+ let p = buffer.pos,
96
+ i = - 1, len = 0, s = '',
97
+ chunk = String.fromCharCode.apply( null, new Uint16Array( buffer.subarray( p, p + chunkSize ) ) );
98
+
99
+ while ( ( 0 > ( i = chunk.indexOf( NEWLINE ) ) ) && ( len < lineLimit ) && ( p < buffer.byteLength ) ) {
100
+
101
+ s += chunk; len += chunk.length;
102
+ p += chunkSize;
103
+ chunk += String.fromCharCode.apply( null, new Uint16Array( buffer.subarray( p, p + chunkSize ) ) );
104
+
105
+ }
106
+
107
+ if ( - 1 < i ) {
108
+
109
+ /*for (i=l-1; i>=0; i--) {
110
+ byteCode = m.charCodeAt(i);
111
+ if (byteCode > 0x7f && byteCode <= 0x7ff) byteLen++;
112
+ else if (byteCode > 0x7ff && byteCode <= 0xffff) byteLen += 2;
113
+ if (byteCode >= 0xDC00 && byteCode <= 0xDFFF) i--; //trail surrogate
114
+ }*/
115
+ if ( false !== consume ) buffer.pos += len + i + 1;
116
+ return s + chunk.slice( 0, i );
117
+
118
+ }
119
+
120
+ return false;
121
+
122
+ },
123
+
124
+ /* minimal header reading. modify if you want to parse more information */
125
+ RGBE_ReadHeader = function ( buffer ) {
126
+
127
+
128
+ // regexes to parse header info fields
129
+ const magic_token_re = /^#\?(\S+)/,
130
+ gamma_re = /^\s*GAMMA\s*=\s*(\d+(\.\d+)?)\s*$/,
131
+ exposure_re = /^\s*EXPOSURE\s*=\s*(\d+(\.\d+)?)\s*$/,
132
+ format_re = /^\s*FORMAT=(\S+)\s*$/,
133
+ dimensions_re = /^\s*\-Y\s+(\d+)\s+\+X\s+(\d+)\s*$/,
134
+
135
+ // RGBE format header struct
136
+ header = {
137
+
138
+ valid: 0, /* indicate which fields are valid */
139
+
140
+ string: '', /* the actual header string */
141
+
142
+ comments: '', /* comments found in header */
143
+
144
+ programtype: 'RGBE', /* listed at beginning of file to identify it after "#?". defaults to "RGBE" */
145
+
146
+ format: '', /* RGBE format, default 32-bit_rle_rgbe */
147
+
148
+ gamma: 1.0, /* image has already been gamma corrected with given gamma. defaults to 1.0 (no correction) */
149
+
150
+ exposure: 1.0, /* a value of 1.0 in an image corresponds to <exposure> watts/steradian/m^2. defaults to 1.0 */
151
+
152
+ width: 0, height: 0 /* image dimensions, width/height */
153
+
154
+ };
155
+
156
+ let line, match;
157
+
158
+ if ( buffer.pos >= buffer.byteLength || ! ( line = fgets( buffer ) ) ) {
159
+
160
+ rgbe_error( rgbe_read_error, 'no header found' );
161
+
162
+ }
163
+
164
+ /* if you want to require the magic token then uncomment the next line */
165
+ if ( ! ( match = line.match( magic_token_re ) ) ) {
166
+
167
+ rgbe_error( rgbe_format_error, 'bad initial token' );
168
+
169
+ }
170
+
171
+ header.valid |= RGBE_VALID_PROGRAMTYPE;
172
+ header.programtype = match[ 1 ];
173
+ header.string += line + '\n';
174
+
175
+ while ( true ) {
176
+
177
+ line = fgets( buffer );
178
+ if ( false === line ) break;
179
+ header.string += line + '\n';
180
+
181
+ if ( '#' === line.charAt( 0 ) ) {
182
+
183
+ header.comments += line + '\n';
184
+ continue; // comment line
185
+
186
+ }
187
+
188
+ if ( match = line.match( gamma_re ) ) {
189
+
190
+ header.gamma = parseFloat( match[ 1 ] );
191
+
192
+ }
193
+
194
+ if ( match = line.match( exposure_re ) ) {
195
+
196
+ header.exposure = parseFloat( match[ 1 ] );
197
+
198
+ }
199
+
200
+ if ( match = line.match( format_re ) ) {
201
+
202
+ header.valid |= RGBE_VALID_FORMAT;
203
+ header.format = match[ 1 ];//'32-bit_rle_rgbe';
204
+
205
+ }
206
+
207
+ if ( match = line.match( dimensions_re ) ) {
208
+
209
+ header.valid |= RGBE_VALID_DIMENSIONS;
210
+ header.height = parseInt( match[ 1 ], 10 );
211
+ header.width = parseInt( match[ 2 ], 10 );
212
+
213
+ }
214
+
215
+ if ( ( header.valid & RGBE_VALID_FORMAT ) && ( header.valid & RGBE_VALID_DIMENSIONS ) ) break;
216
+
217
+ }
218
+
219
+ if ( ! ( header.valid & RGBE_VALID_FORMAT ) ) {
220
+
221
+ rgbe_error( rgbe_format_error, 'missing format specifier' );
222
+
223
+ }
224
+
225
+ if ( ! ( header.valid & RGBE_VALID_DIMENSIONS ) ) {
226
+
227
+ rgbe_error( rgbe_format_error, 'missing image size specifier' );
228
+
229
+ }
230
+
231
+ return header;
232
+
233
+ },
234
+
235
+ RGBE_ReadPixels_RLE = function ( buffer, w, h ) {
236
+
237
+ const scanline_width = w;
238
+
239
+ if (
240
+ // run length encoding is not allowed so read flat
241
+ ( ( scanline_width < 8 ) || ( scanline_width > 0x7fff ) ) ||
242
+ // this file is not run length encoded
243
+ ( ( 2 !== buffer[ 0 ] ) || ( 2 !== buffer[ 1 ] ) || ( buffer[ 2 ] & 0x80 ) )
244
+ ) {
245
+
246
+ // return the flat buffer
247
+ return new Uint8Array( buffer );
248
+
249
+ }
250
+
251
+ if ( scanline_width !== ( ( buffer[ 2 ] << 8 ) | buffer[ 3 ] ) ) {
252
+
253
+ rgbe_error( rgbe_format_error, 'wrong scanline width' );
254
+
255
+ }
256
+
257
+ const data_rgba = new Uint8Array( 4 * w * h );
258
+
259
+ if ( ! data_rgba.length ) {
260
+
261
+ rgbe_error( rgbe_memory_error, 'unable to allocate buffer space' );
262
+
263
+ }
264
+
265
+ let offset = 0, pos = 0;
266
+
267
+ const ptr_end = 4 * scanline_width;
268
+ const rgbeStart = new Uint8Array( 4 );
269
+ const scanline_buffer = new Uint8Array( ptr_end );
270
+ let num_scanlines = h;
271
+
272
+ // read in each successive scanline
273
+ while ( ( num_scanlines > 0 ) && ( pos < buffer.byteLength ) ) {
274
+
275
+ if ( pos + 4 > buffer.byteLength ) {
276
+
277
+ rgbe_error( rgbe_read_error );
278
+
279
+ }
280
+
281
+ rgbeStart[ 0 ] = buffer[ pos ++ ];
282
+ rgbeStart[ 1 ] = buffer[ pos ++ ];
283
+ rgbeStart[ 2 ] = buffer[ pos ++ ];
284
+ rgbeStart[ 3 ] = buffer[ pos ++ ];
285
+
286
+ if ( ( 2 != rgbeStart[ 0 ] ) || ( 2 != rgbeStart[ 1 ] ) || ( ( ( rgbeStart[ 2 ] << 8 ) | rgbeStart[ 3 ] ) != scanline_width ) ) {
287
+
288
+ rgbe_error( rgbe_format_error, 'bad rgbe scanline format' );
289
+
290
+ }
291
+
292
+ // read each of the four channels for the scanline into the buffer
293
+ // first red, then green, then blue, then exponent
294
+ let ptr = 0, count;
295
+
296
+ while ( ( ptr < ptr_end ) && ( pos < buffer.byteLength ) ) {
297
+
298
+ count = buffer[ pos ++ ];
299
+ const isEncodedRun = count > 128;
300
+ if ( isEncodedRun ) count -= 128;
301
+
302
+ if ( ( 0 === count ) || ( ptr + count > ptr_end ) ) {
303
+
304
+ rgbe_error( rgbe_format_error, 'bad scanline data' );
305
+
306
+ }
307
+
308
+ if ( isEncodedRun ) {
309
+
310
+ // a (encoded) run of the same value
311
+ const byteValue = buffer[ pos ++ ];
312
+ for ( let i = 0; i < count; i ++ ) {
313
+
314
+ scanline_buffer[ ptr ++ ] = byteValue;
315
+
316
+ }
317
+ //ptr += count;
318
+
319
+ } else {
320
+
321
+ // a literal-run
322
+ scanline_buffer.set( buffer.subarray( pos, pos + count ), ptr );
323
+ ptr += count; pos += count;
324
+
325
+ }
326
+
327
+ }
328
+
329
+
330
+ // now convert data from buffer into rgba
331
+ // first red, then green, then blue, then exponent (alpha)
332
+ const l = scanline_width; //scanline_buffer.byteLength;
333
+ for ( let i = 0; i < l; i ++ ) {
334
+
335
+ let off = 0;
336
+ data_rgba[ offset ] = scanline_buffer[ i + off ];
337
+ off += scanline_width; //1;
338
+ data_rgba[ offset + 1 ] = scanline_buffer[ i + off ];
339
+ off += scanline_width; //1;
340
+ data_rgba[ offset + 2 ] = scanline_buffer[ i + off ];
341
+ off += scanline_width; //1;
342
+ data_rgba[ offset + 3 ] = scanline_buffer[ i + off ];
343
+ offset += 4;
344
+
345
+ }
346
+
347
+ num_scanlines --;
348
+
349
+ }
350
+
351
+ return data_rgba;
352
+
353
+ };
354
+
355
+ const RGBEByteToRGBFloat = function ( sourceArray, sourceOffset, destArray, destOffset ) {
356
+
357
+ const e = sourceArray[ sourceOffset + 3 ];
358
+ const scale = Math.pow( 2.0, e - 128.0 ) / 255.0;
359
+
360
+ destArray[ destOffset + 0 ] = sourceArray[ sourceOffset + 0 ] * scale;
361
+ destArray[ destOffset + 1 ] = sourceArray[ sourceOffset + 1 ] * scale;
362
+ destArray[ destOffset + 2 ] = sourceArray[ sourceOffset + 2 ] * scale;
363
+ destArray[ destOffset + 3 ] = 1;
364
+
365
+ };
366
+
367
+ const RGBEByteToRGBHalf = function ( sourceArray, sourceOffset, destArray, destOffset ) {
368
+
369
+ const e = sourceArray[ sourceOffset + 3 ];
370
+ const scale = Math.pow( 2.0, e - 128.0 ) / 255.0;
371
+
372
+ // clamping to 65504, the maximum representable value in float16
373
+ destArray[ destOffset + 0 ] = DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 0 ] * scale, 65504 ) );
374
+ destArray[ destOffset + 1 ] = DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 1 ] * scale, 65504 ) );
375
+ destArray[ destOffset + 2 ] = DataUtils.toHalfFloat( Math.min( sourceArray[ sourceOffset + 2 ] * scale, 65504 ) );
376
+ destArray[ destOffset + 3 ] = DataUtils.toHalfFloat( 1 );
377
+
378
+ };
379
+
380
+ const byteArray = new Uint8Array( buffer );
381
+ byteArray.pos = 0;
382
+ const rgbe_header_info = RGBE_ReadHeader( byteArray );
383
+
384
+ const w = rgbe_header_info.width,
385
+ h = rgbe_header_info.height,
386
+ image_rgba_data = RGBE_ReadPixels_RLE( byteArray.subarray( byteArray.pos ), w, h );
387
+
388
+
389
+ let data, type;
390
+ let numElements;
391
+
392
+ switch ( this.type ) {
393
+
394
+ case FloatType:
395
+
396
+ numElements = image_rgba_data.length / 4;
397
+ const floatArray = new Float32Array( numElements * 4 );
398
+
399
+ for ( let j = 0; j < numElements; j ++ ) {
400
+
401
+ RGBEByteToRGBFloat( image_rgba_data, j * 4, floatArray, j * 4 );
402
+
403
+ }
404
+
405
+ data = floatArray;
406
+ type = FloatType;
407
+ break;
408
+
409
+ case HalfFloatType:
410
+
411
+ numElements = image_rgba_data.length / 4;
412
+ const halfArray = new Uint16Array( numElements * 4 );
413
+
414
+ for ( let j = 0; j < numElements; j ++ ) {
415
+
416
+ RGBEByteToRGBHalf( image_rgba_data, j * 4, halfArray, j * 4 );
417
+
418
+ }
419
+
420
+ data = halfArray;
421
+ type = HalfFloatType;
422
+ break;
423
+
424
+ default:
425
+
426
+ throw new Error( 'THREE.HDRLoader: Unsupported type: ' + this.type );
427
+ break;
428
+
429
+ }
430
+
431
+ return {
432
+ width: w, height: h,
433
+ data: data,
434
+ header: rgbe_header_info.string,
435
+ gamma: rgbe_header_info.gamma,
436
+ exposure: rgbe_header_info.exposure,
437
+ type: type
438
+ };
439
+
440
+ }
441
+
442
+ /**
443
+ * Sets the texture type.
444
+ *
445
+ * @param {(HalfFloatType|FloatType)} value - The texture type to set.
446
+ * @return {HDRLoader} A reference to this loader.
447
+ */
448
+ setDataType( value ) {
449
+
450
+ this.type = value;
451
+ return this;
452
+
453
+ }
454
+
455
+ load( url, onLoad, onProgress, onError ) {
456
+
457
+ function onLoadCallback( texture, texData ) {
458
+
459
+ switch ( texture.type ) {
460
+
461
+ case FloatType:
462
+ case HalfFloatType:
463
+
464
+ texture.colorSpace = LinearSRGBColorSpace;
465
+ texture.minFilter = LinearFilter;
466
+ texture.magFilter = LinearFilter;
467
+ texture.generateMipmaps = false;
468
+ texture.flipY = true;
469
+
470
+ break;
471
+
472
+ }
473
+
474
+ if ( onLoad ) onLoad( texture, texData );
475
+
476
+ }
477
+
478
+ return super.load( url, onLoadCallback, onProgress, onError );
479
+
480
+ }
481
+
482
+ }
483
+
484
+ export { HDRLoader };
485
+
486
+