@needle-tools/three 0.146.10 → 0.153.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.
Files changed (865) hide show
  1. package/LICENSE +1 -1
  2. package/build/three.cjs +39486 -20286
  3. package/build/three.js +39471 -20270
  4. package/build/three.min.js +3 -2
  5. package/build/three.module.js +6717 -5427
  6. package/build/three.module.min.js +6 -0
  7. package/examples/jsm/animation/AnimationClipCreator.js +5 -3
  8. package/examples/jsm/cameras/CinematicCamera.js +1 -2
  9. package/examples/jsm/capabilities/WebGPU.js +17 -5
  10. package/examples/jsm/controls/ArcballControls.js +1828 -1821
  11. package/examples/jsm/controls/MapControls.js +28 -0
  12. package/examples/jsm/controls/OrbitControls.js +26 -53
  13. package/examples/jsm/controls/PointerLockControls.js +70 -65
  14. package/examples/jsm/controls/TrackballControls.js +18 -4
  15. package/examples/jsm/controls/TransformControls.js +0 -1
  16. package/examples/jsm/csm/CSM.js +11 -5
  17. package/examples/jsm/csm/CSMShader.js +7 -6
  18. package/examples/jsm/effects/AnaglyphEffect.js +6 -20
  19. package/examples/jsm/effects/AsciiEffect.js +3 -6
  20. package/examples/jsm/effects/OutlineEffect.js +1 -15
  21. package/examples/jsm/effects/ParallaxBarrierEffect.js +3 -0
  22. package/examples/jsm/exporters/DRACOExporter.js +53 -11
  23. package/examples/jsm/exporters/EXRExporter.js +3 -9
  24. package/examples/jsm/exporters/GLTFExporter.js +561 -154
  25. package/examples/jsm/exporters/KTX2Exporter.js +34 -23
  26. package/examples/jsm/exporters/MMDExporter.js +1 -1
  27. package/examples/jsm/exporters/PLYExporter.js +8 -1
  28. package/examples/jsm/exporters/STLExporter.js +8 -4
  29. package/examples/jsm/exporters/USDZExporter.js +305 -792
  30. package/examples/jsm/geometries/ConvexGeometry.js +0 -6
  31. package/examples/jsm/geometries/ParametricGeometry.js +10 -0
  32. package/examples/jsm/helpers/OctreeHelper.js +1 -0
  33. package/examples/jsm/helpers/ViewHelper.js +71 -57
  34. package/examples/jsm/interactive/HTMLMesh.js +16 -3
  35. package/examples/jsm/interactive/InteractiveGroup.js +1 -1
  36. package/examples/{js → jsm}/libs/basis/README.md +4 -4
  37. package/examples/jsm/libs/draco/draco_decoder.js +34 -0
  38. package/examples/jsm/libs/draco/draco_decoder.wasm +0 -0
  39. package/examples/jsm/libs/draco/draco_wasm_wrapper.js +117 -0
  40. package/examples/jsm/libs/draco/gltf/draco_decoder.js +33 -0
  41. package/examples/jsm/libs/draco/gltf/draco_decoder.wasm +0 -0
  42. package/examples/jsm/libs/draco/gltf/draco_wasm_wrapper.js +116 -0
  43. package/examples/jsm/libs/lil-gui.module.min.js +2 -2
  44. package/examples/jsm/libs/tween.module.js +803 -0
  45. package/examples/jsm/lights/IESSpotLight.js +25 -0
  46. package/examples/jsm/lights/LightProbeGenerator.js +11 -9
  47. package/examples/jsm/lines/LineSegments2.js +16 -10
  48. package/examples/jsm/loaders/3DMLoader.js +8 -5
  49. package/examples/jsm/loaders/3MFLoader.js +12 -11
  50. package/examples/jsm/loaders/AMFLoader.js +2 -3
  51. package/examples/jsm/loaders/BVHLoader.js +2 -2
  52. package/examples/jsm/loaders/ColladaLoader.js +15 -16
  53. package/examples/jsm/loaders/DRACOLoader.js +69 -18
  54. package/examples/jsm/loaders/EXRLoader.js +23 -24
  55. package/examples/jsm/loaders/FBXLoader.js +34 -50
  56. package/examples/jsm/loaders/GCodeLoader.js +1 -2
  57. package/examples/jsm/loaders/GLTFLoader.js +417 -895
  58. package/examples/jsm/loaders/GLTFLoaderAnimationPointer.js +684 -0
  59. package/examples/jsm/loaders/HDRCubeTextureLoader.js +4 -4
  60. package/examples/jsm/loaders/IESLoader.js +337 -0
  61. package/examples/jsm/loaders/KMZLoader.js +4 -4
  62. package/examples/jsm/loaders/KTX2Loader.js +145 -69
  63. package/examples/jsm/loaders/LDrawLoader.js +20 -18
  64. package/examples/jsm/loaders/LWOLoader.js +12 -29
  65. package/examples/jsm/loaders/LottieLoader.js +3 -1
  66. package/examples/jsm/loaders/MMDLoader.js +49 -18
  67. package/examples/jsm/loaders/MTLLoader.js +2 -2
  68. package/examples/jsm/loaders/MaterialXLoader.js +9 -3
  69. package/examples/jsm/loaders/NRRDLoader.js +33 -5
  70. package/examples/jsm/loaders/OBJLoader.js +1 -1
  71. package/examples/jsm/loaders/PCDLoader.js +26 -12
  72. package/examples/jsm/loaders/PDBLoader.js +7 -2
  73. package/examples/jsm/loaders/PLYLoader.js +254 -109
  74. package/examples/jsm/loaders/RGBELoader.js +3 -3
  75. package/examples/jsm/loaders/STLLoader.js +9 -5
  76. package/examples/jsm/loaders/SVGLoader.js +36 -27
  77. package/examples/jsm/loaders/TTFLoader.js +1 -8
  78. package/examples/jsm/loaders/TiltLoader.js +13 -7
  79. package/examples/jsm/loaders/USDZLoader.js +6 -6
  80. package/examples/jsm/loaders/VOXLoader.js +8 -2
  81. package/examples/jsm/loaders/VRMLLoader.js +44 -16
  82. package/examples/jsm/loaders/VTKLoader.js +19 -10
  83. package/examples/jsm/loaders/XYZLoader.js +9 -3
  84. package/examples/jsm/loaders/lwo/IFFParser.js +19 -19
  85. package/examples/jsm/materials/MeshGouraudMaterial.js +0 -3
  86. package/examples/jsm/math/ConvexHull.js +3 -3
  87. package/examples/jsm/math/Lut.js +5 -4
  88. package/examples/jsm/math/MeshSurfaceSampler.js +7 -9
  89. package/examples/jsm/math/Octree.js +1 -1
  90. package/examples/jsm/misc/ConvexObjectBreaker.js +2 -8
  91. package/examples/jsm/misc/GPUComputationRenderer.js +6 -5
  92. package/examples/jsm/misc/MD2Character.js +2 -2
  93. package/examples/jsm/misc/MD2CharacterComplex.js +2 -2
  94. package/examples/jsm/misc/ProgressiveLightMap.js +12 -10
  95. package/examples/jsm/misc/RollerCoaster.js +7 -1
  96. package/examples/jsm/misc/Volume.js +20 -5
  97. package/examples/jsm/misc/VolumeSlice.js +3 -1
  98. package/examples/jsm/modifiers/CurveModifier.js +1 -0
  99. package/examples/jsm/modifiers/TessellateModifier.js +19 -19
  100. package/examples/jsm/nodes/Nodes.js +144 -335
  101. package/examples/jsm/nodes/accessors/BitangentNode.js +43 -16
  102. package/examples/jsm/nodes/accessors/BufferAttributeNode.js +86 -0
  103. package/examples/jsm/nodes/accessors/BufferNode.js +6 -0
  104. package/examples/jsm/nodes/accessors/CameraNode.js +12 -2
  105. package/examples/jsm/nodes/accessors/CubeTextureNode.js +27 -33
  106. package/examples/jsm/nodes/accessors/ExtendedMaterialNode.js +58 -0
  107. package/examples/jsm/nodes/accessors/InstanceNode.js +41 -26
  108. package/examples/jsm/nodes/accessors/MaterialNode.js +155 -38
  109. package/examples/jsm/nodes/accessors/MaterialReferenceNode.js +16 -0
  110. package/examples/jsm/nodes/accessors/ModelNode.js +11 -0
  111. package/examples/jsm/nodes/accessors/ModelViewProjectionNode.js +13 -14
  112. package/examples/jsm/nodes/accessors/NormalNode.js +35 -19
  113. package/examples/jsm/nodes/accessors/Object3DNode.js +32 -12
  114. package/examples/jsm/nodes/accessors/PointUVNode.js +6 -1
  115. package/examples/jsm/nodes/accessors/PositionNode.js +38 -23
  116. package/examples/jsm/nodes/accessors/ReferenceNode.js +21 -14
  117. package/examples/jsm/nodes/accessors/ReflectVectorNode.js +11 -7
  118. package/examples/jsm/nodes/accessors/SkinningNode.js +43 -40
  119. package/examples/jsm/nodes/accessors/StorageBufferNode.js +6 -0
  120. package/examples/jsm/nodes/accessors/TangentNode.js +28 -20
  121. package/examples/jsm/nodes/accessors/TextureNode.js +80 -12
  122. package/examples/jsm/nodes/accessors/UVNode.js +6 -0
  123. package/examples/jsm/nodes/accessors/UserDataNode.js +6 -0
  124. package/examples/jsm/nodes/code/CodeNode.js +75 -0
  125. package/examples/jsm/nodes/code/ExpressionNode.js +37 -0
  126. package/examples/jsm/nodes/{core → code}/FunctionCallNode.js +15 -1
  127. package/examples/jsm/nodes/{core → code}/FunctionNode.js +8 -7
  128. package/examples/jsm/nodes/code/ScriptableNode.js +488 -0
  129. package/examples/jsm/nodes/code/ScriptableValueNode.js +167 -0
  130. package/examples/jsm/nodes/core/ArrayUniformNode.js +3 -0
  131. package/examples/jsm/nodes/core/AttributeNode.js +17 -9
  132. package/examples/jsm/nodes/core/BypassNode.js +9 -2
  133. package/examples/jsm/nodes/core/CacheNode.js +46 -0
  134. package/examples/jsm/nodes/core/ConstNode.js +3 -0
  135. package/examples/jsm/nodes/core/ContextNode.js +8 -1
  136. package/examples/jsm/nodes/core/InputNode.js +26 -5
  137. package/examples/jsm/nodes/core/InstanceIndexNode.js +26 -2
  138. package/examples/jsm/nodes/core/LightingModel.js +16 -0
  139. package/examples/jsm/nodes/core/Node.js +129 -35
  140. package/examples/jsm/nodes/core/NodeAttribute.js +2 -1
  141. package/examples/jsm/nodes/core/NodeBuilder.js +271 -121
  142. package/examples/jsm/nodes/core/NodeCache.js +26 -0
  143. package/examples/jsm/nodes/core/NodeFrame.js +56 -5
  144. package/examples/jsm/nodes/core/NodeUtils.js +115 -28
  145. package/examples/jsm/nodes/core/PropertyNode.js +19 -2
  146. package/examples/jsm/nodes/core/StackNode.js +99 -0
  147. package/examples/jsm/nodes/core/TempNode.js +11 -3
  148. package/examples/jsm/nodes/core/UniformNode.js +16 -1
  149. package/examples/jsm/nodes/core/VarNode.js +21 -29
  150. package/examples/jsm/nodes/core/VaryingNode.js +15 -2
  151. package/examples/jsm/nodes/core/constants.js +6 -0
  152. package/examples/jsm/nodes/display/BlendModeNode.js +25 -11
  153. package/examples/jsm/nodes/display/ColorAdjustmentNode.js +30 -14
  154. package/examples/jsm/nodes/display/ColorSpaceNode.js +39 -27
  155. package/examples/jsm/nodes/display/FrontFacingNode.js +7 -1
  156. package/examples/jsm/nodes/display/NormalMapNode.js +31 -18
  157. package/examples/jsm/nodes/display/PosterizeNode.js +10 -3
  158. package/examples/jsm/nodes/display/ToneMappingNode.js +101 -11
  159. package/examples/jsm/nodes/display/ViewportNode.js +27 -18
  160. package/examples/jsm/nodes/display/ViewportSharedTextureNode.js +30 -0
  161. package/examples/jsm/nodes/display/ViewportTextureNode.js +67 -0
  162. package/examples/jsm/nodes/fog/FogExp2Node.js +35 -0
  163. package/examples/jsm/nodes/fog/FogNode.js +12 -6
  164. package/examples/jsm/nodes/fog/FogRangeNode.js +12 -5
  165. package/examples/jsm/nodes/functions/BSDF/BRDF_BlinnPhong.js +30 -0
  166. package/examples/jsm/nodes/functions/BSDF/BRDF_GGX.js +10 -13
  167. package/examples/jsm/nodes/functions/BSDF/BRDF_Lambert.js +2 -2
  168. package/examples/jsm/nodes/functions/BSDF/DFGApprox.js +8 -6
  169. package/examples/jsm/nodes/functions/BSDF/D_GGX.js +4 -4
  170. package/examples/jsm/nodes/functions/BSDF/F_Schlick.js +3 -3
  171. package/examples/jsm/nodes/functions/BSDF/V_GGX_SmithCorrelated.js +7 -5
  172. package/examples/jsm/nodes/functions/PhongLightingModel.js +28 -0
  173. package/examples/jsm/nodes/functions/PhysicalLightingModel.js +35 -36
  174. package/examples/jsm/nodes/functions/material/getGeometryRoughness.js +4 -3
  175. package/examples/jsm/nodes/functions/material/getRoughness.js +4 -4
  176. package/examples/jsm/nodes/geometry/RangeNode.js +50 -55
  177. package/examples/jsm/nodes/gpgpu/ComputeNode.js +9 -2
  178. package/examples/jsm/nodes/lighting/AONode.js +5 -3
  179. package/examples/jsm/nodes/lighting/AmbientLightNode.js +27 -0
  180. package/examples/jsm/nodes/lighting/AnalyticLightNode.js +114 -5
  181. package/examples/jsm/nodes/lighting/DirectionalLightNode.js +43 -0
  182. package/examples/jsm/nodes/lighting/EnvironmentNode.js +121 -35
  183. package/examples/jsm/nodes/lighting/HemisphereLightNode.js +15 -10
  184. package/examples/jsm/nodes/lighting/IESSpotLightNode.js +39 -0
  185. package/examples/jsm/nodes/lighting/LightNode.js +57 -0
  186. package/examples/jsm/nodes/lighting/LightUtils.js +17 -0
  187. package/examples/jsm/nodes/lighting/LightingContextNode.js +30 -8
  188. package/examples/jsm/nodes/lighting/LightingNode.js +3 -1
  189. package/examples/jsm/nodes/lighting/LightsNode.js +18 -10
  190. package/examples/jsm/nodes/lighting/PointLightNode.js +71 -0
  191. package/examples/jsm/nodes/lighting/SpotLightNode.js +92 -0
  192. package/examples/jsm/nodes/loaders/NodeLoader.js +5 -4
  193. package/examples/jsm/nodes/loaders/NodeMaterialLoader.js +4 -20
  194. package/examples/jsm/nodes/materials/LineBasicNodeMaterial.js +6 -9
  195. package/examples/jsm/nodes/materials/Materials.js +11 -55
  196. package/examples/jsm/nodes/materials/MeshBasicNodeMaterial.js +5 -11
  197. package/examples/jsm/nodes/materials/MeshNormalNodeMaterial.js +48 -0
  198. package/examples/jsm/nodes/materials/MeshPhongNodeMaterial.js +74 -0
  199. package/examples/jsm/nodes/materials/MeshPhysicalNodeMaterial.js +6 -6
  200. package/examples/jsm/nodes/materials/MeshStandardNodeMaterial.js +21 -96
  201. package/examples/jsm/nodes/materials/NodeMaterial.js +284 -62
  202. package/examples/jsm/nodes/materials/PointsNodeMaterial.js +7 -1
  203. package/examples/jsm/nodes/materials/SpriteNodeMaterial.js +29 -25
  204. package/examples/jsm/nodes/materialx/MaterialXNodes.js +31 -22
  205. package/examples/jsm/nodes/materialx/lib/mx_hsv.js +1 -1
  206. package/examples/jsm/nodes/materialx/lib/mx_noise.js +2 -1
  207. package/examples/jsm/nodes/materialx/lib/mx_transform_color.js +2 -1
  208. package/examples/jsm/nodes/math/CondNode.js +43 -17
  209. package/examples/jsm/nodes/math/MathNode.js +178 -73
  210. package/examples/jsm/nodes/math/OperatorNode.js +52 -2
  211. package/examples/jsm/nodes/procedural/CheckerNode.js +14 -6
  212. package/examples/jsm/nodes/shadernode/ShaderNode.js +186 -63
  213. package/examples/jsm/nodes/utils/ArrayElementNode.js +4 -2
  214. package/examples/jsm/nodes/utils/ConvertNode.js +19 -1
  215. package/examples/jsm/nodes/utils/DiscardNode.js +26 -0
  216. package/examples/jsm/nodes/utils/EquirectUVNode.js +10 -4
  217. package/examples/jsm/nodes/utils/JoinNode.js +4 -1
  218. package/examples/jsm/nodes/utils/LoopNode.js +186 -0
  219. package/examples/jsm/nodes/utils/MatcapUVNode.js +11 -4
  220. package/examples/jsm/nodes/utils/MaxMipLevelNode.js +18 -5
  221. package/examples/jsm/nodes/utils/OscNode.js +21 -14
  222. package/examples/jsm/nodes/utils/PackingNode.js +55 -0
  223. package/examples/jsm/nodes/utils/RemapNode.js +13 -5
  224. package/examples/jsm/nodes/utils/RotateUVNode.js +18 -7
  225. package/examples/jsm/nodes/utils/SpecularMIPLevelNode.js +37 -0
  226. package/examples/jsm/nodes/utils/SplitNode.js +7 -5
  227. package/examples/jsm/nodes/utils/SpriteSheetUVNode.js +15 -30
  228. package/examples/jsm/nodes/utils/TimerNode.js +16 -6
  229. package/examples/jsm/nodes/utils/TriplanarTexturesNode.js +21 -10
  230. package/examples/jsm/objects/GroundProjectedSkybox.js +172 -0
  231. package/examples/jsm/objects/Lensflare.js +3 -4
  232. package/examples/jsm/objects/MarchingCubes.js +5 -1
  233. package/examples/jsm/objects/Reflector.js +7 -4
  234. package/examples/jsm/objects/Refractor.js +4 -4
  235. package/examples/jsm/objects/ShadowMesh.js +3 -3
  236. package/examples/jsm/objects/Water.js +2 -1
  237. package/examples/jsm/physics/AmmoPhysics.js +27 -28
  238. package/examples/jsm/physics/RapierPhysics.js +199 -0
  239. package/examples/jsm/postprocessing/AfterimagePass.js +3 -2
  240. package/examples/jsm/postprocessing/BloomPass.js +7 -4
  241. package/examples/jsm/postprocessing/BokehPass.js +3 -8
  242. package/examples/jsm/postprocessing/DotScreenPass.js +1 -2
  243. package/examples/jsm/postprocessing/EffectComposer.js +5 -95
  244. package/examples/jsm/postprocessing/FilmPass.js +1 -2
  245. package/examples/jsm/postprocessing/GlitchPass.js +0 -2
  246. package/examples/jsm/postprocessing/HalftonePass.js +0 -6
  247. package/examples/jsm/postprocessing/OutlinePass.js +7 -7
  248. package/examples/jsm/postprocessing/OutputPass.js +72 -0
  249. package/examples/jsm/postprocessing/Pass.js +2 -0
  250. package/examples/jsm/postprocessing/RenderPixelatedPass.js +4 -3
  251. package/examples/jsm/postprocessing/SAOPass.js +4 -26
  252. package/examples/jsm/postprocessing/SMAAPass.js +5 -8
  253. package/examples/jsm/postprocessing/SSAARenderPass.js +15 -6
  254. package/examples/jsm/postprocessing/SSAOPass.js +4 -14
  255. package/examples/jsm/postprocessing/SSRPass.js +3 -7
  256. package/examples/jsm/postprocessing/SavePass.js +2 -3
  257. package/examples/jsm/postprocessing/ShaderPass.js +1 -0
  258. package/examples/jsm/postprocessing/TAARenderPass.js +3 -2
  259. package/examples/jsm/postprocessing/TexturePass.js +0 -2
  260. package/examples/jsm/postprocessing/UnrealBloomPass.js +4 -11
  261. package/examples/jsm/renderers/CSS2DRenderer.js +6 -1
  262. package/examples/jsm/renderers/CSS3DRenderer.js +27 -5
  263. package/examples/jsm/renderers/{webgpu/WebGPUAnimation.js → common/Animation.js} +4 -4
  264. package/examples/jsm/renderers/common/Attributes.js +75 -0
  265. package/examples/jsm/renderers/common/Backend.js +160 -0
  266. package/examples/jsm/renderers/common/Background.js +133 -0
  267. package/examples/jsm/renderers/common/Binding.js +11 -0
  268. package/examples/jsm/renderers/common/Bindings.js +169 -0
  269. package/examples/jsm/renderers/common/Buffer.js +38 -0
  270. package/examples/jsm/renderers/{webgpu/WebGPUBufferUtils.js → common/BufferUtils.js} +2 -2
  271. package/examples/jsm/renderers/common/ChainMap.js +89 -0
  272. package/examples/jsm/renderers/common/ComputePipeline.js +17 -0
  273. package/examples/jsm/renderers/common/Constants.js +14 -0
  274. package/examples/jsm/renderers/common/CubeRenderTarget.js +65 -0
  275. package/examples/jsm/renderers/common/DataMap.js +54 -0
  276. package/examples/jsm/renderers/common/Geometries.js +215 -0
  277. package/examples/jsm/renderers/{webgpu/WebGPUInfo.js → common/Info.js} +2 -3
  278. package/examples/jsm/renderers/common/Pipeline.js +13 -0
  279. package/examples/jsm/renderers/common/Pipelines.js +309 -0
  280. package/examples/jsm/renderers/common/ProgrammableStage.js +18 -0
  281. package/examples/jsm/renderers/common/RenderContext.js +37 -0
  282. package/examples/jsm/renderers/common/RenderContexts.js +38 -0
  283. package/examples/jsm/renderers/{webgpu/WebGPURenderLists.js → common/RenderList.js} +26 -47
  284. package/examples/jsm/renderers/common/RenderLists.js +38 -0
  285. package/examples/jsm/renderers/common/RenderObject.js +95 -0
  286. package/examples/jsm/renderers/common/RenderObjects.js +92 -0
  287. package/examples/jsm/renderers/common/RenderPipeline.js +16 -0
  288. package/examples/jsm/renderers/common/RenderTarget.js +15 -0
  289. package/examples/jsm/renderers/common/Renderer.js +822 -0
  290. package/examples/jsm/renderers/common/SampledTexture.js +80 -0
  291. package/examples/jsm/renderers/common/Sampler.js +18 -0
  292. package/examples/jsm/renderers/common/StorageBuffer.js +17 -0
  293. package/examples/jsm/renderers/common/Textures.js +206 -0
  294. package/examples/jsm/renderers/{webgpu/WebGPUUniform.js → common/Uniform.js} +13 -9
  295. package/examples/jsm/renderers/common/UniformBuffer.js +15 -0
  296. package/examples/jsm/renderers/{webgpu/WebGPUUniformsGroup.js → common/UniformsGroup.js} +13 -13
  297. package/examples/jsm/renderers/common/nodes/NodeRender.js +302 -0
  298. package/examples/jsm/renderers/{webgpu/nodes/WebGPUNodeSampledTexture.js → common/nodes/NodeSampledTexture.js} +4 -4
  299. package/examples/jsm/renderers/{webgpu/nodes/WebGPUNodeSampler.js → common/nodes/NodeSampler.js} +3 -3
  300. package/examples/jsm/renderers/{webgpu/nodes/WebGPUNodeUniform.js → common/nodes/NodeUniform.js} +1 -1
  301. package/examples/jsm/renderers/common/nodes/Nodes.js +319 -0
  302. package/examples/jsm/renderers/webgl/nodes/WebGLNodeBuilder.js +35 -31
  303. package/examples/jsm/renderers/webgpu/WebGPUBackend.js +765 -0
  304. package/examples/jsm/renderers/webgpu/WebGPURenderer.js +15 -987
  305. package/examples/jsm/renderers/webgpu/nodes/{WebGPUNodeBuilder.js → WGSLNodeBuilder.js} +117 -90
  306. package/examples/jsm/{nodes/parsers → renderers/webgpu/nodes}/WGSLNodeFunction.js +2 -2
  307. package/examples/jsm/{nodes/parsers → renderers/webgpu/nodes}/WGSLNodeParser.js +1 -1
  308. package/examples/jsm/renderers/webgpu/utils/WebGPUAttributeUtils.js +251 -0
  309. package/examples/jsm/renderers/webgpu/utils/WebGPUBindingUtils.js +145 -0
  310. package/examples/jsm/renderers/webgpu/{constants.js → utils/WebGPUConstants.js} +73 -12
  311. package/examples/jsm/renderers/webgpu/{WebGPURenderPipeline.js → utils/WebGPUPipelineUtils.js} +135 -285
  312. package/examples/jsm/renderers/webgpu/{WebGPUTextureUtils.js → utils/WebGPUTextureMipmapUtils.js} +5 -25
  313. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureUtils.js +855 -0
  314. package/examples/jsm/renderers/webgpu/utils/WebGPUUtils.js +88 -0
  315. package/examples/jsm/shaders/BleachBypassShader.js +2 -0
  316. package/examples/jsm/shaders/BokehShader2.js +3 -0
  317. package/examples/jsm/shaders/ColorifyShader.js +2 -0
  318. package/examples/jsm/shaders/ConvolutionShader.js +2 -0
  319. package/examples/jsm/shaders/CopyShader.js +2 -0
  320. package/examples/jsm/shaders/DotScreenShader.js +2 -0
  321. package/examples/jsm/shaders/ExposureShader.js +44 -0
  322. package/examples/jsm/shaders/FilmShader.js +2 -0
  323. package/examples/jsm/shaders/GammaCorrectionShader.js +2 -0
  324. package/examples/jsm/shaders/HorizontalBlurShader.js +2 -0
  325. package/examples/jsm/shaders/MMDToonShader.js +15 -4
  326. package/examples/jsm/shaders/OutputShader.js +61 -0
  327. package/examples/jsm/shaders/RGBShiftShader.js +4 -2
  328. package/examples/jsm/shaders/SepiaShader.js +2 -0
  329. package/examples/jsm/shaders/ToonShader.js +13 -5
  330. package/examples/jsm/shaders/VelocityShader.js +1 -1
  331. package/examples/jsm/shaders/VerticalBlurShader.js +2 -0
  332. package/examples/jsm/shaders/VignetteShader.js +2 -0
  333. package/examples/jsm/shaders/WaterRefractionShader.js +5 -2
  334. package/examples/jsm/utils/BufferGeometryUtils.js +54 -36
  335. package/examples/jsm/utils/LDrawUtils.js +4 -4
  336. package/examples/jsm/utils/PackedPhongMaterial.js +5 -78
  337. package/examples/jsm/utils/SceneUtils.js +8 -4
  338. package/examples/jsm/utils/SkeletonUtils.js +27 -210
  339. package/examples/jsm/utils/TextureUtils.js +41 -40
  340. package/examples/jsm/webxr/VRButton.js +1 -2
  341. package/examples/jsm/webxr/XRButton.js +198 -0
  342. package/examples/jsm/webxr/XRHandPrimitiveModel.js +1 -0
  343. package/examples/jsm/webxr/XRPlanes.js +100 -0
  344. package/package.json +34 -87
  345. package/src/Three.Legacy.js +19 -110
  346. package/src/Three.js +4 -3
  347. package/src/animation/AnimationUtils.js +13 -1
  348. package/src/audio/Audio.js +7 -2
  349. package/src/audio/PositionalAudio.js +8 -0
  350. package/src/cameras/Camera.js +5 -0
  351. package/src/cameras/CubeCamera.js +76 -13
  352. package/src/cameras/OrthographicCamera.js +1 -1
  353. package/src/cameras/PerspectiveCamera.js +1 -1
  354. package/src/constants.js +22 -2
  355. package/src/core/BufferAttribute.js +150 -9
  356. package/src/core/BufferGeometry.js +4 -10
  357. package/src/core/GLBufferAttribute.js +2 -0
  358. package/src/core/InterleavedBufferAttribute.js +5 -5
  359. package/src/core/Object3D.js +37 -8
  360. package/src/extras/DataUtils.js +7 -1
  361. package/src/extras/ImageUtils.js +2 -2
  362. package/src/extras/PMREMGenerator.js +5 -5
  363. package/src/extras/core/Curve.js +1 -1
  364. package/src/extras/curves/LineCurve.js +6 -4
  365. package/src/extras/curves/LineCurve3.js +13 -0
  366. package/src/geometries/BoxGeometry.js +10 -0
  367. package/src/geometries/CircleGeometry.js +11 -1
  368. package/src/geometries/ConeGeometry.js +1 -1
  369. package/src/geometries/CylinderGeometry.js +11 -1
  370. package/src/geometries/EdgesGeometry.js +10 -0
  371. package/src/geometries/ExtrudeGeometry.js +11 -1
  372. package/src/geometries/LatheGeometry.js +10 -0
  373. package/src/geometries/PlaneGeometry.js +10 -0
  374. package/src/geometries/PolyhedronGeometry.js +11 -1
  375. package/src/geometries/RingGeometry.js +11 -1
  376. package/src/geometries/ShapeGeometry.js +11 -1
  377. package/src/geometries/SphereGeometry.js +12 -2
  378. package/src/geometries/TorusGeometry.js +11 -1
  379. package/src/geometries/TorusKnotGeometry.js +10 -0
  380. package/src/geometries/TubeGeometry.js +10 -0
  381. package/src/geometries/WireframeGeometry.js +10 -0
  382. package/src/helpers/Box3Helper.js +1 -2
  383. package/src/lights/DirectionalLight.js +1 -1
  384. package/src/lights/HemisphereLight.js +1 -1
  385. package/src/lights/SpotLight.js +1 -1
  386. package/src/loaders/AudioLoader.js +14 -8
  387. package/src/loaders/CubeTextureLoader.js +2 -0
  388. package/src/loaders/DataTextureLoader.js +5 -1
  389. package/src/loaders/MaterialLoader.js +8 -0
  390. package/src/loaders/ObjectLoader.js +10 -2
  391. package/src/materials/LineBasicMaterial.js +4 -0
  392. package/src/materials/Material.js +16 -4
  393. package/src/materials/MeshDistanceMaterial.js +0 -9
  394. package/src/materials/MeshPhysicalMaterial.js +32 -6
  395. package/src/materials/ShaderMaterial.js +6 -1
  396. package/src/math/Box2.js +3 -2
  397. package/src/math/Box3.js +49 -64
  398. package/src/math/Color.js +88 -66
  399. package/src/math/ColorManagement.js +75 -16
  400. package/src/math/Euler.js +2 -11
  401. package/src/math/Frustum.js +29 -5
  402. package/src/math/MathUtils.js +43 -1
  403. package/src/math/Matrix3.js +26 -6
  404. package/src/math/Matrix4.js +74 -19
  405. package/src/math/Plane.js +2 -2
  406. package/src/math/Quaternion.js +6 -0
  407. package/src/math/Ray.js +7 -7
  408. package/src/math/Triangle.js +37 -7
  409. package/src/math/Vector2.js +16 -0
  410. package/src/math/Vector3.js +10 -0
  411. package/src/math/interpolants/CubicInterpolant.js +1 -2
  412. package/src/objects/InstancedMesh.js +82 -1
  413. package/src/objects/Mesh.js +108 -76
  414. package/src/objects/Skeleton.js +1 -1
  415. package/src/objects/SkinnedMesh.js +123 -8
  416. package/src/objects/Sprite.js +1 -1
  417. package/src/renderers/WebGLCubeRenderTarget.js +12 -3
  418. package/src/renderers/WebGLMultipleRenderTargets.js +4 -2
  419. package/src/renderers/WebGLRenderTarget.js +14 -2
  420. package/src/renderers/WebGLRenderer.js +1433 -1236
  421. package/src/renderers/shaders/ShaderChunk/alphamap_fragment.glsl.js +1 -1
  422. package/src/renderers/shaders/ShaderChunk/aomap_fragment.glsl.js +1 -1
  423. package/src/renderers/shaders/ShaderChunk/bsdfs.glsl.js +0 -271
  424. package/src/renderers/shaders/ShaderChunk/bumpmap_pars_fragment.glsl.js +5 -5
  425. package/src/renderers/shaders/ShaderChunk/clearcoat_normal_fragment_maps.glsl.js +2 -10
  426. package/src/renderers/shaders/ShaderChunk/clearcoat_pars_fragment.glsl.js +5 -5
  427. package/src/renderers/shaders/ShaderChunk/common.glsl.js +32 -0
  428. package/src/renderers/shaders/ShaderChunk/cube_uv_reflection_fragment.glsl.js +1 -1
  429. package/src/renderers/shaders/ShaderChunk/displacementmap_vertex.glsl.js +1 -1
  430. package/src/renderers/shaders/ShaderChunk/emissivemap_fragment.glsl.js +1 -1
  431. package/src/renderers/shaders/ShaderChunk/envmap_physical_pars_fragment.glsl.js +26 -3
  432. package/src/renderers/shaders/ShaderChunk/lightmap_fragment.glsl.js +1 -1
  433. package/src/renderers/shaders/ShaderChunk/lights_fragment_begin.glsl.js +3 -3
  434. package/src/renderers/shaders/ShaderChunk/lights_fragment_maps.glsl.js +10 -2
  435. package/src/renderers/shaders/ShaderChunk/lights_pars_begin.glsl.js +11 -11
  436. package/src/renderers/shaders/ShaderChunk/lights_physical_fragment.glsl.js +39 -13
  437. package/src/renderers/shaders/ShaderChunk/lights_physical_pars_fragment.glsl.js +306 -10
  438. package/src/renderers/shaders/ShaderChunk/map_fragment.glsl.js +2 -10
  439. package/src/renderers/shaders/ShaderChunk/map_particle_fragment.glsl.js +9 -1
  440. package/src/renderers/shaders/ShaderChunk/map_particle_pars_fragment.glsl.js +10 -2
  441. package/src/renderers/shaders/ShaderChunk/metalnessmap_fragment.glsl.js +1 -1
  442. package/src/renderers/shaders/ShaderChunk/normal_fragment_begin.glsl.js +32 -10
  443. package/src/renderers/shaders/ShaderChunk/normal_fragment_maps.glsl.js +5 -13
  444. package/src/renderers/shaders/ShaderChunk/normalmap_pars_fragment.glsl.js +7 -7
  445. package/src/renderers/shaders/ShaderChunk/output_fragment.glsl.js +1 -2
  446. package/src/renderers/shaders/ShaderChunk/packing.glsl.js +11 -5
  447. package/src/renderers/shaders/ShaderChunk/roughnessmap_fragment.glsl.js +1 -1
  448. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_fragment.glsl.js +4 -11
  449. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_vertex.glsl.js +2 -2
  450. package/src/renderers/shaders/ShaderChunk/shadowmap_vertex.glsl.js +39 -34
  451. package/src/renderers/shaders/ShaderChunk/specularmap_fragment.glsl.js +1 -1
  452. package/src/renderers/shaders/ShaderChunk/tonemapping_pars_fragment.glsl.js +1 -1
  453. package/src/renderers/shaders/ShaderChunk/transmission_fragment.glsl.js +5 -5
  454. package/src/renderers/shaders/ShaderChunk/transmission_pars_fragment.glsl.js +101 -16
  455. package/src/renderers/shaders/ShaderChunk/uv_pars_fragment.glsl.js +113 -1
  456. package/src/renderers/shaders/ShaderChunk/uv_pars_vertex.glsl.js +134 -6
  457. package/src/renderers/shaders/ShaderChunk/uv_vertex.glsl.js +116 -1
  458. package/src/renderers/shaders/ShaderChunk.js +0 -6
  459. package/src/renderers/shaders/ShaderLib/background.glsl.js +0 -8
  460. package/src/renderers/shaders/ShaderLib/linedashed.glsl.js +5 -0
  461. package/src/renderers/shaders/ShaderLib/meshbasic.glsl.js +1 -4
  462. package/src/renderers/shaders/ShaderLib/meshlambert.glsl.js +0 -3
  463. package/src/renderers/shaders/ShaderLib/meshnormal.glsl.js +3 -3
  464. package/src/renderers/shaders/ShaderLib/meshphong.glsl.js +0 -3
  465. package/src/renderers/shaders/ShaderLib/meshphysical.glsl.js +16 -12
  466. package/src/renderers/shaders/ShaderLib/meshtoon.glsl.js +0 -3
  467. package/src/renderers/shaders/ShaderLib/points.glsl.js +13 -0
  468. package/src/renderers/shaders/ShaderLib/shadow.glsl.js +5 -0
  469. package/src/renderers/shaders/ShaderLib.js +18 -4
  470. package/src/renderers/shaders/UniformsLib.js +27 -15
  471. package/src/renderers/shaders/UniformsUtils.js +12 -3
  472. package/src/renderers/webgl/WebGLBackground.js +23 -12
  473. package/src/renderers/webgl/WebGLBindingStates.js +13 -5
  474. package/src/renderers/webgl/WebGLCapabilities.js +1 -2
  475. package/src/renderers/webgl/WebGLClipping.js +7 -3
  476. package/src/renderers/webgl/WebGLGeometries.js +12 -0
  477. package/src/renderers/webgl/WebGLInfo.js +0 -1
  478. package/src/renderers/webgl/WebGLLights.js +2 -2
  479. package/src/renderers/webgl/WebGLMaterials.js +123 -234
  480. package/src/renderers/webgl/WebGLMorphtargets.js +1 -1
  481. package/src/renderers/webgl/WebGLProgram.js +130 -48
  482. package/src/renderers/webgl/WebGLPrograms.js +210 -130
  483. package/src/renderers/webgl/WebGLRenderStates.js +2 -2
  484. package/src/renderers/webgl/WebGLShadowMap.js +40 -27
  485. package/src/renderers/webgl/WebGLState.js +23 -9
  486. package/src/renderers/webgl/WebGLTextures.js +39 -19
  487. package/src/renderers/webgl/WebGLUniformsGroups.js +74 -33
  488. package/src/renderers/webgl/WebGLUtils.js +41 -29
  489. package/src/renderers/webxr/WebXRController.js +3 -0
  490. package/src/renderers/webxr/WebXRManager.js +85 -141
  491. package/src/scenes/Scene.js +4 -6
  492. package/src/textures/CompressedTexture.js +2 -2
  493. package/src/textures/CubeTexture.js +2 -2
  494. package/src/textures/DataTexture.js +2 -2
  495. package/src/textures/DepthTexture.js +22 -0
  496. package/src/textures/FramebufferTexture.js +1 -3
  497. package/src/textures/Source.js +4 -0
  498. package/src/textures/Texture.js +43 -13
  499. package/src/utils.js +13 -1
  500. package/examples/fonts/open-sans/open-sans-v15-cyrillic-ext_greek_greek-ext_cyrillic_latin_latin-ext_vietnamese-regular.woff +0 -0
  501. package/examples/fonts/open-sans/open-sans-v15-cyrillic-ext_greek_greek-ext_cyrillic_latin_latin-ext_vietnamese-regular.woff2 +0 -0
  502. package/examples/fonts/open-sans/open-sans.css +0 -9
  503. package/examples/fonts/tabler-icons/fonts/tabler-icons.eot +0 -0
  504. package/examples/fonts/tabler-icons/fonts/tabler-icons.svg +0 -3966
  505. package/examples/fonts/tabler-icons/fonts/tabler-icons.ttf +0 -0
  506. package/examples/fonts/tabler-icons/fonts/tabler-icons.woff +0 -0
  507. package/examples/fonts/tabler-icons/fonts/tabler-icons.woff2 +0 -0
  508. package/examples/fonts/tabler-icons/tabler-icons.min.css +0 -4
  509. package/examples/js/animation/AnimationClipCreator.js +0 -89
  510. package/examples/js/animation/CCDIKSolver.js +0 -416
  511. package/examples/js/animation/MMDAnimationHelper.js +0 -1046
  512. package/examples/js/animation/MMDPhysics.js +0 -1174
  513. package/examples/js/cameras/CinematicCamera.js +0 -168
  514. package/examples/js/controls/ArcballControls.js +0 -2770
  515. package/examples/js/controls/DragControls.js +0 -205
  516. package/examples/js/controls/FirstPersonControls.js +0 -312
  517. package/examples/js/controls/FlyControls.js +0 -321
  518. package/examples/js/controls/OrbitControls.js +0 -1065
  519. package/examples/js/controls/PointerLockControls.js +0 -144
  520. package/examples/js/controls/TrackballControls.js +0 -729
  521. package/examples/js/controls/TransformControls.js +0 -1301
  522. package/examples/js/csm/CSM.js +0 -347
  523. package/examples/js/csm/CSMFrustum.js +0 -127
  524. package/examples/js/csm/CSMHelper.js +0 -165
  525. package/examples/js/csm/CSMShader.js +0 -253
  526. package/examples/js/curves/CurveExtras.js +0 -348
  527. package/examples/js/curves/NURBSCurve.js +0 -63
  528. package/examples/js/curves/NURBSSurface.js +0 -48
  529. package/examples/js/curves/NURBSUtils.js +0 -439
  530. package/examples/js/effects/AnaglyphEffect.js +0 -86
  531. package/examples/js/effects/AsciiEffect.js +0 -260
  532. package/examples/js/effects/OutlineEffect.js +0 -450
  533. package/examples/js/effects/ParallaxBarrierEffect.js +0 -62
  534. package/examples/js/effects/PeppersGhostEffect.js +0 -139
  535. package/examples/js/effects/StereoEffect.js +0 -46
  536. package/examples/js/environments/DebugEnvironment.js +0 -53
  537. package/examples/js/environments/RoomEnvironment.js +0 -124
  538. package/examples/js/exporters/ColladaExporter.js +0 -487
  539. package/examples/js/exporters/DRACOExporter.js +0 -212
  540. package/examples/js/exporters/EXRExporter.js +0 -455
  541. package/examples/js/exporters/GLTFExporter.js +0 -2425
  542. package/examples/js/exporters/MMDExporter.js +0 -187
  543. package/examples/js/exporters/OBJExporter.js +0 -260
  544. package/examples/js/exporters/PLYExporter.js +0 -427
  545. package/examples/js/exporters/STLExporter.js +0 -188
  546. package/examples/js/exporters/USDZExporter.js +0 -608
  547. package/examples/js/geometries/BoxLineGeometry.js +0 -59
  548. package/examples/js/geometries/ConvexGeometry.js +0 -53
  549. package/examples/js/geometries/DecalGeometry.js +0 -324
  550. package/examples/js/geometries/LightningStrike.js +0 -861
  551. package/examples/js/geometries/ParametricGeometries.js +0 -216
  552. package/examples/js/geometries/ParametricGeometry.js +0 -121
  553. package/examples/js/geometries/RoundedBoxGeometry.js +0 -142
  554. package/examples/js/geometries/TeapotGeometry.js +0 -335
  555. package/examples/js/geometries/TextGeometry.js +0 -53
  556. package/examples/js/helpers/LightProbeHelper.js +0 -48
  557. package/examples/js/helpers/OctreeHelper.js +0 -76
  558. package/examples/js/helpers/PositionalAudioHelper.js +0 -91
  559. package/examples/js/helpers/RectAreaLightHelper.js +0 -73
  560. package/examples/js/helpers/VertexNormalsHelper.js +0 -74
  561. package/examples/js/helpers/VertexTangentsHelper.js +0 -68
  562. package/examples/js/helpers/ViewHelper.js +0 -281
  563. package/examples/js/interactive/HTMLMesh.js +0 -497
  564. package/examples/js/interactive/InteractiveGroup.js +0 -95
  565. package/examples/js/interactive/SelectionBox.js +0 -195
  566. package/examples/js/interactive/SelectionHelper.js +0 -83
  567. package/examples/js/libs/chevrotain.min.js +0 -3
  568. package/examples/js/libs/draco/draco_decoder.js +0 -52
  569. package/examples/js/libs/draco/draco_decoder.wasm +0 -0
  570. package/examples/js/libs/draco/draco_wasm_wrapper.js +0 -104
  571. package/examples/js/libs/draco/gltf/draco_decoder.js +0 -48
  572. package/examples/js/libs/draco/gltf/draco_decoder.wasm +0 -0
  573. package/examples/js/libs/draco/gltf/draco_wasm_wrapper.js +0 -104
  574. package/examples/js/libs/fflate.min.js +0 -7
  575. package/examples/js/libs/ktx-parse.umd.js +0 -1
  576. package/examples/js/libs/meshopt_decoder.js +0 -188
  577. package/examples/js/libs/opentype.min.js +0 -1
  578. package/examples/js/libs/stats.min.js +0 -5
  579. package/examples/js/lights/LightProbeGenerator.js +0 -221
  580. package/examples/js/lights/RectAreaLightUniformsLib.js +0 -60
  581. package/examples/js/lines/Line2.js +0 -19
  582. package/examples/js/lines/LineGeometry.js +0 -69
  583. package/examples/js/lines/LineMaterial.js +0 -635
  584. package/examples/js/lines/LineSegments2.js +0 -311
  585. package/examples/js/lines/LineSegmentsGeometry.js +0 -198
  586. package/examples/js/lines/Wireframe.js +0 -47
  587. package/examples/js/lines/WireframeGeometry2.js +0 -20
  588. package/examples/js/loaders/3DMLoader.js +0 -1273
  589. package/examples/js/loaders/3MFLoader.js +0 -1306
  590. package/examples/js/loaders/AMFLoader.js +0 -504
  591. package/examples/js/loaders/BVHLoader.js +0 -395
  592. package/examples/js/loaders/BasisTextureLoader.js +0 -706
  593. package/examples/js/loaders/ColladaLoader.js +0 -3663
  594. package/examples/js/loaders/DDSLoader.js +0 -244
  595. package/examples/js/loaders/DRACOLoader.js +0 -511
  596. package/examples/js/loaders/EXRLoader.js +0 -2039
  597. package/examples/js/loaders/FBXLoader.js +0 -3680
  598. package/examples/js/loaders/FontLoader.js +0 -160
  599. package/examples/js/loaders/GCodeLoader.js +0 -255
  600. package/examples/js/loaders/GLTFLoader.js +0 -4108
  601. package/examples/js/loaders/HDRCubeTextureLoader.js +0 -87
  602. package/examples/js/loaders/KMZLoader.js +0 -121
  603. package/examples/js/loaders/KTXLoader.js +0 -159
  604. package/examples/js/loaders/LDrawLoader.js +0 -2263
  605. package/examples/js/loaders/LUT3dlLoader.js +0 -135
  606. package/examples/js/loaders/LUTCubeLoader.js +0 -132
  607. package/examples/js/loaders/LWOLoader.js +0 -901
  608. package/examples/js/loaders/LogLuvLoader.js +0 -715
  609. package/examples/js/loaders/LottieLoader.js +0 -62
  610. package/examples/js/loaders/MD2Loader.js +0 -248
  611. package/examples/js/loaders/MDDLoader.js +0 -91
  612. package/examples/js/loaders/MMDLoader.js +0 -1915
  613. package/examples/js/loaders/MTLLoader.js +0 -472
  614. package/examples/js/loaders/MaterialXLoader.js +0 -392
  615. package/examples/js/loaders/NRRDLoader.js +0 -609
  616. package/examples/js/loaders/OBJLoader.js +0 -789
  617. package/examples/js/loaders/PCDLoader.js +0 -413
  618. package/examples/js/loaders/PDBLoader.js +0 -317
  619. package/examples/js/loaders/PLYLoader.js +0 -532
  620. package/examples/js/loaders/PRWMLoader.js +0 -249
  621. package/examples/js/loaders/PVRLoader.js +0 -218
  622. package/examples/js/loaders/RGBELoader.js +0 -442
  623. package/examples/js/loaders/RGBMLoader.js +0 -1354
  624. package/examples/js/loaders/STLLoader.js +0 -364
  625. package/examples/js/loaders/SVGLoader.js +0 -2783
  626. package/examples/js/loaders/TDSLoader.js +0 -992
  627. package/examples/js/loaders/TGALoader.js +0 -484
  628. package/examples/js/loaders/TIFFLoader.js +0 -30
  629. package/examples/js/loaders/TTFLoader.js +0 -203
  630. package/examples/js/loaders/TiltLoader.js +0 -459
  631. package/examples/js/loaders/VOXLoader.js +0 -240
  632. package/examples/js/loaders/VRMLLoader.js +0 -3140
  633. package/examples/js/loaders/VTKLoader.js +0 -1078
  634. package/examples/js/loaders/XYZLoader.js +0 -89
  635. package/examples/js/loaders/lwo/IFFParser.js +0 -1067
  636. package/examples/js/loaders/lwo/LWO2Parser.js +0 -397
  637. package/examples/js/loaders/lwo/LWO3Parser.js +0 -360
  638. package/examples/js/materials/MeshGouraudMaterial.js +0 -387
  639. package/examples/js/math/Capsule.js +0 -103
  640. package/examples/js/math/ColorConverter.js +0 -33
  641. package/examples/js/math/ConvexHull.js +0 -1154
  642. package/examples/js/math/ImprovedNoise.js +0 -66
  643. package/examples/js/math/Lut.js +0 -164
  644. package/examples/js/math/MeshSurfaceSampler.js +0 -171
  645. package/examples/js/math/OBB.js +0 -382
  646. package/examples/js/math/Octree.js +0 -410
  647. package/examples/js/math/SimplexNoise.js +0 -445
  648. package/examples/js/misc/ConvexObjectBreaker.js +0 -474
  649. package/examples/js/misc/GPUComputationRenderer.js +0 -393
  650. package/examples/js/misc/Gyroscope.js +0 -56
  651. package/examples/js/misc/MD2Character.js +0 -235
  652. package/examples/js/misc/MD2CharacterComplex.js +0 -513
  653. package/examples/js/misc/MorphAnimMesh.js +0 -63
  654. package/examples/js/misc/MorphBlendMesh.js +0 -265
  655. package/examples/js/misc/ProgressiveLightMap.js +0 -335
  656. package/examples/js/misc/RollerCoaster.js +0 -430
  657. package/examples/js/misc/TubePainter.js +0 -167
  658. package/examples/js/misc/Volume.js +0 -437
  659. package/examples/js/misc/VolumeSlice.js +0 -214
  660. package/examples/js/modifiers/CurveModifier.js +0 -309
  661. package/examples/js/modifiers/EdgeSplitModifier.js +0 -228
  662. package/examples/js/modifiers/SimplifyModifier.js +0 -465
  663. package/examples/js/modifiers/TessellateModifier.js +0 -276
  664. package/examples/js/objects/GroundProjectedEnv.js +0 -181
  665. package/examples/js/objects/Lensflare.js +0 -356
  666. package/examples/js/objects/LightningStorm.js +0 -206
  667. package/examples/js/objects/MarchingCubes.js +0 -759
  668. package/examples/js/objects/Reflector.js +0 -216
  669. package/examples/js/objects/ReflectorForSSRPass.js +0 -315
  670. package/examples/js/objects/Refractor.js +0 -283
  671. package/examples/js/objects/ShadowMesh.js +0 -59
  672. package/examples/js/objects/Sky.js +0 -218
  673. package/examples/js/objects/Water.js +0 -292
  674. package/examples/js/objects/Water2.js +0 -307
  675. package/examples/js/physics/AmmoPhysics.js +0 -259
  676. package/examples/js/physics/OimoPhysics.js +0 -217
  677. package/examples/js/postprocessing/AdaptiveToneMappingPass.js +0 -335
  678. package/examples/js/postprocessing/AfterimagePass.js +0 -77
  679. package/examples/js/postprocessing/BloomPass.js +0 -135
  680. package/examples/js/postprocessing/BokehPass.js +0 -120
  681. package/examples/js/postprocessing/ClearPass.js +0 -39
  682. package/examples/js/postprocessing/CubeTexturePass.js +0 -60
  683. package/examples/js/postprocessing/DotScreenPass.js +0 -51
  684. package/examples/js/postprocessing/EffectComposer.js +0 -272
  685. package/examples/js/postprocessing/FilmPass.js +0 -52
  686. package/examples/js/postprocessing/GlitchPass.js +0 -104
  687. package/examples/js/postprocessing/HalftonePass.js +0 -75
  688. package/examples/js/postprocessing/LUTPass.js +0 -171
  689. package/examples/js/postprocessing/MaskPass.js +0 -95
  690. package/examples/js/postprocessing/OutlinePass.js +0 -598
  691. package/examples/js/postprocessing/Pass.js +0 -72
  692. package/examples/js/postprocessing/RenderPass.js +0 -70
  693. package/examples/js/postprocessing/SAOPass.js +0 -374
  694. package/examples/js/postprocessing/SMAAPass.js +0 -170
  695. package/examples/js/postprocessing/SSAARenderPass.js +0 -156
  696. package/examples/js/postprocessing/SSAOPass.js +0 -365
  697. package/examples/js/postprocessing/SSRPass.js +0 -567
  698. package/examples/js/postprocessing/SavePass.js +0 -59
  699. package/examples/js/postprocessing/ShaderPass.js +0 -64
  700. package/examples/js/postprocessing/TAARenderPass.js +0 -130
  701. package/examples/js/postprocessing/TexturePass.js +0 -49
  702. package/examples/js/postprocessing/UnrealBloomPass.js +0 -375
  703. package/examples/js/renderers/CSS2DRenderer.js +0 -178
  704. package/examples/js/renderers/CSS3DRenderer.js +0 -237
  705. package/examples/js/renderers/Projector.js +0 -818
  706. package/examples/js/renderers/SVGRenderer.js +0 -491
  707. package/examples/js/shaders/ACESFilmicToneMappingShader.js +0 -89
  708. package/examples/js/shaders/AfterimageShader.js +0 -60
  709. package/examples/js/shaders/BasicShader.js +0 -27
  710. package/examples/js/shaders/BleachBypassShader.js +0 -62
  711. package/examples/js/shaders/BlendShader.js +0 -54
  712. package/examples/js/shaders/BokehShader.js +0 -156
  713. package/examples/js/shaders/BokehShader2.js +0 -419
  714. package/examples/js/shaders/BrightnessContrastShader.js +0 -58
  715. package/examples/js/shaders/ColorCorrectionShader.js +0 -52
  716. package/examples/js/shaders/ColorifyShader.js +0 -47
  717. package/examples/js/shaders/ConvolutionShader.js +0 -92
  718. package/examples/js/shaders/CopyShader.js +0 -45
  719. package/examples/js/shaders/DOFMipMapShader.js +0 -60
  720. package/examples/js/shaders/DepthLimitedBlurShader.js +0 -173
  721. package/examples/js/shaders/DigitalGlitch.js +0 -127
  722. package/examples/js/shaders/DotScreenShader.js +0 -72
  723. package/examples/js/shaders/FXAAShader.js +0 -284
  724. package/examples/js/shaders/FilmShader.js +0 -110
  725. package/examples/js/shaders/FocusShader.js +0 -95
  726. package/examples/js/shaders/FreiChenShader.js +0 -93
  727. package/examples/js/shaders/GammaCorrectionShader.js +0 -41
  728. package/examples/js/shaders/GodRaysShader.js +0 -284
  729. package/examples/js/shaders/HalftoneShader.js +0 -336
  730. package/examples/js/shaders/HorizontalBlurShader.js +0 -59
  731. package/examples/js/shaders/HorizontalTiltShiftShader.js +0 -65
  732. package/examples/js/shaders/HueSaturationShader.js +0 -69
  733. package/examples/js/shaders/KaleidoShader.js +0 -60
  734. package/examples/js/shaders/LuminosityHighPassShader.js +0 -67
  735. package/examples/js/shaders/LuminosityShader.js +0 -46
  736. package/examples/js/shaders/MMDToonShader.js +0 -96
  737. package/examples/js/shaders/MirrorShader.js +0 -56
  738. package/examples/js/shaders/NormalMapShader.js +0 -55
  739. package/examples/js/shaders/RGBShiftShader.js +0 -56
  740. package/examples/js/shaders/SAOShader.js +0 -209
  741. package/examples/js/shaders/SMAAShader.js +0 -454
  742. package/examples/js/shaders/SSAOShader.js +0 -295
  743. package/examples/js/shaders/SSRShader.js +0 -381
  744. package/examples/js/shaders/SepiaShader.js +0 -52
  745. package/examples/js/shaders/SobelOperatorShader.js +0 -88
  746. package/examples/js/shaders/SubsurfaceScatteringShader.js +0 -49
  747. package/examples/js/shaders/TechnicolorShader.js +0 -43
  748. package/examples/js/shaders/ToneMapShader.js +0 -84
  749. package/examples/js/shaders/ToonShader.js +0 -335
  750. package/examples/js/shaders/TriangleBlurShader.js +0 -70
  751. package/examples/js/shaders/UnpackDepthRGBAShader.js +0 -47
  752. package/examples/js/shaders/VelocityShader.js +0 -126
  753. package/examples/js/shaders/VerticalBlurShader.js +0 -59
  754. package/examples/js/shaders/VerticalTiltShiftShader.js +0 -65
  755. package/examples/js/shaders/VignetteShader.js +0 -53
  756. package/examples/js/shaders/VolumeShader.js +0 -296
  757. package/examples/js/shaders/WaterRefractionShader.js +0 -84
  758. package/examples/js/textures/FlakesTexture.js +0 -40
  759. package/examples/js/utils/BufferGeometryUtils.js +0 -1160
  760. package/examples/js/utils/CameraUtils.js +0 -71
  761. package/examples/js/utils/GPUStatsPanel.js +0 -125
  762. package/examples/js/utils/GeometryCompressionUtils.js +0 -549
  763. package/examples/js/utils/GeometryUtils.js +0 -168
  764. package/examples/js/utils/LDrawUtils.js +0 -179
  765. package/examples/js/utils/PackedPhongMaterial.js +0 -109
  766. package/examples/js/utils/SceneUtils.js +0 -214
  767. package/examples/js/utils/ShadowMapViewer.js +0 -183
  768. package/examples/js/utils/SkeletonUtils.js +0 -493
  769. package/examples/js/utils/UVsDebug.js +0 -143
  770. package/examples/js/utils/WorkerPool.js +0 -105
  771. package/examples/jsm/exporters/ColladaExporter.js +0 -713
  772. package/examples/jsm/geometries/LightningStrike.js +0 -1017
  773. package/examples/jsm/libs/OimoPhysics/OimoPhysics.js +0 -37071
  774. package/examples/jsm/libs/OimoPhysics/index.js +0 -43
  775. package/examples/jsm/libs/flow.module.js +0 -4552
  776. package/examples/jsm/libs/tween.module.min.js +0 -3
  777. package/examples/jsm/loaders/BasisTextureLoader.js +0 -790
  778. package/examples/jsm/loaders/IFCLoader.js +0 -2431
  779. package/examples/jsm/loaders/PRWMLoader.js +0 -299
  780. package/examples/jsm/loaders/ifc/web-ifc-api.js +0 -47504
  781. package/examples/jsm/loaders/ifc/web-ifc.wasm +0 -0
  782. package/examples/jsm/node-editor/NodeEditor.js +0 -857
  783. package/examples/jsm/node-editor/accessors/MatcapUVEditor.js +0 -14
  784. package/examples/jsm/node-editor/accessors/NormalEditor.js +0 -30
  785. package/examples/jsm/node-editor/accessors/PositionEditor.js +0 -30
  786. package/examples/jsm/node-editor/accessors/UVEditor.js +0 -25
  787. package/examples/jsm/node-editor/core/BaseNode.js +0 -96
  788. package/examples/jsm/node-editor/core/DataFile.js +0 -59
  789. package/examples/jsm/node-editor/core/FileEditor.js +0 -20
  790. package/examples/jsm/node-editor/core/FileURLEditor.js +0 -29
  791. package/examples/jsm/node-editor/display/BlendEditor.js +0 -44
  792. package/examples/jsm/node-editor/display/NormalMapEditor.js +0 -49
  793. package/examples/jsm/node-editor/examples/animate-uv.json +0 -1
  794. package/examples/jsm/node-editor/examples/fake-top-light.json +0 -1
  795. package/examples/jsm/node-editor/examples/matcap.json +0 -1
  796. package/examples/jsm/node-editor/examples/oscillator-color.json +0 -1
  797. package/examples/jsm/node-editor/examples/rim.json +0 -1
  798. package/examples/jsm/node-editor/inputs/ColorEditor.js +0 -96
  799. package/examples/jsm/node-editor/inputs/FloatEditor.js +0 -23
  800. package/examples/jsm/node-editor/inputs/SliderEditor.js +0 -67
  801. package/examples/jsm/node-editor/inputs/TextureEditor.js +0 -155
  802. package/examples/jsm/node-editor/inputs/Vector2Editor.js +0 -28
  803. package/examples/jsm/node-editor/inputs/Vector3Editor.js +0 -30
  804. package/examples/jsm/node-editor/inputs/Vector4Editor.js +0 -37
  805. package/examples/jsm/node-editor/materials/BasicMaterialEditor.js +0 -84
  806. package/examples/jsm/node-editor/materials/PointsMaterialEditor.js +0 -102
  807. package/examples/jsm/node-editor/materials/StandardMaterialEditor.js +0 -118
  808. package/examples/jsm/node-editor/math/AngleEditor.js +0 -40
  809. package/examples/jsm/node-editor/math/DotEditor.js +0 -35
  810. package/examples/jsm/node-editor/math/InvertEditor.js +0 -39
  811. package/examples/jsm/node-editor/math/LimiterEditor.js +0 -62
  812. package/examples/jsm/node-editor/math/NormalizeEditor.js +0 -28
  813. package/examples/jsm/node-editor/math/OperatorEditor.js +0 -63
  814. package/examples/jsm/node-editor/math/PowerEditor.js +0 -44
  815. package/examples/jsm/node-editor/math/TrigonometryEditor.js +0 -45
  816. package/examples/jsm/node-editor/procedural/CheckerEditor.js +0 -27
  817. package/examples/jsm/node-editor/scene/MeshEditor.js +0 -102
  818. package/examples/jsm/node-editor/scene/Object3DEditor.js +0 -160
  819. package/examples/jsm/node-editor/scene/PointsEditor.js +0 -99
  820. package/examples/jsm/node-editor/utils/JoinEditor.js +0 -58
  821. package/examples/jsm/node-editor/utils/OscillatorEditor.js +0 -43
  822. package/examples/jsm/node-editor/utils/PreviewEditor.js +0 -170
  823. package/examples/jsm/node-editor/utils/SplitEditor.js +0 -39
  824. package/examples/jsm/node-editor/utils/TimerEditor.js +0 -58
  825. package/examples/jsm/nodes/core/CodeNode.js +0 -50
  826. package/examples/jsm/nodes/core/ExpressionNode.js +0 -32
  827. package/examples/jsm/nodes/functions/light/getDistanceAttenuation.js +0 -22
  828. package/examples/jsm/nodes/lighting/PunctualLightNode.js +0 -68
  829. package/examples/jsm/nodes/shadernode/ShaderNodeBaseElements.js +0 -301
  830. package/examples/jsm/nodes/shadernode/ShaderNodeElements.js +0 -149
  831. package/examples/jsm/objects/GroundProjectedEnv.js +0 -186
  832. package/examples/jsm/objects/LightningStorm.js +0 -245
  833. package/examples/jsm/physics/OimoPhysics.js +0 -231
  834. package/examples/jsm/postprocessing/AdaptiveToneMappingPass.js +0 -369
  835. package/examples/jsm/renderers/webgpu/WebGPUAttributes.js +0 -187
  836. package/examples/jsm/renderers/webgpu/WebGPUBackground.js +0 -173
  837. package/examples/jsm/renderers/webgpu/WebGPUBinding.js +0 -22
  838. package/examples/jsm/renderers/webgpu/WebGPUBindings.js +0 -255
  839. package/examples/jsm/renderers/webgpu/WebGPUBuffer.js +0 -43
  840. package/examples/jsm/renderers/webgpu/WebGPUComputePipelines.js +0 -78
  841. package/examples/jsm/renderers/webgpu/WebGPUGeometries.js +0 -82
  842. package/examples/jsm/renderers/webgpu/WebGPUObjects.js +0 -36
  843. package/examples/jsm/renderers/webgpu/WebGPUProgrammableStage.js +0 -22
  844. package/examples/jsm/renderers/webgpu/WebGPUProperties.js +0 -38
  845. package/examples/jsm/renderers/webgpu/WebGPURenderPipelines.js +0 -296
  846. package/examples/jsm/renderers/webgpu/WebGPURenderStates.js +0 -66
  847. package/examples/jsm/renderers/webgpu/WebGPUSampledTexture.js +0 -73
  848. package/examples/jsm/renderers/webgpu/WebGPUSampler.js +0 -29
  849. package/examples/jsm/renderers/webgpu/WebGPUStorageBuffer.js +0 -20
  850. package/examples/jsm/renderers/webgpu/WebGPUTextureRenderer.js +0 -40
  851. package/examples/jsm/renderers/webgpu/WebGPUTextures.js +0 -794
  852. package/examples/jsm/renderers/webgpu/WebGPUUniformBuffer.js +0 -18
  853. package/examples/jsm/renderers/webgpu/WebGPUUtils.js +0 -81
  854. package/examples/jsm/renderers/webgpu/nodes/WebGPUNodes.js +0 -83
  855. package/examples/jsm/shaders/ToneMapShader.js +0 -73
  856. package/src/renderers/shaders/ShaderChunk/uv2_pars_fragment.glsl.js +0 -7
  857. package/src/renderers/shaders/ShaderChunk/uv2_pars_vertex.glsl.js +0 -10
  858. package/src/renderers/shaders/ShaderChunk/uv2_vertex.glsl.js +0 -7
  859. /package/examples/{js → jsm}/libs/ammo.wasm.js +0 -0
  860. /package/examples/{js → jsm}/libs/ammo.wasm.wasm +0 -0
  861. /package/examples/{js → jsm}/libs/basis/basis_transcoder.js +0 -0
  862. /package/examples/{js → jsm}/libs/basis/basis_transcoder.wasm +0 -0
  863. /package/examples/{js → jsm}/libs/draco/README.md +0 -0
  864. /package/examples/{js → jsm}/libs/draco/draco_encoder.js +0 -0
  865. /package/examples/{js → jsm}/libs/draco/gltf/draco_encoder.js +0 -0
