@needle-tools/three 0.145.4 → 0.146.2

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 (393) hide show
  1. package/README.md +1 -1
  2. package/build/three.cjs +32586 -35951
  3. package/build/three.js +32600 -35965
  4. package/build/three.min.js +6 -7
  5. package/build/three.module.js +1547 -1154
  6. package/examples/js/animation/AnimationClipCreator.js +0 -8
  7. package/examples/js/animation/CCDIKSolver.js +49 -66
  8. package/examples/js/animation/MMDAnimationHelper.js +66 -137
  9. package/examples/js/animation/MMDPhysics.js +70 -134
  10. package/examples/js/cameras/CinematicCamera.js +33 -22
  11. package/examples/js/controls/ArcballControls.js +138 -405
  12. package/examples/js/controls/DragControls.js +8 -33
  13. package/examples/js/controls/FirstPersonControls.js +32 -54
  14. package/examples/js/controls/FlyControls.js +29 -55
  15. package/examples/js/controls/OrbitControls.js +85 -95
  16. package/examples/js/controls/PointerLockControls.js +5 -14
  17. package/examples/js/controls/TrackballControls.js +33 -86
  18. package/examples/js/controls/TransformControls.js +84 -169
  19. package/examples/js/csm/CSM.js +4 -39
  20. package/examples/js/csm/CSMFrustum.js +3 -9
  21. package/examples/js/csm/CSMHelper.js +24 -4
  22. package/examples/js/csm/CSMShader.js +2 -6
  23. package/examples/js/curves/CurveExtras.js +27 -27
  24. package/examples/js/curves/NURBSCurve.js +4 -16
  25. package/examples/js/curves/NURBSSurface.js +3 -9
  26. package/examples/js/curves/NURBSUtils.js +8 -45
  27. package/examples/js/effects/AnaglyphEffect.js +4 -18
  28. package/examples/js/effects/AsciiEffect.js +32 -31
  29. package/examples/js/effects/OutlineEffect.js +26 -30
  30. package/examples/js/effects/ParallaxBarrierEffect.js +0 -13
  31. package/examples/js/effects/PeppersGhostEffect.js +12 -39
  32. package/examples/js/effects/StereoEffect.js +0 -4
  33. package/examples/js/environments/RoomEnvironment.js +12 -10
  34. package/examples/js/exporters/ColladaExporter.js +48 -65
  35. package/examples/js/exporters/DRACOExporter.js +22 -22
  36. package/examples/js/exporters/EXRExporter.js +15 -18
  37. package/examples/js/exporters/GLTFExporter.js +143 -261
  38. package/examples/js/exporters/MMDExporter.js +5 -12
  39. package/examples/js/exporters/OBJExporter.js +42 -33
  40. package/examples/js/exporters/PLYExporter.js +38 -33
  41. package/examples/js/exporters/STLExporter.js +5 -7
  42. package/examples/js/exporters/USDZExporter.js +110 -25
  43. package/examples/js/geometries/BoxLineGeometry.js +0 -1
  44. package/examples/js/geometries/ConvexGeometry.js +11 -6
  45. package/examples/js/geometries/DecalGeometry.js +53 -20
  46. package/examples/js/geometries/LightningStrike.js +54 -67
  47. package/examples/js/geometries/ParametricGeometries.js +8 -7
  48. package/examples/js/geometries/ParametricGeometry.js +25 -12
  49. package/examples/js/geometries/RoundedBoxGeometry.js +21 -19
  50. package/examples/js/geometries/TeapotGeometry.js +54 -50
  51. package/examples/js/geometries/TextGeometry.js +6 -4
  52. package/examples/js/helpers/LightProbeHelper.js +1 -2
  53. package/examples/js/helpers/OctreeHelper.js +22 -20
  54. package/examples/js/helpers/PositionalAudioHelper.js +8 -6
  55. package/examples/js/helpers/RectAreaLightHelper.js +6 -7
  56. package/examples/js/helpers/VertexNormalsHelper.js +15 -13
  57. package/examples/js/helpers/VertexTangentsHelper.js +15 -9
  58. package/examples/js/helpers/ViewHelper.js +31 -16
  59. package/examples/js/interactive/HTMLMesh.js +22 -33
  60. package/examples/js/interactive/InteractiveGroup.js +6 -12
  61. package/examples/js/interactive/SelectionBox.js +3 -70
  62. package/examples/js/interactive/SelectionHelper.js +0 -8
  63. package/examples/js/lights/LightProbeGenerator.js +32 -39
  64. package/examples/js/lights/RectAreaLightUniformsLib.js +5 -1
  65. package/examples/js/lines/LineGeometry.js +3 -5
  66. package/examples/js/lines/LineMaterial.js +4 -11
  67. package/examples/js/lines/LineSegments2.js +38 -89
  68. package/examples/js/lines/LineSegmentsGeometry.js +7 -28
  69. package/examples/js/lines/Wireframe.js +2 -7
  70. package/examples/js/lines/WireframeGeometry2.js +3 -1
  71. package/examples/js/loaders/3DMLoader.js +58 -155
  72. package/examples/js/loaders/3MFLoader.js +72 -106
  73. package/examples/js/loaders/AMFLoader.js +0 -25
  74. package/examples/js/loaders/BVHLoader.js +44 -43
  75. package/examples/js/loaders/BasisTextureLoader.js +16 -46
  76. package/examples/js/loaders/ColladaLoader.js +201 -359
  77. package/examples/js/loaders/DDSLoader.js +24 -25
  78. package/examples/js/loaders/DRACOLoader.js +29 -66
  79. package/examples/js/loaders/EXRLoader.js +67 -164
  80. package/examples/js/loaders/FBXLoader.js +286 -441
  81. package/examples/js/loaders/FontLoader.js +6 -15
  82. package/examples/js/loaders/GCodeLoader.js +15 -16
  83. package/examples/js/loaders/GLTFLoader.js +354 -405
  84. package/examples/js/loaders/HDRCubeTextureLoader.js +0 -6
  85. package/examples/js/loaders/KMZLoader.js +3 -7
  86. package/examples/js/loaders/KTXLoader.js +12 -30
  87. package/examples/js/loaders/LDrawLoader.js +178 -289
  88. package/examples/js/loaders/LUT3dlLoader.js +7 -11
  89. package/examples/js/loaders/LUTCubeLoader.js +0 -8
  90. package/examples/js/loaders/LWOLoader.js +59 -124
  91. package/examples/js/loaders/LogLuvLoader.js +27 -77
  92. package/examples/js/loaders/LottieLoader.js +4 -4
  93. package/examples/js/loaders/MD2Loader.js +26 -27
  94. package/examples/js/loaders/MDDLoader.js +6 -10
  95. package/examples/js/loaders/MMDLoader.js +180 -189
  96. package/examples/js/loaders/MTLLoader.js +18 -47
  97. package/examples/js/loaders/MaterialXLoader.js +392 -0
  98. package/examples/js/loaders/NRRDLoader.js +44 -84
  99. package/examples/js/loaders/OBJLoader.js +50 -65
  100. package/examples/js/loaders/PCDLoader.js +34 -29
  101. package/examples/js/loaders/PDBLoader.js +17 -13
  102. package/examples/js/loaders/PLYLoader.js +9 -39
  103. package/examples/js/loaders/PRWMLoader.js +11 -22
  104. package/examples/js/loaders/PVRLoader.js +7 -16
  105. package/examples/js/loaders/RGBELoader.js +36 -61
  106. package/examples/js/loaders/RGBMLoader.js +26 -87
  107. package/examples/js/loaders/STLLoader.js +20 -27
  108. package/examples/js/loaders/SVGLoader.js +361 -233
  109. package/examples/js/loaders/TDSLoader.js +81 -118
  110. package/examples/js/loaders/TGALoader.js +39 -41
  111. package/examples/js/loaders/TIFFLoader.js +0 -1
  112. package/examples/js/loaders/TTFLoader.js +0 -8
  113. package/examples/js/loaders/TiltLoader.js +14 -15
  114. package/examples/js/loaders/VOXLoader.js +8 -16
  115. package/examples/js/loaders/VRMLLoader.js +243 -340
  116. package/examples/js/loaders/VTKLoader.js +101 -118
  117. package/examples/js/loaders/XYZLoader.js +2 -4
  118. package/examples/js/loaders/lwo/IFFParser.js +55 -136
  119. package/examples/js/loaders/lwo/LWO2Parser.js +32 -83
  120. package/examples/js/loaders/lwo/LWO3Parser.js +31 -73
  121. package/examples/js/materials/MeshGouraudMaterial.js +15 -13
  122. package/examples/js/math/Capsule.js +0 -17
  123. package/examples/js/math/ColorConverter.js +3 -3
  124. package/examples/js/math/ConvexHull.js +183 -139
  125. package/examples/js/math/ImprovedNoise.js +1 -1
  126. package/examples/js/math/Lut.js +8 -15
  127. package/examples/js/math/MeshSurfaceSampler.js +6 -28
  128. package/examples/js/math/OBB.js +90 -49
  129. package/examples/js/math/Octree.js +2 -57
  130. package/examples/js/math/SimplexNoise.js +74 -88
  131. package/examples/js/misc/ConvexObjectBreaker.js +37 -48
  132. package/examples/js/misc/GPUComputationRenderer.js +14 -18
  133. package/examples/js/misc/Gyroscope.js +5 -9
  134. package/examples/js/misc/MD2Character.js +14 -23
  135. package/examples/js/misc/MD2CharacterComplex.js +73 -54
  136. package/examples/js/misc/MorphAnimMesh.js +0 -6
  137. package/examples/js/misc/MorphBlendMesh.js +3 -30
  138. package/examples/js/misc/ProgressiveLightMap.js +47 -43
  139. package/examples/js/misc/RollerCoaster.js +17 -24
  140. package/examples/js/misc/TubePainter.js +18 -12
  141. package/examples/js/misc/Volume.js +16 -45
  142. package/examples/js/misc/VolumeSlice.js +14 -24
  143. package/examples/js/modifiers/CurveModifier.js +19 -21
  144. package/examples/js/modifiers/EdgeSplitModifier.js +0 -30
  145. package/examples/js/modifiers/SimplifyModifier.js +56 -59
  146. package/examples/js/modifiers/TessellateModifier.js +2 -9
  147. package/examples/js/objects/GroundProjectedEnv.js +2 -14
  148. package/examples/js/objects/Lensflare.js +47 -38
  149. package/examples/js/objects/LightningStorm.js +10 -13
  150. package/examples/js/objects/MarchingCubes.js +80 -59
  151. package/examples/js/objects/Reflector.js +22 -20
  152. package/examples/js/objects/ReflectorForSSRPass.js +19 -23
  153. package/examples/js/objects/Refractor.js +52 -30
  154. package/examples/js/objects/ShadowMesh.js +1 -2
  155. package/examples/js/objects/Sky.js +2 -7
  156. package/examples/js/objects/Water.js +23 -18
  157. package/examples/js/objects/Water2.js +20 -19
  158. package/examples/js/physics/AmmoPhysics.js +23 -20
  159. package/examples/js/physics/OimoPhysics.js +19 -17
  160. package/examples/js/postprocessing/AdaptiveToneMappingPass.js +13 -20
  161. package/examples/js/postprocessing/AfterimagePass.js +19 -12
  162. package/examples/js/postprocessing/BloomPass.js +38 -17
  163. package/examples/js/postprocessing/BokehPass.js +29 -12
  164. package/examples/js/postprocessing/ClearPass.js +1 -6
  165. package/examples/js/postprocessing/CubeTexturePass.js +12 -9
  166. package/examples/js/postprocessing/DotScreenPass.js +7 -5
  167. package/examples/js/postprocessing/EffectComposer.js +25 -32
  168. package/examples/js/postprocessing/FilmPass.js +7 -5
  169. package/examples/js/postprocessing/GlitchPass.js +10 -11
  170. package/examples/js/postprocessing/HalftonePass.js +9 -9
  171. package/examples/js/postprocessing/LUTPass.js +2 -15
  172. package/examples/js/postprocessing/MaskPass.js +20 -17
  173. package/examples/js/postprocessing/OutlinePass.js +45 -36
  174. package/examples/js/postprocessing/Pass.js +11 -14
  175. package/examples/js/postprocessing/RenderPass.js +3 -7
  176. package/examples/js/postprocessing/SAOPass.js +40 -32
  177. package/examples/js/postprocessing/SMAAPass.js +34 -17
  178. package/examples/js/postprocessing/SSAARenderPass.js +14 -14
  179. package/examples/js/postprocessing/SSAOPass.js +56 -42
  180. package/examples/js/postprocessing/SSRPass.js +78 -61
  181. package/examples/js/postprocessing/SavePass.js +14 -6
  182. package/examples/js/postprocessing/ShaderPass.js +9 -8
  183. package/examples/js/postprocessing/TAARenderPass.js +11 -9
  184. package/examples/js/postprocessing/TexturePass.js +7 -4
  185. package/examples/js/postprocessing/UnrealBloomPass.js +43 -25
  186. package/examples/js/renderers/CSS2DRenderer.js +2 -21
  187. package/examples/js/renderers/CSS3DRenderer.js +3 -24
  188. package/examples/js/renderers/Projector.js +29 -85
  189. package/examples/js/renderers/SVGRenderer.js +4 -50
  190. package/examples/js/shaders/ACESFilmicToneMappingShader.js +3 -6
  191. package/examples/js/shaders/AfterimageShader.js +3 -6
  192. package/examples/js/shaders/BasicShader.js +3 -6
  193. package/examples/js/shaders/BleachBypassShader.js +3 -6
  194. package/examples/js/shaders/BlendShader.js +3 -6
  195. package/examples/js/shaders/BokehShader.js +3 -6
  196. package/examples/js/shaders/BokehShader2.js +4 -13
  197. package/examples/js/shaders/BrightnessContrastShader.js +3 -6
  198. package/examples/js/shaders/ColorCorrectionShader.js +2 -6
  199. package/examples/js/shaders/ColorifyShader.js +2 -6
  200. package/examples/js/shaders/ConvolutionShader.js +5 -10
  201. package/examples/js/shaders/CopyShader.js +3 -6
  202. package/examples/js/shaders/DOFMipMapShader.js +3 -6
  203. package/examples/js/shaders/DepthLimitedBlurShader.js +2 -9
  204. package/examples/js/shaders/DigitalGlitch.js +3 -6
  205. package/examples/js/shaders/DotScreenShader.js +2 -6
  206. package/examples/js/shaders/FXAAShader.js +1 -3
  207. package/examples/js/shaders/FilmShader.js +3 -6
  208. package/examples/js/shaders/FocusShader.js +3 -6
  209. package/examples/js/shaders/FreiChenShader.js +2 -6
  210. package/examples/js/shaders/GammaCorrectionShader.js +3 -6
  211. package/examples/js/shaders/GodRaysShader.js +11 -24
  212. package/examples/js/shaders/HalftoneShader.js +3 -6
  213. package/examples/js/shaders/HorizontalBlurShader.js +3 -6
  214. package/examples/js/shaders/HorizontalTiltShiftShader.js +3 -6
  215. package/examples/js/shaders/HueSaturationShader.js +3 -6
  216. package/examples/js/shaders/KaleidoShader.js +3 -6
  217. package/examples/js/shaders/LuminosityHighPassShader.js +2 -6
  218. package/examples/js/shaders/LuminosityShader.js +3 -6
  219. package/examples/js/shaders/MMDToonShader.js +2 -6
  220. package/examples/js/shaders/MirrorShader.js +3 -6
  221. package/examples/js/shaders/NormalMapShader.js +2 -6
  222. package/examples/js/shaders/RGBShiftShader.js +3 -6
  223. package/examples/js/shaders/SAOShader.js +2 -6
  224. package/examples/js/shaders/SMAAShader.js +6 -18
  225. package/examples/js/shaders/SSAOShader.js +2 -6
  226. package/examples/js/shaders/SSRShader.js +6 -18
  227. package/examples/js/shaders/SepiaShader.js +3 -6
  228. package/examples/js/shaders/SobelOperatorShader.js +2 -6
  229. package/examples/js/shaders/TechnicolorShader.js +3 -6
  230. package/examples/js/shaders/ToneMapShader.js +3 -6
  231. package/examples/js/shaders/ToonShader.js +8 -24
  232. package/examples/js/shaders/TriangleBlurShader.js +2 -6
  233. package/examples/js/shaders/UnpackDepthRGBAShader.js +3 -6
  234. package/examples/js/shaders/VelocityShader.js +126 -0
  235. package/examples/js/shaders/VerticalBlurShader.js +3 -6
  236. package/examples/js/shaders/VerticalTiltShiftShader.js +3 -6
  237. package/examples/js/shaders/VignetteShader.js +3 -6
  238. package/examples/js/shaders/VolumeShader.js +2 -6
  239. package/examples/js/shaders/WaterRefractionShader.js +2 -6
  240. package/examples/js/textures/FlakesTexture.js +0 -1
  241. package/examples/js/utils/BufferGeometryUtils.js +234 -168
  242. package/examples/js/utils/CameraUtils.js +5 -20
  243. package/examples/js/utils/GPUStatsPanel.js +3 -12
  244. package/examples/js/utils/GeometryCompressionUtils.js +19 -44
  245. package/examples/js/utils/GeometryUtils.js +13 -18
  246. package/examples/js/utils/LDrawUtils.js +8 -11
  247. package/examples/js/utils/PackedPhongMaterial.js +6 -4
  248. package/examples/js/utils/SceneUtils.js +117 -6
  249. package/examples/js/utils/ShadowMapViewer.js +17 -14
  250. package/examples/js/utils/SkeletonUtils.js +13 -27
  251. package/examples/js/utils/UVsDebug.js +20 -12
  252. package/examples/js/utils/WorkerPool.js +1 -11
  253. package/examples/jsm/animation/CCDIKSolver.js +1 -1
  254. package/examples/jsm/capabilities/WebGPU.js +3 -1
  255. package/examples/jsm/controls/OrbitControls.js +44 -4
  256. package/examples/jsm/exporters/GLTFExporter.js +17 -131
  257. package/examples/jsm/exporters/USDZExporter.js +75 -19
  258. package/examples/jsm/interactive/HTMLMesh.js +2 -0
  259. package/examples/jsm/libs/lottie_canvas.module.js +14844 -0
  260. package/examples/jsm/loaders/3DMLoader.js +1 -2
  261. package/examples/jsm/loaders/ColladaLoader.js +28 -0
  262. package/examples/jsm/loaders/FBXLoader.js +16 -2
  263. package/examples/jsm/loaders/GLTFLoader.js +204 -377
  264. package/examples/jsm/loaders/KTX2Loader.js +68 -29
  265. package/examples/jsm/loaders/LDrawLoader.js +14 -13
  266. package/examples/jsm/loaders/LottieLoader.js +4 -2
  267. package/examples/jsm/loaders/MaterialXLoader.js +728 -0
  268. package/examples/jsm/loaders/PCDLoader.js +1 -1
  269. package/examples/jsm/loaders/PLYLoader.js +68 -16
  270. package/examples/jsm/loaders/SVGLoader.js +227 -14
  271. package/examples/jsm/loaders/USDZLoader.js +31 -16
  272. package/examples/jsm/nodes/Nodes.js +14 -2
  273. package/examples/jsm/nodes/accessors/Object3DNode.js +1 -1
  274. package/examples/jsm/nodes/accessors/PositionNode.js +6 -0
  275. package/examples/jsm/nodes/accessors/ReferenceNode.js +1 -1
  276. package/examples/jsm/nodes/accessors/SkinningNode.js +1 -1
  277. package/examples/jsm/nodes/core/Node.js +1 -1
  278. package/examples/jsm/nodes/core/NodeBuilder.js +36 -4
  279. package/examples/jsm/nodes/core/NodeFrame.js +2 -2
  280. package/examples/jsm/nodes/core/NodeVarying.js +7 -4
  281. package/examples/jsm/nodes/core/VaryingNode.js +6 -4
  282. package/examples/jsm/nodes/core/constants.js +13 -13
  283. package/examples/jsm/nodes/display/PosterizeNode.js +25 -0
  284. package/examples/jsm/nodes/display/ViewportNode.js +106 -0
  285. package/examples/jsm/nodes/gpgpu/ComputeNode.js +1 -1
  286. package/examples/jsm/nodes/lighting/AnalyticLightNode.js +1 -1
  287. package/examples/jsm/nodes/loaders/NodeMaterialLoader.js +3 -1
  288. package/examples/jsm/nodes/materials/Materials.js +9 -7
  289. package/examples/jsm/nodes/materials/NodeMaterial.js +9 -1
  290. package/examples/jsm/nodes/materialx/MaterialXNodes.js +6 -2
  291. package/examples/jsm/nodes/materialx/lib/mx_transform_color.js +18 -0
  292. package/examples/jsm/nodes/math/MathNode.js +5 -0
  293. package/examples/jsm/nodes/math/OperatorNode.js +6 -1
  294. package/examples/jsm/nodes/shadernode/ShaderNode.js +26 -13
  295. package/examples/jsm/nodes/shadernode/ShaderNodeBaseElements.js +2 -0
  296. package/examples/jsm/nodes/shadernode/ShaderNodeElements.js +18 -0
  297. package/examples/jsm/nodes/utils/EquirectUVNode.js +27 -0
  298. package/examples/jsm/nodes/utils/JoinNode.js +8 -2
  299. package/examples/jsm/nodes/utils/MatcapUVNode.js +2 -4
  300. package/examples/jsm/nodes/utils/MaxMipLevelNode.js +1 -1
  301. package/examples/jsm/nodes/utils/SpriteSheetUVNode.js +8 -10
  302. package/examples/jsm/nodes/utils/TimerNode.js +1 -1
  303. package/examples/jsm/nodes/utils/TriplanarTexturesNode.js +51 -0
  304. package/examples/jsm/postprocessing/AfterimagePass.js +17 -4
  305. package/examples/jsm/postprocessing/BloomPass.js +22 -3
  306. package/examples/jsm/postprocessing/BokehPass.js +18 -4
  307. package/examples/jsm/postprocessing/CubeTexturePass.js +12 -5
  308. package/examples/jsm/postprocessing/DotScreenPass.js +8 -0
  309. package/examples/jsm/postprocessing/EffectComposer.js +9 -0
  310. package/examples/jsm/postprocessing/FilmPass.js +8 -0
  311. package/examples/jsm/postprocessing/GlitchPass.js +13 -1
  312. package/examples/jsm/postprocessing/HalftonePass.js +8 -0
  313. package/examples/jsm/postprocessing/OutlinePass.js +10 -0
  314. package/examples/jsm/postprocessing/Pass.js +2 -0
  315. package/examples/jsm/postprocessing/RenderPixelatedPass.js +234 -0
  316. package/examples/jsm/postprocessing/SAOPass.js +20 -0
  317. package/examples/jsm/postprocessing/SMAAPass.js +16 -0
  318. package/examples/jsm/postprocessing/SSAARenderPass.js +4 -0
  319. package/examples/jsm/postprocessing/SavePass.js +17 -1
  320. package/examples/jsm/postprocessing/ShaderPass.js +8 -0
  321. package/examples/jsm/postprocessing/TAARenderPass.js +9 -0
  322. package/examples/jsm/postprocessing/TexturePass.js +8 -0
  323. package/examples/jsm/postprocessing/UnrealBloomPass.js +16 -0
  324. package/examples/jsm/renderers/webgl/nodes/WebGLNodeBuilder.js +39 -16
  325. package/examples/jsm/renderers/webgpu/WebGPUAnimation.js +58 -0
  326. package/examples/jsm/renderers/webgpu/WebGPUAttributes.js +63 -5
  327. package/examples/jsm/renderers/webgpu/WebGPUBackground.js +36 -7
  328. package/examples/jsm/renderers/webgpu/WebGPURenderer.js +47 -12
  329. package/examples/jsm/renderers/webgpu/nodes/WebGPUNodeBuilder.js +35 -5
  330. package/examples/jsm/shaders/MMDToonShader.js +0 -2
  331. package/examples/jsm/shaders/VelocityShader.js +128 -0
  332. package/examples/jsm/utils/BufferGeometryUtils.js +130 -6
  333. package/examples/jsm/utils/SceneUtils.js +129 -4
  334. package/examples/jsm/utils/TextureUtils.js +85 -0
  335. package/examples/jsm/webxr/OculusHandModel.js +1 -1
  336. package/examples/jsm/webxr/XRHandMeshModel.js +6 -3
  337. package/package.json +11 -12
  338. package/src/Three.js +1 -0
  339. package/src/audio/AudioContext.js +5 -5
  340. package/src/cameras/CubeCamera.js +14 -14
  341. package/src/constants.js +1 -1
  342. package/src/core/InstancedBufferGeometry.js +1 -7
  343. package/src/extras/Earcut.js +67 -67
  344. package/src/helpers/DirectionalLightHelper.js +5 -1
  345. package/src/helpers/HemisphereLightHelper.js +4 -1
  346. package/src/helpers/PointLightHelper.js +2 -1
  347. package/src/helpers/SpotLightHelper.js +4 -2
  348. package/src/lights/PointLight.js +2 -2
  349. package/src/lights/SpotLight.js +2 -2
  350. package/src/loaders/FileLoader.js +4 -1
  351. package/src/loaders/ObjectLoader.js +5 -1
  352. package/src/materials/Material.js +1 -1
  353. package/src/math/Color.js +5 -5
  354. package/src/math/Matrix3.js +53 -18
  355. package/src/math/Ray.js +2 -5
  356. package/src/math/Sphere.js +19 -26
  357. package/src/objects/InstancedMesh.js +7 -0
  358. package/src/objects/LOD.js +25 -6
  359. package/src/renderers/WebGL3DRenderTarget.js +1 -1
  360. package/src/renderers/WebGLArrayRenderTarget.js +1 -1
  361. package/src/renderers/WebGLCubeRenderTarget.js +1 -1
  362. package/src/renderers/WebGLMultipleRenderTargets.js +1 -1
  363. package/src/renderers/WebGLRenderTarget.js +1 -1
  364. package/src/renderers/WebGLRenderer.js +36 -62
  365. package/src/renderers/shaders/ShaderChunk/envmap_fragment.glsl.js +0 -4
  366. package/src/renderers/shaders/ShaderChunk/lights_fragment_begin.glsl.js +0 -1
  367. package/src/renderers/shaders/ShaderChunk/lights_lambert_pars_fragment.glsl.js +0 -2
  368. package/src/renderers/shaders/ShaderChunk/lights_phong_pars_fragment.glsl.js +0 -2
  369. package/src/renderers/shaders/ShaderChunk/lights_toon_pars_fragment.glsl.js +0 -2
  370. package/src/renderers/shaders/ShaderChunk/packing.glsl.js +8 -0
  371. package/src/renderers/shaders/ShaderChunk.js +3 -0
  372. package/src/renderers/shaders/ShaderLib/background.glsl.js +7 -2
  373. package/src/renderers/shaders/ShaderLib/backgroundCube.glsl.js +62 -0
  374. package/src/renderers/shaders/ShaderLib/cube.glsl.js +4 -6
  375. package/src/renderers/shaders/ShaderLib.js +20 -6
  376. package/src/renderers/shaders/UniformsLib.js +1 -1
  377. package/src/renderers/shaders/UniformsUtils.js +15 -0
  378. package/src/renderers/webgl/WebGLAttributes.js +2 -0
  379. package/src/renderers/webgl/WebGLBackground.js +15 -7
  380. package/src/renderers/webgl/WebGLLights.js +0 -4
  381. package/src/renderers/webgl/WebGLMaterials.js +2 -1
  382. package/src/renderers/webgl/WebGLShadowMap.js +3 -1
  383. package/src/renderers/webgl/WebGLState.js +31 -1
  384. package/src/renderers/webgl/WebGLTextures.js +71 -18
  385. package/src/renderers/webgl/WebGLUniforms.js +116 -20
  386. package/src/renderers/webgl/WebGLUtils.js +1 -1
  387. package/src/renderers/webxr/WebXRController.js +46 -13
  388. package/src/renderers/webxr/WebXRManager.js +85 -3
  389. package/src/scenes/Scene.js +8 -0
  390. package/src/textures/CompressedArrayTexture.js +18 -0
  391. package/examples/js/libs/lottie_canvas.js +0 -12751
  392. package/examples/js/shaders/PixelShader.js +0 -51
  393. package/examples/jsm/shaders/PixelShader.js +0 -44