@@ -1,2425 +0,0 @@
1
- ( function () {
2
-
3
- class GLTFExporter {
4
-
5
- constructor() {
6
-
7
- this.pluginCallbacks = [];
8
- this.register( function ( writer ) {
9
-
10
- return new GLTFLightExtension( writer );
11
-
12
- } );
13
- this.register( function ( writer ) {
14
-
15
- return new GLTFMaterialsUnlitExtension( writer );
16
-
17
- } );
18
- this.register( function ( writer ) {
19
-
20
- return new GLTFMaterialsPBRSpecularGlossiness( writer );
21
-
22
- } );
23
- this.register( function ( writer ) {
24
-
25
- return new GLTFMaterialsTransmissionExtension( writer );
26
-
27
- } );
28
- this.register( function ( writer ) {
29
-
30
- return new GLTFMaterialsVolumeExtension( writer );
31
-
32
- } );
33
- this.register( function ( writer ) {
34
-
35
- return new GLTFMaterialsClearcoatExtension( writer );
36
-
37
- } );
38
- this.register( function ( writer ) {
39
-
40
- return new GLTFMaterialsIridescenceExtension( writer );
41
-
42
- } );
43
-
44
- }
45
- register( callback ) {
46
-
47
- if ( this.pluginCallbacks.indexOf( callback ) === - 1 ) {
48
-
49
- this.pluginCallbacks.push( callback );
50
-
51
- }
52
-
53
- return this;
54
-
55
- }
56
- unregister( callback ) {
57
-
58
- if ( this.pluginCallbacks.indexOf( callback ) !== - 1 ) {
59
-
60
- this.pluginCallbacks.splice( this.pluginCallbacks.indexOf( callback ), 1 );
61
-
62
- }
63
-
64
- return this;
65
-
66
- }
67
-
68
- /**
69
- * Parse scenes and generate GLTF output
70
- * @param {Scene or [THREE.Scenes]} input THREE.Scene or Array of THREE.Scenes
71
- * @param {Function} onDone Callback on completed
72
- * @param {Function} onError Callback on errors
73
- * @param {Object} options options
74
- */
75
- parse( input, onDone, onError, options ) {
76
-
77
- const writer = new GLTFWriter();
78
- const plugins = [];
79
- for ( let i = 0, il = this.pluginCallbacks.length; i < il; i ++ ) {
80
-
81
- plugins.push( this.pluginCallbacks[ i ]( writer ) );
82
-
83
- }
84
-
85
- writer.setPlugins( plugins );
86
- writer.write( input, onDone, options ).catch( onError );
87
-
88
- }
89
- parseAsync( input, options ) {
90
-
91
- const scope = this;
92
- return new Promise( function ( resolve, reject ) {
93
-
94
- scope.parse( input, resolve, reject, options );
95
-
96
- } );
97
-
98
- }
99
-
100
- }
101
-
102
- //------------------------------------------------------------------------------
103
- // Constants
104
- //------------------------------------------------------------------------------
105
-
106
- const WEBGL_CONSTANTS = {
107
- POINTS: 0x0000,
108
- LINES: 0x0001,
109
- LINE_LOOP: 0x0002,
110
- LINE_STRIP: 0x0003,
111
- TRIANGLES: 0x0004,
112
- TRIANGLE_STRIP: 0x0005,
113
- TRIANGLE_FAN: 0x0006,
114
- UNSIGNED_BYTE: 0x1401,
115
- UNSIGNED_SHORT: 0x1403,
116
- FLOAT: 0x1406,
117
- UNSIGNED_INT: 0x1405,
118
- ARRAY_BUFFER: 0x8892,
119
- ELEMENT_ARRAY_BUFFER: 0x8893,
120
- NEAREST: 0x2600,
121
- LINEAR: 0x2601,
122
- NEAREST_MIPMAP_NEAREST: 0x2700,
123
- LINEAR_MIPMAP_NEAREST: 0x2701,
124
- NEAREST_MIPMAP_LINEAR: 0x2702,
125
- LINEAR_MIPMAP_LINEAR: 0x2703,
126
- CLAMP_TO_EDGE: 33071,
127
- MIRRORED_REPEAT: 33648,
128
- REPEAT: 10497
129
- };
130
- const THREE_TO_WEBGL = {};
131
- THREE_TO_WEBGL[ THREE.NearestFilter ] = WEBGL_CONSTANTS.NEAREST;
132
- THREE_TO_WEBGL[ THREE.NearestMipmapNearestFilter ] = WEBGL_CONSTANTS.NEAREST_MIPMAP_NEAREST;
133
- THREE_TO_WEBGL[ THREE.NearestMipmapLinearFilter ] = WEBGL_CONSTANTS.NEAREST_MIPMAP_LINEAR;
134
- THREE_TO_WEBGL[ THREE.LinearFilter ] = WEBGL_CONSTANTS.LINEAR;
135
- THREE_TO_WEBGL[ THREE.LinearMipmapNearestFilter ] = WEBGL_CONSTANTS.LINEAR_MIPMAP_NEAREST;
136
- THREE_TO_WEBGL[ THREE.LinearMipmapLinearFilter ] = WEBGL_CONSTANTS.LINEAR_MIPMAP_LINEAR;
137
- THREE_TO_WEBGL[ THREE.ClampToEdgeWrapping ] = WEBGL_CONSTANTS.CLAMP_TO_EDGE;
138
- THREE_TO_WEBGL[ THREE.RepeatWrapping ] = WEBGL_CONSTANTS.REPEAT;
139
- THREE_TO_WEBGL[ THREE.MirroredRepeatWrapping ] = WEBGL_CONSTANTS.MIRRORED_REPEAT;
140
- const PATH_PROPERTIES = {
141
- scale: 'scale',
142
- position: 'translation',
143
- quaternion: 'rotation',
144
- morphTargetInfluences: 'weights'
145
- };
146
-
147
- // GLB constants
148
- // https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#glb-file-format-specification
149
-
150
- const GLB_HEADER_BYTES = 12;
151
- const GLB_HEADER_MAGIC = 0x46546C67;
152
- const GLB_VERSION = 2;
153
- const GLB_CHUNK_PREFIX_BYTES = 8;
154
- const GLB_CHUNK_TYPE_JSON = 0x4E4F534A;
155
- const GLB_CHUNK_TYPE_BIN = 0x004E4942;
156
-
157
- //------------------------------------------------------------------------------
158
- // Utility functions
159
- //------------------------------------------------------------------------------
160
-
161
- /**
162
- * Compare two arrays
163
- * @param {Array} array1 Array 1 to compare
164
- * @param {Array} array2 Array 2 to compare
165
- * @return {Boolean} Returns true if both arrays are equal
166
- */
167
- function equalArray( array1, array2 ) {
168
-
169
- return array1.length === array2.length && array1.every( function ( element, index ) {
170
-
171
- return element === array2[ index ];
172
-
173
- } );
174
-
175
- }
176
-
177
- /**
178
- * Converts a string to an ArrayBuffer.
179
- * @param {string} text
180
- * @return {ArrayBuffer}
181
- */
182
- function stringToArrayBuffer( text ) {
183
-
184
- return new TextEncoder().encode( text ).buffer;
185
-
186
- }
187
-
188
- /**
189
- * Is identity matrix
190
- *
191
- * @param {Matrix4} matrix
192
- * @returns {Boolean} Returns true, if parameter is identity matrix
193
- */
194
- function isIdentityMatrix( matrix ) {
195
-
196
- return equalArray( matrix.elements, [ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ] );
197
-
198
- }
199
-
200
- /**
201
- * Get the min and max vectors from the given attribute
202
- * @param {BufferAttribute} attribute Attribute to find the min/max in range from start to start + count
203
- * @param {Integer} start
204
- * @param {Integer} count
205
- * @return {Object} Object containing the `min` and `max` values (As an array of attribute.itemSize components)
206
- */
207
- function getMinMax( attribute, start, count ) {
208
-
209
- const output = {
210
- min: new Array( attribute.itemSize ).fill( Number.POSITIVE_INFINITY ),
211
- max: new Array( attribute.itemSize ).fill( Number.NEGATIVE_INFINITY )
212
- };
213
- for ( let i = start; i < start + count; i ++ ) {
214
-
215
- for ( let a = 0; a < attribute.itemSize; a ++ ) {
216
-
217
- let value;
218
- if ( attribute.itemSize > 4 ) {
219
-
220
- // no support for interleaved data for itemSize > 4
221
-
222
- value = attribute.array[ i * attribute.itemSize + a ];
223
-
224
- } else {
225
-
226
- if ( a === 0 ) value = attribute.getX( i ); else if ( a === 1 ) value = attribute.getY( i ); else if ( a === 2 ) value = attribute.getZ( i ); else if ( a === 3 ) value = attribute.getW( i );
227
-
228
- }
229
-
230
- output.min[ a ] = Math.min( output.min[ a ], value );
231
- output.max[ a ] = Math.max( output.max[ a ], value );
232
-
233
- }
234
-
235
- }
236
-
237
- return output;
238
-
239
- }
240
-
241
- /**
242
- * Get the required size + padding for a buffer, rounded to the next 4-byte boundary.
243
- * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#data-alignment
244
- *
245
- * @param {Integer} bufferSize The size the original buffer.
246
- * @returns {Integer} new buffer size with required padding.
247
- *
248
- */
249
- function getPaddedBufferSize( bufferSize ) {
250
-
251
- return Math.ceil( bufferSize / 4 ) * 4;
252
-
253
- }
254
-
255
- /**
256
- * Returns a buffer aligned to 4-byte boundary.
257
- *
258
- * @param {ArrayBuffer} arrayBuffer Buffer to pad
259
- * @param {Integer} paddingByte (Optional)
260
- * @returns {ArrayBuffer} The same buffer if it's already aligned to 4-byte boundary or a new buffer
261
- */
262
- function getPaddedArrayBuffer( arrayBuffer, paddingByte = 0 ) {
263
-
264
- const paddedLength = getPaddedBufferSize( arrayBuffer.byteLength );
265
- if ( paddedLength !== arrayBuffer.byteLength ) {
266
-
267
- const array = new Uint8Array( paddedLength );
268
- array.set( new Uint8Array( arrayBuffer ) );
269
- if ( paddingByte !== 0 ) {
270
-
271
- for ( let i = arrayBuffer.byteLength; i < paddedLength; i ++ ) {
272
-
273
- array[ i ] = paddingByte;
274
-
275
- }
276
-
277
- }
278
-
279
- return array.buffer;
280
-
281
- }
282
-
283
- return arrayBuffer;
284
-
285
- }
286
-
287
- function getCanvas() {
288
-
289
- if ( typeof document === 'undefined' && typeof OffscreenCanvas !== 'undefined' ) {
290
-
291
- return new OffscreenCanvas( 1, 1 );
292
-
293
- }
294
-
295
- return document.createElement( 'canvas' );
296
-
297
- }
298
-
299
- function getToBlobPromise( canvas, mimeType ) {
300
-
301
- if ( canvas.toBlob !== undefined ) {
302
-
303
- return new Promise( resolve => canvas.toBlob( resolve, mimeType ) );
304
-
305
- }
306
-
307
- let quality;
308
-
309
- // Blink's implementation of convertToBlob seems to default to a quality level of 100%
310
- // Use the Blink default quality levels of toBlob instead so that file sizes are comparable.
311
- if ( mimeType === 'image/jpeg' ) {
312
-
313
- quality = 0.92;
314
-
315
- } else if ( mimeType === 'image/webp' ) {
316
-
317
- quality = 0.8;
318
-
319
- }
320
-
321
- return canvas.convertToBlob( {
322
- type: mimeType,
323
- quality: quality
324
- } );
325
-
326
- }
327
-
328
- /**
329
- * Writer
330
- */
331
- class GLTFWriter {
332
-
333
- constructor() {
334
-
335
- this.plugins = [];
336
- this.options = {};
337
- this.pending = [];
338
- this.buffers = [];
339
- this.byteOffset = 0;
340
- this.buffers = [];
341
- this.nodeMap = new Map();
342
- this.skins = [];
343
- this.extensionsUsed = {};
344
- this.uids = new Map();
345
- this.uid = 0;
346
- this.json = {
347
- asset: {
348
- version: '2.0',
349
- generator: 'THREE.GLTFExporter'
350
- }
351
- };
352
- this.cache = {
353
- meshes: new Map(),
354
- attributes: new Map(),
355
- attributesNormalized: new Map(),
356
- materials: new Map(),
357
- textures: new Map(),
358
- images: new Map()
359
- };
360
-
361
- }
362
- setPlugins( plugins ) {
363
-
364
- this.plugins = plugins;
365
-
366
- }
367
-
368
- /**
369
- * Parse scenes and generate GLTF output
370
- * @param {Scene or [THREE.Scenes]} input THREE.Scene or Array of THREE.Scenes
371
- * @param {Function} onDone Callback on completed
372
- * @param {Object} options options
373
- */
374
- async write( input, onDone, options ) {
375
-
376
- this.options = Object.assign( {}, {
377
- // default options
378
- binary: false,
379
- trs: false,
380
- onlyVisible: true,
381
- maxTextureSize: Infinity,
382
- animations: [],
383
- includeCustomExtensions: false
384
- }, options );
385
- if ( this.options.animations.length > 0 ) {
386
-
387
- // Only TRS properties, and not matrices, may be targeted by animation.
388
- this.options.trs = true;
389
-
390
- }
391
-
392
- this.processInput( input );
393
- await Promise.all( this.pending );
394
- const writer = this;
395
- const buffers = writer.buffers;
396
- const json = writer.json;
397
- options = writer.options;
398
- const extensionsUsed = writer.extensionsUsed;
399
-
400
- // Merge buffers.
401
- const blob = new Blob( buffers, {
402
- type: 'application/octet-stream'
403
- } );
404
-
405
- // Declare extensions.
406
- const extensionsUsedList = Object.keys( extensionsUsed );
407
- if ( extensionsUsedList.length > 0 ) json.extensionsUsed = extensionsUsedList;
408
-
409
- // Update bytelength of the single buffer.
410
- if ( json.buffers && json.buffers.length > 0 ) json.buffers[ 0 ].byteLength = blob.size;
411
- if ( options.binary === true ) {
412
-
413
- // https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#glb-file-format-specification
414
-
415
- const reader = new FileReader();
416
- reader.readAsArrayBuffer( blob );
417
- reader.onloadend = function () {
418
-
419
- // Binary chunk.
420
- const binaryChunk = getPaddedArrayBuffer( reader.result );
421
- const binaryChunkPrefix = new DataView( new ArrayBuffer( GLB_CHUNK_PREFIX_BYTES ) );
422
- binaryChunkPrefix.setUint32( 0, binaryChunk.byteLength, true );
423
- binaryChunkPrefix.setUint32( 4, GLB_CHUNK_TYPE_BIN, true );
424
-
425
- // JSON chunk.
426
- const jsonChunk = getPaddedArrayBuffer( stringToArrayBuffer( JSON.stringify( json ) ), 0x20 );
427
- const jsonChunkPrefix = new DataView( new ArrayBuffer( GLB_CHUNK_PREFIX_BYTES ) );
428
- jsonChunkPrefix.setUint32( 0, jsonChunk.byteLength, true );
429
- jsonChunkPrefix.setUint32( 4, GLB_CHUNK_TYPE_JSON, true );
430
-
431
- // GLB header.
432
- const header = new ArrayBuffer( GLB_HEADER_BYTES );
433
- const headerView = new DataView( header );
434
- headerView.setUint32( 0, GLB_HEADER_MAGIC, true );
435
- headerView.setUint32( 4, GLB_VERSION, true );
436
- const totalByteLength = GLB_HEADER_BYTES + jsonChunkPrefix.byteLength + jsonChunk.byteLength + binaryChunkPrefix.byteLength + binaryChunk.byteLength;
437
- headerView.setUint32( 8, totalByteLength, true );
438
- const glbBlob = new Blob( [ header, jsonChunkPrefix, jsonChunk, binaryChunkPrefix, binaryChunk ], {
439
- type: 'application/octet-stream'
440
- } );
441
- const glbReader = new FileReader();
442
- glbReader.readAsArrayBuffer( glbBlob );
443
- glbReader.onloadend = function () {
444
-
445
- onDone( glbReader.result );
446
-
447
- };
448
-
449
- };
450
-
451
- } else {
452
-
453
- if ( json.buffers && json.buffers.length > 0 ) {
454
-
455
- const reader = new FileReader();
456
- reader.readAsDataURL( blob );
457
- reader.onloadend = function () {
458
-
459
- const base64data = reader.result;
460
- json.buffers[ 0 ].uri = base64data;
461
- onDone( json );
462
-
463
- };
464
-
465
- } else {
466
-
467
- onDone( json );
468
-
469
- }
470
-
471
- }
472
-
473
- }
474
-
475
- /**
476
- * Serializes a userData.
477
- *
478
- * @param {THREE.Object3D|THREE.Material} object
479
- * @param {Object} objectDef
480
- */
481
- serializeUserData( object, objectDef ) {
482
-
483
- if ( Object.keys( object.userData ).length === 0 ) return;
484
- const options = this.options;
485
- const extensionsUsed = this.extensionsUsed;
486
- try {
487
-
488
- const json = JSON.parse( JSON.stringify( object.userData ) );
489
- if ( options.includeCustomExtensions && json.gltfExtensions ) {
490
-
491
- if ( objectDef.extensions === undefined ) objectDef.extensions = {};
492
- for ( const extensionName in json.gltfExtensions ) {
493
-
494
- objectDef.extensions[ extensionName ] = json.gltfExtensions[ extensionName ];
495
- extensionsUsed[ extensionName ] = true;
496
-
497
- }
498
-
499
- delete json.gltfExtensions;
500
-
501
- }
502
-
503
- if ( Object.keys( json ).length > 0 ) objectDef.extras = json;
504
-
505
- } catch ( error ) {
506
-
507
- console.warn( 'THREE.GLTFExporter: userData of \'' + object.name + '\' ' + 'won\'t be serialized because of JSON.stringify error - ' + error.message );
508
-
509
- }
510
-
511
- }
512
-
513
- /**
514
- * Returns ids for buffer attributes.
515
- * @param {Object} object
516
- * @return {Integer}
517
- */
518
- getUID( attribute, isRelativeCopy = false ) {
519
-
520
- if ( this.uids.has( attribute ) === false ) {
521
-
522
- const uids = new Map();
523
- uids.set( true, this.uid ++ );
524
- uids.set( false, this.uid ++ );
525
- this.uids.set( attribute, uids );
526
-
527
- }
528
-
529
- const uids = this.uids.get( attribute );
530
- return uids.get( isRelativeCopy );
531
-
532
- }
533
-
534
- /**
535
- * Checks if normal attribute values are normalized.
536
- *
537
- * @param {BufferAttribute} normal
538
- * @returns {Boolean}
539
- */
540
- isNormalizedNormalAttribute( normal ) {
541
-
542
- const cache = this.cache;
543
- if ( cache.attributesNormalized.has( normal ) ) return false;
544
- const v = new THREE.Vector3();
545
- for ( let i = 0, il = normal.count; i < il; i ++ ) {
546
-
547
- // 0.0005 is from glTF-validator
548
- if ( Math.abs( v.fromBufferAttribute( normal, i ).length() - 1.0 ) > 0.0005 ) return false;
549
-
550
- }
551
-
552
- return true;
553
-
554
- }
555
-
556
- /**
557
- * Creates normalized normal buffer attribute.
558
- *
559
- * @param {BufferAttribute} normal
560
- * @returns {BufferAttribute}
561
- *
562
- */
563
- createNormalizedNormalAttribute( normal ) {
564
-
565
- const cache = this.cache;
566
- if ( cache.attributesNormalized.has( normal ) ) return cache.attributesNormalized.get( normal );
567
- const attribute = normal.clone();
568
- const v = new THREE.Vector3();
569
- for ( let i = 0, il = attribute.count; i < il; i ++ ) {
570
-
571
- v.fromBufferAttribute( attribute, i );
572
- if ( v.x === 0 && v.y === 0 && v.z === 0 ) {
573
-
574
- // if values can't be normalized set (1, 0, 0)
575
- v.setX( 1.0 );
576
-
577
- } else {
578
-
579
- v.normalize();
580
-
581
- }
582
-
583
- attribute.setXYZ( i, v.x, v.y, v.z );
584
-
585
- }
586
-
587
- cache.attributesNormalized.set( normal, attribute );
588
- return attribute;
589
-
590
- }
591
-
592
- /**
593
- * Applies a texture transform, if present, to the map definition. Requires
594
- * the KHR_texture_transform extension.
595
- *
596
- * @param {Object} mapDef
597
- * @param {THREE.Texture} texture
598
- */
599
- applyTextureTransform( mapDef, texture ) {
600
-
601
- let didTransform = false;
602
- const transformDef = {};
603
- if ( texture.offset.x !== 0 || texture.offset.y !== 0 ) {
604
-
605
- transformDef.offset = texture.offset.toArray();
606
- didTransform = true;
607
-
608
- }
609
-
610
- if ( texture.rotation !== 0 ) {
611
-
612
- transformDef.rotation = texture.rotation;
613
- didTransform = true;
614
-
615
- }
616
-
617
- if ( texture.repeat.x !== 1 || texture.repeat.y !== 1 ) {
618
-
619
- transformDef.scale = texture.repeat.toArray();
620
- didTransform = true;
621
-
622
- }
623
-
624
- if ( didTransform ) {
625
-
626
- mapDef.extensions = mapDef.extensions || {};
627
- mapDef.extensions[ 'KHR_texture_transform' ] = transformDef;
628
- this.extensionsUsed[ 'KHR_texture_transform' ] = true;
629
-
630
- }
631
-
632
- }
633
- buildMetalRoughTexture( metalnessMap, roughnessMap ) {
634
-
635
- if ( metalnessMap === roughnessMap ) return metalnessMap;
636
- function getEncodingConversion( map ) {
637
-
638
- if ( map.encoding === THREE.sRGBEncoding ) {
639
-
640
- return function SRGBToLinear( c ) {
641
-
642
- return c < 0.04045 ? c * 0.0773993808 : Math.pow( c * 0.9478672986 + 0.0521327014, 2.4 );
643
-
644
- };
645
-
646
- }
647
-
648
- return function LinearToLinear( c ) {
649
-
650
- return c;
651
-
652
- };
653
-
654
- }
655
-
656
- console.warn( 'THREE.GLTFExporter: Merged metalnessMap and roughnessMap textures.' );
657
- const metalness = metalnessMap?.image;
658
- const roughness = roughnessMap?.image;
659
- const width = Math.max( metalness?.width || 0, roughness?.width || 0 );
660
- const height = Math.max( metalness?.height || 0, roughness?.height || 0 );
661
- const canvas = getCanvas();
662
- canvas.width = width;
663
- canvas.height = height;
664
- const context = canvas.getContext( '2d' );
665
- context.fillStyle = '#00ffff';
666
- context.fillRect( 0, 0, width, height );
667
- const composite = context.getImageData( 0, 0, width, height );
668
- if ( metalness ) {
669
-
670
- context.drawImage( metalness, 0, 0, width, height );
671
- const convert = getEncodingConversion( metalnessMap );
672
- const data = context.getImageData( 0, 0, width, height ).data;
673
- for ( let i = 2; i < data.length; i += 4 ) {
674
-
675
- composite.data[ i ] = convert( data[ i ] / 256 ) * 256;
676
-
677
- }
678
-
679
- }
680
-
681
- if ( roughness ) {
682
-
683
- context.drawImage( roughness, 0, 0, width, height );
684
- const convert = getEncodingConversion( roughnessMap );
685
- const data = context.getImageData( 0, 0, width, height ).data;
686
- for ( let i = 1; i < data.length; i += 4 ) {
687
-
688
- composite.data[ i ] = convert( data[ i ] / 256 ) * 256;
689
-
690
- }
691
-
692
- }
693
-
694
- context.putImageData( composite, 0, 0 );
695
-
696
- //
697
-
698
- const reference = metalnessMap || roughnessMap;
699
- const texture = reference.clone();
700
- texture.source = new THREE.Source( canvas );
701
- texture.encoding = THREE.LinearEncoding;
702
- return texture;
703
-
704
- }
705
-
706
- /**
707
- * Process a buffer to append to the default one.
708
- * @param {ArrayBuffer} buffer
709
- * @return {Integer}
710
- */
711
- processBuffer( buffer ) {
712
-
713
- const json = this.json;
714
- const buffers = this.buffers;
715
- if ( ! json.buffers ) json.buffers = [ {
716
- byteLength: 0
717
- } ];
718
-
719
- // All buffers are merged before export.
720
- buffers.push( buffer );
721
- return 0;
722
-
723
- }
724
-
725
- /**
726
- * Process and generate a BufferView
727
- * @param {BufferAttribute} attribute
728
- * @param {number} componentType
729
- * @param {number} start
730
- * @param {number} count
731
- * @param {number} target (Optional) Target usage of the BufferView
732
- * @return {Object}
733
- */
734
- processBufferView( attribute, componentType, start, count, target ) {
735
-
736
- const json = this.json;
737
- if ( ! json.bufferViews ) json.bufferViews = [];
738
-
739
- // Create a new dataview and dump the attribute's array into it
740
-
741
- let componentSize;
742
- if ( componentType === WEBGL_CONSTANTS.UNSIGNED_BYTE ) {
743
-
744
- componentSize = 1;
745
-
746
- } else if ( componentType === WEBGL_CONSTANTS.UNSIGNED_SHORT ) {
747
-
748
- componentSize = 2;
749
-
750
- } else {
751
-
752
- componentSize = 4;
753
-
754
- }
755
-
756
- const byteLength = getPaddedBufferSize( count * attribute.itemSize * componentSize );
757
- const dataView = new DataView( new ArrayBuffer( byteLength ) );
758
- let offset = 0;
759
- for ( let i = start; i < start + count; i ++ ) {
760
-
761
- for ( let a = 0; a < attribute.itemSize; a ++ ) {
762
-
763
- let value;
764
- if ( attribute.itemSize > 4 ) {
765
-
766
- // no support for interleaved data for itemSize > 4
767
-
768
- value = attribute.array[ i * attribute.itemSize + a ];
769
-
770
- } else {
771
-
772
- if ( a === 0 ) value = attribute.getX( i ); else if ( a === 1 ) value = attribute.getY( i ); else if ( a === 2 ) value = attribute.getZ( i ); else if ( a === 3 ) value = attribute.getW( i );
773
-
774
- }
775
-
776
- if ( componentType === WEBGL_CONSTANTS.FLOAT ) {
777
-
778
- dataView.setFloat32( offset, value, true );
779
-
780
- } else if ( componentType === WEBGL_CONSTANTS.UNSIGNED_INT ) {
781
-
782
- dataView.setUint32( offset, value, true );
783
-
784
- } else if ( componentType === WEBGL_CONSTANTS.UNSIGNED_SHORT ) {
785
-
786
- dataView.setUint16( offset, value, true );
787
-
788
- } else if ( componentType === WEBGL_CONSTANTS.UNSIGNED_BYTE ) {
789
-
790
- dataView.setUint8( offset, value );
791
-
792
- }
793
-
794
- offset += componentSize;
795
-
796
- }
797
-
798
- }
799
-
800
- const bufferViewDef = {
801
- buffer: this.processBuffer( dataView.buffer ),
802
- byteOffset: this.byteOffset,
803
- byteLength: byteLength
804
- };
805
- if ( target !== undefined ) bufferViewDef.target = target;
806
- if ( target === WEBGL_CONSTANTS.ARRAY_BUFFER ) {
807
-
808
- // Only define byteStride for vertex attributes.
809
- bufferViewDef.byteStride = attribute.itemSize * componentSize;
810
-
811
- }
812
-
813
- this.byteOffset += byteLength;
814
- json.bufferViews.push( bufferViewDef );
815
-
816
- // @TODO Merge bufferViews where possible.
817
- const output = {
818
- id: json.bufferViews.length - 1,
819
- byteLength: 0
820
- };
821
- return output;
822
-
823
- }
824
-
825
- /**
826
- * Process and generate a BufferView from an image Blob.
827
- * @param {Blob} blob
828
- * @return {Promise<Integer>}
829
- */
830
- processBufferViewImage( blob ) {
831
-
832
- const writer = this;
833
- const json = writer.json;
834
- if ( ! json.bufferViews ) json.bufferViews = [];
835
- return new Promise( function ( resolve ) {
836
-
837
- const reader = new FileReader();
838
- reader.readAsArrayBuffer( blob );
839
- reader.onloadend = function () {
840
-
841
- const buffer = getPaddedArrayBuffer( reader.result );
842
- const bufferViewDef = {
843
- buffer: writer.processBuffer( buffer ),
844
- byteOffset: writer.byteOffset,
845
- byteLength: buffer.byteLength
846
- };
847
- writer.byteOffset += buffer.byteLength;
848
- resolve( json.bufferViews.push( bufferViewDef ) - 1 );
849
-
850
- };
851
-
852
- } );
853
-
854
- }
855
-
856
- /**
857
- * Process attribute to generate an accessor
858
- * @param {BufferAttribute} attribute Attribute to process
859
- * @param {THREE.BufferGeometry} geometry (Optional) Geometry used for truncated draw range
860
- * @param {Integer} start (Optional)
861
- * @param {Integer} count (Optional)
862
- * @return {Integer|null} Index of the processed accessor on the "accessors" array
863
- */
864
- processAccessor( attribute, geometry, start, count ) {
865
-
866
- const json = this.json;
867
- const types = {
868
- 1: 'SCALAR',
869
- 2: 'VEC2',
870
- 3: 'VEC3',
871
- 4: 'VEC4',
872
- 16: 'MAT4'
873
- };
874
- let componentType;
875
-
876
- // Detect the component type of the attribute array (float, uint or ushort)
877
- if ( attribute.array.constructor === Float32Array ) {
878
-
879
- componentType = WEBGL_CONSTANTS.FLOAT;
880
-
881
- } else if ( attribute.array.constructor === Uint32Array ) {
882
-
883
- componentType = WEBGL_CONSTANTS.UNSIGNED_INT;
884
-
885
- } else if ( attribute.array.constructor === Uint16Array ) {
886
-
887
- componentType = WEBGL_CONSTANTS.UNSIGNED_SHORT;
888
-
889
- } else if ( attribute.array.constructor === Uint8Array ) {
890
-
891
- componentType = WEBGL_CONSTANTS.UNSIGNED_BYTE;
892
-
893
- } else {
894
-
895
- throw new Error( 'THREE.GLTFExporter: Unsupported bufferAttribute component type.' );
896
-
897
- }
898
-
899
- if ( start === undefined ) start = 0;
900
- if ( count === undefined ) count = attribute.count;
901
-
902
- // Skip creating an accessor if the attribute doesn't have data to export
903
- if ( count === 0 ) return null;
904
- const minMax = getMinMax( attribute, start, count );
905
- let bufferViewTarget;
906
-
907
- // If geometry isn't provided, don't infer the target usage of the bufferView. For
908
- // animation samplers, target must not be set.
909
- if ( geometry !== undefined ) {
910
-
911
- bufferViewTarget = attribute === geometry.index ? WEBGL_CONSTANTS.ELEMENT_ARRAY_BUFFER : WEBGL_CONSTANTS.ARRAY_BUFFER;
912
-
913
- }
914
-
915
- const bufferView = this.processBufferView( attribute, componentType, start, count, bufferViewTarget );
916
- const accessorDef = {
917
- bufferView: bufferView.id,
918
- byteOffset: bufferView.byteOffset,
919
- componentType: componentType,
920
- count: count,
921
- max: minMax.max,
922
- min: minMax.min,
923
- type: types[ attribute.itemSize ]
924
- };
925
- if ( attribute.normalized === true ) accessorDef.normalized = true;
926
- if ( ! json.accessors ) json.accessors = [];
927
- return json.accessors.push( accessorDef ) - 1;
928
-
929
- }
930
-
931
- /**
932
- * Process image
933
- * @param {Image} image to process
934
- * @param {Integer} format of the image (THREE.RGBAFormat)
935
- * @param {Boolean} flipY before writing out the image
936
- * @param {String} mimeType export format
937
- * @return {Integer} Index of the processed texture in the "images" array
938
- */
939
- processImage( image, format, flipY, mimeType = 'image/png' ) {
940
-
941
- const writer = this;
942
- const cache = writer.cache;
943
- const json = writer.json;
944
- const options = writer.options;
945
- const pending = writer.pending;
946
- if ( ! cache.images.has( image ) ) cache.images.set( image, {} );
947
- const cachedImages = cache.images.get( image );
948
- const key = mimeType + ':flipY/' + flipY.toString();
949
- if ( cachedImages[ key ] !== undefined ) return cachedImages[ key ];
950
- if ( ! json.images ) json.images = [];
951
- const imageDef = {
952
- mimeType: mimeType
953
- };
954
- const canvas = getCanvas();
955
- canvas.width = Math.min( image.width, options.maxTextureSize );
956
- canvas.height = Math.min( image.height, options.maxTextureSize );
957
- const ctx = canvas.getContext( '2d' );
958
- if ( flipY === true ) {
959
-
960
- ctx.translate( 0, canvas.height );
961
- ctx.scale( 1, - 1 );
962
-
963
- }
964
-
965
- if ( image.data !== undefined ) {
966
-
967
- // THREE.DataTexture
968
-
969
- if ( format !== THREE.RGBAFormat ) {
970
-
971
- console.error( 'GLTFExporter: Only THREE.RGBAFormat is supported.' );
972
-
973
- }
974
-
975
- if ( image.width > options.maxTextureSize || image.height > options.maxTextureSize ) {
976
-
977
- console.warn( 'GLTFExporter: Image size is bigger than maxTextureSize', image );
978
-
979
- }
980
-
981
- const data = new Uint8ClampedArray( image.height * image.width * 4 );
982
- for ( let i = 0; i < data.length; i += 4 ) {
983
-
984
- data[ i + 0 ] = image.data[ i + 0 ];
985
- data[ i + 1 ] = image.data[ i + 1 ];
986
- data[ i + 2 ] = image.data[ i + 2 ];
987
- data[ i + 3 ] = image.data[ i + 3 ];
988
-
989
- }
990
-
991
- ctx.putImageData( new ImageData( data, image.width, image.height ), 0, 0 );
992
-
993
- } else {
994
-
995
- ctx.drawImage( image, 0, 0, canvas.width, canvas.height );
996
-
997
- }
998
-
999
- if ( options.binary === true ) {
1000
-
1001
- pending.push( getToBlobPromise( canvas, mimeType ).then( blob => writer.processBufferViewImage( blob ) ).then( bufferViewIndex => {
1002
-
1003
- imageDef.bufferView = bufferViewIndex;
1004
-
1005
- } ) );
1006
-
1007
- } else {
1008
-
1009
- if ( canvas.toDataURL !== undefined ) {
1010
-
1011
- imageDef.uri = canvas.toDataURL( mimeType );
1012
-
1013
- } else {
1014
-
1015
- pending.push( getToBlobPromise( canvas, mimeType ).then( blob => new FileReader().readAsDataURL( blob ) ).then( dataURL => {
1016
-
1017
- imageDef.uri = dataURL;
1018
-
1019
- } ) );
1020
-
1021
- }
1022
-
1023
- }
1024
-
1025
- const index = json.images.push( imageDef ) - 1;
1026
- cachedImages[ key ] = index;
1027
- return index;
1028
-
1029
- }
1030
-
1031
- /**
1032
- * Process sampler
1033
- * @param {Texture} map Texture to process
1034
- * @return {Integer} Index of the processed texture in the "samplers" array
1035
- */
1036
- processSampler( map ) {
1037
-
1038
- const json = this.json;
1039
- if ( ! json.samplers ) json.samplers = [];
1040
- const samplerDef = {
1041
- magFilter: THREE_TO_WEBGL[ map.magFilter ],
1042
- minFilter: THREE_TO_WEBGL[ map.minFilter ],
1043
- wrapS: THREE_TO_WEBGL[ map.wrapS ],
1044
- wrapT: THREE_TO_WEBGL[ map.wrapT ]
1045
- };
1046
- return json.samplers.push( samplerDef ) - 1;
1047
-
1048
- }
1049
-
1050
- /**
1051
- * Process texture
1052
- * @param {Texture} map Map to process
1053
- * @return {Integer} Index of the processed texture in the "textures" array
1054
- */
1055
- processTexture( map ) {
1056
-
1057
- const cache = this.cache;
1058
- const json = this.json;
1059
- if ( cache.textures.has( map ) ) return cache.textures.get( map );
1060
- if ( ! json.textures ) json.textures = [];
1061
- let mimeType = map.userData.mimeType;
1062
- if ( mimeType === 'image/webp' ) mimeType = 'image/png';
1063
- const textureDef = {
1064
- sampler: this.processSampler( map ),
1065
- source: this.processImage( map.image, map.format, map.flipY, mimeType )
1066
- };
1067
- if ( map.name ) textureDef.name = map.name;
1068
- this._invokeAll( function ( ext ) {
1069
-
1070
- ext.writeTexture && ext.writeTexture( map, textureDef );
1071
-
1072
- } );
1073
- const index = json.textures.push( textureDef ) - 1;
1074
- cache.textures.set( map, index );
1075
- return index;
1076
-
1077
- }
1078
-
1079
- /**
1080
- * Process material
1081
- * @param {THREE.Material} material Material to process
1082
- * @return {Integer|null} Index of the processed material in the "materials" array
1083
- */
1084
- processMaterial( material ) {
1085
-
1086
- const cache = this.cache;
1087
- const json = this.json;
1088
- if ( cache.materials.has( material ) ) return cache.materials.get( material );
1089
- if ( material.isShaderMaterial ) {
1090
-
1091
- console.warn( 'GLTFExporter: THREE.ShaderMaterial not supported.' );
1092
- return null;
1093
-
1094
- }
1095
-
1096
- if ( ! json.materials ) json.materials = [];
1097
-
1098
- // @QUESTION Should we avoid including any attribute that has the default value?
1099
- const materialDef = {
1100
- pbrMetallicRoughness: {}
1101
- };
1102
- if ( material.isMeshStandardMaterial !== true && material.isMeshBasicMaterial !== true ) {
1103
-
1104
- console.warn( 'GLTFExporter: Use MeshStandardMaterial or MeshBasicMaterial for best results.' );
1105
-
1106
- }
1107
-
1108
- // pbrMetallicRoughness.baseColorFactor
1109
- const color = material.color.toArray().concat( [ material.opacity ] );
1110
- if ( ! equalArray( color, [ 1, 1, 1, 1 ] ) ) {
1111
-
1112
- materialDef.pbrMetallicRoughness.baseColorFactor = color;
1113
-
1114
- }
1115
-
1116
- if ( material.isMeshStandardMaterial ) {
1117
-
1118
- materialDef.pbrMetallicRoughness.metallicFactor = material.metalness;
1119
- materialDef.pbrMetallicRoughness.roughnessFactor = material.roughness;
1120
-
1121
- } else {
1122
-
1123
- materialDef.pbrMetallicRoughness.metallicFactor = 0.5;
1124
- materialDef.pbrMetallicRoughness.roughnessFactor = 0.5;
1125
-
1126
- }
1127
-
1128
- // pbrMetallicRoughness.metallicRoughnessTexture
1129
- if ( material.metalnessMap || material.roughnessMap ) {
1130
-
1131
- const metalRoughTexture = this.buildMetalRoughTexture( material.metalnessMap, material.roughnessMap );
1132
- const metalRoughMapDef = {
1133
- index: this.processTexture( metalRoughTexture )
1134
- };
1135
- this.applyTextureTransform( metalRoughMapDef, metalRoughTexture );
1136
- materialDef.pbrMetallicRoughness.metallicRoughnessTexture = metalRoughMapDef;
1137
-
1138
- }
1139
-
1140
- // pbrMetallicRoughness.baseColorTexture or pbrSpecularGlossiness diffuseTexture
1141
- if ( material.map ) {
1142
-
1143
- const baseColorMapDef = {
1144
- index: this.processTexture( material.map )
1145
- };
1146
- this.applyTextureTransform( baseColorMapDef, material.map );
1147
- materialDef.pbrMetallicRoughness.baseColorTexture = baseColorMapDef;
1148
-
1149
- }
1150
-
1151
- if ( material.emissive ) {
1152
-
1153
- // note: emissive components are limited to stay within the 0 - 1 range to accommodate glTF spec. see #21849 and #22000.
1154
- const emissive = material.emissive.clone().multiplyScalar( material.emissiveIntensity );
1155
- const maxEmissiveComponent = Math.max( emissive.r, emissive.g, emissive.b );
1156
- if ( maxEmissiveComponent > 1 ) {
1157
-
1158
- emissive.multiplyScalar( 1 / maxEmissiveComponent );
1159
- console.warn( 'THREE.GLTFExporter: Some emissive components exceed 1; emissive has been limited' );
1160
-
1161
- }
1162
-
1163
- if ( maxEmissiveComponent > 0 ) {
1164
-
1165
- materialDef.emissiveFactor = emissive.toArray();
1166
-
1167
- }
1168
-
1169
- // emissiveTexture
1170
- if ( material.emissiveMap ) {
1171
-
1172
- const emissiveMapDef = {
1173
- index: this.processTexture( material.emissiveMap )
1174
- };
1175
- this.applyTextureTransform( emissiveMapDef, material.emissiveMap );
1176
- materialDef.emissiveTexture = emissiveMapDef;
1177
-
1178
- }
1179
-
1180
- }
1181
-
1182
- // normalTexture
1183
- if ( material.normalMap ) {
1184
-
1185
- const normalMapDef = {
1186
- index: this.processTexture( material.normalMap )
1187
- };
1188
- if ( material.normalScale && material.normalScale.x !== 1 ) {
1189
-
1190
- // glTF normal scale is univariate. Ignore `y`, which may be flipped.
1191
- // Context: https://github.com/mrdoob/three.js/issues/11438#issuecomment-507003995
1192
- normalMapDef.scale = material.normalScale.x;
1193
-
1194
- }
1195
-
1196
- this.applyTextureTransform( normalMapDef, material.normalMap );
1197
- materialDef.normalTexture = normalMapDef;
1198
-
1199
- }
1200
-
1201
- // occlusionTexture
1202
- if ( material.aoMap ) {
1203
-
1204
- const occlusionMapDef = {
1205
- index: this.processTexture( material.aoMap ),
1206
- texCoord: 1
1207
- };
1208
- if ( material.aoMapIntensity !== 1.0 ) {
1209
-
1210
- occlusionMapDef.strength = material.aoMapIntensity;
1211
-
1212
- }
1213
-
1214
- this.applyTextureTransform( occlusionMapDef, material.aoMap );
1215
- materialDef.occlusionTexture = occlusionMapDef;
1216
-
1217
- }
1218
-
1219
- // alphaMode
1220
- if ( material.transparent ) {
1221
-
1222
- materialDef.alphaMode = 'BLEND';
1223
-
1224
- } else {
1225
-
1226
- if ( material.alphaTest > 0.0 ) {
1227
-
1228
- materialDef.alphaMode = 'MASK';
1229
- materialDef.alphaCutoff = material.alphaTest;
1230
-
1231
- }
1232
-
1233
- }
1234
-
1235
- // doubleSided
1236
- if ( material.side === THREE.DoubleSide ) materialDef.doubleSided = true;
1237
- if ( material.name !== '' ) materialDef.name = material.name;
1238
- this.serializeUserData( material, materialDef );
1239
- this._invokeAll( function ( ext ) {
1240
-
1241
- ext.writeMaterial && ext.writeMaterial( material, materialDef );
1242
-
1243
- } );
1244
- const index = json.materials.push( materialDef ) - 1;
1245
- cache.materials.set( material, index );
1246
- return index;
1247
-
1248
- }
1249
-
1250
- /**
1251
- * Process mesh
1252
- * @param {THREE.Mesh} mesh Mesh to process
1253
- * @return {Integer|null} Index of the processed mesh in the "meshes" array
1254
- */
1255
- processMesh( mesh ) {
1256
-
1257
- const cache = this.cache;
1258
- const json = this.json;
1259
- const meshCacheKeyParts = [ mesh.geometry.uuid ];
1260
- if ( Array.isArray( mesh.material ) ) {
1261
-
1262
- for ( let i = 0, l = mesh.material.length; i < l; i ++ ) {
1263
-
1264
- meshCacheKeyParts.push( mesh.material[ i ].uuid );
1265
-
1266
- }
1267
-
1268
- } else {
1269
-
1270
- meshCacheKeyParts.push( mesh.material.uuid );
1271
-
1272
- }
1273
-
1274
- const meshCacheKey = meshCacheKeyParts.join( ':' );
1275
- if ( cache.meshes.has( meshCacheKey ) ) return cache.meshes.get( meshCacheKey );
1276
- const geometry = mesh.geometry;
1277
- let mode;
1278
-
1279
- // Use the correct mode
1280
- if ( mesh.isLineSegments ) {
1281
-
1282
- mode = WEBGL_CONSTANTS.LINES;
1283
-
1284
- } else if ( mesh.isLineLoop ) {
1285
-
1286
- mode = WEBGL_CONSTANTS.LINE_LOOP;
1287
-
1288
- } else if ( mesh.isLine ) {
1289
-
1290
- mode = WEBGL_CONSTANTS.LINE_STRIP;
1291
-
1292
- } else if ( mesh.isPoints ) {
1293
-
1294
- mode = WEBGL_CONSTANTS.POINTS;
1295
-
1296
- } else {
1297
-
1298
- mode = mesh.material.wireframe ? WEBGL_CONSTANTS.LINES : WEBGL_CONSTANTS.TRIANGLES;
1299
-
1300
- }
1301
-
1302
- const meshDef = {};
1303
- const attributes = {};
1304
- const primitives = [];
1305
- const targets = [];
1306
-
1307
- // Conversion between attributes names in threejs and gltf spec
1308
- const nameConversion = {
1309
- uv: 'TEXCOORD_0',
1310
- uv2: 'TEXCOORD_1',
1311
- color: 'COLOR_0',
1312
- skinWeight: 'WEIGHTS_0',
1313
- skinIndex: 'JOINTS_0'
1314
- };
1315
- const originalNormal = geometry.getAttribute( 'normal' );
1316
- if ( originalNormal !== undefined && ! this.isNormalizedNormalAttribute( originalNormal ) ) {
1317
-
1318
- console.warn( 'THREE.GLTFExporter: Creating normalized normal attribute from the non-normalized one.' );
1319
- geometry.setAttribute( 'normal', this.createNormalizedNormalAttribute( originalNormal ) );
1320
-
1321
- }
1322
-
1323
- // @QUESTION Detect if .vertexColors = true?
1324
- // For every attribute create an accessor
1325
- let modifiedAttribute = null;
1326
- for ( let attributeName in geometry.attributes ) {
1327
-
1328
- // Ignore morph target attributes, which are exported later.
1329
- if ( attributeName.slice( 0, 5 ) === 'morph' ) continue;
1330
- const attribute = geometry.attributes[ attributeName ];
1331
- attributeName = nameConversion[ attributeName ] || attributeName.toUpperCase();
1332
-
1333
- // Prefix all geometry attributes except the ones specifically
1334
- // listed in the spec; non-spec attributes are considered custom.
1335
- const validVertexAttributes = /^(POSITION|NORMAL|TANGENT|TEXCOORD_\d+|COLOR_\d+|JOINTS_\d+|WEIGHTS_\d+)$/;
1336
- if ( ! validVertexAttributes.test( attributeName ) ) attributeName = '_' + attributeName;
1337
- if ( cache.attributes.has( this.getUID( attribute ) ) ) {
1338
-
1339
- attributes[ attributeName ] = cache.attributes.get( this.getUID( attribute ) );
1340
- continue;
1341
-
1342
- }
1343
-
1344
- // JOINTS_0 must be UNSIGNED_BYTE or UNSIGNED_SHORT.
1345
- modifiedAttribute = null;
1346
- const array = attribute.array;
1347
- if ( attributeName === 'JOINTS_0' && ! ( array instanceof Uint16Array ) && ! ( array instanceof Uint8Array ) ) {
1348
-
1349
- console.warn( 'GLTFExporter: Attribute "skinIndex" converted to type UNSIGNED_SHORT.' );
1350
- modifiedAttribute = new THREE.BufferAttribute( new Uint16Array( array ), attribute.itemSize, attribute.normalized );
1351
-
1352
- }
1353
-
1354
- const accessor = this.processAccessor( modifiedAttribute || attribute, geometry );
1355
- if ( accessor !== null ) {
1356
-
1357
- attributes[ attributeName ] = accessor;
1358
- cache.attributes.set( this.getUID( attribute ), accessor );
1359
-
1360
- }
1361
-
1362
- }
1363
-
1364
- if ( originalNormal !== undefined ) geometry.setAttribute( 'normal', originalNormal );
1365
-
1366
- // Skip if no exportable attributes found
1367
- if ( Object.keys( attributes ).length === 0 ) return null;
1368
-
1369
- // Morph targets
1370
- if ( mesh.morphTargetInfluences !== undefined && mesh.morphTargetInfluences.length > 0 ) {
1371
-
1372
- const weights = [];
1373
- const targetNames = [];
1374
- const reverseDictionary = {};
1375
- if ( mesh.morphTargetDictionary !== undefined ) {
1376
-
1377
- for ( const key in mesh.morphTargetDictionary ) {
1378
-
1379
- reverseDictionary[ mesh.morphTargetDictionary[ key ] ] = key;
1380
-
1381
- }
1382
-
1383
- }
1384
-
1385
- for ( let i = 0; i < mesh.morphTargetInfluences.length; ++ i ) {
1386
-
1387
- const target = {};
1388
- let warned = false;
1389
- for ( const attributeName in geometry.morphAttributes ) {
1390
-
1391
- // glTF 2.0 morph supports only POSITION/NORMAL/TANGENT.
1392
- // Three.js doesn't support TANGENT yet.
1393
-
1394
- if ( attributeName !== 'position' && attributeName !== 'normal' ) {
1395
-
1396
- if ( ! warned ) {
1397
-
1398
- console.warn( 'GLTFExporter: Only POSITION and NORMAL morph are supported.' );
1399
- warned = true;
1400
-
1401
- }
1402
-
1403
- continue;
1404
-
1405
- }
1406
-
1407
- const attribute = geometry.morphAttributes[ attributeName ][ i ];
1408
- const gltfAttributeName = attributeName.toUpperCase();
1409
-
1410
- // Three.js morph attribute has absolute values while the one of glTF has relative values.
1411
- //
1412
- // glTF 2.0 Specification:
1413
- // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#morph-targets
1414
-
1415
- const baseAttribute = geometry.attributes[ attributeName ];
1416
- if ( cache.attributes.has( this.getUID( attribute, true ) ) ) {
1417
-
1418
- target[ gltfAttributeName ] = cache.attributes.get( this.getUID( attribute, true ) );
1419
- continue;
1420
-
1421
- }
1422
-
1423
- // Clones attribute not to override
1424
- const relativeAttribute = attribute.clone();
1425
- if ( ! geometry.morphTargetsRelative ) {
1426
-
1427
- for ( let j = 0, jl = attribute.count; j < jl; j ++ ) {
1428
-
1429
- relativeAttribute.setXYZ( j, attribute.getX( j ) - baseAttribute.getX( j ), attribute.getY( j ) - baseAttribute.getY( j ), attribute.getZ( j ) - baseAttribute.getZ( j ) );
1430
-
1431
- }
1432
-
1433
- }
1434
-
1435
- target[ gltfAttributeName ] = this.processAccessor( relativeAttribute, geometry );
1436
- cache.attributes.set( this.getUID( baseAttribute, true ), target[ gltfAttributeName ] );
1437
-
1438
- }
1439
-
1440
- targets.push( target );
1441
- weights.push( mesh.morphTargetInfluences[ i ] );
1442
- if ( mesh.morphTargetDictionary !== undefined ) targetNames.push( reverseDictionary[ i ] );
1443
-
1444
- }
1445
-
1446
- meshDef.weights = weights;
1447
- if ( targetNames.length > 0 ) {
1448
-
1449
- meshDef.extras = {};
1450
- meshDef.extras.targetNames = targetNames;
1451
-
1452
- }
1453
-
1454
- }
1455
-
1456
- const isMultiMaterial = Array.isArray( mesh.material );
1457
- if ( isMultiMaterial && geometry.groups.length === 0 ) return null;
1458
- const materials = isMultiMaterial ? mesh.material : [ mesh.material ];
1459
- const groups = isMultiMaterial ? geometry.groups : [ {
1460
- materialIndex: 0,
1461
- start: undefined,
1462
- count: undefined
1463
- } ];
1464
- for ( let i = 0, il = groups.length; i < il; i ++ ) {
1465
-
1466
- const primitive = {
1467
- mode: mode,
1468
- attributes: attributes
1469
- };
1470
- this.serializeUserData( geometry, primitive );
1471
- if ( targets.length > 0 ) primitive.targets = targets;
1472
- if ( geometry.index !== null ) {
1473
-
1474
- let cacheKey = this.getUID( geometry.index );
1475
- if ( groups[ i ].start !== undefined || groups[ i ].count !== undefined ) {
1476
-
1477
- cacheKey += ':' + groups[ i ].start + ':' + groups[ i ].count;
1478
-
1479
- }
1480
-
1481
- if ( cache.attributes.has( cacheKey ) ) {
1482
-
1483
- primitive.indices = cache.attributes.get( cacheKey );
1484
-
1485
- } else {
1486
-
1487
- primitive.indices = this.processAccessor( geometry.index, geometry, groups[ i ].start, groups[ i ].count );
1488
- cache.attributes.set( cacheKey, primitive.indices );
1489
-
1490
- }
1491
-
1492
- if ( primitive.indices === null ) delete primitive.indices;
1493
-
1494
- }
1495
-
1496
- const material = this.processMaterial( materials[ groups[ i ].materialIndex ] );
1497
- if ( material !== null ) primitive.material = material;
1498
- primitives.push( primitive );
1499
-
1500
- }
1501
-
1502
- meshDef.primitives = primitives;
1503
- if ( ! json.meshes ) json.meshes = [];
1504
- this._invokeAll( function ( ext ) {
1505
-
1506
- ext.writeMesh && ext.writeMesh( mesh, meshDef );
1507
-
1508
- } );
1509
- const index = json.meshes.push( meshDef ) - 1;
1510
- cache.meshes.set( meshCacheKey, index );
1511
- return index;
1512
-
1513
- }
1514
-
1515
- /**
1516
- * Process camera
1517
- * @param {THREE.Camera} camera Camera to process
1518
- * @return {Integer} Index of the processed mesh in the "camera" array
1519
- */
1520
- processCamera( camera ) {
1521
-
1522
- const json = this.json;
1523
- if ( ! json.cameras ) json.cameras = [];
1524
- const isOrtho = camera.isOrthographicCamera;
1525
- const cameraDef = {
1526
- type: isOrtho ? 'orthographic' : 'perspective'
1527
- };
1528
- if ( isOrtho ) {
1529
-
1530
- cameraDef.orthographic = {
1531
- xmag: camera.right * 2,
1532
- ymag: camera.top * 2,
1533
- zfar: camera.far <= 0 ? 0.001 : camera.far,
1534
- znear: camera.near < 0 ? 0 : camera.near
1535
- };
1536
-
1537
- } else {
1538
-
1539
- cameraDef.perspective = {
1540
- aspectRatio: camera.aspect,
1541
- yfov: THREE.MathUtils.degToRad( camera.fov ),
1542
- zfar: camera.far <= 0 ? 0.001 : camera.far,
1543
- znear: camera.near < 0 ? 0 : camera.near
1544
- };
1545
-
1546
- }
1547
-
1548
- // Question: Is saving "type" as name intentional?
1549
- if ( camera.name !== '' ) cameraDef.name = camera.type;
1550
- return json.cameras.push( cameraDef ) - 1;
1551
-
1552
- }
1553
-
1554
- /**
1555
- * Creates glTF animation entry from AnimationClip object.
1556
- *
1557
- * Status:
1558
- * - Only properties listed in PATH_PROPERTIES may be animated.
1559
- *
1560
- * @param {THREE.AnimationClip} clip
1561
- * @param {THREE.Object3D} root
1562
- * @return {number|null}
1563
- */
1564
- processAnimation( clip, root ) {
1565
-
1566
- const json = this.json;
1567
- const nodeMap = this.nodeMap;
1568
- if ( ! json.animations ) json.animations = [];
1569
- clip = GLTFExporter.Utils.mergeMorphTargetTracks( clip.clone(), root );
1570
- const tracks = clip.tracks;
1571
- const channels = [];
1572
- const samplers = [];
1573
- for ( let i = 0; i < tracks.length; ++ i ) {
1574
-
1575
- const track = tracks[ i ];
1576
- const trackBinding = THREE.PropertyBinding.parseTrackName( track.name );
1577
- let trackNode = THREE.PropertyBinding.findNode( root, trackBinding.nodeName );
1578
- const trackProperty = PATH_PROPERTIES[ trackBinding.propertyName ];
1579
- if ( trackBinding.objectName === 'bones' ) {
1580
-
1581
- if ( trackNode.isSkinnedMesh === true ) {
1582
-
1583
- trackNode = trackNode.skeleton.getBoneByName( trackBinding.objectIndex );
1584
-
1585
- } else {
1586
-
1587
- trackNode = undefined;
1588
-
1589
- }
1590
-
1591
- }
1592
-
1593
- if ( ! trackNode || ! trackProperty ) {
1594
-
1595
- console.warn( 'THREE.GLTFExporter: Could not export animation track "%s".', track.name );
1596
- return null;
1597
-
1598
- }
1599
-
1600
- const inputItemSize = 1;
1601
- let outputItemSize = track.values.length / track.times.length;
1602
- if ( trackProperty === PATH_PROPERTIES.morphTargetInfluences ) {
1603
-
1604
- outputItemSize /= trackNode.morphTargetInfluences.length;
1605
-
1606
- }
1607
-
1608
- let interpolation;
1609
-
1610
- // @TODO export CubicInterpolant(InterpolateSmooth) as CUBICSPLINE
1611
-
1612
- // Detecting glTF cubic spline interpolant by checking factory method's special property
1613
- // GLTFCubicSplineInterpolant is a custom interpolant and track doesn't return
1614
- // valid value from .getInterpolation().
1615
- if ( track.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline === true ) {
1616
-
1617
- interpolation = 'CUBICSPLINE';
1618
-
1619
- // itemSize of CUBICSPLINE keyframe is 9
1620
- // (VEC3 * 3: inTangent, splineVertex, and outTangent)
1621
- // but needs to be stored as VEC3 so dividing by 3 here.
1622
- outputItemSize /= 3;
1623
-
1624
- } else if ( track.getInterpolation() === THREE.InterpolateDiscrete ) {
1625
-
1626
- interpolation = 'STEP';
1627
-
1628
- } else {
1629
-
1630
- interpolation = 'LINEAR';
1631
-
1632
- }
1633
-
1634
- samplers.push( {
1635
- input: this.processAccessor( new THREE.BufferAttribute( track.times, inputItemSize ) ),
1636
- output: this.processAccessor( new THREE.BufferAttribute( track.values, outputItemSize ) ),
1637
- interpolation: interpolation
1638
- } );
1639
- channels.push( {
1640
- sampler: samplers.length - 1,
1641
- target: {
1642
- node: nodeMap.get( trackNode ),
1643
- path: trackProperty
1644
- }
1645
- } );
1646
-
1647
- }
1648
-
1649
- json.animations.push( {
1650
- name: clip.name || 'clip_' + json.animations.length,
1651
- samplers: samplers,
1652
- channels: channels
1653
- } );
1654
- return json.animations.length - 1;
1655
-
1656
- }
1657
-
1658
- /**
1659
- * @param {THREE.Object3D} object
1660
- * @return {number|null}
1661
- */
1662
- processSkin( object ) {
1663
-
1664
- const json = this.json;
1665
- const nodeMap = this.nodeMap;
1666
- const node = json.nodes[ nodeMap.get( object ) ];
1667
- const skeleton = object.skeleton;
1668
- if ( skeleton === undefined ) return null;
1669
- const rootJoint = object.skeleton.bones[ 0 ];
1670
- if ( rootJoint === undefined ) return null;
1671
- const joints = [];
1672
- const inverseBindMatrices = new Float32Array( skeleton.bones.length * 16 );
1673
- const temporaryBoneInverse = new THREE.Matrix4();
1674
- for ( let i = 0; i < skeleton.bones.length; ++ i ) {
1675
-
1676
- joints.push( nodeMap.get( skeleton.bones[ i ] ) );
1677
- temporaryBoneInverse.copy( skeleton.boneInverses[ i ] );
1678
- temporaryBoneInverse.multiply( object.bindMatrix ).toArray( inverseBindMatrices, i * 16 );
1679
-
1680
- }
1681
-
1682
- if ( json.skins === undefined ) json.skins = [];
1683
- json.skins.push( {
1684
- inverseBindMatrices: this.processAccessor( new THREE.BufferAttribute( inverseBindMatrices, 16 ) ),
1685
- joints: joints,
1686
- skeleton: nodeMap.get( rootJoint )
1687
- } );
1688
- const skinIndex = node.skin = json.skins.length - 1;
1689
- return skinIndex;
1690
-
1691
- }
1692
-
1693
- /**
1694
- * Process Object3D node
1695
- * @param {THREE.Object3D} node Object3D to processNode
1696
- * @return {Integer} Index of the node in the nodes list
1697
- */
1698
- processNode( object ) {
1699
-
1700
- const json = this.json;
1701
- const options = this.options;
1702
- const nodeMap = this.nodeMap;
1703
- if ( ! json.nodes ) json.nodes = [];
1704
- const nodeDef = {};
1705
- if ( options.trs ) {
1706
-
1707
- const rotation = object.quaternion.toArray();
1708
- const position = object.position.toArray();
1709
- const scale = object.scale.toArray();
1710
- if ( ! equalArray( rotation, [ 0, 0, 0, 1 ] ) ) {
1711
-
1712
- nodeDef.rotation = rotation;
1713
-
1714
- }
1715
-
1716
- if ( ! equalArray( position, [ 0, 0, 0 ] ) ) {
1717
-
1718
- nodeDef.translation = position;
1719
-
1720
- }
1721
-
1722
- if ( ! equalArray( scale, [ 1, 1, 1 ] ) ) {
1723
-
1724
- nodeDef.scale = scale;
1725
-
1726
- }
1727
-
1728
- } else {
1729
-
1730
- if ( object.matrixAutoUpdate ) {
1731
-
1732
- object.updateMatrix();
1733
-
1734
- }
1735
-
1736
- if ( isIdentityMatrix( object.matrix ) === false ) {
1737
-
1738
- nodeDef.matrix = object.matrix.elements;
1739
-
1740
- }
1741
-
1742
- }
1743
-
1744
- // We don't export empty strings name because it represents no-name in Three.js.
1745
- if ( object.name !== '' ) nodeDef.name = String( object.name );
1746
- this.serializeUserData( object, nodeDef );
1747
- if ( object.isMesh || object.isLine || object.isPoints ) {
1748
-
1749
- const meshIndex = this.processMesh( object );
1750
- if ( meshIndex !== null ) nodeDef.mesh = meshIndex;
1751
-
1752
- } else if ( object.isCamera ) {
1753
-
1754
- nodeDef.camera = this.processCamera( object );
1755
-
1756
- }
1757
-
1758
- if ( object.isSkinnedMesh ) this.skins.push( object );
1759
- if ( object.children.length > 0 ) {
1760
-
1761
- const children = [];
1762
- for ( let i = 0, l = object.children.length; i < l; i ++ ) {
1763
-
1764
- const child = object.children[ i ];
1765
- if ( child.visible || options.onlyVisible === false ) {
1766
-
1767
- const nodeIndex = this.processNode( child );
1768
- if ( nodeIndex !== null ) children.push( nodeIndex );
1769
-
1770
- }
1771
-
1772
- }
1773
-
1774
- if ( children.length > 0 ) nodeDef.children = children;
1775
-
1776
- }
1777
-
1778
- this._invokeAll( function ( ext ) {
1779
-
1780
- ext.writeNode && ext.writeNode( object, nodeDef );
1781
-
1782
- } );
1783
- const nodeIndex = json.nodes.push( nodeDef ) - 1;
1784
- nodeMap.set( object, nodeIndex );
1785
- return nodeIndex;
1786
-
1787
- }
1788
-
1789
- /**
1790
- * Process THREE.Scene
1791
- * @param {Scene} node THREE.Scene to process
1792
- */
1793
- processScene( scene ) {
1794
-
1795
- const json = this.json;
1796
- const options = this.options;
1797
- if ( ! json.scenes ) {
1798
-
1799
- json.scenes = [];
1800
- json.scene = 0;
1801
-
1802
- }
1803
-
1804
- const sceneDef = {};
1805
- if ( scene.name !== '' ) sceneDef.name = scene.name;
1806
- json.scenes.push( sceneDef );
1807
- const nodes = [];
1808
- for ( let i = 0, l = scene.children.length; i < l; i ++ ) {
1809
-
1810
- const child = scene.children[ i ];
1811
- if ( child.visible || options.onlyVisible === false ) {
1812
-
1813
- const nodeIndex = this.processNode( child );
1814
- if ( nodeIndex !== null ) nodes.push( nodeIndex );
1815
-
1816
- }
1817
-
1818
- }
1819
-
1820
- if ( nodes.length > 0 ) sceneDef.nodes = nodes;
1821
- this.serializeUserData( scene, sceneDef );
1822
-
1823
- }
1824
-
1825
- /**
1826
- * Creates a THREE.Scene to hold a list of objects and parse it
1827
- * @param {Array} objects List of objects to process
1828
- */
1829
- processObjects( objects ) {
1830
-
1831
- const scene = new THREE.Scene();
1832
- scene.name = 'AuxScene';
1833
- for ( let i = 0; i < objects.length; i ++ ) {
1834
-
1835
- // We push directly to children instead of calling `add` to prevent
1836
- // modify the .parent and break its original scene and hierarchy
1837
- scene.children.push( objects[ i ] );
1838
-
1839
- }
1840
-
1841
- this.processScene( scene );
1842
-
1843
- }
1844
-
1845
- /**
1846
- * @param {THREE.Object3D|Array<THREE.Object3D>} input
1847
- */
1848
- processInput( input ) {
1849
-
1850
- const options = this.options;
1851
- input = input instanceof Array ? input : [ input ];
1852
- this._invokeAll( function ( ext ) {
1853
-
1854
- ext.beforeParse && ext.beforeParse( input );
1855
-
1856
- } );
1857
- const objectsWithoutScene = [];
1858
- for ( let i = 0; i < input.length; i ++ ) {
1859
-
1860
- if ( input[ i ] instanceof THREE.Scene ) {
1861
-
1862
- this.processScene( input[ i ] );
1863
-
1864
- } else {
1865
-
1866
- objectsWithoutScene.push( input[ i ] );
1867
-
1868
- }
1869
-
1870
- }
1871
-
1872
- if ( objectsWithoutScene.length > 0 ) this.processObjects( objectsWithoutScene );
1873
- for ( let i = 0; i < this.skins.length; ++ i ) {
1874
-
1875
- this.processSkin( this.skins[ i ] );
1876
-
1877
- }
1878
-
1879
- for ( let i = 0; i < options.animations.length; ++ i ) {
1880
-
1881
- this.processAnimation( options.animations[ i ], input[ 0 ] );
1882
-
1883
- }
1884
-
1885
- this._invokeAll( function ( ext ) {
1886
-
1887
- ext.afterParse && ext.afterParse( input );
1888
-
1889
- } );
1890
-
1891
- }
1892
- _invokeAll( func ) {
1893
-
1894
- for ( let i = 0, il = this.plugins.length; i < il; i ++ ) {
1895
-
1896
- func( this.plugins[ i ] );
1897
-
1898
- }
1899
-
1900
- }
1901
-
1902
- }
1903
-
1904
- /**
1905
- * Punctual Lights Extension
1906
- *
1907
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_lights_punctual
1908
- */
1909
- class GLTFLightExtension {
1910
-
1911
- constructor( writer ) {
1912
-
1913
- this.writer = writer;
1914
- this.name = 'KHR_lights_punctual';
1915
-
1916
- }
1917
- writeNode( light, nodeDef ) {
1918
-
1919
- if ( ! light.isLight ) return;
1920
- if ( ! light.isDirectionalLight && ! light.isPointLight && ! light.isSpotLight ) {
1921
-
1922
- console.warn( 'THREE.GLTFExporter: Only directional, point, and spot lights are supported.', light );
1923
- return;
1924
-
1925
- }
1926
-
1927
- const writer = this.writer;
1928
- const json = writer.json;
1929
- const extensionsUsed = writer.extensionsUsed;
1930
- const lightDef = {};
1931
- if ( light.name ) lightDef.name = light.name;
1932
- lightDef.color = light.color.toArray();
1933
- lightDef.intensity = light.intensity;
1934
- if ( light.isDirectionalLight ) {
1935
-
1936
- lightDef.type = 'directional';
1937
-
1938
- } else if ( light.isPointLight ) {
1939
-
1940
- lightDef.type = 'point';
1941
- if ( light.distance > 0 ) lightDef.range = light.distance;
1942
-
1943
- } else if ( light.isSpotLight ) {
1944
-
1945
- lightDef.type = 'spot';
1946
- if ( light.distance > 0 ) lightDef.range = light.distance;
1947
- lightDef.spot = {};
1948
- lightDef.spot.innerConeAngle = ( light.penumbra - 1.0 ) * light.angle * - 1.0;
1949
- lightDef.spot.outerConeAngle = light.angle;
1950
-
1951
- }
1952
-
1953
- if ( light.decay !== undefined && light.decay !== 2 ) {
1954
-
1955
- console.warn( 'THREE.GLTFExporter: Light decay may be lost. glTF is physically-based, ' + 'and expects light.decay=2.' );
1956
-
1957
- }
1958
-
1959
- if ( light.target && ( light.target.parent !== light || light.target.position.x !== 0 || light.target.position.y !== 0 || light.target.position.z !== - 1 ) ) {
1960
-
1961
- console.warn( 'THREE.GLTFExporter: Light direction may be lost. For best results, ' + 'make light.target a child of the light with position 0,0,-1.' );
1962
-
1963
- }
1964
-
1965
- if ( ! extensionsUsed[ this.name ] ) {
1966
-
1967
- json.extensions = json.extensions || {};
1968
- json.extensions[ this.name ] = {
1969
- lights: []
1970
- };
1971
- extensionsUsed[ this.name ] = true;
1972
-
1973
- }
1974
-
1975
- const lights = json.extensions[ this.name ].lights;
1976
- lights.push( lightDef );
1977
- nodeDef.extensions = nodeDef.extensions || {};
1978
- nodeDef.extensions[ this.name ] = {
1979
- light: lights.length - 1
1980
- };
1981
-
1982
- }
1983
-
1984
- }
1985
-
1986
- /**
1987
- * Unlit Materials Extension
1988
- *
1989
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_unlit
1990
- */
1991
- class GLTFMaterialsUnlitExtension {
1992
-
1993
- constructor( writer ) {
1994
-
1995
- this.writer = writer;
1996
- this.name = 'KHR_materials_unlit';
1997
-
1998
- }
1999
- writeMaterial( material, materialDef ) {
2000
-
2001
- if ( ! material.isMeshBasicMaterial ) return;
2002
- const writer = this.writer;
2003
- const extensionsUsed = writer.extensionsUsed;
2004
- materialDef.extensions = materialDef.extensions || {};
2005
- materialDef.extensions[ this.name ] = {};
2006
- extensionsUsed[ this.name ] = true;
2007
- materialDef.pbrMetallicRoughness.metallicFactor = 0.0;
2008
- materialDef.pbrMetallicRoughness.roughnessFactor = 0.9;
2009
-
2010
- }
2011
-
2012
- }
2013
-
2014
- /**
2015
- * Specular-Glossiness Extension
2016
- *
2017
- * Specification: https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Archived/KHR_materials_pbrSpecularGlossiness
2018
- */
2019
- class GLTFMaterialsPBRSpecularGlossiness {
2020
-
2021
- constructor( writer ) {
2022
-
2023
- this.writer = writer;
2024
- this.name = 'KHR_materials_pbrSpecularGlossiness';
2025
-
2026
- }
2027
- writeMaterial( material, materialDef ) {
2028
-
2029
- if ( ! material.isGLTFSpecularGlossinessMaterial ) return;
2030
- const writer = this.writer;
2031
- const extensionsUsed = writer.extensionsUsed;
2032
- const extensionDef = {};
2033
- if ( materialDef.pbrMetallicRoughness.baseColorFactor ) {
2034
-
2035
- extensionDef.diffuseFactor = materialDef.pbrMetallicRoughness.baseColorFactor;
2036
-
2037
- }
2038
-
2039
- const specularFactor = [ 1, 1, 1 ];
2040
- material.specular.toArray( specularFactor, 0 );
2041
- extensionDef.specularFactor = specularFactor;
2042
- extensionDef.glossinessFactor = material.glossiness;
2043
- if ( materialDef.pbrMetallicRoughness.baseColorTexture ) {
2044
-
2045
- extensionDef.diffuseTexture = materialDef.pbrMetallicRoughness.baseColorTexture;
2046
-
2047
- }
2048
-
2049
- if ( material.specularMap ) {
2050
-
2051
- const specularMapDef = {
2052
- index: writer.processTexture( material.specularMap )
2053
- };
2054
- writer.applyTextureTransform( specularMapDef, material.specularMap );
2055
- extensionDef.specularGlossinessTexture = specularMapDef;
2056
-
2057
- }
2058
-
2059
- materialDef.extensions = materialDef.extensions || {};
2060
- materialDef.extensions[ this.name ] = extensionDef;
2061
- extensionsUsed[ this.name ] = true;
2062
-
2063
- }
2064
-
2065
- }
2066
-
2067
- /**
2068
- * Clearcoat Materials Extension
2069
- *
2070
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_clearcoat
2071
- */
2072
- class GLTFMaterialsClearcoatExtension {
2073
-
2074
- constructor( writer ) {
2075
-
2076
- this.writer = writer;
2077
- this.name = 'KHR_materials_clearcoat';
2078
-
2079
- }
2080
- writeMaterial( material, materialDef ) {
2081
-
2082
- if ( ! material.isMeshPhysicalMaterial ) return;
2083
- const writer = this.writer;
2084
- const extensionsUsed = writer.extensionsUsed;
2085
- const extensionDef = {};
2086
- extensionDef.clearcoatFactor = material.clearcoat;
2087
- if ( material.clearcoatMap ) {
2088
-
2089
- const clearcoatMapDef = {
2090
- index: writer.processTexture( material.clearcoatMap )
2091
- };
2092
- writer.applyTextureTransform( clearcoatMapDef, material.clearcoatMap );
2093
- extensionDef.clearcoatTexture = clearcoatMapDef;
2094
-
2095
- }
2096
-
2097
- extensionDef.clearcoatRoughnessFactor = material.clearcoatRoughness;
2098
- if ( material.clearcoatRoughnessMap ) {
2099
-
2100
- const clearcoatRoughnessMapDef = {
2101
- index: writer.processTexture( material.clearcoatRoughnessMap )
2102
- };
2103
- writer.applyTextureTransform( clearcoatRoughnessMapDef, material.clearcoatRoughnessMap );
2104
- extensionDef.clearcoatRoughnessTexture = clearcoatRoughnessMapDef;
2105
-
2106
- }
2107
-
2108
- if ( material.clearcoatNormalMap ) {
2109
-
2110
- const clearcoatNormalMapDef = {
2111
- index: writer.processTexture( material.clearcoatNormalMap )
2112
- };
2113
- writer.applyTextureTransform( clearcoatNormalMapDef, material.clearcoatNormalMap );
2114
- extensionDef.clearcoatNormalTexture = clearcoatNormalMapDef;
2115
-
2116
- }
2117
-
2118
- materialDef.extensions = materialDef.extensions || {};
2119
- materialDef.extensions[ this.name ] = extensionDef;
2120
- extensionsUsed[ this.name ] = true;
2121
-
2122
- }
2123
-
2124
- }
2125
-
2126
- /**
2127
- * Iridescence Materials Extension
2128
- *
2129
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_iridescence
2130
- */
2131
- class GLTFMaterialsIridescenceExtension {
2132
-
2133
- constructor( writer ) {
2134
-
2135
- this.writer = writer;
2136
- this.name = 'KHR_materials_iridescence';
2137
-
2138
- }
2139
- writeMaterial( material, materialDef ) {
2140
-
2141
- if ( ! material.isMeshPhysicalMaterial ) return;
2142
- const writer = this.writer;
2143
- const extensionsUsed = writer.extensionsUsed;
2144
- const extensionDef = {};
2145
- extensionDef.iridescenceFactor = material.iridescence;
2146
- if ( material.iridescenceMap ) {
2147
-
2148
- const iridescenceMapDef = {
2149
- index: writer.processTexture( material.iridescenceMap )
2150
- };
2151
- writer.applyTextureTransform( iridescenceMapDef, material.iridescenceMap );
2152
- extensionDef.iridescenceTexture = iridescenceMapDef;
2153
-
2154
- }
2155
-
2156
- extensionDef.iridescenceIor = material.iridescenceIOR;
2157
- extensionDef.iridescenceThicknessMinimum = material.iridescenceThicknessRange[ 0 ];
2158
- extensionDef.iridescenceThicknessMaximum = material.iridescenceThicknessRange[ 1 ];
2159
- if ( material.iridescenceThicknessMap ) {
2160
-
2161
- const iridescenceThicknessMapDef = {
2162
- index: writer.processTexture( material.iridescenceThicknessMap )
2163
- };
2164
- writer.applyTextureTransform( iridescenceThicknessMapDef, material.iridescenceThicknessMap );
2165
- extensionDef.iridescenceThicknessTexture = iridescenceThicknessMapDef;
2166
-
2167
- }
2168
-
2169
- materialDef.extensions = materialDef.extensions || {};
2170
- materialDef.extensions[ this.name ] = extensionDef;
2171
- extensionsUsed[ this.name ] = true;
2172
-
2173
- }
2174
-
2175
- }
2176
-
2177
- /**
2178
- * Transmission Materials Extension
2179
- *
2180
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_transmission
2181
- */
2182
- class GLTFMaterialsTransmissionExtension {
2183
-
2184
- constructor( writer ) {
2185
-
2186
- this.writer = writer;
2187
- this.name = 'KHR_materials_transmission';
2188
-
2189
- }
2190
- writeMaterial( material, materialDef ) {
2191
-
2192
- if ( ! material.isMeshPhysicalMaterial || material.transmission === 0 ) return;
2193
- const writer = this.writer;
2194
- const extensionsUsed = writer.extensionsUsed;
2195
- const extensionDef = {};
2196
- extensionDef.transmissionFactor = material.transmission;
2197
- if ( material.transmissionMap ) {
2198
-
2199
- const transmissionMapDef = {
2200
- index: writer.processTexture( material.transmissionMap )
2201
- };
2202
- writer.applyTextureTransform( transmissionMapDef, material.transmissionMap );
2203
- extensionDef.transmissionTexture = transmissionMapDef;
2204
-
2205
- }
2206
-
2207
- materialDef.extensions = materialDef.extensions || {};
2208
- materialDef.extensions[ this.name ] = extensionDef;
2209
- extensionsUsed[ this.name ] = true;
2210
-
2211
- }
2212
-
2213
- }
2214
-
2215
- /**
2216
- * Materials Volume Extension
2217
- *
2218
- * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_volume
2219
- */
2220
- class GLTFMaterialsVolumeExtension {
2221
-
2222
- constructor( writer ) {
2223
-
2224
- this.writer = writer;
2225
- this.name = 'KHR_materials_volume';
2226
-
2227
- }
2228
- writeMaterial( material, materialDef ) {
2229
-
2230
- if ( ! material.isMeshPhysicalMaterial || material.transmission === 0 ) return;
2231
- const writer = this.writer;
2232
- const extensionsUsed = writer.extensionsUsed;
2233
- const extensionDef = {};
2234
- extensionDef.thicknessFactor = material.thickness;
2235
- if ( material.thicknessMap ) {
2236
-
2237
- const thicknessMapDef = {
2238
- index: writer.processTexture( material.thicknessMap )
2239
- };
2240
- writer.applyTextureTransform( thicknessMapDef, material.thicknessMap );
2241
- extensionDef.thicknessTexture = thicknessMapDef;
2242
-
2243
- }
2244
-
2245
- extensionDef.attenuationDistance = material.attenuationDistance;
2246
- extensionDef.attenuationColor = material.attenuationColor.toArray();
2247
- materialDef.extensions = materialDef.extensions || {};
2248
- materialDef.extensions[ this.name ] = extensionDef;
2249
- extensionsUsed[ this.name ] = true;
2250
-
2251
- }
2252
-
2253
- }
2254
-
2255
- /**
2256
- * Static utility functions
2257
- */
2258
- GLTFExporter.Utils = {
2259
- insertKeyframe: function ( track, time ) {
2260
-
2261
- const tolerance = 0.001; // 1ms
2262
- const valueSize = track.getValueSize();
2263
- const times = new track.TimeBufferType( track.times.length + 1 );
2264
- const values = new track.ValueBufferType( track.values.length + valueSize );
2265
- const interpolant = track.createInterpolant( new track.ValueBufferType( valueSize ) );
2266
- let index;
2267
- if ( track.times.length === 0 ) {
2268
-
2269
- times[ 0 ] = time;
2270
- for ( let i = 0; i < valueSize; i ++ ) {
2271
-
2272
- values[ i ] = 0;
2273
-
2274
- }
2275
-
2276
- index = 0;
2277
-
2278
- } else if ( time < track.times[ 0 ] ) {
2279
-
2280
- if ( Math.abs( track.times[ 0 ] - time ) < tolerance ) return 0;
2281
- times[ 0 ] = time;
2282
- times.set( track.times, 1 );
2283
- values.set( interpolant.evaluate( time ), 0 );
2284
- values.set( track.values, valueSize );
2285
- index = 0;
2286
-
2287
- } else if ( time > track.times[ track.times.length - 1 ] ) {
2288
-
2289
- if ( Math.abs( track.times[ track.times.length - 1 ] - time ) < tolerance ) {
2290
-
2291
- return track.times.length - 1;
2292
-
2293
- }
2294
-
2295
- times[ times.length - 1 ] = time;
2296
- times.set( track.times, 0 );
2297
- values.set( track.values, 0 );
2298
- values.set( interpolant.evaluate( time ), track.values.length );
2299
- index = times.length - 1;
2300
-
2301
- } else {
2302
-
2303
- for ( let i = 0; i < track.times.length; i ++ ) {
2304
-
2305
- if ( Math.abs( track.times[ i ] - time ) < tolerance ) return i;
2306
- if ( track.times[ i ] < time && track.times[ i + 1 ] > time ) {
2307
-
2308
- times.set( track.times.slice( 0, i + 1 ), 0 );
2309
- times[ i + 1 ] = time;
2310
- times.set( track.times.slice( i + 1 ), i + 2 );
2311
- values.set( track.values.slice( 0, ( i + 1 ) * valueSize ), 0 );
2312
- values.set( interpolant.evaluate( time ), ( i + 1 ) * valueSize );
2313
- values.set( track.values.slice( ( i + 1 ) * valueSize ), ( i + 2 ) * valueSize );
2314
- index = i + 1;
2315
- break;
2316
-
2317
- }
2318
-
2319
- }
2320
-
2321
- }
2322
-
2323
- track.times = times;
2324
- track.values = values;
2325
- return index;
2326
-
2327
- },
2328
- mergeMorphTargetTracks: function ( clip, root ) {
2329
-
2330
- const tracks = [];
2331
- const mergedTracks = {};
2332
- const sourceTracks = clip.tracks;
2333
- for ( let i = 0; i < sourceTracks.length; ++ i ) {
2334
-
2335
- let sourceTrack = sourceTracks[ i ];
2336
- const sourceTrackBinding = THREE.PropertyBinding.parseTrackName( sourceTrack.name );
2337
- const sourceTrackNode = THREE.PropertyBinding.findNode( root, sourceTrackBinding.nodeName );
2338
- if ( sourceTrackBinding.propertyName !== 'morphTargetInfluences' || sourceTrackBinding.propertyIndex === undefined ) {
2339
-
2340
- // Tracks that don't affect morph targets, or that affect all morph targets together, can be left as-is.
2341
- tracks.push( sourceTrack );
2342
- continue;
2343
-
2344
- }
2345
-
2346
- if ( sourceTrack.createInterpolant !== sourceTrack.InterpolantFactoryMethodDiscrete && sourceTrack.createInterpolant !== sourceTrack.InterpolantFactoryMethodLinear ) {
2347
-
2348
- if ( sourceTrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline ) {
2349
-
2350
- // This should never happen, because glTF morph target animations
2351
- // affect all targets already.
2352
- throw new Error( 'THREE.GLTFExporter: Cannot merge tracks with glTF CUBICSPLINE interpolation.' );
2353
-
2354
- }
2355
-
2356
- console.warn( 'THREE.GLTFExporter: Morph target interpolation mode not yet supported. Using LINEAR instead.' );
2357
- sourceTrack = sourceTrack.clone();
2358
- sourceTrack.setInterpolation( THREE.InterpolateLinear );
2359
-
2360
- }
2361
-
2362
- const targetCount = sourceTrackNode.morphTargetInfluences.length;
2363
- const targetIndex = sourceTrackNode.morphTargetDictionary[ sourceTrackBinding.propertyIndex ];
2364
- if ( targetIndex === undefined ) {
2365
-
2366
- throw new Error( 'THREE.GLTFExporter: Morph target name not found: ' + sourceTrackBinding.propertyIndex );
2367
-
2368
- }
2369
-
2370
- let mergedTrack;
2371
-
2372
- // If this is the first time we've seen this object, create a new
2373
- // track to store merged keyframe data for each morph target.
2374
- if ( mergedTracks[ sourceTrackNode.uuid ] === undefined ) {
2375
-
2376
- mergedTrack = sourceTrack.clone();
2377
- const values = new mergedTrack.ValueBufferType( targetCount * mergedTrack.times.length );
2378
- for ( let j = 0; j < mergedTrack.times.length; j ++ ) {
2379
-
2380
- values[ j * targetCount + targetIndex ] = mergedTrack.values[ j ];
2381
-
2382
- }
2383
-
2384
- // We need to take into consideration the intended target node
2385
- // of our original un-merged morphTarget animation.
2386
- mergedTrack.name = ( sourceTrackBinding.nodeName || '' ) + '.morphTargetInfluences';
2387
- mergedTrack.values = values;
2388
- mergedTracks[ sourceTrackNode.uuid ] = mergedTrack;
2389
- tracks.push( mergedTrack );
2390
- continue;
2391
-
2392
- }
2393
-
2394
- const sourceInterpolant = sourceTrack.createInterpolant( new sourceTrack.ValueBufferType( 1 ) );
2395
- mergedTrack = mergedTracks[ sourceTrackNode.uuid ];
2396
-
2397
- // For every existing keyframe of the merged track, write a (possibly
2398
- // interpolated) value from the source track.
2399
- for ( let j = 0; j < mergedTrack.times.length; j ++ ) {
2400
-
2401
- mergedTrack.values[ j * targetCount + targetIndex ] = sourceInterpolant.evaluate( mergedTrack.times[ j ] );
2402
-
2403
- }
2404
-
2405
- // For every existing keyframe of the source track, write a (possibly
2406
- // new) keyframe to the merged track. Values from the previous loop may
2407
- // be written again, but keyframes are de-duplicated.
2408
- for ( let j = 0; j < sourceTrack.times.length; j ++ ) {
2409
-
2410
- const keyframeIndex = this.insertKeyframe( mergedTrack, sourceTrack.times[ j ] );
2411
- mergedTrack.values[ keyframeIndex * targetCount + targetIndex ] = sourceTrack.values[ j ];
2412
-
2413
- }
2414
-
2415
- }
2416
-
2417
- clip.tracks = tracks;
2418
- return clip;
2419
-
2420
- }
2421
- };
2422
-
2423
- THREE.GLTFExporter = GLTFExporter;
2424
-
2425
- } )();