@@ -0,0 +1,728 @@
1
+ import {
2
+ FileLoader,
3
+ Loader,
4
+ TextureLoader,
5
+ RepeatWrapping
6
+ } from 'three';
7
+
8
+ import {
9
+ MeshPhysicalNodeMaterial,
10
+ float, bool, int, vec2, vec3, vec4, color, texture,
11
+ positionLocal,
12
+ add, sub, mul, div, mod, abs, sign, floor, ceil, round, pow, sin, cos, tan,
13
+ asin, acos, atan2, sqrt, exp, clamp, min, max, normalize, length, dot, cross, normalMap,
14
+ remap, smoothstep, luminance, mx_rgbtohsv, mx_hsvtorgb,
15
+ mix,
16
+ mx_ramplr, mx_ramptb, mx_splitlr, mx_splittb,
17
+ mx_fractal_noise_float, mx_noise_float, mx_cell_noise_float, mx_worley_noise_float,
18
+ mx_transform_uv,
19
+ mx_safepower, mx_contrast,
20
+ mx_srgb_texture_to_lin_rec709,
21
+ saturation
22
+ } from 'three/nodes';
23
+
24
+ const colorSpaceLib = {
25
+ mx_srgb_texture_to_lin_rec709
26
+ };
27
+
28
+ class MtlXElement {
29
+
30
+ constructor( name, nodeFunc, params = null ) {
31
+
32
+ this.name = name;
33
+ this.nodeFunc = nodeFunc;
34
+ this.params = params;
35
+
36
+ }
37
+
38
+ }
39
+
40
+ // Ref: https://github.com/mrdoob/three.js/issues/24674
41
+
42
+ const MtlXElements = [
43
+
44
+ // << Math >>
45
+ new MtlXElement( 'add', add, [ 'in1', 'in2' ] ),
46
+ new MtlXElement( 'subtract', sub, [ 'in1', 'in2' ] ),
47
+ new MtlXElement( 'multiply', mul, [ 'in1', 'in2' ] ),
48
+ new MtlXElement( 'divide', div, [ 'in1', 'in2' ] ),
49
+ new MtlXElement( 'modulo', mod, [ 'in1', 'in2' ] ),
50
+ new MtlXElement( 'absval', abs, [ 'in1', 'in2' ] ),
51
+ new MtlXElement( 'sign', sign, [ 'in1', 'in2' ] ),
52
+ new MtlXElement( 'floor', floor, [ 'in1', 'in2' ] ),
53
+ new MtlXElement( 'ceil', ceil, [ 'in1', 'in2' ] ),
54
+ new MtlXElement( 'round', round, [ 'in1', 'in2' ] ),
55
+ new MtlXElement( 'power', pow, [ 'in1', 'in2' ] ),
56
+ new MtlXElement( 'sin', sin, [ 'in' ] ),
57
+ new MtlXElement( 'cos', cos, [ 'in' ] ),
58
+ new MtlXElement( 'tan', tan, [ 'in' ] ),
59
+ new MtlXElement( 'asin', asin, [ 'in' ] ),
60
+ new MtlXElement( 'acos', acos, [ 'in' ] ),
61
+ new MtlXElement( 'atan2', atan2, [ 'in1', 'in2' ] ),
62
+ new MtlXElement( 'sqrt', sqrt, [ 'in' ] ),
63
+ //new MtlXElement( 'ln', ... ),
64
+ new MtlXElement( 'exp', exp, [ 'in' ] ),
65
+ new MtlXElement( 'clamp', clamp, [ 'in', 'low', 'high' ] ),
66
+ new MtlXElement( 'min', min, [ 'in1', 'in2' ] ),
67
+ new MtlXElement( 'max', max, [ 'in1', 'in2' ] ),
68
+ new MtlXElement( 'normalize', normalize, [ 'in' ] ),
69
+ new MtlXElement( 'magnitude', length, [ 'in1', 'in2' ] ),
70
+ new MtlXElement( 'dotproduct', dot, [ 'in1', 'in2' ] ),
71
+ new MtlXElement( 'crossproduct', cross, [ 'in' ] ),
72
+ //new MtlXElement( 'transformpoint', ... ),
73
+ //new MtlXElement( 'transformvector', ... ),
74
+ //new MtlXElement( 'transformnormal', ... ),
75
+ //new MtlXElement( 'transformmatrix', ... ),
76
+ new MtlXElement( 'normalmap', normalMap, [ 'in', 'scale' ] ),
77
+ //new MtlXElement( 'transpose', ... ),
78
+ //new MtlXElement( 'determinant', ... ),
79
+ //new MtlXElement( 'invertmatrix', ... ),
80
+ //new MtlXElement( 'rotate2d', rotateUV, [ 'in', radians( 'amount' )** ] ),
81
+ //new MtlXElement( 'rotate3d', ... ),
82
+ //new MtlXElement( 'arrayappend', ... ),
83
+ //new MtlXElement( 'dot', ... ),
84
+
85
+ // << Adjustment >>
86
+ new MtlXElement( 'remap', remap, [ 'in', 'inlow', 'inhigh', 'outlow', 'outhigh' ] ),
87
+ new MtlXElement( 'smoothstep', smoothstep, [ 'in', 'low', 'high' ] ),
88
+ //new MtlXElement( 'curveadjust', ... ),
89
+ //new MtlXElement( 'curvelookup', ... ),
90
+ new MtlXElement( 'luminance', luminance, [ 'in', 'lumacoeffs' ] ),
91
+ new MtlXElement( 'rgbtohsv', mx_rgbtohsv, [ 'in' ] ),
92
+ new MtlXElement( 'hsvtorgb', mx_hsvtorgb, [ 'in' ] ),
93
+
94
+ // << Mix >>
95
+ new MtlXElement( 'mix', mix, [ 'bg', 'fg', 'mix' ] ),
96
+
97
+ // << Channel >>
98
+ new MtlXElement( 'combine2', vec2, [ 'in1', 'in2' ] ),
99
+ new MtlXElement( 'combine3', vec3, [ 'in1', 'in2', 'in3' ] ),
100
+ new MtlXElement( 'combine4', vec4, [ 'in1', 'in2', 'in3', 'in4' ] ),
101
+
102
+ // << Procedural >>
103
+ new MtlXElement( 'ramplr', mx_ramplr, [ 'valuel', 'valuer', 'texcoord' ] ),
104
+ new MtlXElement( 'ramptb', mx_ramptb, [ 'valuet', 'valueb', 'texcoord' ] ),
105
+ new MtlXElement( 'splitlr', mx_splitlr, [ 'valuel', 'valuer', 'texcoord' ] ),
106
+ new MtlXElement( 'splittb', mx_splittb, [ 'valuet', 'valueb', 'texcoord' ] ),
107
+ new MtlXElement( 'noise2d', mx_noise_float, [ 'texcoord', 'amplitude', 'pivot' ] ),
108
+ new MtlXElement( 'noise3d', mx_noise_float, [ 'texcoord', 'amplitude', 'pivot' ] ),
109
+ new MtlXElement( 'fractal3d', mx_fractal_noise_float, [ 'position', 'octaves', 'lacunarity', 'diminish', 'amplitude' ] ),
110
+ new MtlXElement( 'cellnoise2d', mx_cell_noise_float, [ 'texcoord' ] ),
111
+ new MtlXElement( 'cellnoise3d', mx_cell_noise_float, [ 'texcoord' ] ),
112
+ new MtlXElement( 'worleynoise2d', mx_worley_noise_float, [ 'texcoord', 'jitter' ] ),
113
+ new MtlXElement( 'worleynoise3d', mx_worley_noise_float, [ 'texcoord', 'jitter' ] ),
114
+
115
+ // << Supplemental >>
116
+ //new MtlXElement( 'tiledimage', ... ),
117
+ //new MtlXElement( 'triplanarprojection', triplanarTextures, [ 'filex', 'filey', 'filez' ] ),
118
+ //new MtlXElement( 'ramp4', ... ),
119
+ //new MtlXElement( 'place2d', mx_place2d, [ 'texcoord', 'pivot', 'scale', 'rotate', 'offset' ] ),
120
+ new MtlXElement( 'safepower', mx_safepower, [ 'in1', 'in2' ] ),
121
+ new MtlXElement( 'contrast', mx_contrast, [ 'in', 'amount', 'pivot' ] ),
122
+ //new MtlXElement( 'hsvadjust', ... ),
123
+ new MtlXElement( 'saturate', saturation, [ 'in', 'amount' ] ),
124
+ //new MtlXElement( 'extract', ... ),
125
+ //new MtlXElement( 'separate2', ... ),
126
+ //new MtlXElement( 'separate3', ... ),
127
+ //new MtlXElement( 'separate4', ... )
128
+
129
+ ];
130
+
131
+ const MtlXLibrary = {};
132
+ MtlXElements.forEach( element => MtlXLibrary[ element.name ] = element );
133
+
134
+ class MaterialXLoader extends Loader {
135
+
136
+ constructor( manager ) {
137
+
138
+ super( manager );
139
+
140
+ }
141
+
142
+ load( url, onLoad, onProgress, onError ) {
143
+
144
+ new FileLoader( this.manager )
145
+ .setPath( this.path )
146
+ .load( url, async ( text ) => {
147
+
148
+ try {
149
+
150
+ onLoad( this.parse( text ) );
151
+
152
+ } catch ( e ) {
153
+
154
+ onError( e );
155
+
156
+ }
157
+
158
+ }, onProgress, onError );
159
+
160
+ return this;
161
+
162
+ }
163
+
164
+ parse( text ) {
165
+
166
+ return new MaterialX( this.manager, this.path ).parse( text );
167
+
168
+ }
169
+
170
+ }
171
+
172
+ class MaterialXNode {
173
+
174
+ constructor( materialX, nodeXML, nodePath = '' ) {
175
+
176
+ this.materialX = materialX;
177
+ this.nodeXML = nodeXML;
178
+ this.nodePath = nodePath ? nodePath + '/' + this.name : this.name;
179
+
180
+ this.parent = null;
181
+
182
+ this.node = null;
183
+
184
+ this.children = [];
185
+
186
+ }
187
+
188
+ get element() {
189
+
190
+ return this.nodeXML.nodeName;
191
+
192
+ }
193
+
194
+ get nodeGraph() {
195
+
196
+ return this.getAttribute( 'nodegraph' );
197
+
198
+ }
199
+
200
+ get nodeName() {
201
+
202
+ return this.getAttribute( 'nodename' );
203
+
204
+ }
205
+
206
+ get interfaceName() {
207
+
208
+ return this.getAttribute( 'interfacename' );
209
+
210
+ }
211
+
212
+ get output() {
213
+
214
+ return this.getAttribute( 'output' );
215
+
216
+ }
217
+
218
+ get name() {
219
+
220
+ return this.getAttribute( 'name' );
221
+
222
+ }
223
+
224
+ get type() {
225
+
226
+ return this.getAttribute( 'type' );
227
+
228
+ }
229
+
230
+ get value() {
231
+
232
+ return this.getAttribute( 'value' );
233
+
234
+ }
235
+
236
+ getNodeGraph() {
237
+
238
+ let nodeX = this;
239
+
240
+ while ( nodeX !== null ) {
241
+
242
+ if ( nodeX.element === 'nodegraph' ) {
243
+
244
+ break;
245
+
246
+ }
247
+
248
+ nodeX = nodeX.parent;
249
+
250
+ }
251
+
252
+ return nodeX;
253
+
254
+ }
255
+
256
+ getRoot() {
257
+
258
+ let nodeX = this;
259
+
260
+ while ( nodeX.parent !== null ) {
261
+
262
+ nodeX = nodeX.parent;
263
+
264
+ }
265
+
266
+ return nodeX;
267
+
268
+ }
269
+
270
+ get referencePath() {
271
+
272
+ let referencePath = null;
273
+
274
+ if ( this.nodeGraph !== null && this.output !== null ) {
275
+
276
+ referencePath = this.nodeGraph + '/' + this.output;
277
+
278
+ } else if ( this.nodeName !== null || this.interfaceName !== null ) {
279
+
280
+ referencePath = this.getNodeGraph().nodePath + '/' + ( this.nodeName || this.interfaceName );
281
+
282
+ }
283
+
284
+ return referencePath;
285
+
286
+ }
287
+
288
+ get hasReference() {
289
+
290
+ return this.referencePath !== null;
291
+
292
+ }
293
+
294
+ get isConst() {
295
+
296
+ return this.element === 'input' && this.value !== null && this.type !== 'filename';
297
+
298
+ }
299
+
300
+ getColorSpaceNode() {
301
+
302
+ const csSource = this.getAttribute( 'colorspace' );
303
+ const csTarget = this.getRoot().getAttribute( 'colorspace' );
304
+
305
+ const nodeName = `mx_${ csSource }_to_${ csTarget }`;
306
+
307
+ return colorSpaceLib[ nodeName ];
308
+
309
+ }
310
+
311
+ getTexture() {
312
+
313
+ const filePrefix = this.getRecursiveAttribute( 'fileprefix' ) || '';
314
+
315
+ const texture = this.materialX.textureLoader.load( filePrefix + this.value );
316
+ texture.wrapS = texture.wrapT = RepeatWrapping;
317
+ texture.flipY = false;
318
+
319
+ return texture;
320
+
321
+ }
322
+
323
+ getClassFromType( type ) {
324
+
325
+ let nodeClass = null;
326
+
327
+ if ( type === 'integer' ) nodeClass = int;
328
+ else if ( type === 'float' ) nodeClass = float;
329
+ else if ( type === 'vector2' ) nodeClass = vec2;
330
+ else if ( type === 'vector3' ) nodeClass = vec3;
331
+ else if ( type === 'vector4' || type === 'color4' ) nodeClass = vec4;
332
+ else if ( type === 'color3' ) nodeClass = color;
333
+ else if ( type === 'boolean' ) nodeClass = bool;
334
+
335
+ return nodeClass;
336
+
337
+ }
338
+
339
+ getNode() {
340
+
341
+ let node = this.node;
342
+
343
+ if ( node !== null ) { return node; }
344
+
345
+ //
346
+
347
+ const type = this.type;
348
+
349
+ if ( this.isConst ) {
350
+
351
+ const nodeClass = this.getClassFromType( type );
352
+
353
+ node = nodeClass( ...this.getVector() );
354
+
355
+ } else if ( this.hasReference ) {
356
+
357
+ node = this.materialX.getMaterialXNode( this.referencePath ).getNode();
358
+
359
+ } else {
360
+
361
+ const element = this.element;
362
+
363
+ if ( element === 'convert' ) {
364
+
365
+ const nodeClass = this.getClassFromType( type );
366
+
367
+ node = nodeClass( this.getNodeByName( 'in' ) );
368
+
369
+ } else if ( element === 'constant' ) {
370
+
371
+ node = this.getNodeByName( 'value' );
372
+
373
+ } else if ( element === 'position' ) {
374
+
375
+ node = positionLocal;
376
+
377
+ } else if ( element === 'tiledimage' ) {
378
+
379
+ const file = this.getChildByName( 'file' );
380
+
381
+ const textureFile = file.getTexture();
382
+ const uvTiling = mx_transform_uv( ...this.getNodesByNames( [ 'uvtiling', 'uvoffset' ] ) );
383
+
384
+ node = texture( textureFile, uvTiling );
385
+
386
+ const colorSpaceNode = file.getColorSpaceNode();
387
+
388
+ if ( colorSpaceNode ) {
389
+
390
+ node = colorSpaceNode( node );
391
+
392
+ }
393
+
394
+ } else if ( element === 'image' ) {
395
+
396
+ const file = this.getChildByName( 'file' );
397
+ const uvNode = this.getNodeByName( 'texcoord' );
398
+
399
+ const textureFile = file.getTexture();
400
+
401
+ node = texture( textureFile, uvNode );
402
+
403
+ const colorSpaceNode = file.getColorSpaceNode();
404
+
405
+ if ( colorSpaceNode ) {
406
+
407
+ node = colorSpaceNode( node );
408
+
409
+ }
410
+
411
+ } else if ( MtlXLibrary[ element ] !== undefined ) {
412
+
413
+ const nodeElement = MtlXLibrary[ element ];
414
+
415
+ node = nodeElement.nodeFunc( ...this.getNodesByNames( ...nodeElement.params ) );
416
+
417
+ }
418
+
419
+ }
420
+
421
+ //
422
+
423
+ if ( node === null ) {
424
+
425
+ console.warn( `THREE.MaterialXLoader: Unexpected node ${ new XMLSerializer().serializeToString( this.nodeXML ) }.` );
426
+
427
+ node = float( 0 );
428
+
429
+ }
430
+
431
+ //
432
+
433
+ const nodeToTypeClass = this.getClassFromType( type );
434
+
435
+ if ( nodeToTypeClass !== null ) {
436
+
437
+ node = nodeToTypeClass( node );
438
+
439
+ }
440
+
441
+ node.name = this.name;
442
+
443
+ this.node = node;
444
+
445
+ return node;
446
+
447
+ }
448
+
449
+ getChildByName( name ) {
450
+
451
+ for ( const input of this.children ) {
452
+
453
+ if ( input.name === name ) {
454
+
455
+ return input;
456
+
457
+ }
458
+
459
+ }
460
+
461
+ }
462
+
463
+ getNodes() {
464
+
465
+ const nodes = {};
466
+
467
+ for ( const input of this.children ) {
468
+
469
+ const node = input.getNode();
470
+
471
+ nodes[ node.name ] = node;
472
+
473
+ }
474
+
475
+ return nodes;
476
+
477
+ }
478
+
479
+ getNodeByName( name ) {
480
+
481
+ return this.getChildByName( name )?.getNode();
482
+
483
+ }
484
+
485
+ getNodesByNames( ...names ) {
486
+
487
+ const nodes = [];
488
+
489
+ for ( const name of names ) {
490
+
491
+ const node = this.getNodeByName( name );
492
+
493
+ if ( node ) nodes.push( node );
494
+
495
+ }
496
+
497
+ return nodes;
498
+
499
+ }
500
+
501
+ getValue() {
502
+
503
+ return this.value.trim();
504
+
505
+ }
506
+
507
+ getVector() {
508
+
509
+ const vector = [];
510
+
511
+ for ( const val of this.getValue().split( /[,|\s]/ ) ) {
512
+
513
+ if ( val !== '' ) {
514
+
515
+ vector.push( Number( val.trim() ) );
516
+
517
+ }
518
+
519
+ }
520
+
521
+ return vector;
522
+
523
+ }
524
+
525
+ getAttribute( name ) {
526
+
527
+ return this.nodeXML.getAttribute( name );
528
+
529
+ }
530
+
531
+ getRecursiveAttribute( name ) {
532
+
533
+ let attribute = this.nodeXML.getAttribute( name );
534
+
535
+ if ( attribute === null && this.parent !== null ) {
536
+
537
+ attribute = this.parent.getRecursiveAttribute( name );
538
+
539
+ }
540
+
541
+ return attribute;
542
+
543
+ }
544
+
545
+ setStandardSurfaceToGltfPBR( material ) {
546
+
547
+ const inputs = this.getNodes();
548
+
549
+ //
550
+
551
+ let colorNode = null;
552
+
553
+ if ( inputs.base && inputs.base_color ) colorNode = mul( inputs.base, inputs.base_color );
554
+ else if ( inputs.base ) colorNode = inputs.base;
555
+ else if ( inputs.base_color ) colorNode = inputs.base_color;
556
+
557
+ //
558
+
559
+ let roughnessNode = null;
560
+
561
+ if ( inputs.specular_roughness ) roughnessNode = inputs.specular_roughness;
562
+
563
+ //
564
+
565
+ let metalnessNode = null;
566
+
567
+ if ( inputs.metalness ) metalnessNode = inputs.metalness;
568
+
569
+ //
570
+
571
+ let clearcoatNode = null;
572
+ let clearcoatRoughnessNode = null;
573
+
574
+ if ( inputs.coat ) clearcoatNode = inputs.coat;
575
+ if ( inputs.coat_roughness ) clearcoatRoughnessNode = inputs.coat_roughness;
576
+
577
+ if ( inputs.coat_color ) {
578
+
579
+ colorNode = colorNode ? mul( colorNode, inputs.coat_color ) : colorNode;
580
+
581
+ }
582
+
583
+ //
584
+
585
+ material.colorNode = colorNode || color( 0.8, 0.8, 0.8 );
586
+ material.roughnessNode = roughnessNode || float( 0.2 );
587
+ material.metalnessNode = metalnessNode || float( 0 );
588
+ material.clearcoatNode = clearcoatNode || float( 0 );
589
+ material.clearcoatRoughnessNode = clearcoatRoughnessNode || float( 0 );
590
+
591
+ }
592
+
593
+ /*setGltfPBR( material ) {
594
+
595
+ const inputs = this.getNodes();
596
+
597
+ console.log( inputs );
598
+
599
+ }*/
600
+
601
+ setMaterial( material ) {
602
+
603
+ const element = this.element;
604
+
605
+ if ( element === 'gltf_pbr' ) {
606
+
607
+ //this.setGltfPBR( material );
608
+
609
+ } else if ( element === 'standard_surface' ) {
610
+
611
+ this.setStandardSurfaceToGltfPBR( material );
612
+
613
+ }
614
+
615
+ }
616
+
617
+ toMaterial() {
618
+
619
+ const material = new MeshPhysicalNodeMaterial();
620
+ material.name = this.name;
621
+
622
+ for ( const nodeX of this.children ) {
623
+
624
+ const shaderProperties = this.materialX.getMaterialXNode( nodeX.nodeName );
625
+ shaderProperties.setMaterial( material );
626
+
627
+ }
628
+
629
+ return material;
630
+
631
+ }
632
+
633
+ toMaterials() {
634
+
635
+ const materials = {};
636
+
637
+ for ( const nodeX of this.children ) {
638
+
639
+ if ( nodeX.element === 'surfacematerial' ) {
640
+
641
+ const material = nodeX.toMaterial();
642
+
643
+ materials[ material.name ] = material;
644
+
645
+ }
646
+
647
+ }
648
+
649
+ return materials;
650
+
651
+ }
652
+
653
+ add( materialXNode ) {
654
+
655
+ materialXNode.parent = this;
656
+
657
+ this.children.push( materialXNode );
658
+
659
+ }
660
+
661
+ }
662
+
663
+ class MaterialX {
664
+
665
+ constructor( manager, path ) {
666
+
667
+ this.manager = manager;
668
+ this.path = path;
669
+ this.resourcePath = '';
670
+
671
+ this.nodesXLib = new Map();
672
+ //this.nodesXRefLib = new WeakMap();
673
+
674
+ this.textureLoader = new TextureLoader( manager );
675
+
676
+ }
677
+
678
+ addMaterialXNode( materialXNode ) {
679
+
680
+ this.nodesXLib.set( materialXNode.nodePath, materialXNode );
681
+
682
+ }
683
+
684
+ /*getMaterialXNodeFromXML( xmlNode ) {
685
+
686
+ return this.nodesXRefLib.get( xmlNode );
687
+
688
+ }*/
689
+
690
+ getMaterialXNode( ...names ) {
691
+
692
+ return this.nodesXLib.get( names.join( '/' ) );
693
+
694
+ }
695
+
696
+ parseNode( nodeXML, nodePath = '' ) {
697
+
698
+ const materialXNode = new MaterialXNode( this, nodeXML, nodePath );
699
+ if ( materialXNode.nodePath ) this.addMaterialXNode( materialXNode );
700
+
701
+ for ( const childNodeXML of nodeXML.children ) {
702
+
703
+ const childMXNode = this.parseNode( childNodeXML, materialXNode.nodePath );
704
+ materialXNode.add( childMXNode );
705
+
706
+ }
707
+
708
+ return materialXNode;
709
+
710
+ }
711
+
712
+ parse( text ) {
713
+
714
+ const rootXML = new DOMParser().parseFromString( text, 'application/xml' ).documentElement;
715
+
716
+ this.textureLoader.setPath( this.path );
717
+
718
+ //
719
+
720
+ const materials = this.parseNode( rootXML ).toMaterials();
721
+
722
+ return { materials };
723
+
724
+ }
725
+
726
+ }
727
+
728
+ export { MaterialXLoader };