@anov/3d 0.0.4-alpha.1 → 0.0.4-alpha13

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 (588) hide show
  1. package/README.md +1 -144
  2. package/dist/applicationApi.d.ts +34 -0
  3. package/dist/{core/cssRenderer.js → applicationApi.js} +53 -21
  4. package/dist/environment/index.d.ts +27 -0
  5. package/dist/environment/index.js +84 -0
  6. package/dist/environment/time/index.d.ts +12 -0
  7. package/dist/environment/time/index.js +27 -0
  8. package/dist/environment/weather/type.d.ts +15 -0
  9. package/dist/environment/weather/type.js +27 -0
  10. package/dist/hooksManager.d.ts +2 -0
  11. package/dist/hooksManager.js +15 -0
  12. package/dist/index.d.ts +15 -3
  13. package/dist/index.js +38 -5
  14. package/dist/messageStatus.d.ts +49 -0
  15. package/dist/messageStatus.js +50 -0
  16. package/dist/utils/index.d.ts +11 -50
  17. package/dist/utils/index.js +29 -92
  18. package/dist/utils/messageFn.d.ts +12 -0
  19. package/dist/utils/messageFn.js +33 -0
  20. package/package.json +8 -24
  21. package/dist/commonEnu.d.ts +0 -5
  22. package/dist/commonEnu.js +0 -6
  23. package/dist/core/camera.d.ts +0 -32
  24. package/dist/core/camera.js +0 -74
  25. package/dist/core/control/transformControls.d.ts +0 -12
  26. package/dist/core/control/transformControls.js +0 -72
  27. package/dist/core/cssRenderer.d.ts +0 -17
  28. package/dist/core/events.d.ts +0 -16
  29. package/dist/core/events.js +0 -38
  30. package/dist/core/global/global.d.ts +0 -27
  31. package/dist/core/global/global.js +0 -72
  32. package/dist/core/global/globalControl.d.ts +0 -17
  33. package/dist/core/global/globalControl.js +0 -62
  34. package/dist/core/group.d.ts +0 -57
  35. package/dist/core/group.js +0 -157
  36. package/dist/core/line.d.ts +0 -13
  37. package/dist/core/line.js +0 -83
  38. package/dist/core/mesh.d.ts +0 -59
  39. package/dist/core/mesh.js +0 -180
  40. package/dist/core/model.d.ts +0 -30
  41. package/dist/core/model.js +0 -109
  42. package/dist/core/scene.d.ts +0 -175
  43. package/dist/core/scene.js +0 -381
  44. package/dist/core/use/useScene.d.ts +0 -10
  45. package/dist/core/use/useScene.js +0 -14
  46. package/dist/core/use/useframe.d.ts +0 -6
  47. package/dist/core/use/useframe.js +0 -11
  48. package/dist/export.d.ts +0 -40
  49. package/dist/export.js +0 -36
  50. package/dist/threeCell.d.ts +0 -8
  51. package/dist/threeCell.js +0 -16
  52. package/dist/type.d.ts +0 -3
  53. package/dist/type.js +0 -1
  54. package/dist/utils/createElement.d.ts +0 -103
  55. package/dist/utils/createElement.js +0 -145
  56. package/dist/utils/createLabel.d.ts +0 -2
  57. package/dist/utils/createLabel.js +0 -4
  58. package/dist/utils/line.d.ts +0 -0
  59. package/dist/utils/line.js +0 -0
  60. package/dist/utils/move.d.ts +0 -48
  61. package/dist/utils/move.js +0 -149
  62. package/examples/fonts/LICENSE +0 -13
  63. package/examples/fonts/README.md +0 -11
  64. package/examples/fonts/droid/NOTICE +0 -190
  65. package/examples/fonts/droid/README.txt +0 -18
  66. package/examples/fonts/droid/droid_sans_bold.typeface.json +0 -1
  67. package/examples/fonts/droid/droid_sans_mono_regular.typeface.json +0 -1
  68. package/examples/fonts/droid/droid_sans_regular.typeface.json +0 -1
  69. package/examples/fonts/droid/droid_serif_bold.typeface.json +0 -1
  70. package/examples/fonts/droid/droid_serif_regular.typeface.json +0 -1
  71. package/examples/fonts/gentilis_bold.typeface.json +0 -1
  72. package/examples/fonts/gentilis_regular.typeface.json +0 -1
  73. package/examples/fonts/helvetiker_bold.typeface.json +0 -1
  74. package/examples/fonts/helvetiker_regular.typeface.json +0 -1
  75. package/examples/fonts/optimer_bold.typeface.json +0 -1
  76. package/examples/fonts/optimer_regular.typeface.json +0 -1
  77. package/examples/fonts/ttf/README.md +0 -9
  78. package/examples/fonts/ttf/kenpixel.ttf +0 -0
  79. package/examples/jsm/animation/AnimationClipCreator.js +0 -116
  80. package/examples/jsm/animation/CCDIKSolver.js +0 -482
  81. package/examples/jsm/animation/MMDAnimationHelper.js +0 -1207
  82. package/examples/jsm/animation/MMDPhysics.js +0 -1406
  83. package/examples/jsm/cameras/CinematicCamera.js +0 -208
  84. package/examples/jsm/capabilities/WebGL.js +0 -91
  85. package/examples/jsm/capabilities/WebGPU.js +0 -53
  86. package/examples/jsm/controls/ArcballControls.js +0 -3224
  87. package/examples/jsm/controls/DragControls.js +0 -220
  88. package/examples/jsm/controls/FirstPersonControls.js +0 -325
  89. package/examples/jsm/controls/FlyControls.js +0 -300
  90. package/examples/jsm/controls/MapControls.js +0 -28
  91. package/examples/jsm/controls/OrbitControls.js +0 -1388
  92. package/examples/jsm/controls/PointerLockControls.js +0 -162
  93. package/examples/jsm/controls/TrackballControls.js +0 -828
  94. package/examples/jsm/controls/TransformControls.js +0 -1557
  95. package/examples/jsm/csm/CSM.js +0 -384
  96. package/examples/jsm/csm/CSMFrustum.js +0 -152
  97. package/examples/jsm/csm/CSMHelper.js +0 -193
  98. package/examples/jsm/csm/CSMShader.js +0 -252
  99. package/examples/jsm/curves/CurveExtras.js +0 -422
  100. package/examples/jsm/curves/NURBSCurve.js +0 -80
  101. package/examples/jsm/curves/NURBSSurface.js +0 -52
  102. package/examples/jsm/curves/NURBSUtils.js +0 -487
  103. package/examples/jsm/effects/AnaglyphEffect.js +0 -154
  104. package/examples/jsm/effects/AsciiEffect.js +0 -263
  105. package/examples/jsm/effects/OutlineEffect.js +0 -539
  106. package/examples/jsm/effects/ParallaxBarrierEffect.js +0 -119
  107. package/examples/jsm/effects/PeppersGhostEffect.js +0 -153
  108. package/examples/jsm/effects/StereoEffect.js +0 -55
  109. package/examples/jsm/environments/DebugEnvironment.js +0 -52
  110. package/examples/jsm/environments/RoomEnvironment.js +0 -148
  111. package/examples/jsm/exporters/DRACOExporter.js +0 -267
  112. package/examples/jsm/exporters/EXRExporter.js +0 -501
  113. package/examples/jsm/exporters/GLTFExporter.js +0 -3161
  114. package/examples/jsm/exporters/KTX2Exporter.js +0 -292
  115. package/examples/jsm/exporters/MMDExporter.js +0 -217
  116. package/examples/jsm/exporters/OBJExporter.js +0 -284
  117. package/examples/jsm/exporters/PLYExporter.js +0 -528
  118. package/examples/jsm/exporters/STLExporter.js +0 -199
  119. package/examples/jsm/exporters/USDZExporter.js +0 -711
  120. package/examples/jsm/geometries/BoxLineGeometry.js +0 -69
  121. package/examples/jsm/geometries/ConvexGeometry.js +0 -53
  122. package/examples/jsm/geometries/DecalGeometry.js +0 -356
  123. package/examples/jsm/geometries/ParametricGeometries.js +0 -254
  124. package/examples/jsm/geometries/ParametricGeometry.js +0 -139
  125. package/examples/jsm/geometries/RoundedBoxGeometry.js +0 -155
  126. package/examples/jsm/geometries/TeapotGeometry.js +0 -704
  127. package/examples/jsm/geometries/TextGeometry.js +0 -57
  128. package/examples/jsm/helpers/LightProbeHelper.js +0 -130
  129. package/examples/jsm/helpers/OctreeHelper.js +0 -73
  130. package/examples/jsm/helpers/PositionalAudioHelper.js +0 -109
  131. package/examples/jsm/helpers/RectAreaLightHelper.js +0 -85
  132. package/examples/jsm/helpers/VertexNormalsHelper.js +0 -96
  133. package/examples/jsm/helpers/VertexTangentsHelper.js +0 -88
  134. package/examples/jsm/helpers/ViewHelper.js +0 -333
  135. package/examples/jsm/interactive/HTMLMesh.js +0 -565
  136. package/examples/jsm/interactive/InteractiveGroup.js +0 -116
  137. package/examples/jsm/interactive/SelectionBox.js +0 -227
  138. package/examples/jsm/interactive/SelectionHelper.js +0 -104
  139. package/examples/jsm/libs/ammo.wasm.js +0 -822
  140. package/examples/jsm/libs/ammo.wasm.wasm +0 -0
  141. package/examples/jsm/libs/basis/README.md +0 -46
  142. package/examples/jsm/libs/basis/basis_transcoder.js +0 -21
  143. package/examples/jsm/libs/basis/basis_transcoder.wasm +0 -0
  144. package/examples/jsm/libs/chevrotain.module.min.js +0 -141
  145. package/examples/jsm/libs/draco/README.md +0 -32
  146. package/examples/jsm/libs/draco/draco_decoder.js +0 -34
  147. package/examples/jsm/libs/draco/draco_decoder.wasm +0 -0
  148. package/examples/jsm/libs/draco/draco_encoder.js +0 -33
  149. package/examples/jsm/libs/draco/draco_wasm_wrapper.js +0 -117
  150. package/examples/jsm/libs/draco/gltf/draco_decoder.js +0 -33
  151. package/examples/jsm/libs/draco/gltf/draco_decoder.wasm +0 -0
  152. package/examples/jsm/libs/draco/gltf/draco_encoder.js +0 -33
  153. package/examples/jsm/libs/draco/gltf/draco_wasm_wrapper.js +0 -116
  154. package/examples/jsm/libs/ecsy.module.js +0 -1792
  155. package/examples/jsm/libs/fflate.module.js +0 -2474
  156. package/examples/jsm/libs/ktx-parse.module.js +0 -1
  157. package/examples/jsm/libs/lil-gui.module.min.js +0 -8
  158. package/examples/jsm/libs/lottie_canvas.module.js +0 -14844
  159. package/examples/jsm/libs/meshopt_decoder.module.js +0 -178
  160. package/examples/jsm/libs/mikktspace.module.js +0 -128
  161. package/examples/jsm/libs/mmdparser.module.js +0 -11530
  162. package/examples/jsm/libs/motion-controllers.module.js +0 -397
  163. package/examples/jsm/libs/opentype.module.js +0 -14568
  164. package/examples/jsm/libs/potpack.module.js +0 -125
  165. package/examples/jsm/libs/rhino3dm/rhino3dm.js +0 -21
  166. package/examples/jsm/libs/rhino3dm/rhino3dm.module.js +0 -16
  167. package/examples/jsm/libs/rhino3dm/rhino3dm.wasm +0 -0
  168. package/examples/jsm/libs/stats.module.js +0 -167
  169. package/examples/jsm/libs/tween.module.js +0 -803
  170. package/examples/jsm/libs/utif.module.js +0 -1579
  171. package/examples/jsm/libs/zstddec.module.js +0 -1
  172. package/examples/jsm/lights/IESSpotLight.js +0 -25
  173. package/examples/jsm/lights/LightProbeGenerator.js +0 -252
  174. package/examples/jsm/lights/RectAreaLightUniformsLib.js +0 -79
  175. package/examples/jsm/lines/Line2.js +0 -19
  176. package/examples/jsm/lines/LineGeometry.js +0 -79
  177. package/examples/jsm/lines/LineMaterial.js +0 -702
  178. package/examples/jsm/lines/LineSegments2.js +0 -361
  179. package/examples/jsm/lines/LineSegmentsGeometry.js +0 -241
  180. package/examples/jsm/lines/Wireframe.js +0 -56
  181. package/examples/jsm/lines/WireframeGeometry2.js +0 -24
  182. package/examples/jsm/loaders/3DMLoader.js +0 -1497
  183. package/examples/jsm/loaders/3MFLoader.js +0 -1478
  184. package/examples/jsm/loaders/AMFLoader.js +0 -521
  185. package/examples/jsm/loaders/BVHLoader.js +0 -437
  186. package/examples/jsm/loaders/ColladaLoader.js +0 -4122
  187. package/examples/jsm/loaders/DDSLoader.js +0 -274
  188. package/examples/jsm/loaders/DRACOLoader.js +0 -612
  189. package/examples/jsm/loaders/EXRLoader.js +0 -2309
  190. package/examples/jsm/loaders/FBXLoader.js +0 -4142
  191. package/examples/jsm/loaders/FontLoader.js +0 -183
  192. package/examples/jsm/loaders/GCodeLoader.js +0 -261
  193. package/examples/jsm/loaders/GLTFLoader.js +0 -4576
  194. package/examples/jsm/loaders/HDRCubeTextureLoader.js +0 -115
  195. package/examples/jsm/loaders/IESLoader.js +0 -337
  196. package/examples/jsm/loaders/KMZLoader.js +0 -130
  197. package/examples/jsm/loaders/KTX2Loader.js +0 -868
  198. package/examples/jsm/loaders/KTXLoader.js +0 -176
  199. package/examples/jsm/loaders/LDrawLoader.js +0 -2464
  200. package/examples/jsm/loaders/LUT3dlLoader.js +0 -151
  201. package/examples/jsm/loaders/LUTCubeLoader.js +0 -153
  202. package/examples/jsm/loaders/LWOLoader.js +0 -1052
  203. package/examples/jsm/loaders/LogLuvLoader.js +0 -606
  204. package/examples/jsm/loaders/LottieLoader.js +0 -77
  205. package/examples/jsm/loaders/MD2Loader.js +0 -399
  206. package/examples/jsm/loaders/MDDLoader.js +0 -102
  207. package/examples/jsm/loaders/MMDLoader.js +0 -2273
  208. package/examples/jsm/loaders/MTLLoader.js +0 -567
  209. package/examples/jsm/loaders/MaterialXLoader.js +0 -734
  210. package/examples/jsm/loaders/NRRDLoader.js +0 -699
  211. package/examples/jsm/loaders/OBJLoader.js +0 -905
  212. package/examples/jsm/loaders/PCDLoader.js +0 -467
  213. package/examples/jsm/loaders/PDBLoader.js +0 -232
  214. package/examples/jsm/loaders/PLYLoader.js +0 -771
  215. package/examples/jsm/loaders/PVRLoader.js +0 -251
  216. package/examples/jsm/loaders/RGBELoader.js +0 -468
  217. package/examples/jsm/loaders/RGBMLoader.js +0 -1065
  218. package/examples/jsm/loaders/STLLoader.js +0 -403
  219. package/examples/jsm/loaders/SVGLoader.js +0 -3172
  220. package/examples/jsm/loaders/TDSLoader.js +0 -1124
  221. package/examples/jsm/loaders/TGALoader.js +0 -517
  222. package/examples/jsm/loaders/TIFFLoader.js +0 -36
  223. package/examples/jsm/loaders/TTFLoader.js +0 -214
  224. package/examples/jsm/loaders/TiltLoader.js +0 -520
  225. package/examples/jsm/loaders/USDZLoader.js +0 -633
  226. package/examples/jsm/loaders/VOXLoader.js +0 -311
  227. package/examples/jsm/loaders/VRMLLoader.js +0 -3533
  228. package/examples/jsm/loaders/VTKLoader.js +0 -1163
  229. package/examples/jsm/loaders/XYZLoader.js +0 -106
  230. package/examples/jsm/loaders/lwo/IFFParser.js +0 -1218
  231. package/examples/jsm/loaders/lwo/LWO2Parser.js +0 -414
  232. package/examples/jsm/loaders/lwo/LWO3Parser.js +0 -373
  233. package/examples/jsm/materials/MeshGouraudMaterial.js +0 -420
  234. package/examples/jsm/math/Capsule.js +0 -137
  235. package/examples/jsm/math/ColorConverter.js +0 -36
  236. package/examples/jsm/math/ConvexHull.js +0 -1271
  237. package/examples/jsm/math/ImprovedNoise.js +0 -71
  238. package/examples/jsm/math/Lut.js +0 -204
  239. package/examples/jsm/math/MeshSurfaceSampler.js +0 -250
  240. package/examples/jsm/math/OBB.js +0 -423
  241. package/examples/jsm/math/Octree.js +0 -462
  242. package/examples/jsm/math/SimplexNoise.js +0 -444
  243. package/examples/jsm/misc/ConvexObjectBreaker.js +0 -519
  244. package/examples/jsm/misc/GPUComputationRenderer.js +0 -446
  245. package/examples/jsm/misc/Gyroscope.js +0 -66
  246. package/examples/jsm/misc/MD2Character.js +0 -276
  247. package/examples/jsm/misc/MD2CharacterComplex.js +0 -576
  248. package/examples/jsm/misc/MorphAnimMesh.js +0 -75
  249. package/examples/jsm/misc/MorphBlendMesh.js +0 -322
  250. package/examples/jsm/misc/ProgressiveLightMap.js +0 -323
  251. package/examples/jsm/misc/RollerCoaster.js +0 -566
  252. package/examples/jsm/misc/TubePainter.js +0 -205
  253. package/examples/jsm/misc/Volume.js +0 -473
  254. package/examples/jsm/misc/VolumeSlice.js +0 -229
  255. package/examples/jsm/modifiers/CurveModifier.js +0 -326
  256. package/examples/jsm/modifiers/EdgeSplitModifier.js +0 -279
  257. package/examples/jsm/modifiers/SimplifyModifier.js +0 -525
  258. package/examples/jsm/modifiers/TessellateModifier.js +0 -307
  259. package/examples/jsm/nodes/Nodes.js +0 -171
  260. package/examples/jsm/nodes/accessors/BitangentNode.js +0 -89
  261. package/examples/jsm/nodes/accessors/BufferAttributeNode.js +0 -99
  262. package/examples/jsm/nodes/accessors/BufferNode.js +0 -30
  263. package/examples/jsm/nodes/accessors/CameraNode.js +0 -98
  264. package/examples/jsm/nodes/accessors/CubeTextureNode.js +0 -103
  265. package/examples/jsm/nodes/accessors/ExtendedMaterialNode.js +0 -77
  266. package/examples/jsm/nodes/accessors/InstanceNode.js +0 -71
  267. package/examples/jsm/nodes/accessors/MaterialNode.js +0 -267
  268. package/examples/jsm/nodes/accessors/MaterialReferenceNode.js +0 -39
  269. package/examples/jsm/nodes/accessors/ModelNode.js +0 -34
  270. package/examples/jsm/nodes/accessors/ModelViewProjectionNode.js +0 -29
  271. package/examples/jsm/nodes/accessors/MorphNode.js +0 -70
  272. package/examples/jsm/nodes/accessors/NormalNode.js +0 -96
  273. package/examples/jsm/nodes/accessors/Object3DNode.js +0 -150
  274. package/examples/jsm/nodes/accessors/PointUVNode.js +0 -26
  275. package/examples/jsm/nodes/accessors/PositionNode.js +0 -104
  276. package/examples/jsm/nodes/accessors/ReferenceNode.js +0 -72
  277. package/examples/jsm/nodes/accessors/ReflectVectorNode.js +0 -35
  278. package/examples/jsm/nodes/accessors/SceneNode.js +0 -52
  279. package/examples/jsm/nodes/accessors/SkinningNode.js +0 -93
  280. package/examples/jsm/nodes/accessors/StorageBufferNode.js +0 -27
  281. package/examples/jsm/nodes/accessors/TangentNode.js +0 -103
  282. package/examples/jsm/nodes/accessors/TextureBicubicNode.js +0 -94
  283. package/examples/jsm/nodes/accessors/TextureNode.js +0 -271
  284. package/examples/jsm/nodes/accessors/TextureSizeNode.js +0 -35
  285. package/examples/jsm/nodes/accessors/UVNode.js +0 -47
  286. package/examples/jsm/nodes/accessors/UserDataNode.js +0 -29
  287. package/examples/jsm/nodes/code/CodeNode.js +0 -78
  288. package/examples/jsm/nodes/code/ExpressionNode.js +0 -37
  289. package/examples/jsm/nodes/code/FunctionCallNode.js +0 -96
  290. package/examples/jsm/nodes/code/FunctionNode.js +0 -127
  291. package/examples/jsm/nodes/code/ScriptableNode.js +0 -488
  292. package/examples/jsm/nodes/code/ScriptableValueNode.js +0 -167
  293. package/examples/jsm/nodes/core/ArrayUniformNode.js +0 -26
  294. package/examples/jsm/nodes/core/AttributeNode.js +0 -102
  295. package/examples/jsm/nodes/core/BypassNode.js +0 -45
  296. package/examples/jsm/nodes/core/CacheNode.js +0 -46
  297. package/examples/jsm/nodes/core/ConstNode.js +0 -32
  298. package/examples/jsm/nodes/core/ContextNode.js +0 -61
  299. package/examples/jsm/nodes/core/IndexNode.js +0 -66
  300. package/examples/jsm/nodes/core/InputNode.js +0 -83
  301. package/examples/jsm/nodes/core/LightingModel.js +0 -15
  302. package/examples/jsm/nodes/core/Node.js +0 -454
  303. package/examples/jsm/nodes/core/NodeAttribute.js +0 -15
  304. package/examples/jsm/nodes/core/NodeBuilder.js +0 -1016
  305. package/examples/jsm/nodes/core/NodeCache.js +0 -26
  306. package/examples/jsm/nodes/core/NodeCode.js +0 -15
  307. package/examples/jsm/nodes/core/NodeFrame.js +0 -110
  308. package/examples/jsm/nodes/core/NodeFunction.js +0 -22
  309. package/examples/jsm/nodes/core/NodeFunctionInput.js +0 -17
  310. package/examples/jsm/nodes/core/NodeKeywords.js +0 -80
  311. package/examples/jsm/nodes/core/NodeParser.js +0 -11
  312. package/examples/jsm/nodes/core/NodeUniform.js +0 -28
  313. package/examples/jsm/nodes/core/NodeUtils.js +0 -212
  314. package/examples/jsm/nodes/core/NodeVar.js +0 -14
  315. package/examples/jsm/nodes/core/NodeVarying.js +0 -17
  316. package/examples/jsm/nodes/core/PropertyNode.js +0 -61
  317. package/examples/jsm/nodes/core/StackNode.js +0 -99
  318. package/examples/jsm/nodes/core/TempNode.js +0 -58
  319. package/examples/jsm/nodes/core/UniformNode.js +0 -61
  320. package/examples/jsm/nodes/core/VarNode.js +0 -87
  321. package/examples/jsm/nodes/core/VaryingNode.js +0 -69
  322. package/examples/jsm/nodes/core/constants.js +0 -27
  323. package/examples/jsm/nodes/display/BlendModeNode.js +0 -99
  324. package/examples/jsm/nodes/display/BumpMapNode.js +0 -77
  325. package/examples/jsm/nodes/display/ColorAdjustmentNode.js +0 -100
  326. package/examples/jsm/nodes/display/ColorSpaceNode.js +0 -108
  327. package/examples/jsm/nodes/display/FrontFacingNode.js +0 -27
  328. package/examples/jsm/nodes/display/NormalMapNode.js +0 -106
  329. package/examples/jsm/nodes/display/PosterizeNode.js +0 -32
  330. package/examples/jsm/nodes/display/ToneMappingNode.js +0 -141
  331. package/examples/jsm/nodes/display/ViewportDepthNode.js +0 -69
  332. package/examples/jsm/nodes/display/ViewportDepthTextureNode.js +0 -34
  333. package/examples/jsm/nodes/display/ViewportNode.js +0 -115
  334. package/examples/jsm/nodes/display/ViewportSharedTextureNode.js +0 -31
  335. package/examples/jsm/nodes/display/ViewportTextureNode.js +0 -75
  336. package/examples/jsm/nodes/fog/FogExp2Node.js +0 -35
  337. package/examples/jsm/nodes/fog/FogNode.js +0 -37
  338. package/examples/jsm/nodes/fog/FogRangeNode.js +0 -34
  339. package/examples/jsm/nodes/functions/BSDF/BRDF_GGX.js +0 -40
  340. package/examples/jsm/nodes/functions/BSDF/BRDF_Lambert.js +0 -9
  341. package/examples/jsm/nodes/functions/BSDF/BRDF_Sheen.js +0 -43
  342. package/examples/jsm/nodes/functions/BSDF/DFGApprox.js +0 -29
  343. package/examples/jsm/nodes/functions/BSDF/D_GGX.js +0 -18
  344. package/examples/jsm/nodes/functions/BSDF/EnvironmentBRDF.js +0 -13
  345. package/examples/jsm/nodes/functions/BSDF/F_Schlick.js +0 -16
  346. package/examples/jsm/nodes/functions/BSDF/Schlick_to_F0.js +0 -13
  347. package/examples/jsm/nodes/functions/BSDF/V_GGX_SmithCorrelated.js +0 -20
  348. package/examples/jsm/nodes/functions/PhongLightingModel.js +0 -67
  349. package/examples/jsm/nodes/functions/PhysicalLightingModel.js +0 -343
  350. package/examples/jsm/nodes/functions/material/getGeometryRoughness.js +0 -13
  351. package/examples/jsm/nodes/functions/material/getRoughness.js +0 -18
  352. package/examples/jsm/nodes/geometry/RangeNode.js +0 -104
  353. package/examples/jsm/nodes/gpgpu/ComputeNode.js +0 -85
  354. package/examples/jsm/nodes/lighting/AONode.js +0 -27
  355. package/examples/jsm/nodes/lighting/AmbientLightNode.js +0 -27
  356. package/examples/jsm/nodes/lighting/AnalyticLightNode.js +0 -184
  357. package/examples/jsm/nodes/lighting/DirectionalLightNode.js +0 -40
  358. package/examples/jsm/nodes/lighting/EnvironmentNode.js +0 -191
  359. package/examples/jsm/nodes/lighting/HemisphereLightNode.js +0 -55
  360. package/examples/jsm/nodes/lighting/IESSpotLightNode.js +0 -39
  361. package/examples/jsm/nodes/lighting/LightNode.js +0 -57
  362. package/examples/jsm/nodes/lighting/LightUtils.js +0 -17
  363. package/examples/jsm/nodes/lighting/LightingContextNode.js +0 -102
  364. package/examples/jsm/nodes/lighting/LightingNode.js +0 -21
  365. package/examples/jsm/nodes/lighting/LightsNode.js +0 -128
  366. package/examples/jsm/nodes/lighting/PointLightNode.js +0 -68
  367. package/examples/jsm/nodes/lighting/SpotLightNode.js +0 -89
  368. package/examples/jsm/nodes/loaders/NodeLoader.js +0 -108
  369. package/examples/jsm/nodes/loaders/NodeMaterialLoader.js +0 -59
  370. package/examples/jsm/nodes/loaders/NodeObjectLoader.js +0 -70
  371. package/examples/jsm/nodes/materials/LineBasicNodeMaterial.js +0 -28
  372. package/examples/jsm/nodes/materials/Materials.js +0 -12
  373. package/examples/jsm/nodes/materials/MeshBasicNodeMaterial.js +0 -27
  374. package/examples/jsm/nodes/materials/MeshLambertNodeMaterial.js +0 -34
  375. package/examples/jsm/nodes/materials/MeshNormalNodeMaterial.js +0 -40
  376. package/examples/jsm/nodes/materials/MeshPhongNodeMaterial.js +0 -65
  377. package/examples/jsm/nodes/materials/MeshPhysicalNodeMaterial.js +0 -128
  378. package/examples/jsm/nodes/materials/MeshStandardNodeMaterial.js +0 -80
  379. package/examples/jsm/nodes/materials/NodeMaterial.js +0 -536
  380. package/examples/jsm/nodes/materials/PointsNodeMaterial.js +0 -49
  381. package/examples/jsm/nodes/materials/SpriteNodeMaterial.js +0 -103
  382. package/examples/jsm/nodes/materialx/DISCLAIMER.md +0 -199
  383. package/examples/jsm/nodes/materialx/MaterialXNodes.js +0 -68
  384. package/examples/jsm/nodes/materialx/lib/mx_hsv.js +0 -56
  385. package/examples/jsm/nodes/materialx/lib/mx_noise.js +0 -618
  386. package/examples/jsm/nodes/materialx/lib/mx_transform_color.js +0 -19
  387. package/examples/jsm/nodes/math/CondNode.js +0 -86
  388. package/examples/jsm/nodes/math/MathNode.js +0 -359
  389. package/examples/jsm/nodes/math/OperatorNode.js +0 -269
  390. package/examples/jsm/nodes/parsers/GLSLNodeFunction.js +0 -152
  391. package/examples/jsm/nodes/parsers/GLSLNodeParser.js +0 -14
  392. package/examples/jsm/nodes/procedural/CheckerNode.js +0 -42
  393. package/examples/jsm/nodes/shadernode/ShaderNode.js +0 -420
  394. package/examples/jsm/nodes/utils/ArrayElementNode.js +0 -33
  395. package/examples/jsm/nodes/utils/ConvertNode.js +0 -65
  396. package/examples/jsm/nodes/utils/DiscardNode.js +0 -26
  397. package/examples/jsm/nodes/utils/EquirectUVNode.js +0 -33
  398. package/examples/jsm/nodes/utils/JoinNode.js +0 -51
  399. package/examples/jsm/nodes/utils/LoopNode.js +0 -186
  400. package/examples/jsm/nodes/utils/MatcapUVNode.js +0 -30
  401. package/examples/jsm/nodes/utils/MaxMipLevelNode.js +0 -46
  402. package/examples/jsm/nodes/utils/OscNode.js +0 -81
  403. package/examples/jsm/nodes/utils/PackingNode.js +0 -55
  404. package/examples/jsm/nodes/utils/RemapNode.js +0 -42
  405. package/examples/jsm/nodes/utils/RotateUVNode.js +0 -43
  406. package/examples/jsm/nodes/utils/SpecularMIPLevelNode.js +0 -37
  407. package/examples/jsm/nodes/utils/SplitNode.js +0 -104
  408. package/examples/jsm/nodes/utils/SpriteSheetUVNode.js +0 -41
  409. package/examples/jsm/nodes/utils/TimerNode.js +0 -94
  410. package/examples/jsm/nodes/utils/TriplanarTexturesNode.js +0 -62
  411. package/examples/jsm/objects/GroundProjectedSkybox.js +0 -172
  412. package/examples/jsm/objects/Lensflare.js +0 -377
  413. package/examples/jsm/objects/MarchingCubes.js +0 -1176
  414. package/examples/jsm/objects/Reflector.js +0 -264
  415. package/examples/jsm/objects/ReflectorForSSRPass.js +0 -349
  416. package/examples/jsm/objects/Refractor.js +0 -324
  417. package/examples/jsm/objects/ShadowMesh.js +0 -80
  418. package/examples/jsm/objects/Sky.js +0 -219
  419. package/examples/jsm/objects/Water.js +0 -330
  420. package/examples/jsm/objects/Water2.js +0 -358
  421. package/examples/jsm/offscreen/jank.js +0 -45
  422. package/examples/jsm/offscreen/offscreen.js +0 -8
  423. package/examples/jsm/offscreen/scene.js +0 -86
  424. package/examples/jsm/physics/AmmoPhysics.js +0 -285
  425. package/examples/jsm/physics/RapierPhysics.js +0 -199
  426. package/examples/jsm/postprocessing/AfterimagePass.js +0 -104
  427. package/examples/jsm/postprocessing/BloomPass.js +0 -172
  428. package/examples/jsm/postprocessing/BokehPass.js +0 -140
  429. package/examples/jsm/postprocessing/ClearPass.js +0 -46
  430. package/examples/jsm/postprocessing/CubeTexturePass.js +0 -85
  431. package/examples/jsm/postprocessing/DotScreenPass.js +0 -65
  432. package/examples/jsm/postprocessing/EffectComposer.js +0 -231
  433. package/examples/jsm/postprocessing/FilmPass.js +0 -66
  434. package/examples/jsm/postprocessing/GlitchPass.js +0 -128
  435. package/examples/jsm/postprocessing/HalftonePass.js +0 -79
  436. package/examples/jsm/postprocessing/LUTPass.js +0 -173
  437. package/examples/jsm/postprocessing/MaskPass.js +0 -104
  438. package/examples/jsm/postprocessing/OutlinePass.js +0 -654
  439. package/examples/jsm/postprocessing/OutputPass.js +0 -91
  440. package/examples/jsm/postprocessing/Pass.js +0 -84
  441. package/examples/jsm/postprocessing/RenderPass.js +0 -81
  442. package/examples/jsm/postprocessing/RenderPixelatedPass.js +0 -235
  443. package/examples/jsm/postprocessing/SAOPass.js +0 -411
  444. package/examples/jsm/postprocessing/SMAAPass.js +0 -201
  445. package/examples/jsm/postprocessing/SSAARenderPass.js +0 -228
  446. package/examples/jsm/postprocessing/SSAOPass.js +0 -440
  447. package/examples/jsm/postprocessing/SSRPass.js +0 -641
  448. package/examples/jsm/postprocessing/SavePass.js +0 -79
  449. package/examples/jsm/postprocessing/ShaderPass.js +0 -77
  450. package/examples/jsm/postprocessing/TAARenderPass.js +0 -189
  451. package/examples/jsm/postprocessing/TexturePass.js +0 -67
  452. package/examples/jsm/postprocessing/UnrealBloomPass.js +0 -415
  453. package/examples/jsm/renderers/CSS2DRenderer.js +0 -215
  454. package/examples/jsm/renderers/CSS3DRenderer.js +0 -335
  455. package/examples/jsm/renderers/Projector.js +0 -918
  456. package/examples/jsm/renderers/SVGRenderer.js +0 -553
  457. package/examples/jsm/renderers/common/Animation.js +0 -58
  458. package/examples/jsm/renderers/common/Attributes.js +0 -75
  459. package/examples/jsm/renderers/common/Backend.js +0 -162
  460. package/examples/jsm/renderers/common/Background.js +0 -136
  461. package/examples/jsm/renderers/common/Binding.js +0 -19
  462. package/examples/jsm/renderers/common/Bindings.js +0 -165
  463. package/examples/jsm/renderers/common/Buffer.js +0 -38
  464. package/examples/jsm/renderers/common/BufferUtils.js +0 -33
  465. package/examples/jsm/renderers/common/ChainMap.js +0 -89
  466. package/examples/jsm/renderers/common/ComputePipeline.js +0 -17
  467. package/examples/jsm/renderers/common/Constants.js +0 -14
  468. package/examples/jsm/renderers/common/CubeRenderTarget.js +0 -65
  469. package/examples/jsm/renderers/common/DataMap.js +0 -54
  470. package/examples/jsm/renderers/common/Geometries.js +0 -215
  471. package/examples/jsm/renderers/common/Info.js +0 -73
  472. package/examples/jsm/renderers/common/Pipeline.js +0 -13
  473. package/examples/jsm/renderers/common/Pipelines.js +0 -370
  474. package/examples/jsm/renderers/common/ProgrammableStage.js +0 -18
  475. package/examples/jsm/renderers/common/RenderContext.js +0 -38
  476. package/examples/jsm/renderers/common/RenderContexts.js +0 -49
  477. package/examples/jsm/renderers/common/RenderList.js +0 -178
  478. package/examples/jsm/renderers/common/RenderLists.js +0 -38
  479. package/examples/jsm/renderers/common/RenderObject.js +0 -129
  480. package/examples/jsm/renderers/common/RenderObjects.js +0 -95
  481. package/examples/jsm/renderers/common/RenderPipeline.js +0 -16
  482. package/examples/jsm/renderers/common/Renderer.js +0 -895
  483. package/examples/jsm/renderers/common/SampledTexture.js +0 -80
  484. package/examples/jsm/renderers/common/Sampler.js +0 -18
  485. package/examples/jsm/renderers/common/StorageBuffer.js +0 -17
  486. package/examples/jsm/renderers/common/Textures.js +0 -218
  487. package/examples/jsm/renderers/common/Uniform.js +0 -140
  488. package/examples/jsm/renderers/common/UniformBuffer.js +0 -15
  489. package/examples/jsm/renderers/common/UniformsGroup.js +0 -299
  490. package/examples/jsm/renderers/common/nodes/NodeSampledTexture.js +0 -39
  491. package/examples/jsm/renderers/common/nodes/NodeSampler.js +0 -21
  492. package/examples/jsm/renderers/common/nodes/NodeUniform.js +0 -135
  493. package/examples/jsm/renderers/common/nodes/Nodes.js +0 -330
  494. package/examples/jsm/renderers/webgl/nodes/GLSLNodeBuilder.js +0 -340
  495. package/examples/jsm/renderers/webgl/nodes/SlotNode.js +0 -26
  496. package/examples/jsm/renderers/webgl/nodes/WebGLNodeBuilder.js +0 -764
  497. package/examples/jsm/renderers/webgl/nodes/WebGLNodes.js +0 -49
  498. package/examples/jsm/renderers/webgpu/WebGPUBackend.js +0 -844
  499. package/examples/jsm/renderers/webgpu/WebGPURenderer.js +0 -32
  500. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeBuilder.js +0 -902
  501. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeFunction.js +0 -104
  502. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeParser.js +0 -14
  503. package/examples/jsm/renderers/webgpu/utils/WebGPUAttributeUtils.js +0 -274
  504. package/examples/jsm/renderers/webgpu/utils/WebGPUBindingUtils.js +0 -223
  505. package/examples/jsm/renderers/webgpu/utils/WebGPUConstants.js +0 -324
  506. package/examples/jsm/renderers/webgpu/utils/WebGPUPipelineUtils.js +0 -533
  507. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureMipmapUtils.js +0 -163
  508. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureUtils.js +0 -964
  509. package/examples/jsm/renderers/webgpu/utils/WebGPUUtils.js +0 -92
  510. package/examples/jsm/shaders/ACESFilmicToneMappingShader.js +0 -87
  511. package/examples/jsm/shaders/AfterimageShader.js +0 -56
  512. package/examples/jsm/shaders/BasicShader.js +0 -27
  513. package/examples/jsm/shaders/BleachBypassShader.js +0 -62
  514. package/examples/jsm/shaders/BlendShader.js +0 -47
  515. package/examples/jsm/shaders/BokehShader.js +0 -143
  516. package/examples/jsm/shaders/BokehShader2.js +0 -393
  517. package/examples/jsm/shaders/BrightnessContrastShader.js +0 -54
  518. package/examples/jsm/shaders/ColorCorrectionShader.js +0 -50
  519. package/examples/jsm/shaders/ColorifyShader.js +0 -51
  520. package/examples/jsm/shaders/ConvolutionShader.js +0 -103
  521. package/examples/jsm/shaders/CopyShader.js +0 -45
  522. package/examples/jsm/shaders/DOFMipMapShader.js +0 -54
  523. package/examples/jsm/shaders/DepthLimitedBlurShader.js +0 -166
  524. package/examples/jsm/shaders/DigitalGlitch.js +0 -101
  525. package/examples/jsm/shaders/DotScreenShader.js +0 -70
  526. package/examples/jsm/shaders/ExposureShader.js +0 -44
  527. package/examples/jsm/shaders/FXAAShader.js +0 -286
  528. package/examples/jsm/shaders/FilmShader.js +0 -102
  529. package/examples/jsm/shaders/FocusShader.js +0 -87
  530. package/examples/jsm/shaders/FreiChenShader.js +0 -94
  531. package/examples/jsm/shaders/GammaCorrectionShader.js +0 -43
  532. package/examples/jsm/shaders/GodRaysShader.js +0 -313
  533. package/examples/jsm/shaders/HalftoneShader.js +0 -310
  534. package/examples/jsm/shaders/HorizontalBlurShader.js +0 -59
  535. package/examples/jsm/shaders/HorizontalTiltShiftShader.js +0 -61
  536. package/examples/jsm/shaders/HueSaturationShader.js +0 -65
  537. package/examples/jsm/shaders/KaleidoShader.js +0 -56
  538. package/examples/jsm/shaders/LuminosityHighPassShader.js +0 -64
  539. package/examples/jsm/shaders/LuminosityShader.js +0 -46
  540. package/examples/jsm/shaders/MMDToonShader.js +0 -132
  541. package/examples/jsm/shaders/MirrorShader.js +0 -54
  542. package/examples/jsm/shaders/NormalMapShader.js +0 -53
  543. package/examples/jsm/shaders/OutputShader.js +0 -78
  544. package/examples/jsm/shaders/RGBShiftShader.js +0 -54
  545. package/examples/jsm/shaders/SAOShader.js +0 -188
  546. package/examples/jsm/shaders/SMAAShader.js +0 -460
  547. package/examples/jsm/shaders/SSAOShader.js +0 -288
  548. package/examples/jsm/shaders/SSRShader.js +0 -364
  549. package/examples/jsm/shaders/SepiaShader.js +0 -52
  550. package/examples/jsm/shaders/SobelOperatorShader.js +0 -90
  551. package/examples/jsm/shaders/SubsurfaceScatteringShader.js +0 -88
  552. package/examples/jsm/shaders/TechnicolorShader.js +0 -43
  553. package/examples/jsm/shaders/ToonShader.js +0 -326
  554. package/examples/jsm/shaders/TriangleBlurShader.js +0 -72
  555. package/examples/jsm/shaders/UnpackDepthRGBAShader.js +0 -45
  556. package/examples/jsm/shaders/VelocityShader.js +0 -128
  557. package/examples/jsm/shaders/VerticalBlurShader.js +0 -59
  558. package/examples/jsm/shaders/VerticalTiltShiftShader.js +0 -61
  559. package/examples/jsm/shaders/VignetteShader.js +0 -51
  560. package/examples/jsm/shaders/VolumeShader.js +0 -289
  561. package/examples/jsm/shaders/WaterRefractionShader.js +0 -93
  562. package/examples/jsm/textures/FlakesTexture.js +0 -40
  563. package/examples/jsm/utils/BufferGeometryUtils.js +0 -1373
  564. package/examples/jsm/utils/CameraUtils.js +0 -73
  565. package/examples/jsm/utils/GPUStatsPanel.js +0 -128
  566. package/examples/jsm/utils/GeometryCompressionUtils.js +0 -639
  567. package/examples/jsm/utils/GeometryUtils.js +0 -221
  568. package/examples/jsm/utils/LDrawUtils.js +0 -202
  569. package/examples/jsm/utils/PackedPhongMaterial.js +0 -178
  570. package/examples/jsm/utils/SceneUtils.js +0 -254
  571. package/examples/jsm/utils/ShadowMapViewer.js +0 -210
  572. package/examples/jsm/utils/SkeletonUtils.js +0 -413
  573. package/examples/jsm/utils/TextureUtils.js +0 -86
  574. package/examples/jsm/utils/UVsDebug.js +0 -165
  575. package/examples/jsm/utils/WorkerPool.js +0 -102
  576. package/examples/jsm/webxr/ARButton.js +0 -208
  577. package/examples/jsm/webxr/OculusHandModel.js +0 -109
  578. package/examples/jsm/webxr/OculusHandPointerModel.js +0 -413
  579. package/examples/jsm/webxr/Text2D.js +0 -38
  580. package/examples/jsm/webxr/VRButton.js +0 -200
  581. package/examples/jsm/webxr/XRButton.js +0 -198
  582. package/examples/jsm/webxr/XRControllerModelFactory.js +0 -299
  583. package/examples/jsm/webxr/XREstimatedLight.js +0 -223
  584. package/examples/jsm/webxr/XRHandMeshModel.js +0 -112
  585. package/examples/jsm/webxr/XRHandModelFactory.js +0 -105
  586. package/examples/jsm/webxr/XRHandPrimitiveModel.js +0 -103
  587. package/examples/jsm/webxr/XRPlanes.js +0 -100
  588. package/lib/3d.min.js +0 -1
@@ -1,4122 +0,0 @@
1
- import {
2
- AmbientLight,
3
- AnimationClip,
4
- Bone,
5
- BufferGeometry,
6
- ClampToEdgeWrapping,
7
- Color,
8
- DirectionalLight,
9
- DoubleSide,
10
- FileLoader,
11
- Float32BufferAttribute,
12
- FrontSide,
13
- Group,
14
- Line,
15
- LineBasicMaterial,
16
- LineSegments,
17
- Loader,
18
- LoaderUtils,
19
- MathUtils,
20
- Matrix4,
21
- Mesh,
22
- MeshBasicMaterial,
23
- MeshLambertMaterial,
24
- MeshPhongMaterial,
25
- OrthographicCamera,
26
- PerspectiveCamera,
27
- PointLight,
28
- Quaternion,
29
- QuaternionKeyframeTrack,
30
- RepeatWrapping,
31
- Scene,
32
- Skeleton,
33
- SkinnedMesh,
34
- SpotLight,
35
- TextureLoader,
36
- Vector2,
37
- Vector3,
38
- VectorKeyframeTrack,
39
- SRGBColorSpace
40
- } from 'three';
41
- import { TGALoader } from '../loaders/TGALoader.js';
42
-
43
- class ColladaLoader extends Loader {
44
-
45
- constructor( manager ) {
46
-
47
- super( manager );
48
-
49
- }
50
-
51
- load( url, onLoad, onProgress, onError ) {
52
-
53
- const scope = this;
54
-
55
- const path = ( scope.path === '' ) ? LoaderUtils.extractUrlBase( url ) : scope.path;
56
-
57
- const loader = new FileLoader( scope.manager );
58
- loader.setPath( scope.path );
59
- loader.setRequestHeader( scope.requestHeader );
60
- loader.setWithCredentials( scope.withCredentials );
61
- loader.load( url, function ( text ) {
62
-
63
- try {
64
-
65
- onLoad( scope.parse( text, path ) );
66
-
67
- } catch ( e ) {
68
-
69
- if ( onError ) {
70
-
71
- onError( e );
72
-
73
- } else {
74
-
75
- console.error( e );
76
-
77
- }
78
-
79
- scope.manager.itemError( url );
80
-
81
- }
82
-
83
- }, onProgress, onError );
84
-
85
- }
86
-
87
- parse( text, path ) {
88
-
89
- function getElementsByTagName( xml, name ) {
90
-
91
- // Non recursive xml.getElementsByTagName() ...
92
-
93
- const array = [];
94
- const childNodes = xml.childNodes;
95
-
96
- for ( let i = 0, l = childNodes.length; i < l; i ++ ) {
97
-
98
- const child = childNodes[ i ];
99
-
100
- if ( child.nodeName === name ) {
101
-
102
- array.push( child );
103
-
104
- }
105
-
106
- }
107
-
108
- return array;
109
-
110
- }
111
-
112
- function parseStrings( text ) {
113
-
114
- if ( text.length === 0 ) return [];
115
-
116
- const parts = text.trim().split( /\s+/ );
117
- const array = new Array( parts.length );
118
-
119
- for ( let i = 0, l = parts.length; i < l; i ++ ) {
120
-
121
- array[ i ] = parts[ i ];
122
-
123
- }
124
-
125
- return array;
126
-
127
- }
128
-
129
- function parseFloats( text ) {
130
-
131
- if ( text.length === 0 ) return [];
132
-
133
- const parts = text.trim().split( /\s+/ );
134
- const array = new Array( parts.length );
135
-
136
- for ( let i = 0, l = parts.length; i < l; i ++ ) {
137
-
138
- array[ i ] = parseFloat( parts[ i ] );
139
-
140
- }
141
-
142
- return array;
143
-
144
- }
145
-
146
- function parseInts( text ) {
147
-
148
- if ( text.length === 0 ) return [];
149
-
150
- const parts = text.trim().split( /\s+/ );
151
- const array = new Array( parts.length );
152
-
153
- for ( let i = 0, l = parts.length; i < l; i ++ ) {
154
-
155
- array[ i ] = parseInt( parts[ i ] );
156
-
157
- }
158
-
159
- return array;
160
-
161
- }
162
-
163
- function parseId( text ) {
164
-
165
- return text.substring( 1 );
166
-
167
- }
168
-
169
- function generateId() {
170
-
171
- return 'three_default_' + ( count ++ );
172
-
173
- }
174
-
175
- function isEmpty( object ) {
176
-
177
- return Object.keys( object ).length === 0;
178
-
179
- }
180
-
181
- // asset
182
-
183
- function parseAsset( xml ) {
184
-
185
- return {
186
- unit: parseAssetUnit( getElementsByTagName( xml, 'unit' )[ 0 ] ),
187
- upAxis: parseAssetUpAxis( getElementsByTagName( xml, 'up_axis' )[ 0 ] )
188
- };
189
-
190
- }
191
-
192
- function parseAssetUnit( xml ) {
193
-
194
- if ( ( xml !== undefined ) && ( xml.hasAttribute( 'meter' ) === true ) ) {
195
-
196
- return parseFloat( xml.getAttribute( 'meter' ) );
197
-
198
- } else {
199
-
200
- return 1; // default 1 meter
201
-
202
- }
203
-
204
- }
205
-
206
- function parseAssetUpAxis( xml ) {
207
-
208
- return xml !== undefined ? xml.textContent : 'Y_UP';
209
-
210
- }
211
-
212
- // library
213
-
214
- function parseLibrary( xml, libraryName, nodeName, parser ) {
215
-
216
- const library = getElementsByTagName( xml, libraryName )[ 0 ];
217
-
218
- if ( library !== undefined ) {
219
-
220
- const elements = getElementsByTagName( library, nodeName );
221
-
222
- for ( let i = 0; i < elements.length; i ++ ) {
223
-
224
- parser( elements[ i ] );
225
-
226
- }
227
-
228
- }
229
-
230
- }
231
-
232
- function buildLibrary( data, builder ) {
233
-
234
- for ( const name in data ) {
235
-
236
- const object = data[ name ];
237
- object.build = builder( data[ name ] );
238
-
239
- }
240
-
241
- }
242
-
243
- // get
244
-
245
- function getBuild( data, builder ) {
246
-
247
- if ( data.build !== undefined ) return data.build;
248
-
249
- data.build = builder( data );
250
-
251
- return data.build;
252
-
253
- }
254
-
255
- // animation
256
-
257
- function parseAnimation( xml ) {
258
-
259
- const data = {
260
- sources: {},
261
- samplers: {},
262
- channels: {}
263
- };
264
-
265
- let hasChildren = false;
266
-
267
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
268
-
269
- const child = xml.childNodes[ i ];
270
-
271
- if ( child.nodeType !== 1 ) continue;
272
-
273
- let id;
274
-
275
- switch ( child.nodeName ) {
276
-
277
- case 'source':
278
- id = child.getAttribute( 'id' );
279
- data.sources[ id ] = parseSource( child );
280
- break;
281
-
282
- case 'sampler':
283
- id = child.getAttribute( 'id' );
284
- data.samplers[ id ] = parseAnimationSampler( child );
285
- break;
286
-
287
- case 'channel':
288
- id = child.getAttribute( 'target' );
289
- data.channels[ id ] = parseAnimationChannel( child );
290
- break;
291
-
292
- case 'animation':
293
- // hierarchy of related animations
294
- parseAnimation( child );
295
- hasChildren = true;
296
- break;
297
-
298
- default:
299
- console.log( child );
300
-
301
- }
302
-
303
- }
304
-
305
- if ( hasChildren === false ) {
306
-
307
- // since 'id' attributes can be optional, it's necessary to generate a UUID for unqiue assignment
308
-
309
- library.animations[ xml.getAttribute( 'id' ) || MathUtils.generateUUID() ] = data;
310
-
311
- }
312
-
313
- }
314
-
315
- function parseAnimationSampler( xml ) {
316
-
317
- const data = {
318
- inputs: {},
319
- };
320
-
321
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
322
-
323
- const child = xml.childNodes[ i ];
324
-
325
- if ( child.nodeType !== 1 ) continue;
326
-
327
- switch ( child.nodeName ) {
328
-
329
- case 'input':
330
- const id = parseId( child.getAttribute( 'source' ) );
331
- const semantic = child.getAttribute( 'semantic' );
332
- data.inputs[ semantic ] = id;
333
- break;
334
-
335
- }
336
-
337
- }
338
-
339
- return data;
340
-
341
- }
342
-
343
- function parseAnimationChannel( xml ) {
344
-
345
- const data = {};
346
-
347
- const target = xml.getAttribute( 'target' );
348
-
349
- // parsing SID Addressing Syntax
350
-
351
- let parts = target.split( '/' );
352
-
353
- const id = parts.shift();
354
- let sid = parts.shift();
355
-
356
- // check selection syntax
357
-
358
- const arraySyntax = ( sid.indexOf( '(' ) !== - 1 );
359
- const memberSyntax = ( sid.indexOf( '.' ) !== - 1 );
360
-
361
- if ( memberSyntax ) {
362
-
363
- // member selection access
364
-
365
- parts = sid.split( '.' );
366
- sid = parts.shift();
367
- data.member = parts.shift();
368
-
369
- } else if ( arraySyntax ) {
370
-
371
- // array-access syntax. can be used to express fields in one-dimensional vectors or two-dimensional matrices.
372
-
373
- const indices = sid.split( '(' );
374
- sid = indices.shift();
375
-
376
- for ( let i = 0; i < indices.length; i ++ ) {
377
-
378
- indices[ i ] = parseInt( indices[ i ].replace( /\)/, '' ) );
379
-
380
- }
381
-
382
- data.indices = indices;
383
-
384
- }
385
-
386
- data.id = id;
387
- data.sid = sid;
388
-
389
- data.arraySyntax = arraySyntax;
390
- data.memberSyntax = memberSyntax;
391
-
392
- data.sampler = parseId( xml.getAttribute( 'source' ) );
393
-
394
- return data;
395
-
396
- }
397
-
398
- function buildAnimation( data ) {
399
-
400
- const tracks = [];
401
-
402
- const channels = data.channels;
403
- const samplers = data.samplers;
404
- const sources = data.sources;
405
-
406
- for ( const target in channels ) {
407
-
408
- if ( channels.hasOwnProperty( target ) ) {
409
-
410
- const channel = channels[ target ];
411
- const sampler = samplers[ channel.sampler ];
412
-
413
- const inputId = sampler.inputs.INPUT;
414
- const outputId = sampler.inputs.OUTPUT;
415
-
416
- const inputSource = sources[ inputId ];
417
- const outputSource = sources[ outputId ];
418
-
419
- const animation = buildAnimationChannel( channel, inputSource, outputSource );
420
-
421
- createKeyframeTracks( animation, tracks );
422
-
423
- }
424
-
425
- }
426
-
427
- return tracks;
428
-
429
- }
430
-
431
- function getAnimation( id ) {
432
-
433
- return getBuild( library.animations[ id ], buildAnimation );
434
-
435
- }
436
-
437
- function buildAnimationChannel( channel, inputSource, outputSource ) {
438
-
439
- const node = library.nodes[ channel.id ];
440
- const object3D = getNode( node.id );
441
-
442
- const transform = node.transforms[ channel.sid ];
443
- const defaultMatrix = node.matrix.clone().transpose();
444
-
445
- let time, stride;
446
- let i, il, j, jl;
447
-
448
- const data = {};
449
-
450
- // the collada spec allows the animation of data in various ways.
451
- // depending on the transform type (matrix, translate, rotate, scale), we execute different logic
452
-
453
- switch ( transform ) {
454
-
455
- case 'matrix':
456
-
457
- for ( i = 0, il = inputSource.array.length; i < il; i ++ ) {
458
-
459
- time = inputSource.array[ i ];
460
- stride = i * outputSource.stride;
461
-
462
- if ( data[ time ] === undefined ) data[ time ] = {};
463
-
464
- if ( channel.arraySyntax === true ) {
465
-
466
- const value = outputSource.array[ stride ];
467
- const index = channel.indices[ 0 ] + 4 * channel.indices[ 1 ];
468
-
469
- data[ time ][ index ] = value;
470
-
471
- } else {
472
-
473
- for ( j = 0, jl = outputSource.stride; j < jl; j ++ ) {
474
-
475
- data[ time ][ j ] = outputSource.array[ stride + j ];
476
-
477
- }
478
-
479
- }
480
-
481
- }
482
-
483
- break;
484
-
485
- case 'translate':
486
- console.warn( 'THREE.ColladaLoader: Animation transform type "%s" not yet implemented.', transform );
487
- break;
488
-
489
- case 'rotate':
490
- console.warn( 'THREE.ColladaLoader: Animation transform type "%s" not yet implemented.', transform );
491
- break;
492
-
493
- case 'scale':
494
- console.warn( 'THREE.ColladaLoader: Animation transform type "%s" not yet implemented.', transform );
495
- break;
496
-
497
- }
498
-
499
- const keyframes = prepareAnimationData( data, defaultMatrix );
500
-
501
- const animation = {
502
- name: object3D.uuid,
503
- keyframes: keyframes
504
- };
505
-
506
- return animation;
507
-
508
- }
509
-
510
- function prepareAnimationData( data, defaultMatrix ) {
511
-
512
- const keyframes = [];
513
-
514
- // transfer data into a sortable array
515
-
516
- for ( const time in data ) {
517
-
518
- keyframes.push( { time: parseFloat( time ), value: data[ time ] } );
519
-
520
- }
521
-
522
- // ensure keyframes are sorted by time
523
-
524
- keyframes.sort( ascending );
525
-
526
- // now we clean up all animation data, so we can use them for keyframe tracks
527
-
528
- for ( let i = 0; i < 16; i ++ ) {
529
-
530
- transformAnimationData( keyframes, i, defaultMatrix.elements[ i ] );
531
-
532
- }
533
-
534
- return keyframes;
535
-
536
- // array sort function
537
-
538
- function ascending( a, b ) {
539
-
540
- return a.time - b.time;
541
-
542
- }
543
-
544
- }
545
-
546
- const position = new Vector3();
547
- const scale = new Vector3();
548
- const quaternion = new Quaternion();
549
-
550
- function createKeyframeTracks( animation, tracks ) {
551
-
552
- const keyframes = animation.keyframes;
553
- const name = animation.name;
554
-
555
- const times = [];
556
- const positionData = [];
557
- const quaternionData = [];
558
- const scaleData = [];
559
-
560
- for ( let i = 0, l = keyframes.length; i < l; i ++ ) {
561
-
562
- const keyframe = keyframes[ i ];
563
-
564
- const time = keyframe.time;
565
- const value = keyframe.value;
566
-
567
- matrix.fromArray( value ).transpose();
568
- matrix.decompose( position, quaternion, scale );
569
-
570
- times.push( time );
571
- positionData.push( position.x, position.y, position.z );
572
- quaternionData.push( quaternion.x, quaternion.y, quaternion.z, quaternion.w );
573
- scaleData.push( scale.x, scale.y, scale.z );
574
-
575
- }
576
-
577
- if ( positionData.length > 0 ) tracks.push( new VectorKeyframeTrack( name + '.position', times, positionData ) );
578
- if ( quaternionData.length > 0 ) tracks.push( new QuaternionKeyframeTrack( name + '.quaternion', times, quaternionData ) );
579
- if ( scaleData.length > 0 ) tracks.push( new VectorKeyframeTrack( name + '.scale', times, scaleData ) );
580
-
581
- return tracks;
582
-
583
- }
584
-
585
- function transformAnimationData( keyframes, property, defaultValue ) {
586
-
587
- let keyframe;
588
-
589
- let empty = true;
590
- let i, l;
591
-
592
- // check, if values of a property are missing in our keyframes
593
-
594
- for ( i = 0, l = keyframes.length; i < l; i ++ ) {
595
-
596
- keyframe = keyframes[ i ];
597
-
598
- if ( keyframe.value[ property ] === undefined ) {
599
-
600
- keyframe.value[ property ] = null; // mark as missing
601
-
602
- } else {
603
-
604
- empty = false;
605
-
606
- }
607
-
608
- }
609
-
610
- if ( empty === true ) {
611
-
612
- // no values at all, so we set a default value
613
-
614
- for ( i = 0, l = keyframes.length; i < l; i ++ ) {
615
-
616
- keyframe = keyframes[ i ];
617
-
618
- keyframe.value[ property ] = defaultValue;
619
-
620
- }
621
-
622
- } else {
623
-
624
- // filling gaps
625
-
626
- createMissingKeyframes( keyframes, property );
627
-
628
- }
629
-
630
- }
631
-
632
- function createMissingKeyframes( keyframes, property ) {
633
-
634
- let prev, next;
635
-
636
- for ( let i = 0, l = keyframes.length; i < l; i ++ ) {
637
-
638
- const keyframe = keyframes[ i ];
639
-
640
- if ( keyframe.value[ property ] === null ) {
641
-
642
- prev = getPrev( keyframes, i, property );
643
- next = getNext( keyframes, i, property );
644
-
645
- if ( prev === null ) {
646
-
647
- keyframe.value[ property ] = next.value[ property ];
648
- continue;
649
-
650
- }
651
-
652
- if ( next === null ) {
653
-
654
- keyframe.value[ property ] = prev.value[ property ];
655
- continue;
656
-
657
- }
658
-
659
- interpolate( keyframe, prev, next, property );
660
-
661
- }
662
-
663
- }
664
-
665
- }
666
-
667
- function getPrev( keyframes, i, property ) {
668
-
669
- while ( i >= 0 ) {
670
-
671
- const keyframe = keyframes[ i ];
672
-
673
- if ( keyframe.value[ property ] !== null ) return keyframe;
674
-
675
- i --;
676
-
677
- }
678
-
679
- return null;
680
-
681
- }
682
-
683
- function getNext( keyframes, i, property ) {
684
-
685
- while ( i < keyframes.length ) {
686
-
687
- const keyframe = keyframes[ i ];
688
-
689
- if ( keyframe.value[ property ] !== null ) return keyframe;
690
-
691
- i ++;
692
-
693
- }
694
-
695
- return null;
696
-
697
- }
698
-
699
- function interpolate( key, prev, next, property ) {
700
-
701
- if ( ( next.time - prev.time ) === 0 ) {
702
-
703
- key.value[ property ] = prev.value[ property ];
704
- return;
705
-
706
- }
707
-
708
- key.value[ property ] = ( ( key.time - prev.time ) * ( next.value[ property ] - prev.value[ property ] ) / ( next.time - prev.time ) ) + prev.value[ property ];
709
-
710
- }
711
-
712
- // animation clips
713
-
714
- function parseAnimationClip( xml ) {
715
-
716
- const data = {
717
- name: xml.getAttribute( 'id' ) || 'default',
718
- start: parseFloat( xml.getAttribute( 'start' ) || 0 ),
719
- end: parseFloat( xml.getAttribute( 'end' ) || 0 ),
720
- animations: []
721
- };
722
-
723
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
724
-
725
- const child = xml.childNodes[ i ];
726
-
727
- if ( child.nodeType !== 1 ) continue;
728
-
729
- switch ( child.nodeName ) {
730
-
731
- case 'instance_animation':
732
- data.animations.push( parseId( child.getAttribute( 'url' ) ) );
733
- break;
734
-
735
- }
736
-
737
- }
738
-
739
- library.clips[ xml.getAttribute( 'id' ) ] = data;
740
-
741
- }
742
-
743
- function buildAnimationClip( data ) {
744
-
745
- const tracks = [];
746
-
747
- const name = data.name;
748
- const duration = ( data.end - data.start ) || - 1;
749
- const animations = data.animations;
750
-
751
- for ( let i = 0, il = animations.length; i < il; i ++ ) {
752
-
753
- const animationTracks = getAnimation( animations[ i ] );
754
-
755
- for ( let j = 0, jl = animationTracks.length; j < jl; j ++ ) {
756
-
757
- tracks.push( animationTracks[ j ] );
758
-
759
- }
760
-
761
- }
762
-
763
- return new AnimationClip( name, duration, tracks );
764
-
765
- }
766
-
767
- function getAnimationClip( id ) {
768
-
769
- return getBuild( library.clips[ id ], buildAnimationClip );
770
-
771
- }
772
-
773
- // controller
774
-
775
- function parseController( xml ) {
776
-
777
- const data = {};
778
-
779
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
780
-
781
- const child = xml.childNodes[ i ];
782
-
783
- if ( child.nodeType !== 1 ) continue;
784
-
785
- switch ( child.nodeName ) {
786
-
787
- case 'skin':
788
- // there is exactly one skin per controller
789
- data.id = parseId( child.getAttribute( 'source' ) );
790
- data.skin = parseSkin( child );
791
- break;
792
-
793
- case 'morph':
794
- data.id = parseId( child.getAttribute( 'source' ) );
795
- console.warn( 'THREE.ColladaLoader: Morph target animation not supported yet.' );
796
- break;
797
-
798
- }
799
-
800
- }
801
-
802
- library.controllers[ xml.getAttribute( 'id' ) ] = data;
803
-
804
- }
805
-
806
- function parseSkin( xml ) {
807
-
808
- const data = {
809
- sources: {}
810
- };
811
-
812
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
813
-
814
- const child = xml.childNodes[ i ];
815
-
816
- if ( child.nodeType !== 1 ) continue;
817
-
818
- switch ( child.nodeName ) {
819
-
820
- case 'bind_shape_matrix':
821
- data.bindShapeMatrix = parseFloats( child.textContent );
822
- break;
823
-
824
- case 'source':
825
- const id = child.getAttribute( 'id' );
826
- data.sources[ id ] = parseSource( child );
827
- break;
828
-
829
- case 'joints':
830
- data.joints = parseJoints( child );
831
- break;
832
-
833
- case 'vertex_weights':
834
- data.vertexWeights = parseVertexWeights( child );
835
- break;
836
-
837
- }
838
-
839
- }
840
-
841
- return data;
842
-
843
- }
844
-
845
- function parseJoints( xml ) {
846
-
847
- const data = {
848
- inputs: {}
849
- };
850
-
851
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
852
-
853
- const child = xml.childNodes[ i ];
854
-
855
- if ( child.nodeType !== 1 ) continue;
856
-
857
- switch ( child.nodeName ) {
858
-
859
- case 'input':
860
- const semantic = child.getAttribute( 'semantic' );
861
- const id = parseId( child.getAttribute( 'source' ) );
862
- data.inputs[ semantic ] = id;
863
- break;
864
-
865
- }
866
-
867
- }
868
-
869
- return data;
870
-
871
- }
872
-
873
- function parseVertexWeights( xml ) {
874
-
875
- const data = {
876
- inputs: {}
877
- };
878
-
879
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
880
-
881
- const child = xml.childNodes[ i ];
882
-
883
- if ( child.nodeType !== 1 ) continue;
884
-
885
- switch ( child.nodeName ) {
886
-
887
- case 'input':
888
- const semantic = child.getAttribute( 'semantic' );
889
- const id = parseId( child.getAttribute( 'source' ) );
890
- const offset = parseInt( child.getAttribute( 'offset' ) );
891
- data.inputs[ semantic ] = { id: id, offset: offset };
892
- break;
893
-
894
- case 'vcount':
895
- data.vcount = parseInts( child.textContent );
896
- break;
897
-
898
- case 'v':
899
- data.v = parseInts( child.textContent );
900
- break;
901
-
902
- }
903
-
904
- }
905
-
906
- return data;
907
-
908
- }
909
-
910
- function buildController( data ) {
911
-
912
- const build = {
913
- id: data.id
914
- };
915
-
916
- const geometry = library.geometries[ build.id ];
917
-
918
- if ( data.skin !== undefined ) {
919
-
920
- build.skin = buildSkin( data.skin );
921
-
922
- // we enhance the 'sources' property of the corresponding geometry with our skin data
923
-
924
- geometry.sources.skinIndices = build.skin.indices;
925
- geometry.sources.skinWeights = build.skin.weights;
926
-
927
- }
928
-
929
- return build;
930
-
931
- }
932
-
933
- function buildSkin( data ) {
934
-
935
- const BONE_LIMIT = 4;
936
-
937
- const build = {
938
- joints: [], // this must be an array to preserve the joint order
939
- indices: {
940
- array: [],
941
- stride: BONE_LIMIT
942
- },
943
- weights: {
944
- array: [],
945
- stride: BONE_LIMIT
946
- }
947
- };
948
-
949
- const sources = data.sources;
950
- const vertexWeights = data.vertexWeights;
951
-
952
- const vcount = vertexWeights.vcount;
953
- const v = vertexWeights.v;
954
- const jointOffset = vertexWeights.inputs.JOINT.offset;
955
- const weightOffset = vertexWeights.inputs.WEIGHT.offset;
956
-
957
- const jointSource = data.sources[ data.joints.inputs.JOINT ];
958
- const inverseSource = data.sources[ data.joints.inputs.INV_BIND_MATRIX ];
959
-
960
- const weights = sources[ vertexWeights.inputs.WEIGHT.id ].array;
961
- let stride = 0;
962
-
963
- let i, j, l;
964
-
965
- // process skin data for each vertex
966
-
967
- for ( i = 0, l = vcount.length; i < l; i ++ ) {
968
-
969
- const jointCount = vcount[ i ]; // this is the amount of joints that affect a single vertex
970
- const vertexSkinData = [];
971
-
972
- for ( j = 0; j < jointCount; j ++ ) {
973
-
974
- const skinIndex = v[ stride + jointOffset ];
975
- const weightId = v[ stride + weightOffset ];
976
- const skinWeight = weights[ weightId ];
977
-
978
- vertexSkinData.push( { index: skinIndex, weight: skinWeight } );
979
-
980
- stride += 2;
981
-
982
- }
983
-
984
- // we sort the joints in descending order based on the weights.
985
- // this ensures, we only procced the most important joints of the vertex
986
-
987
- vertexSkinData.sort( descending );
988
-
989
- // now we provide for each vertex a set of four index and weight values.
990
- // the order of the skin data matches the order of vertices
991
-
992
- for ( j = 0; j < BONE_LIMIT; j ++ ) {
993
-
994
- const d = vertexSkinData[ j ];
995
-
996
- if ( d !== undefined ) {
997
-
998
- build.indices.array.push( d.index );
999
- build.weights.array.push( d.weight );
1000
-
1001
- } else {
1002
-
1003
- build.indices.array.push( 0 );
1004
- build.weights.array.push( 0 );
1005
-
1006
- }
1007
-
1008
- }
1009
-
1010
- }
1011
-
1012
- // setup bind matrix
1013
-
1014
- if ( data.bindShapeMatrix ) {
1015
-
1016
- build.bindMatrix = new Matrix4().fromArray( data.bindShapeMatrix ).transpose();
1017
-
1018
- } else {
1019
-
1020
- build.bindMatrix = new Matrix4().identity();
1021
-
1022
- }
1023
-
1024
- // process bones and inverse bind matrix data
1025
-
1026
- for ( i = 0, l = jointSource.array.length; i < l; i ++ ) {
1027
-
1028
- const name = jointSource.array[ i ];
1029
- const boneInverse = new Matrix4().fromArray( inverseSource.array, i * inverseSource.stride ).transpose();
1030
-
1031
- build.joints.push( { name: name, boneInverse: boneInverse } );
1032
-
1033
- }
1034
-
1035
- return build;
1036
-
1037
- // array sort function
1038
-
1039
- function descending( a, b ) {
1040
-
1041
- return b.weight - a.weight;
1042
-
1043
- }
1044
-
1045
- }
1046
-
1047
- function getController( id ) {
1048
-
1049
- return getBuild( library.controllers[ id ], buildController );
1050
-
1051
- }
1052
-
1053
- // image
1054
-
1055
- function parseImage( xml ) {
1056
-
1057
- const data = {
1058
- init_from: getElementsByTagName( xml, 'init_from' )[ 0 ].textContent
1059
- };
1060
-
1061
- library.images[ xml.getAttribute( 'id' ) ] = data;
1062
-
1063
- }
1064
-
1065
- function buildImage( data ) {
1066
-
1067
- if ( data.build !== undefined ) return data.build;
1068
-
1069
- return data.init_from;
1070
-
1071
- }
1072
-
1073
- function getImage( id ) {
1074
-
1075
- const data = library.images[ id ];
1076
-
1077
- if ( data !== undefined ) {
1078
-
1079
- return getBuild( data, buildImage );
1080
-
1081
- }
1082
-
1083
- console.warn( 'THREE.ColladaLoader: Couldn\'t find image with ID:', id );
1084
-
1085
- return null;
1086
-
1087
- }
1088
-
1089
- // effect
1090
-
1091
- function parseEffect( xml ) {
1092
-
1093
- const data = {};
1094
-
1095
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1096
-
1097
- const child = xml.childNodes[ i ];
1098
-
1099
- if ( child.nodeType !== 1 ) continue;
1100
-
1101
- switch ( child.nodeName ) {
1102
-
1103
- case 'profile_COMMON':
1104
- data.profile = parseEffectProfileCOMMON( child );
1105
- break;
1106
-
1107
- }
1108
-
1109
- }
1110
-
1111
- library.effects[ xml.getAttribute( 'id' ) ] = data;
1112
-
1113
- }
1114
-
1115
- function parseEffectProfileCOMMON( xml ) {
1116
-
1117
- const data = {
1118
- surfaces: {},
1119
- samplers: {}
1120
- };
1121
-
1122
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1123
-
1124
- const child = xml.childNodes[ i ];
1125
-
1126
- if ( child.nodeType !== 1 ) continue;
1127
-
1128
- switch ( child.nodeName ) {
1129
-
1130
- case 'newparam':
1131
- parseEffectNewparam( child, data );
1132
- break;
1133
-
1134
- case 'technique':
1135
- data.technique = parseEffectTechnique( child );
1136
- break;
1137
-
1138
- case 'extra':
1139
- data.extra = parseEffectExtra( child );
1140
- break;
1141
-
1142
- }
1143
-
1144
- }
1145
-
1146
- return data;
1147
-
1148
- }
1149
-
1150
- function parseEffectNewparam( xml, data ) {
1151
-
1152
- const sid = xml.getAttribute( 'sid' );
1153
-
1154
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1155
-
1156
- const child = xml.childNodes[ i ];
1157
-
1158
- if ( child.nodeType !== 1 ) continue;
1159
-
1160
- switch ( child.nodeName ) {
1161
-
1162
- case 'surface':
1163
- data.surfaces[ sid ] = parseEffectSurface( child );
1164
- break;
1165
-
1166
- case 'sampler2D':
1167
- data.samplers[ sid ] = parseEffectSampler( child );
1168
- break;
1169
-
1170
- }
1171
-
1172
- }
1173
-
1174
- }
1175
-
1176
- function parseEffectSurface( xml ) {
1177
-
1178
- const data = {};
1179
-
1180
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1181
-
1182
- const child = xml.childNodes[ i ];
1183
-
1184
- if ( child.nodeType !== 1 ) continue;
1185
-
1186
- switch ( child.nodeName ) {
1187
-
1188
- case 'init_from':
1189
- data.init_from = child.textContent;
1190
- break;
1191
-
1192
- }
1193
-
1194
- }
1195
-
1196
- return data;
1197
-
1198
- }
1199
-
1200
- function parseEffectSampler( xml ) {
1201
-
1202
- const data = {};
1203
-
1204
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1205
-
1206
- const child = xml.childNodes[ i ];
1207
-
1208
- if ( child.nodeType !== 1 ) continue;
1209
-
1210
- switch ( child.nodeName ) {
1211
-
1212
- case 'source':
1213
- data.source = child.textContent;
1214
- break;
1215
-
1216
- }
1217
-
1218
- }
1219
-
1220
- return data;
1221
-
1222
- }
1223
-
1224
- function parseEffectTechnique( xml ) {
1225
-
1226
- const data = {};
1227
-
1228
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1229
-
1230
- const child = xml.childNodes[ i ];
1231
-
1232
- if ( child.nodeType !== 1 ) continue;
1233
-
1234
- switch ( child.nodeName ) {
1235
-
1236
- case 'constant':
1237
- case 'lambert':
1238
- case 'blinn':
1239
- case 'phong':
1240
- data.type = child.nodeName;
1241
- data.parameters = parseEffectParameters( child );
1242
- break;
1243
-
1244
- case 'extra':
1245
- data.extra = parseEffectExtra( child );
1246
- break;
1247
-
1248
- }
1249
-
1250
- }
1251
-
1252
- return data;
1253
-
1254
- }
1255
-
1256
- function parseEffectParameters( xml ) {
1257
-
1258
- const data = {};
1259
-
1260
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1261
-
1262
- const child = xml.childNodes[ i ];
1263
-
1264
- if ( child.nodeType !== 1 ) continue;
1265
-
1266
- switch ( child.nodeName ) {
1267
-
1268
- case 'emission':
1269
- case 'diffuse':
1270
- case 'specular':
1271
- case 'bump':
1272
- case 'ambient':
1273
- case 'shininess':
1274
- case 'transparency':
1275
- data[ child.nodeName ] = parseEffectParameter( child );
1276
- break;
1277
- case 'transparent':
1278
- data[ child.nodeName ] = {
1279
- opaque: child.hasAttribute( 'opaque' ) ? child.getAttribute( 'opaque' ) : 'A_ONE',
1280
- data: parseEffectParameter( child )
1281
- };
1282
- break;
1283
-
1284
- }
1285
-
1286
- }
1287
-
1288
- return data;
1289
-
1290
- }
1291
-
1292
- function parseEffectParameter( xml ) {
1293
-
1294
- const data = {};
1295
-
1296
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1297
-
1298
- const child = xml.childNodes[ i ];
1299
-
1300
- if ( child.nodeType !== 1 ) continue;
1301
-
1302
- switch ( child.nodeName ) {
1303
-
1304
- case 'color':
1305
- data[ child.nodeName ] = parseFloats( child.textContent );
1306
- break;
1307
-
1308
- case 'float':
1309
- data[ child.nodeName ] = parseFloat( child.textContent );
1310
- break;
1311
-
1312
- case 'texture':
1313
- data[ child.nodeName ] = { id: child.getAttribute( 'texture' ), extra: parseEffectParameterTexture( child ) };
1314
- break;
1315
-
1316
- }
1317
-
1318
- }
1319
-
1320
- return data;
1321
-
1322
- }
1323
-
1324
- function parseEffectParameterTexture( xml ) {
1325
-
1326
- const data = {
1327
- technique: {}
1328
- };
1329
-
1330
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1331
-
1332
- const child = xml.childNodes[ i ];
1333
-
1334
- if ( child.nodeType !== 1 ) continue;
1335
-
1336
- switch ( child.nodeName ) {
1337
-
1338
- case 'extra':
1339
- parseEffectParameterTextureExtra( child, data );
1340
- break;
1341
-
1342
- }
1343
-
1344
- }
1345
-
1346
- return data;
1347
-
1348
- }
1349
-
1350
- function parseEffectParameterTextureExtra( xml, data ) {
1351
-
1352
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1353
-
1354
- const child = xml.childNodes[ i ];
1355
-
1356
- if ( child.nodeType !== 1 ) continue;
1357
-
1358
- switch ( child.nodeName ) {
1359
-
1360
- case 'technique':
1361
- parseEffectParameterTextureExtraTechnique( child, data );
1362
- break;
1363
-
1364
- }
1365
-
1366
- }
1367
-
1368
- }
1369
-
1370
- function parseEffectParameterTextureExtraTechnique( xml, data ) {
1371
-
1372
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1373
-
1374
- const child = xml.childNodes[ i ];
1375
-
1376
- if ( child.nodeType !== 1 ) continue;
1377
-
1378
- switch ( child.nodeName ) {
1379
-
1380
- case 'repeatU':
1381
- case 'repeatV':
1382
- case 'offsetU':
1383
- case 'offsetV':
1384
- data.technique[ child.nodeName ] = parseFloat( child.textContent );
1385
- break;
1386
-
1387
- case 'wrapU':
1388
- case 'wrapV':
1389
-
1390
- // some files have values for wrapU/wrapV which become NaN via parseInt
1391
-
1392
- if ( child.textContent.toUpperCase() === 'TRUE' ) {
1393
-
1394
- data.technique[ child.nodeName ] = 1;
1395
-
1396
- } else if ( child.textContent.toUpperCase() === 'FALSE' ) {
1397
-
1398
- data.technique[ child.nodeName ] = 0;
1399
-
1400
- } else {
1401
-
1402
- data.technique[ child.nodeName ] = parseInt( child.textContent );
1403
-
1404
- }
1405
-
1406
- break;
1407
-
1408
- case 'bump':
1409
- data[ child.nodeName ] = parseEffectExtraTechniqueBump( child );
1410
- break;
1411
-
1412
- }
1413
-
1414
- }
1415
-
1416
- }
1417
-
1418
- function parseEffectExtra( xml ) {
1419
-
1420
- const data = {};
1421
-
1422
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1423
-
1424
- const child = xml.childNodes[ i ];
1425
-
1426
- if ( child.nodeType !== 1 ) continue;
1427
-
1428
- switch ( child.nodeName ) {
1429
-
1430
- case 'technique':
1431
- data.technique = parseEffectExtraTechnique( child );
1432
- break;
1433
-
1434
- }
1435
-
1436
- }
1437
-
1438
- return data;
1439
-
1440
- }
1441
-
1442
- function parseEffectExtraTechnique( xml ) {
1443
-
1444
- const data = {};
1445
-
1446
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1447
-
1448
- const child = xml.childNodes[ i ];
1449
-
1450
- if ( child.nodeType !== 1 ) continue;
1451
-
1452
- switch ( child.nodeName ) {
1453
-
1454
- case 'double_sided':
1455
- data[ child.nodeName ] = parseInt( child.textContent );
1456
- break;
1457
-
1458
- case 'bump':
1459
- data[ child.nodeName ] = parseEffectExtraTechniqueBump( child );
1460
- break;
1461
-
1462
- }
1463
-
1464
- }
1465
-
1466
- return data;
1467
-
1468
- }
1469
-
1470
- function parseEffectExtraTechniqueBump( xml ) {
1471
-
1472
- const data = {};
1473
-
1474
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1475
-
1476
- const child = xml.childNodes[ i ];
1477
-
1478
- if ( child.nodeType !== 1 ) continue;
1479
-
1480
- switch ( child.nodeName ) {
1481
-
1482
- case 'texture':
1483
- data[ child.nodeName ] = { id: child.getAttribute( 'texture' ), texcoord: child.getAttribute( 'texcoord' ), extra: parseEffectParameterTexture( child ) };
1484
- break;
1485
-
1486
- }
1487
-
1488
- }
1489
-
1490
- return data;
1491
-
1492
- }
1493
-
1494
- function buildEffect( data ) {
1495
-
1496
- return data;
1497
-
1498
- }
1499
-
1500
- function getEffect( id ) {
1501
-
1502
- return getBuild( library.effects[ id ], buildEffect );
1503
-
1504
- }
1505
-
1506
- // material
1507
-
1508
- function parseMaterial( xml ) {
1509
-
1510
- const data = {
1511
- name: xml.getAttribute( 'name' )
1512
- };
1513
-
1514
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1515
-
1516
- const child = xml.childNodes[ i ];
1517
-
1518
- if ( child.nodeType !== 1 ) continue;
1519
-
1520
- switch ( child.nodeName ) {
1521
-
1522
- case 'instance_effect':
1523
- data.url = parseId( child.getAttribute( 'url' ) );
1524
- break;
1525
-
1526
- }
1527
-
1528
- }
1529
-
1530
- library.materials[ xml.getAttribute( 'id' ) ] = data;
1531
-
1532
- }
1533
-
1534
- function getTextureLoader( image ) {
1535
-
1536
- let loader;
1537
-
1538
- let extension = image.slice( ( image.lastIndexOf( '.' ) - 1 >>> 0 ) + 2 ); // http://www.jstips.co/en/javascript/get-file-extension/
1539
- extension = extension.toLowerCase();
1540
-
1541
- switch ( extension ) {
1542
-
1543
- case 'tga':
1544
- loader = tgaLoader;
1545
- break;
1546
-
1547
- default:
1548
- loader = textureLoader;
1549
-
1550
- }
1551
-
1552
- return loader;
1553
-
1554
- }
1555
-
1556
- function buildMaterial( data ) {
1557
-
1558
- const effect = getEffect( data.url );
1559
- const technique = effect.profile.technique;
1560
-
1561
- let material;
1562
-
1563
- switch ( technique.type ) {
1564
-
1565
- case 'phong':
1566
- case 'blinn':
1567
- material = new MeshPhongMaterial();
1568
- break;
1569
-
1570
- case 'lambert':
1571
- material = new MeshLambertMaterial();
1572
- break;
1573
-
1574
- default:
1575
- material = new MeshBasicMaterial();
1576
- break;
1577
-
1578
- }
1579
-
1580
- material.name = data.name || '';
1581
-
1582
- function getTexture( textureObject, colorSpace = null ) {
1583
-
1584
- const sampler = effect.profile.samplers[ textureObject.id ];
1585
- let image = null;
1586
-
1587
- // get image
1588
-
1589
- if ( sampler !== undefined ) {
1590
-
1591
- const surface = effect.profile.surfaces[ sampler.source ];
1592
- image = getImage( surface.init_from );
1593
-
1594
- } else {
1595
-
1596
- console.warn( 'THREE.ColladaLoader: Undefined sampler. Access image directly (see #12530).' );
1597
- image = getImage( textureObject.id );
1598
-
1599
- }
1600
-
1601
- // create texture if image is avaiable
1602
-
1603
- if ( image !== null ) {
1604
-
1605
- const loader = getTextureLoader( image );
1606
-
1607
- if ( loader !== undefined ) {
1608
-
1609
- const texture = loader.load( image );
1610
-
1611
- const extra = textureObject.extra;
1612
-
1613
- if ( extra !== undefined && extra.technique !== undefined && isEmpty( extra.technique ) === false ) {
1614
-
1615
- const technique = extra.technique;
1616
-
1617
- texture.wrapS = technique.wrapU ? RepeatWrapping : ClampToEdgeWrapping;
1618
- texture.wrapT = technique.wrapV ? RepeatWrapping : ClampToEdgeWrapping;
1619
-
1620
- texture.offset.set( technique.offsetU || 0, technique.offsetV || 0 );
1621
- texture.repeat.set( technique.repeatU || 1, technique.repeatV || 1 );
1622
-
1623
- } else {
1624
-
1625
- texture.wrapS = RepeatWrapping;
1626
- texture.wrapT = RepeatWrapping;
1627
-
1628
- }
1629
-
1630
- if ( colorSpace !== null ) {
1631
-
1632
- texture.colorSpace = colorSpace;
1633
-
1634
- }
1635
-
1636
- return texture;
1637
-
1638
- } else {
1639
-
1640
- console.warn( 'THREE.ColladaLoader: Loader for texture %s not found.', image );
1641
-
1642
- return null;
1643
-
1644
- }
1645
-
1646
- } else {
1647
-
1648
- console.warn( 'THREE.ColladaLoader: Couldn\'t create texture with ID:', textureObject.id );
1649
-
1650
- return null;
1651
-
1652
- }
1653
-
1654
- }
1655
-
1656
- const parameters = technique.parameters;
1657
-
1658
- for ( const key in parameters ) {
1659
-
1660
- const parameter = parameters[ key ];
1661
-
1662
- switch ( key ) {
1663
-
1664
- case 'diffuse':
1665
- if ( parameter.color ) material.color.fromArray( parameter.color );
1666
- if ( parameter.texture ) material.map = getTexture( parameter.texture, SRGBColorSpace );
1667
- break;
1668
- case 'specular':
1669
- if ( parameter.color && material.specular ) material.specular.fromArray( parameter.color );
1670
- if ( parameter.texture ) material.specularMap = getTexture( parameter.texture );
1671
- break;
1672
- case 'bump':
1673
- if ( parameter.texture ) material.normalMap = getTexture( parameter.texture );
1674
- break;
1675
- case 'ambient':
1676
- if ( parameter.texture ) material.lightMap = getTexture( parameter.texture, SRGBColorSpace );
1677
- break;
1678
- case 'shininess':
1679
- if ( parameter.float && material.shininess ) material.shininess = parameter.float;
1680
- break;
1681
- case 'emission':
1682
- if ( parameter.color && material.emissive ) material.emissive.fromArray( parameter.color );
1683
- if ( parameter.texture ) material.emissiveMap = getTexture( parameter.texture, SRGBColorSpace );
1684
- break;
1685
-
1686
- }
1687
-
1688
- }
1689
-
1690
- material.color.convertSRGBToLinear();
1691
- if ( material.specular ) material.specular.convertSRGBToLinear();
1692
- if ( material.emissive ) material.emissive.convertSRGBToLinear();
1693
-
1694
- //
1695
-
1696
- let transparent = parameters[ 'transparent' ];
1697
- let transparency = parameters[ 'transparency' ];
1698
-
1699
- // <transparency> does not exist but <transparent>
1700
-
1701
- if ( transparency === undefined && transparent ) {
1702
-
1703
- transparency = {
1704
- float: 1
1705
- };
1706
-
1707
- }
1708
-
1709
- // <transparent> does not exist but <transparency>
1710
-
1711
- if ( transparent === undefined && transparency ) {
1712
-
1713
- transparent = {
1714
- opaque: 'A_ONE',
1715
- data: {
1716
- color: [ 1, 1, 1, 1 ]
1717
- } };
1718
-
1719
- }
1720
-
1721
- if ( transparent && transparency ) {
1722
-
1723
- // handle case if a texture exists but no color
1724
-
1725
- if ( transparent.data.texture ) {
1726
-
1727
- // we do not set an alpha map (see #13792)
1728
-
1729
- material.transparent = true;
1730
-
1731
- } else {
1732
-
1733
- const color = transparent.data.color;
1734
-
1735
- switch ( transparent.opaque ) {
1736
-
1737
- case 'A_ONE':
1738
- material.opacity = color[ 3 ] * transparency.float;
1739
- break;
1740
- case 'RGB_ZERO':
1741
- material.opacity = 1 - ( color[ 0 ] * transparency.float );
1742
- break;
1743
- case 'A_ZERO':
1744
- material.opacity = 1 - ( color[ 3 ] * transparency.float );
1745
- break;
1746
- case 'RGB_ONE':
1747
- material.opacity = color[ 0 ] * transparency.float;
1748
- break;
1749
- default:
1750
- console.warn( 'THREE.ColladaLoader: Invalid opaque type "%s" of transparent tag.', transparent.opaque );
1751
-
1752
- }
1753
-
1754
- if ( material.opacity < 1 ) material.transparent = true;
1755
-
1756
- }
1757
-
1758
- }
1759
-
1760
- //
1761
-
1762
-
1763
- if ( technique.extra !== undefined && technique.extra.technique !== undefined ) {
1764
-
1765
- const techniques = technique.extra.technique;
1766
-
1767
- for ( const k in techniques ) {
1768
-
1769
- const v = techniques[ k ];
1770
-
1771
- switch ( k ) {
1772
-
1773
- case 'double_sided':
1774
- material.side = ( v === 1 ? DoubleSide : FrontSide );
1775
- break;
1776
-
1777
- case 'bump':
1778
- material.normalMap = getTexture( v.texture );
1779
- material.normalScale = new Vector2( 1, 1 );
1780
- break;
1781
-
1782
- }
1783
-
1784
- }
1785
-
1786
- }
1787
-
1788
- return material;
1789
-
1790
- }
1791
-
1792
- function getMaterial( id ) {
1793
-
1794
- return getBuild( library.materials[ id ], buildMaterial );
1795
-
1796
- }
1797
-
1798
- // camera
1799
-
1800
- function parseCamera( xml ) {
1801
-
1802
- const data = {
1803
- name: xml.getAttribute( 'name' )
1804
- };
1805
-
1806
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1807
-
1808
- const child = xml.childNodes[ i ];
1809
-
1810
- if ( child.nodeType !== 1 ) continue;
1811
-
1812
- switch ( child.nodeName ) {
1813
-
1814
- case 'optics':
1815
- data.optics = parseCameraOptics( child );
1816
- break;
1817
-
1818
- }
1819
-
1820
- }
1821
-
1822
- library.cameras[ xml.getAttribute( 'id' ) ] = data;
1823
-
1824
- }
1825
-
1826
- function parseCameraOptics( xml ) {
1827
-
1828
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
1829
-
1830
- const child = xml.childNodes[ i ];
1831
-
1832
- switch ( child.nodeName ) {
1833
-
1834
- case 'technique_common':
1835
- return parseCameraTechnique( child );
1836
-
1837
- }
1838
-
1839
- }
1840
-
1841
- return {};
1842
-
1843
- }
1844
-
1845
- function parseCameraTechnique( xml ) {
1846
-
1847
- const data = {};
1848
-
1849
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
1850
-
1851
- const child = xml.childNodes[ i ];
1852
-
1853
- switch ( child.nodeName ) {
1854
-
1855
- case 'perspective':
1856
- case 'orthographic':
1857
-
1858
- data.technique = child.nodeName;
1859
- data.parameters = parseCameraParameters( child );
1860
-
1861
- break;
1862
-
1863
- }
1864
-
1865
- }
1866
-
1867
- return data;
1868
-
1869
- }
1870
-
1871
- function parseCameraParameters( xml ) {
1872
-
1873
- const data = {};
1874
-
1875
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
1876
-
1877
- const child = xml.childNodes[ i ];
1878
-
1879
- switch ( child.nodeName ) {
1880
-
1881
- case 'xfov':
1882
- case 'yfov':
1883
- case 'xmag':
1884
- case 'ymag':
1885
- case 'znear':
1886
- case 'zfar':
1887
- case 'aspect_ratio':
1888
- data[ child.nodeName ] = parseFloat( child.textContent );
1889
- break;
1890
-
1891
- }
1892
-
1893
- }
1894
-
1895
- return data;
1896
-
1897
- }
1898
-
1899
- function buildCamera( data ) {
1900
-
1901
- let camera;
1902
-
1903
- switch ( data.optics.technique ) {
1904
-
1905
- case 'perspective':
1906
- camera = new PerspectiveCamera(
1907
- data.optics.parameters.yfov,
1908
- data.optics.parameters.aspect_ratio,
1909
- data.optics.parameters.znear,
1910
- data.optics.parameters.zfar
1911
- );
1912
- break;
1913
-
1914
- case 'orthographic':
1915
- let ymag = data.optics.parameters.ymag;
1916
- let xmag = data.optics.parameters.xmag;
1917
- const aspectRatio = data.optics.parameters.aspect_ratio;
1918
-
1919
- xmag = ( xmag === undefined ) ? ( ymag * aspectRatio ) : xmag;
1920
- ymag = ( ymag === undefined ) ? ( xmag / aspectRatio ) : ymag;
1921
-
1922
- xmag *= 0.5;
1923
- ymag *= 0.5;
1924
-
1925
- camera = new OrthographicCamera(
1926
- - xmag, xmag, ymag, - ymag, // left, right, top, bottom
1927
- data.optics.parameters.znear,
1928
- data.optics.parameters.zfar
1929
- );
1930
- break;
1931
-
1932
- default:
1933
- camera = new PerspectiveCamera();
1934
- break;
1935
-
1936
- }
1937
-
1938
- camera.name = data.name || '';
1939
-
1940
- return camera;
1941
-
1942
- }
1943
-
1944
- function getCamera( id ) {
1945
-
1946
- const data = library.cameras[ id ];
1947
-
1948
- if ( data !== undefined ) {
1949
-
1950
- return getBuild( data, buildCamera );
1951
-
1952
- }
1953
-
1954
- console.warn( 'THREE.ColladaLoader: Couldn\'t find camera with ID:', id );
1955
-
1956
- return null;
1957
-
1958
- }
1959
-
1960
- // light
1961
-
1962
- function parseLight( xml ) {
1963
-
1964
- let data = {};
1965
-
1966
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1967
-
1968
- const child = xml.childNodes[ i ];
1969
-
1970
- if ( child.nodeType !== 1 ) continue;
1971
-
1972
- switch ( child.nodeName ) {
1973
-
1974
- case 'technique_common':
1975
- data = parseLightTechnique( child );
1976
- break;
1977
-
1978
- }
1979
-
1980
- }
1981
-
1982
- library.lights[ xml.getAttribute( 'id' ) ] = data;
1983
-
1984
- }
1985
-
1986
- function parseLightTechnique( xml ) {
1987
-
1988
- const data = {};
1989
-
1990
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
1991
-
1992
- const child = xml.childNodes[ i ];
1993
-
1994
- if ( child.nodeType !== 1 ) continue;
1995
-
1996
- switch ( child.nodeName ) {
1997
-
1998
- case 'directional':
1999
- case 'point':
2000
- case 'spot':
2001
- case 'ambient':
2002
-
2003
- data.technique = child.nodeName;
2004
- data.parameters = parseLightParameters( child );
2005
-
2006
- }
2007
-
2008
- }
2009
-
2010
- return data;
2011
-
2012
- }
2013
-
2014
- function parseLightParameters( xml ) {
2015
-
2016
- const data = {};
2017
-
2018
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
2019
-
2020
- const child = xml.childNodes[ i ];
2021
-
2022
- if ( child.nodeType !== 1 ) continue;
2023
-
2024
- switch ( child.nodeName ) {
2025
-
2026
- case 'color':
2027
- const array = parseFloats( child.textContent );
2028
- data.color = new Color().fromArray( array ).convertSRGBToLinear();
2029
- break;
2030
-
2031
- case 'falloff_angle':
2032
- data.falloffAngle = parseFloat( child.textContent );
2033
- break;
2034
-
2035
- case 'quadratic_attenuation':
2036
- const f = parseFloat( child.textContent );
2037
- data.distance = f ? Math.sqrt( 1 / f ) : 0;
2038
- break;
2039
-
2040
- }
2041
-
2042
- }
2043
-
2044
- return data;
2045
-
2046
- }
2047
-
2048
- function buildLight( data ) {
2049
-
2050
- let light;
2051
-
2052
- switch ( data.technique ) {
2053
-
2054
- case 'directional':
2055
- light = new DirectionalLight();
2056
- break;
2057
-
2058
- case 'point':
2059
- light = new PointLight();
2060
- break;
2061
-
2062
- case 'spot':
2063
- light = new SpotLight();
2064
- break;
2065
-
2066
- case 'ambient':
2067
- light = new AmbientLight();
2068
- break;
2069
-
2070
- }
2071
-
2072
- if ( data.parameters.color ) light.color.copy( data.parameters.color );
2073
- if ( data.parameters.distance ) light.distance = data.parameters.distance;
2074
-
2075
- return light;
2076
-
2077
- }
2078
-
2079
- function getLight( id ) {
2080
-
2081
- const data = library.lights[ id ];
2082
-
2083
- if ( data !== undefined ) {
2084
-
2085
- return getBuild( data, buildLight );
2086
-
2087
- }
2088
-
2089
- console.warn( 'THREE.ColladaLoader: Couldn\'t find light with ID:', id );
2090
-
2091
- return null;
2092
-
2093
- }
2094
-
2095
- // geometry
2096
-
2097
- function parseGeometry( xml ) {
2098
-
2099
- const data = {
2100
- name: xml.getAttribute( 'name' ),
2101
- sources: {},
2102
- vertices: {},
2103
- primitives: []
2104
- };
2105
-
2106
- const mesh = getElementsByTagName( xml, 'mesh' )[ 0 ];
2107
-
2108
- // the following tags inside geometry are not supported yet (see https://github.com/mrdoob/three.js/pull/12606): convex_mesh, spline, brep
2109
- if ( mesh === undefined ) return;
2110
-
2111
- for ( let i = 0; i < mesh.childNodes.length; i ++ ) {
2112
-
2113
- const child = mesh.childNodes[ i ];
2114
-
2115
- if ( child.nodeType !== 1 ) continue;
2116
-
2117
- const id = child.getAttribute( 'id' );
2118
-
2119
- switch ( child.nodeName ) {
2120
-
2121
- case 'source':
2122
- data.sources[ id ] = parseSource( child );
2123
- break;
2124
-
2125
- case 'vertices':
2126
- // data.sources[ id ] = data.sources[ parseId( getElementsByTagName( child, 'input' )[ 0 ].getAttribute( 'source' ) ) ];
2127
- data.vertices = parseGeometryVertices( child );
2128
- break;
2129
-
2130
- case 'polygons':
2131
- console.warn( 'THREE.ColladaLoader: Unsupported primitive type: ', child.nodeName );
2132
- break;
2133
-
2134
- case 'lines':
2135
- case 'linestrips':
2136
- case 'polylist':
2137
- case 'triangles':
2138
- data.primitives.push( parseGeometryPrimitive( child ) );
2139
- break;
2140
-
2141
- default:
2142
- console.log( child );
2143
-
2144
- }
2145
-
2146
- }
2147
-
2148
- library.geometries[ xml.getAttribute( 'id' ) ] = data;
2149
-
2150
- }
2151
-
2152
- function parseSource( xml ) {
2153
-
2154
- const data = {
2155
- array: [],
2156
- stride: 3
2157
- };
2158
-
2159
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2160
-
2161
- const child = xml.childNodes[ i ];
2162
-
2163
- if ( child.nodeType !== 1 ) continue;
2164
-
2165
- switch ( child.nodeName ) {
2166
-
2167
- case 'float_array':
2168
- data.array = parseFloats( child.textContent );
2169
- break;
2170
-
2171
- case 'Name_array':
2172
- data.array = parseStrings( child.textContent );
2173
- break;
2174
-
2175
- case 'technique_common':
2176
- const accessor = getElementsByTagName( child, 'accessor' )[ 0 ];
2177
-
2178
- if ( accessor !== undefined ) {
2179
-
2180
- data.stride = parseInt( accessor.getAttribute( 'stride' ) );
2181
-
2182
- }
2183
-
2184
- break;
2185
-
2186
- }
2187
-
2188
- }
2189
-
2190
- return data;
2191
-
2192
- }
2193
-
2194
- function parseGeometryVertices( xml ) {
2195
-
2196
- const data = {};
2197
-
2198
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2199
-
2200
- const child = xml.childNodes[ i ];
2201
-
2202
- if ( child.nodeType !== 1 ) continue;
2203
-
2204
- data[ child.getAttribute( 'semantic' ) ] = parseId( child.getAttribute( 'source' ) );
2205
-
2206
- }
2207
-
2208
- return data;
2209
-
2210
- }
2211
-
2212
- function parseGeometryPrimitive( xml ) {
2213
-
2214
- const primitive = {
2215
- type: xml.nodeName,
2216
- material: xml.getAttribute( 'material' ),
2217
- count: parseInt( xml.getAttribute( 'count' ) ),
2218
- inputs: {},
2219
- stride: 0,
2220
- hasUV: false
2221
- };
2222
-
2223
- for ( let i = 0, l = xml.childNodes.length; i < l; i ++ ) {
2224
-
2225
- const child = xml.childNodes[ i ];
2226
-
2227
- if ( child.nodeType !== 1 ) continue;
2228
-
2229
- switch ( child.nodeName ) {
2230
-
2231
- case 'input':
2232
- const id = parseId( child.getAttribute( 'source' ) );
2233
- const semantic = child.getAttribute( 'semantic' );
2234
- const offset = parseInt( child.getAttribute( 'offset' ) );
2235
- const set = parseInt( child.getAttribute( 'set' ) );
2236
- const inputname = ( set > 0 ? semantic + set : semantic );
2237
- primitive.inputs[ inputname ] = { id: id, offset: offset };
2238
- primitive.stride = Math.max( primitive.stride, offset + 1 );
2239
- if ( semantic === 'TEXCOORD' ) primitive.hasUV = true;
2240
- break;
2241
-
2242
- case 'vcount':
2243
- primitive.vcount = parseInts( child.textContent );
2244
- break;
2245
-
2246
- case 'p':
2247
- primitive.p = parseInts( child.textContent );
2248
- break;
2249
-
2250
- }
2251
-
2252
- }
2253
-
2254
- return primitive;
2255
-
2256
- }
2257
-
2258
- function groupPrimitives( primitives ) {
2259
-
2260
- const build = {};
2261
-
2262
- for ( let i = 0; i < primitives.length; i ++ ) {
2263
-
2264
- const primitive = primitives[ i ];
2265
-
2266
- if ( build[ primitive.type ] === undefined ) build[ primitive.type ] = [];
2267
-
2268
- build[ primitive.type ].push( primitive );
2269
-
2270
- }
2271
-
2272
- return build;
2273
-
2274
- }
2275
-
2276
- function checkUVCoordinates( primitives ) {
2277
-
2278
- let count = 0;
2279
-
2280
- for ( let i = 0, l = primitives.length; i < l; i ++ ) {
2281
-
2282
- const primitive = primitives[ i ];
2283
-
2284
- if ( primitive.hasUV === true ) {
2285
-
2286
- count ++;
2287
-
2288
- }
2289
-
2290
- }
2291
-
2292
- if ( count > 0 && count < primitives.length ) {
2293
-
2294
- primitives.uvsNeedsFix = true;
2295
-
2296
- }
2297
-
2298
- }
2299
-
2300
- function buildGeometry( data ) {
2301
-
2302
- const build = {};
2303
-
2304
- const sources = data.sources;
2305
- const vertices = data.vertices;
2306
- const primitives = data.primitives;
2307
-
2308
- if ( primitives.length === 0 ) return {};
2309
-
2310
- // our goal is to create one buffer geometry for a single type of primitives
2311
- // first, we group all primitives by their type
2312
-
2313
- const groupedPrimitives = groupPrimitives( primitives );
2314
-
2315
- for ( const type in groupedPrimitives ) {
2316
-
2317
- const primitiveType = groupedPrimitives[ type ];
2318
-
2319
- // second, ensure consistent uv coordinates for each type of primitives (polylist,triangles or lines)
2320
-
2321
- checkUVCoordinates( primitiveType );
2322
-
2323
- // third, create a buffer geometry for each type of primitives
2324
-
2325
- build[ type ] = buildGeometryType( primitiveType, sources, vertices );
2326
-
2327
- }
2328
-
2329
- return build;
2330
-
2331
- }
2332
-
2333
- function buildGeometryType( primitives, sources, vertices ) {
2334
-
2335
- const build = {};
2336
-
2337
- const position = { array: [], stride: 0 };
2338
- const normal = { array: [], stride: 0 };
2339
- const uv = { array: [], stride: 0 };
2340
- const uv1 = { array: [], stride: 0 };
2341
- const color = { array: [], stride: 0 };
2342
-
2343
- const skinIndex = { array: [], stride: 4 };
2344
- const skinWeight = { array: [], stride: 4 };
2345
-
2346
- const geometry = new BufferGeometry();
2347
-
2348
- const materialKeys = [];
2349
-
2350
- let start = 0;
2351
-
2352
- for ( let p = 0; p < primitives.length; p ++ ) {
2353
-
2354
- const primitive = primitives[ p ];
2355
- const inputs = primitive.inputs;
2356
-
2357
- // groups
2358
-
2359
- let count = 0;
2360
-
2361
- switch ( primitive.type ) {
2362
-
2363
- case 'lines':
2364
- case 'linestrips':
2365
- count = primitive.count * 2;
2366
- break;
2367
-
2368
- case 'triangles':
2369
- count = primitive.count * 3;
2370
- break;
2371
-
2372
- case 'polylist':
2373
-
2374
- for ( let g = 0; g < primitive.count; g ++ ) {
2375
-
2376
- const vc = primitive.vcount[ g ];
2377
-
2378
- switch ( vc ) {
2379
-
2380
- case 3:
2381
- count += 3; // single triangle
2382
- break;
2383
-
2384
- case 4:
2385
- count += 6; // quad, subdivided into two triangles
2386
- break;
2387
-
2388
- default:
2389
- count += ( vc - 2 ) * 3; // polylist with more than four vertices
2390
- break;
2391
-
2392
- }
2393
-
2394
- }
2395
-
2396
- break;
2397
-
2398
- default:
2399
- console.warn( 'THREE.ColladaLoader: Unknow primitive type:', primitive.type );
2400
-
2401
- }
2402
-
2403
- geometry.addGroup( start, count, p );
2404
- start += count;
2405
-
2406
- // material
2407
-
2408
- if ( primitive.material ) {
2409
-
2410
- materialKeys.push( primitive.material );
2411
-
2412
- }
2413
-
2414
- // geometry data
2415
-
2416
- for ( const name in inputs ) {
2417
-
2418
- const input = inputs[ name ];
2419
-
2420
- switch ( name ) {
2421
-
2422
- case 'VERTEX':
2423
- for ( const key in vertices ) {
2424
-
2425
- const id = vertices[ key ];
2426
-
2427
- switch ( key ) {
2428
-
2429
- case 'POSITION':
2430
- const prevLength = position.array.length;
2431
- buildGeometryData( primitive, sources[ id ], input.offset, position.array );
2432
- position.stride = sources[ id ].stride;
2433
-
2434
- if ( sources.skinWeights && sources.skinIndices ) {
2435
-
2436
- buildGeometryData( primitive, sources.skinIndices, input.offset, skinIndex.array );
2437
- buildGeometryData( primitive, sources.skinWeights, input.offset, skinWeight.array );
2438
-
2439
- }
2440
-
2441
- // see #3803
2442
-
2443
- if ( primitive.hasUV === false && primitives.uvsNeedsFix === true ) {
2444
-
2445
- const count = ( position.array.length - prevLength ) / position.stride;
2446
-
2447
- for ( let i = 0; i < count; i ++ ) {
2448
-
2449
- // fill missing uv coordinates
2450
-
2451
- uv.array.push( 0, 0 );
2452
-
2453
- }
2454
-
2455
- }
2456
-
2457
- break;
2458
-
2459
- case 'NORMAL':
2460
- buildGeometryData( primitive, sources[ id ], input.offset, normal.array );
2461
- normal.stride = sources[ id ].stride;
2462
- break;
2463
-
2464
- case 'COLOR':
2465
- buildGeometryData( primitive, sources[ id ], input.offset, color.array );
2466
- color.stride = sources[ id ].stride;
2467
- break;
2468
-
2469
- case 'TEXCOORD':
2470
- buildGeometryData( primitive, sources[ id ], input.offset, uv.array );
2471
- uv.stride = sources[ id ].stride;
2472
- break;
2473
-
2474
- case 'TEXCOORD1':
2475
- buildGeometryData( primitive, sources[ id ], input.offset, uv1.array );
2476
- uv.stride = sources[ id ].stride;
2477
- break;
2478
-
2479
- default:
2480
- console.warn( 'THREE.ColladaLoader: Semantic "%s" not handled in geometry build process.', key );
2481
-
2482
- }
2483
-
2484
- }
2485
-
2486
- break;
2487
-
2488
- case 'NORMAL':
2489
- buildGeometryData( primitive, sources[ input.id ], input.offset, normal.array );
2490
- normal.stride = sources[ input.id ].stride;
2491
- break;
2492
-
2493
- case 'COLOR':
2494
- buildGeometryData( primitive, sources[ input.id ], input.offset, color.array, true );
2495
- color.stride = sources[ input.id ].stride;
2496
- break;
2497
-
2498
- case 'TEXCOORD':
2499
- buildGeometryData( primitive, sources[ input.id ], input.offset, uv.array );
2500
- uv.stride = sources[ input.id ].stride;
2501
- break;
2502
-
2503
- case 'TEXCOORD1':
2504
- buildGeometryData( primitive, sources[ input.id ], input.offset, uv1.array );
2505
- uv1.stride = sources[ input.id ].stride;
2506
- break;
2507
-
2508
- }
2509
-
2510
- }
2511
-
2512
- }
2513
-
2514
- // build geometry
2515
-
2516
- if ( position.array.length > 0 ) geometry.setAttribute( 'position', new Float32BufferAttribute( position.array, position.stride ) );
2517
- if ( normal.array.length > 0 ) geometry.setAttribute( 'normal', new Float32BufferAttribute( normal.array, normal.stride ) );
2518
- if ( color.array.length > 0 ) geometry.setAttribute( 'color', new Float32BufferAttribute( color.array, color.stride ) );
2519
- if ( uv.array.length > 0 ) geometry.setAttribute( 'uv', new Float32BufferAttribute( uv.array, uv.stride ) );
2520
- if ( uv1.array.length > 0 ) geometry.setAttribute( 'uv1', new Float32BufferAttribute( uv1.array, uv1.stride ) );
2521
-
2522
- if ( skinIndex.array.length > 0 ) geometry.setAttribute( 'skinIndex', new Float32BufferAttribute( skinIndex.array, skinIndex.stride ) );
2523
- if ( skinWeight.array.length > 0 ) geometry.setAttribute( 'skinWeight', new Float32BufferAttribute( skinWeight.array, skinWeight.stride ) );
2524
-
2525
- build.data = geometry;
2526
- build.type = primitives[ 0 ].type;
2527
- build.materialKeys = materialKeys;
2528
-
2529
- return build;
2530
-
2531
- }
2532
-
2533
- function buildGeometryData( primitive, source, offset, array, isColor = false ) {
2534
-
2535
- const indices = primitive.p;
2536
- const stride = primitive.stride;
2537
- const vcount = primitive.vcount;
2538
-
2539
- function pushVector( i ) {
2540
-
2541
- let index = indices[ i + offset ] * sourceStride;
2542
- const length = index + sourceStride;
2543
-
2544
- for ( ; index < length; index ++ ) {
2545
-
2546
- array.push( sourceArray[ index ] );
2547
-
2548
- }
2549
-
2550
- if ( isColor ) {
2551
-
2552
- // convert the vertex colors from srgb to linear if present
2553
- const startIndex = array.length - sourceStride - 1;
2554
- tempColor.setRGB(
2555
- array[ startIndex + 0 ],
2556
- array[ startIndex + 1 ],
2557
- array[ startIndex + 2 ]
2558
- ).convertSRGBToLinear();
2559
-
2560
- array[ startIndex + 0 ] = tempColor.r;
2561
- array[ startIndex + 1 ] = tempColor.g;
2562
- array[ startIndex + 2 ] = tempColor.b;
2563
-
2564
- }
2565
-
2566
- }
2567
-
2568
- const sourceArray = source.array;
2569
- const sourceStride = source.stride;
2570
-
2571
- if ( primitive.vcount !== undefined ) {
2572
-
2573
- let index = 0;
2574
-
2575
- for ( let i = 0, l = vcount.length; i < l; i ++ ) {
2576
-
2577
- const count = vcount[ i ];
2578
-
2579
- if ( count === 4 ) {
2580
-
2581
- const a = index + stride * 0;
2582
- const b = index + stride * 1;
2583
- const c = index + stride * 2;
2584
- const d = index + stride * 3;
2585
-
2586
- pushVector( a ); pushVector( b ); pushVector( d );
2587
- pushVector( b ); pushVector( c ); pushVector( d );
2588
-
2589
- } else if ( count === 3 ) {
2590
-
2591
- const a = index + stride * 0;
2592
- const b = index + stride * 1;
2593
- const c = index + stride * 2;
2594
-
2595
- pushVector( a ); pushVector( b ); pushVector( c );
2596
-
2597
- } else if ( count > 4 ) {
2598
-
2599
- for ( let k = 1, kl = ( count - 2 ); k <= kl; k ++ ) {
2600
-
2601
- const a = index + stride * 0;
2602
- const b = index + stride * k;
2603
- const c = index + stride * ( k + 1 );
2604
-
2605
- pushVector( a ); pushVector( b ); pushVector( c );
2606
-
2607
- }
2608
-
2609
- }
2610
-
2611
- index += stride * count;
2612
-
2613
- }
2614
-
2615
- } else {
2616
-
2617
- for ( let i = 0, l = indices.length; i < l; i += stride ) {
2618
-
2619
- pushVector( i );
2620
-
2621
- }
2622
-
2623
- }
2624
-
2625
- }
2626
-
2627
- function getGeometry( id ) {
2628
-
2629
- return getBuild( library.geometries[ id ], buildGeometry );
2630
-
2631
- }
2632
-
2633
- // kinematics
2634
-
2635
- function parseKinematicsModel( xml ) {
2636
-
2637
- const data = {
2638
- name: xml.getAttribute( 'name' ) || '',
2639
- joints: {},
2640
- links: []
2641
- };
2642
-
2643
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2644
-
2645
- const child = xml.childNodes[ i ];
2646
-
2647
- if ( child.nodeType !== 1 ) continue;
2648
-
2649
- switch ( child.nodeName ) {
2650
-
2651
- case 'technique_common':
2652
- parseKinematicsTechniqueCommon( child, data );
2653
- break;
2654
-
2655
- }
2656
-
2657
- }
2658
-
2659
- library.kinematicsModels[ xml.getAttribute( 'id' ) ] = data;
2660
-
2661
- }
2662
-
2663
- function buildKinematicsModel( data ) {
2664
-
2665
- if ( data.build !== undefined ) return data.build;
2666
-
2667
- return data;
2668
-
2669
- }
2670
-
2671
- function getKinematicsModel( id ) {
2672
-
2673
- return getBuild( library.kinematicsModels[ id ], buildKinematicsModel );
2674
-
2675
- }
2676
-
2677
- function parseKinematicsTechniqueCommon( xml, data ) {
2678
-
2679
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2680
-
2681
- const child = xml.childNodes[ i ];
2682
-
2683
- if ( child.nodeType !== 1 ) continue;
2684
-
2685
- switch ( child.nodeName ) {
2686
-
2687
- case 'joint':
2688
- data.joints[ child.getAttribute( 'sid' ) ] = parseKinematicsJoint( child );
2689
- break;
2690
-
2691
- case 'link':
2692
- data.links.push( parseKinematicsLink( child ) );
2693
- break;
2694
-
2695
- }
2696
-
2697
- }
2698
-
2699
- }
2700
-
2701
- function parseKinematicsJoint( xml ) {
2702
-
2703
- let data;
2704
-
2705
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2706
-
2707
- const child = xml.childNodes[ i ];
2708
-
2709
- if ( child.nodeType !== 1 ) continue;
2710
-
2711
- switch ( child.nodeName ) {
2712
-
2713
- case 'prismatic':
2714
- case 'revolute':
2715
- data = parseKinematicsJointParameter( child );
2716
- break;
2717
-
2718
- }
2719
-
2720
- }
2721
-
2722
- return data;
2723
-
2724
- }
2725
-
2726
- function parseKinematicsJointParameter( xml ) {
2727
-
2728
- const data = {
2729
- sid: xml.getAttribute( 'sid' ),
2730
- name: xml.getAttribute( 'name' ) || '',
2731
- axis: new Vector3(),
2732
- limits: {
2733
- min: 0,
2734
- max: 0
2735
- },
2736
- type: xml.nodeName,
2737
- static: false,
2738
- zeroPosition: 0,
2739
- middlePosition: 0
2740
- };
2741
-
2742
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2743
-
2744
- const child = xml.childNodes[ i ];
2745
-
2746
- if ( child.nodeType !== 1 ) continue;
2747
-
2748
- switch ( child.nodeName ) {
2749
-
2750
- case 'axis':
2751
- const array = parseFloats( child.textContent );
2752
- data.axis.fromArray( array );
2753
- break;
2754
- case 'limits':
2755
- const max = child.getElementsByTagName( 'max' )[ 0 ];
2756
- const min = child.getElementsByTagName( 'min' )[ 0 ];
2757
-
2758
- data.limits.max = parseFloat( max.textContent );
2759
- data.limits.min = parseFloat( min.textContent );
2760
- break;
2761
-
2762
- }
2763
-
2764
- }
2765
-
2766
- // if min is equal to or greater than max, consider the joint static
2767
-
2768
- if ( data.limits.min >= data.limits.max ) {
2769
-
2770
- data.static = true;
2771
-
2772
- }
2773
-
2774
- // calculate middle position
2775
-
2776
- data.middlePosition = ( data.limits.min + data.limits.max ) / 2.0;
2777
-
2778
- return data;
2779
-
2780
- }
2781
-
2782
- function parseKinematicsLink( xml ) {
2783
-
2784
- const data = {
2785
- sid: xml.getAttribute( 'sid' ),
2786
- name: xml.getAttribute( 'name' ) || '',
2787
- attachments: [],
2788
- transforms: []
2789
- };
2790
-
2791
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2792
-
2793
- const child = xml.childNodes[ i ];
2794
-
2795
- if ( child.nodeType !== 1 ) continue;
2796
-
2797
- switch ( child.nodeName ) {
2798
-
2799
- case 'attachment_full':
2800
- data.attachments.push( parseKinematicsAttachment( child ) );
2801
- break;
2802
-
2803
- case 'matrix':
2804
- case 'translate':
2805
- case 'rotate':
2806
- data.transforms.push( parseKinematicsTransform( child ) );
2807
- break;
2808
-
2809
- }
2810
-
2811
- }
2812
-
2813
- return data;
2814
-
2815
- }
2816
-
2817
- function parseKinematicsAttachment( xml ) {
2818
-
2819
- const data = {
2820
- joint: xml.getAttribute( 'joint' ).split( '/' ).pop(),
2821
- transforms: [],
2822
- links: []
2823
- };
2824
-
2825
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2826
-
2827
- const child = xml.childNodes[ i ];
2828
-
2829
- if ( child.nodeType !== 1 ) continue;
2830
-
2831
- switch ( child.nodeName ) {
2832
-
2833
- case 'link':
2834
- data.links.push( parseKinematicsLink( child ) );
2835
- break;
2836
-
2837
- case 'matrix':
2838
- case 'translate':
2839
- case 'rotate':
2840
- data.transforms.push( parseKinematicsTransform( child ) );
2841
- break;
2842
-
2843
- }
2844
-
2845
- }
2846
-
2847
- return data;
2848
-
2849
- }
2850
-
2851
- function parseKinematicsTransform( xml ) {
2852
-
2853
- const data = {
2854
- type: xml.nodeName
2855
- };
2856
-
2857
- const array = parseFloats( xml.textContent );
2858
-
2859
- switch ( data.type ) {
2860
-
2861
- case 'matrix':
2862
- data.obj = new Matrix4();
2863
- data.obj.fromArray( array ).transpose();
2864
- break;
2865
-
2866
- case 'translate':
2867
- data.obj = new Vector3();
2868
- data.obj.fromArray( array );
2869
- break;
2870
-
2871
- case 'rotate':
2872
- data.obj = new Vector3();
2873
- data.obj.fromArray( array );
2874
- data.angle = MathUtils.degToRad( array[ 3 ] );
2875
- break;
2876
-
2877
- }
2878
-
2879
- return data;
2880
-
2881
- }
2882
-
2883
- // physics
2884
-
2885
- function parsePhysicsModel( xml ) {
2886
-
2887
- const data = {
2888
- name: xml.getAttribute( 'name' ) || '',
2889
- rigidBodies: {}
2890
- };
2891
-
2892
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2893
-
2894
- const child = xml.childNodes[ i ];
2895
-
2896
- if ( child.nodeType !== 1 ) continue;
2897
-
2898
- switch ( child.nodeName ) {
2899
-
2900
- case 'rigid_body':
2901
- data.rigidBodies[ child.getAttribute( 'name' ) ] = {};
2902
- parsePhysicsRigidBody( child, data.rigidBodies[ child.getAttribute( 'name' ) ] );
2903
- break;
2904
-
2905
- }
2906
-
2907
- }
2908
-
2909
- library.physicsModels[ xml.getAttribute( 'id' ) ] = data;
2910
-
2911
- }
2912
-
2913
- function parsePhysicsRigidBody( xml, data ) {
2914
-
2915
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2916
-
2917
- const child = xml.childNodes[ i ];
2918
-
2919
- if ( child.nodeType !== 1 ) continue;
2920
-
2921
- switch ( child.nodeName ) {
2922
-
2923
- case 'technique_common':
2924
- parsePhysicsTechniqueCommon( child, data );
2925
- break;
2926
-
2927
- }
2928
-
2929
- }
2930
-
2931
- }
2932
-
2933
- function parsePhysicsTechniqueCommon( xml, data ) {
2934
-
2935
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2936
-
2937
- const child = xml.childNodes[ i ];
2938
-
2939
- if ( child.nodeType !== 1 ) continue;
2940
-
2941
- switch ( child.nodeName ) {
2942
-
2943
- case 'inertia':
2944
- data.inertia = parseFloats( child.textContent );
2945
- break;
2946
-
2947
- case 'mass':
2948
- data.mass = parseFloats( child.textContent )[ 0 ];
2949
- break;
2950
-
2951
- }
2952
-
2953
- }
2954
-
2955
- }
2956
-
2957
- // scene
2958
-
2959
- function parseKinematicsScene( xml ) {
2960
-
2961
- const data = {
2962
- bindJointAxis: []
2963
- };
2964
-
2965
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2966
-
2967
- const child = xml.childNodes[ i ];
2968
-
2969
- if ( child.nodeType !== 1 ) continue;
2970
-
2971
- switch ( child.nodeName ) {
2972
-
2973
- case 'bind_joint_axis':
2974
- data.bindJointAxis.push( parseKinematicsBindJointAxis( child ) );
2975
- break;
2976
-
2977
- }
2978
-
2979
- }
2980
-
2981
- library.kinematicsScenes[ parseId( xml.getAttribute( 'url' ) ) ] = data;
2982
-
2983
- }
2984
-
2985
- function parseKinematicsBindJointAxis( xml ) {
2986
-
2987
- const data = {
2988
- target: xml.getAttribute( 'target' ).split( '/' ).pop()
2989
- };
2990
-
2991
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
2992
-
2993
- const child = xml.childNodes[ i ];
2994
-
2995
- if ( child.nodeType !== 1 ) continue;
2996
-
2997
- switch ( child.nodeName ) {
2998
-
2999
- case 'axis':
3000
- const param = child.getElementsByTagName( 'param' )[ 0 ];
3001
- data.axis = param.textContent;
3002
- const tmpJointIndex = data.axis.split( 'inst_' ).pop().split( 'axis' )[ 0 ];
3003
- data.jointIndex = tmpJointIndex.substring( 0, tmpJointIndex.length - 1 );
3004
- break;
3005
-
3006
- }
3007
-
3008
- }
3009
-
3010
- return data;
3011
-
3012
- }
3013
-
3014
- function buildKinematicsScene( data ) {
3015
-
3016
- if ( data.build !== undefined ) return data.build;
3017
-
3018
- return data;
3019
-
3020
- }
3021
-
3022
- function getKinematicsScene( id ) {
3023
-
3024
- return getBuild( library.kinematicsScenes[ id ], buildKinematicsScene );
3025
-
3026
- }
3027
-
3028
- function setupKinematics() {
3029
-
3030
- const kinematicsModelId = Object.keys( library.kinematicsModels )[ 0 ];
3031
- const kinematicsSceneId = Object.keys( library.kinematicsScenes )[ 0 ];
3032
- const visualSceneId = Object.keys( library.visualScenes )[ 0 ];
3033
-
3034
- if ( kinematicsModelId === undefined || kinematicsSceneId === undefined ) return;
3035
-
3036
- const kinematicsModel = getKinematicsModel( kinematicsModelId );
3037
- const kinematicsScene = getKinematicsScene( kinematicsSceneId );
3038
- const visualScene = getVisualScene( visualSceneId );
3039
-
3040
- const bindJointAxis = kinematicsScene.bindJointAxis;
3041
- const jointMap = {};
3042
-
3043
- for ( let i = 0, l = bindJointAxis.length; i < l; i ++ ) {
3044
-
3045
- const axis = bindJointAxis[ i ];
3046
-
3047
- // the result of the following query is an element of type 'translate', 'rotate','scale' or 'matrix'
3048
-
3049
- const targetElement = collada.querySelector( '[sid="' + axis.target + '"]' );
3050
-
3051
- if ( targetElement ) {
3052
-
3053
- // get the parent of the transform element
3054
-
3055
- const parentVisualElement = targetElement.parentElement;
3056
-
3057
- // connect the joint of the kinematics model with the element in the visual scene
3058
-
3059
- connect( axis.jointIndex, parentVisualElement );
3060
-
3061
- }
3062
-
3063
- }
3064
-
3065
- function connect( jointIndex, visualElement ) {
3066
-
3067
- const visualElementName = visualElement.getAttribute( 'name' );
3068
- const joint = kinematicsModel.joints[ jointIndex ];
3069
-
3070
- visualScene.traverse( function ( object ) {
3071
-
3072
- if ( object.name === visualElementName ) {
3073
-
3074
- jointMap[ jointIndex ] = {
3075
- object: object,
3076
- transforms: buildTransformList( visualElement ),
3077
- joint: joint,
3078
- position: joint.zeroPosition
3079
- };
3080
-
3081
- }
3082
-
3083
- } );
3084
-
3085
- }
3086
-
3087
- const m0 = new Matrix4();
3088
-
3089
- kinematics = {
3090
-
3091
- joints: kinematicsModel && kinematicsModel.joints,
3092
-
3093
- getJointValue: function ( jointIndex ) {
3094
-
3095
- const jointData = jointMap[ jointIndex ];
3096
-
3097
- if ( jointData ) {
3098
-
3099
- return jointData.position;
3100
-
3101
- } else {
3102
-
3103
- console.warn( 'THREE.ColladaLoader: Joint ' + jointIndex + ' doesn\'t exist.' );
3104
-
3105
- }
3106
-
3107
- },
3108
-
3109
- setJointValue: function ( jointIndex, value ) {
3110
-
3111
- const jointData = jointMap[ jointIndex ];
3112
-
3113
- if ( jointData ) {
3114
-
3115
- const joint = jointData.joint;
3116
-
3117
- if ( value > joint.limits.max || value < joint.limits.min ) {
3118
-
3119
- console.warn( 'THREE.ColladaLoader: Joint ' + jointIndex + ' value ' + value + ' outside of limits (min: ' + joint.limits.min + ', max: ' + joint.limits.max + ').' );
3120
-
3121
- } else if ( joint.static ) {
3122
-
3123
- console.warn( 'THREE.ColladaLoader: Joint ' + jointIndex + ' is static.' );
3124
-
3125
- } else {
3126
-
3127
- const object = jointData.object;
3128
- const axis = joint.axis;
3129
- const transforms = jointData.transforms;
3130
-
3131
- matrix.identity();
3132
-
3133
- // each update, we have to apply all transforms in the correct order
3134
-
3135
- for ( let i = 0; i < transforms.length; i ++ ) {
3136
-
3137
- const transform = transforms[ i ];
3138
-
3139
- // if there is a connection of the transform node with a joint, apply the joint value
3140
-
3141
- if ( transform.sid && transform.sid.indexOf( jointIndex ) !== - 1 ) {
3142
-
3143
- switch ( joint.type ) {
3144
-
3145
- case 'revolute':
3146
- matrix.multiply( m0.makeRotationAxis( axis, MathUtils.degToRad( value ) ) );
3147
- break;
3148
-
3149
- case 'prismatic':
3150
- matrix.multiply( m0.makeTranslation( axis.x * value, axis.y * value, axis.z * value ) );
3151
- break;
3152
-
3153
- default:
3154
- console.warn( 'THREE.ColladaLoader: Unknown joint type: ' + joint.type );
3155
- break;
3156
-
3157
- }
3158
-
3159
- } else {
3160
-
3161
- switch ( transform.type ) {
3162
-
3163
- case 'matrix':
3164
- matrix.multiply( transform.obj );
3165
- break;
3166
-
3167
- case 'translate':
3168
- matrix.multiply( m0.makeTranslation( transform.obj.x, transform.obj.y, transform.obj.z ) );
3169
- break;
3170
-
3171
- case 'scale':
3172
- matrix.scale( transform.obj );
3173
- break;
3174
-
3175
- case 'rotate':
3176
- matrix.multiply( m0.makeRotationAxis( transform.obj, transform.angle ) );
3177
- break;
3178
-
3179
- }
3180
-
3181
- }
3182
-
3183
- }
3184
-
3185
- object.matrix.copy( matrix );
3186
- object.matrix.decompose( object.position, object.quaternion, object.scale );
3187
-
3188
- jointMap[ jointIndex ].position = value;
3189
-
3190
- }
3191
-
3192
- } else {
3193
-
3194
- console.log( 'THREE.ColladaLoader: ' + jointIndex + ' does not exist.' );
3195
-
3196
- }
3197
-
3198
- }
3199
-
3200
- };
3201
-
3202
- }
3203
-
3204
- function buildTransformList( node ) {
3205
-
3206
- const transforms = [];
3207
-
3208
- const xml = collada.querySelector( '[id="' + node.id + '"]' );
3209
-
3210
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
3211
-
3212
- const child = xml.childNodes[ i ];
3213
-
3214
- if ( child.nodeType !== 1 ) continue;
3215
-
3216
- let array, vector;
3217
-
3218
- switch ( child.nodeName ) {
3219
-
3220
- case 'matrix':
3221
- array = parseFloats( child.textContent );
3222
- const matrix = new Matrix4().fromArray( array ).transpose();
3223
- transforms.push( {
3224
- sid: child.getAttribute( 'sid' ),
3225
- type: child.nodeName,
3226
- obj: matrix
3227
- } );
3228
- break;
3229
-
3230
- case 'translate':
3231
- case 'scale':
3232
- array = parseFloats( child.textContent );
3233
- vector = new Vector3().fromArray( array );
3234
- transforms.push( {
3235
- sid: child.getAttribute( 'sid' ),
3236
- type: child.nodeName,
3237
- obj: vector
3238
- } );
3239
- break;
3240
-
3241
- case 'rotate':
3242
- array = parseFloats( child.textContent );
3243
- vector = new Vector3().fromArray( array );
3244
- const angle = MathUtils.degToRad( array[ 3 ] );
3245
- transforms.push( {
3246
- sid: child.getAttribute( 'sid' ),
3247
- type: child.nodeName,
3248
- obj: vector,
3249
- angle: angle
3250
- } );
3251
- break;
3252
-
3253
- }
3254
-
3255
- }
3256
-
3257
- return transforms;
3258
-
3259
- }
3260
-
3261
- // nodes
3262
-
3263
- function prepareNodes( xml ) {
3264
-
3265
- const elements = xml.getElementsByTagName( 'node' );
3266
-
3267
- // ensure all node elements have id attributes
3268
-
3269
- for ( let i = 0; i < elements.length; i ++ ) {
3270
-
3271
- const element = elements[ i ];
3272
-
3273
- if ( element.hasAttribute( 'id' ) === false ) {
3274
-
3275
- element.setAttribute( 'id', generateId() );
3276
-
3277
- }
3278
-
3279
- }
3280
-
3281
- }
3282
-
3283
- const matrix = new Matrix4();
3284
- const vector = new Vector3();
3285
-
3286
- function parseNode( xml ) {
3287
-
3288
- const data = {
3289
- name: xml.getAttribute( 'name' ) || '',
3290
- type: xml.getAttribute( 'type' ),
3291
- id: xml.getAttribute( 'id' ),
3292
- sid: xml.getAttribute( 'sid' ),
3293
- matrix: new Matrix4(),
3294
- nodes: [],
3295
- instanceCameras: [],
3296
- instanceControllers: [],
3297
- instanceLights: [],
3298
- instanceGeometries: [],
3299
- instanceNodes: [],
3300
- transforms: {}
3301
- };
3302
-
3303
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
3304
-
3305
- const child = xml.childNodes[ i ];
3306
-
3307
- if ( child.nodeType !== 1 ) continue;
3308
-
3309
- let array;
3310
-
3311
- switch ( child.nodeName ) {
3312
-
3313
- case 'node':
3314
- data.nodes.push( child.getAttribute( 'id' ) );
3315
- parseNode( child );
3316
- break;
3317
-
3318
- case 'instance_camera':
3319
- data.instanceCameras.push( parseId( child.getAttribute( 'url' ) ) );
3320
- break;
3321
-
3322
- case 'instance_controller':
3323
- data.instanceControllers.push( parseNodeInstance( child ) );
3324
- break;
3325
-
3326
- case 'instance_light':
3327
- data.instanceLights.push( parseId( child.getAttribute( 'url' ) ) );
3328
- break;
3329
-
3330
- case 'instance_geometry':
3331
- data.instanceGeometries.push( parseNodeInstance( child ) );
3332
- break;
3333
-
3334
- case 'instance_node':
3335
- data.instanceNodes.push( parseId( child.getAttribute( 'url' ) ) );
3336
- break;
3337
-
3338
- case 'matrix':
3339
- array = parseFloats( child.textContent );
3340
- data.matrix.multiply( matrix.fromArray( array ).transpose() );
3341
- data.transforms[ child.getAttribute( 'sid' ) ] = child.nodeName;
3342
- break;
3343
-
3344
- case 'translate':
3345
- array = parseFloats( child.textContent );
3346
- vector.fromArray( array );
3347
- data.matrix.multiply( matrix.makeTranslation( vector.x, vector.y, vector.z ) );
3348
- data.transforms[ child.getAttribute( 'sid' ) ] = child.nodeName;
3349
- break;
3350
-
3351
- case 'rotate':
3352
- array = parseFloats( child.textContent );
3353
- const angle = MathUtils.degToRad( array[ 3 ] );
3354
- data.matrix.multiply( matrix.makeRotationAxis( vector.fromArray( array ), angle ) );
3355
- data.transforms[ child.getAttribute( 'sid' ) ] = child.nodeName;
3356
- break;
3357
-
3358
- case 'scale':
3359
- array = parseFloats( child.textContent );
3360
- data.matrix.scale( vector.fromArray( array ) );
3361
- data.transforms[ child.getAttribute( 'sid' ) ] = child.nodeName;
3362
- break;
3363
-
3364
- case 'extra':
3365
- break;
3366
-
3367
- default:
3368
- console.log( child );
3369
-
3370
- }
3371
-
3372
- }
3373
-
3374
- if ( hasNode( data.id ) ) {
3375
-
3376
- console.warn( 'THREE.ColladaLoader: There is already a node with ID %s. Exclude current node from further processing.', data.id );
3377
-
3378
- } else {
3379
-
3380
- library.nodes[ data.id ] = data;
3381
-
3382
- }
3383
-
3384
- return data;
3385
-
3386
- }
3387
-
3388
- function parseNodeInstance( xml ) {
3389
-
3390
- const data = {
3391
- id: parseId( xml.getAttribute( 'url' ) ),
3392
- materials: {},
3393
- skeletons: []
3394
- };
3395
-
3396
- for ( let i = 0; i < xml.childNodes.length; i ++ ) {
3397
-
3398
- const child = xml.childNodes[ i ];
3399
-
3400
- switch ( child.nodeName ) {
3401
-
3402
- case 'bind_material':
3403
- const instances = child.getElementsByTagName( 'instance_material' );
3404
-
3405
- for ( let j = 0; j < instances.length; j ++ ) {
3406
-
3407
- const instance = instances[ j ];
3408
- const symbol = instance.getAttribute( 'symbol' );
3409
- const target = instance.getAttribute( 'target' );
3410
-
3411
- data.materials[ symbol ] = parseId( target );
3412
-
3413
- }
3414
-
3415
- break;
3416
-
3417
- case 'skeleton':
3418
- data.skeletons.push( parseId( child.textContent ) );
3419
- break;
3420
-
3421
- default:
3422
- break;
3423
-
3424
- }
3425
-
3426
- }
3427
-
3428
- return data;
3429
-
3430
- }
3431
-
3432
- function buildSkeleton( skeletons, joints ) {
3433
-
3434
- const boneData = [];
3435
- const sortedBoneData = [];
3436
-
3437
- let i, j, data;
3438
-
3439
- // a skeleton can have multiple root bones. collada expresses this
3440
- // situtation with multiple "skeleton" tags per controller instance
3441
-
3442
- for ( i = 0; i < skeletons.length; i ++ ) {
3443
-
3444
- const skeleton = skeletons[ i ];
3445
-
3446
- let root;
3447
-
3448
- if ( hasNode( skeleton ) ) {
3449
-
3450
- root = getNode( skeleton );
3451
- buildBoneHierarchy( root, joints, boneData );
3452
-
3453
- } else if ( hasVisualScene( skeleton ) ) {
3454
-
3455
- // handle case where the skeleton refers to the visual scene (#13335)
3456
-
3457
- const visualScene = library.visualScenes[ skeleton ];
3458
- const children = visualScene.children;
3459
-
3460
- for ( let j = 0; j < children.length; j ++ ) {
3461
-
3462
- const child = children[ j ];
3463
-
3464
- if ( child.type === 'JOINT' ) {
3465
-
3466
- const root = getNode( child.id );
3467
- buildBoneHierarchy( root, joints, boneData );
3468
-
3469
- }
3470
-
3471
- }
3472
-
3473
- } else {
3474
-
3475
- console.error( 'THREE.ColladaLoader: Unable to find root bone of skeleton with ID:', skeleton );
3476
-
3477
- }
3478
-
3479
- }
3480
-
3481
- // sort bone data (the order is defined in the corresponding controller)
3482
-
3483
- for ( i = 0; i < joints.length; i ++ ) {
3484
-
3485
- for ( j = 0; j < boneData.length; j ++ ) {
3486
-
3487
- data = boneData[ j ];
3488
-
3489
- if ( data.bone.name === joints[ i ].name ) {
3490
-
3491
- sortedBoneData[ i ] = data;
3492
- data.processed = true;
3493
- break;
3494
-
3495
- }
3496
-
3497
- }
3498
-
3499
- }
3500
-
3501
- // add unprocessed bone data at the end of the list
3502
-
3503
- for ( i = 0; i < boneData.length; i ++ ) {
3504
-
3505
- data = boneData[ i ];
3506
-
3507
- if ( data.processed === false ) {
3508
-
3509
- sortedBoneData.push( data );
3510
- data.processed = true;
3511
-
3512
- }
3513
-
3514
- }
3515
-
3516
- // setup arrays for skeleton creation
3517
-
3518
- const bones = [];
3519
- const boneInverses = [];
3520
-
3521
- for ( i = 0; i < sortedBoneData.length; i ++ ) {
3522
-
3523
- data = sortedBoneData[ i ];
3524
-
3525
- bones.push( data.bone );
3526
- boneInverses.push( data.boneInverse );
3527
-
3528
- }
3529
-
3530
- return new Skeleton( bones, boneInverses );
3531
-
3532
- }
3533
-
3534
- function buildBoneHierarchy( root, joints, boneData ) {
3535
-
3536
- // setup bone data from visual scene
3537
-
3538
- root.traverse( function ( object ) {
3539
-
3540
- if ( object.isBone === true ) {
3541
-
3542
- let boneInverse;
3543
-
3544
- // retrieve the boneInverse from the controller data
3545
-
3546
- for ( let i = 0; i < joints.length; i ++ ) {
3547
-
3548
- const joint = joints[ i ];
3549
-
3550
- if ( joint.name === object.name ) {
3551
-
3552
- boneInverse = joint.boneInverse;
3553
- break;
3554
-
3555
- }
3556
-
3557
- }
3558
-
3559
- if ( boneInverse === undefined ) {
3560
-
3561
- // Unfortunately, there can be joints in the visual scene that are not part of the
3562
- // corresponding controller. In this case, we have to create a dummy boneInverse matrix
3563
- // for the respective bone. This bone won't affect any vertices, because there are no skin indices
3564
- // and weights defined for it. But we still have to add the bone to the sorted bone list in order to
3565
- // ensure a correct animation of the model.
3566
-
3567
- boneInverse = new Matrix4();
3568
-
3569
- }
3570
-
3571
- boneData.push( { bone: object, boneInverse: boneInverse, processed: false } );
3572
-
3573
- }
3574
-
3575
- } );
3576
-
3577
- }
3578
-
3579
- function buildNode( data ) {
3580
-
3581
- const objects = [];
3582
-
3583
- const matrix = data.matrix;
3584
- const nodes = data.nodes;
3585
- const type = data.type;
3586
- const instanceCameras = data.instanceCameras;
3587
- const instanceControllers = data.instanceControllers;
3588
- const instanceLights = data.instanceLights;
3589
- const instanceGeometries = data.instanceGeometries;
3590
- const instanceNodes = data.instanceNodes;
3591
-
3592
- // nodes
3593
-
3594
- for ( let i = 0, l = nodes.length; i < l; i ++ ) {
3595
-
3596
- objects.push( getNode( nodes[ i ] ) );
3597
-
3598
- }
3599
-
3600
- // instance cameras
3601
-
3602
- for ( let i = 0, l = instanceCameras.length; i < l; i ++ ) {
3603
-
3604
- const instanceCamera = getCamera( instanceCameras[ i ] );
3605
-
3606
- if ( instanceCamera !== null ) {
3607
-
3608
- objects.push( instanceCamera.clone() );
3609
-
3610
- }
3611
-
3612
- }
3613
-
3614
- // instance controllers
3615
-
3616
- for ( let i = 0, l = instanceControllers.length; i < l; i ++ ) {
3617
-
3618
- const instance = instanceControllers[ i ];
3619
- const controller = getController( instance.id );
3620
- const geometries = getGeometry( controller.id );
3621
- const newObjects = buildObjects( geometries, instance.materials );
3622
-
3623
- const skeletons = instance.skeletons;
3624
- const joints = controller.skin.joints;
3625
-
3626
- const skeleton = buildSkeleton( skeletons, joints );
3627
-
3628
- for ( let j = 0, jl = newObjects.length; j < jl; j ++ ) {
3629
-
3630
- const object = newObjects[ j ];
3631
-
3632
- if ( object.isSkinnedMesh ) {
3633
-
3634
- object.bind( skeleton, controller.skin.bindMatrix );
3635
- object.normalizeSkinWeights();
3636
-
3637
- }
3638
-
3639
- objects.push( object );
3640
-
3641
- }
3642
-
3643
- }
3644
-
3645
- // instance lights
3646
-
3647
- for ( let i = 0, l = instanceLights.length; i < l; i ++ ) {
3648
-
3649
- const instanceLight = getLight( instanceLights[ i ] );
3650
-
3651
- if ( instanceLight !== null ) {
3652
-
3653
- objects.push( instanceLight.clone() );
3654
-
3655
- }
3656
-
3657
- }
3658
-
3659
- // instance geometries
3660
-
3661
- for ( let i = 0, l = instanceGeometries.length; i < l; i ++ ) {
3662
-
3663
- const instance = instanceGeometries[ i ];
3664
-
3665
- // a single geometry instance in collada can lead to multiple object3Ds.
3666
- // this is the case when primitives are combined like triangles and lines
3667
-
3668
- const geometries = getGeometry( instance.id );
3669
- const newObjects = buildObjects( geometries, instance.materials );
3670
-
3671
- for ( let j = 0, jl = newObjects.length; j < jl; j ++ ) {
3672
-
3673
- objects.push( newObjects[ j ] );
3674
-
3675
- }
3676
-
3677
- }
3678
-
3679
- // instance nodes
3680
-
3681
- for ( let i = 0, l = instanceNodes.length; i < l; i ++ ) {
3682
-
3683
- objects.push( getNode( instanceNodes[ i ] ).clone() );
3684
-
3685
- }
3686
-
3687
- let object;
3688
-
3689
- if ( nodes.length === 0 && objects.length === 1 ) {
3690
-
3691
- object = objects[ 0 ];
3692
-
3693
- } else {
3694
-
3695
- object = ( type === 'JOINT' ) ? new Bone() : new Group();
3696
-
3697
- for ( let i = 0; i < objects.length; i ++ ) {
3698
-
3699
- object.add( objects[ i ] );
3700
-
3701
- }
3702
-
3703
- }
3704
-
3705
- object.name = ( type === 'JOINT' ) ? data.sid : data.name;
3706
- object.matrix.copy( matrix );
3707
- object.matrix.decompose( object.position, object.quaternion, object.scale );
3708
-
3709
- return object;
3710
-
3711
- }
3712
-
3713
- const fallbackMaterial = new MeshBasicMaterial( {
3714
- name: Loader.DEFAULT_MATERIAL_NAME,
3715
- color: 0xff00ff
3716
- } );
3717
-
3718
- function resolveMaterialBinding( keys, instanceMaterials ) {
3719
-
3720
- const materials = [];
3721
-
3722
- for ( let i = 0, l = keys.length; i < l; i ++ ) {
3723
-
3724
- const id = instanceMaterials[ keys[ i ] ];
3725
-
3726
- if ( id === undefined ) {
3727
-
3728
- console.warn( 'THREE.ColladaLoader: Material with key %s not found. Apply fallback material.', keys[ i ] );
3729
- materials.push( fallbackMaterial );
3730
-
3731
- } else {
3732
-
3733
- materials.push( getMaterial( id ) );
3734
-
3735
- }
3736
-
3737
- }
3738
-
3739
- return materials;
3740
-
3741
- }
3742
-
3743
- function buildObjects( geometries, instanceMaterials ) {
3744
-
3745
- const objects = [];
3746
-
3747
- for ( const type in geometries ) {
3748
-
3749
- const geometry = geometries[ type ];
3750
-
3751
- const materials = resolveMaterialBinding( geometry.materialKeys, instanceMaterials );
3752
-
3753
- // handle case if no materials are defined
3754
-
3755
- if ( materials.length === 0 ) {
3756
-
3757
- if ( type === 'lines' || type === 'linestrips' ) {
3758
-
3759
- materials.push( new LineBasicMaterial() );
3760
-
3761
- } else {
3762
-
3763
- materials.push( new MeshPhongMaterial() );
3764
-
3765
- }
3766
-
3767
- }
3768
-
3769
- // Collada allows to use phong and lambert materials with lines. Replacing these cases with LineBasicMaterial.
3770
-
3771
- if ( type === 'lines' || type === 'linestrips' ) {
3772
-
3773
- for ( let i = 0, l = materials.length; i < l; i ++ ) {
3774
-
3775
- const material = materials[ i ];
3776
-
3777
- if ( material.isMeshPhongMaterial === true || material.isMeshLambertMaterial === true ) {
3778
-
3779
- const lineMaterial = new LineBasicMaterial();
3780
-
3781
- // copy compatible properties
3782
-
3783
- lineMaterial.color.copy( material.color );
3784
- lineMaterial.opacity = material.opacity;
3785
- lineMaterial.transparent = material.transparent;
3786
-
3787
- // replace material
3788
-
3789
- materials[ i ] = lineMaterial;
3790
-
3791
- }
3792
-
3793
- }
3794
-
3795
- }
3796
-
3797
- // regard skinning
3798
-
3799
- const skinning = ( geometry.data.attributes.skinIndex !== undefined );
3800
-
3801
- // choose between a single or multi materials (material array)
3802
-
3803
- const material = ( materials.length === 1 ) ? materials[ 0 ] : materials;
3804
-
3805
- // now create a specific 3D object
3806
-
3807
- let object;
3808
-
3809
- switch ( type ) {
3810
-
3811
- case 'lines':
3812
- object = new LineSegments( geometry.data, material );
3813
- break;
3814
-
3815
- case 'linestrips':
3816
- object = new Line( geometry.data, material );
3817
- break;
3818
-
3819
- case 'triangles':
3820
- case 'polylist':
3821
- if ( skinning ) {
3822
-
3823
- object = new SkinnedMesh( geometry.data, material );
3824
-
3825
- } else {
3826
-
3827
- object = new Mesh( geometry.data, material );
3828
-
3829
- }
3830
-
3831
- break;
3832
-
3833
- }
3834
-
3835
- objects.push( object );
3836
-
3837
- }
3838
-
3839
- return objects;
3840
-
3841
- }
3842
-
3843
- function hasNode( id ) {
3844
-
3845
- return library.nodes[ id ] !== undefined;
3846
-
3847
- }
3848
-
3849
- function getNode( id ) {
3850
-
3851
- return getBuild( library.nodes[ id ], buildNode );
3852
-
3853
- }
3854
-
3855
- // visual scenes
3856
-
3857
- function parseVisualScene( xml ) {
3858
-
3859
- const data = {
3860
- name: xml.getAttribute( 'name' ),
3861
- children: []
3862
- };
3863
-
3864
- prepareNodes( xml );
3865
-
3866
- const elements = getElementsByTagName( xml, 'node' );
3867
-
3868
- for ( let i = 0; i < elements.length; i ++ ) {
3869
-
3870
- data.children.push( parseNode( elements[ i ] ) );
3871
-
3872
- }
3873
-
3874
- library.visualScenes[ xml.getAttribute( 'id' ) ] = data;
3875
-
3876
- }
3877
-
3878
- function buildVisualScene( data ) {
3879
-
3880
- const group = new Group();
3881
- group.name = data.name;
3882
-
3883
- const children = data.children;
3884
-
3885
- for ( let i = 0; i < children.length; i ++ ) {
3886
-
3887
- const child = children[ i ];
3888
-
3889
- group.add( getNode( child.id ) );
3890
-
3891
- }
3892
-
3893
- return group;
3894
-
3895
- }
3896
-
3897
- function hasVisualScene( id ) {
3898
-
3899
- return library.visualScenes[ id ] !== undefined;
3900
-
3901
- }
3902
-
3903
- function getVisualScene( id ) {
3904
-
3905
- return getBuild( library.visualScenes[ id ], buildVisualScene );
3906
-
3907
- }
3908
-
3909
- // scenes
3910
-
3911
- function parseScene( xml ) {
3912
-
3913
- const instance = getElementsByTagName( xml, 'instance_visual_scene' )[ 0 ];
3914
- return getVisualScene( parseId( instance.getAttribute( 'url' ) ) );
3915
-
3916
- }
3917
-
3918
- function setupAnimations() {
3919
-
3920
- const clips = library.clips;
3921
-
3922
- if ( isEmpty( clips ) === true ) {
3923
-
3924
- if ( isEmpty( library.animations ) === false ) {
3925
-
3926
- // if there are animations but no clips, we create a default clip for playback
3927
-
3928
- const tracks = [];
3929
-
3930
- for ( const id in library.animations ) {
3931
-
3932
- const animationTracks = getAnimation( id );
3933
-
3934
- for ( let i = 0, l = animationTracks.length; i < l; i ++ ) {
3935
-
3936
- tracks.push( animationTracks[ i ] );
3937
-
3938
- }
3939
-
3940
- }
3941
-
3942
- animations.push( new AnimationClip( 'default', - 1, tracks ) );
3943
-
3944
- }
3945
-
3946
- } else {
3947
-
3948
- for ( const id in clips ) {
3949
-
3950
- animations.push( getAnimationClip( id ) );
3951
-
3952
- }
3953
-
3954
- }
3955
-
3956
- }
3957
-
3958
- // convert the parser error element into text with each child elements text
3959
- // separated by new lines.
3960
-
3961
- function parserErrorToText( parserError ) {
3962
-
3963
- let result = '';
3964
- const stack = [ parserError ];
3965
-
3966
- while ( stack.length ) {
3967
-
3968
- const node = stack.shift();
3969
-
3970
- if ( node.nodeType === Node.TEXT_NODE ) {
3971
-
3972
- result += node.textContent;
3973
-
3974
- } else {
3975
-
3976
- result += '\n';
3977
- stack.push.apply( stack, node.childNodes );
3978
-
3979
- }
3980
-
3981
- }
3982
-
3983
- return result.trim();
3984
-
3985
- }
3986
-
3987
- if ( text.length === 0 ) {
3988
-
3989
- return { scene: new Scene() };
3990
-
3991
- }
3992
-
3993
- const xml = new DOMParser().parseFromString( text, 'application/xml' );
3994
-
3995
- const collada = getElementsByTagName( xml, 'COLLADA' )[ 0 ];
3996
-
3997
- const parserError = xml.getElementsByTagName( 'parsererror' )[ 0 ];
3998
- if ( parserError !== undefined ) {
3999
-
4000
- // Chrome will return parser error with a div in it
4001
-
4002
- const errorElement = getElementsByTagName( parserError, 'div' )[ 0 ];
4003
- let errorText;
4004
-
4005
- if ( errorElement ) {
4006
-
4007
- errorText = errorElement.textContent;
4008
-
4009
- } else {
4010
-
4011
- errorText = parserErrorToText( parserError );
4012
-
4013
- }
4014
-
4015
- console.error( 'THREE.ColladaLoader: Failed to parse collada file.\n', errorText );
4016
-
4017
- return null;
4018
-
4019
- }
4020
-
4021
- // metadata
4022
-
4023
- const version = collada.getAttribute( 'version' );
4024
- console.debug( 'THREE.ColladaLoader: File version', version );
4025
-
4026
- const asset = parseAsset( getElementsByTagName( collada, 'asset' )[ 0 ] );
4027
- const textureLoader = new TextureLoader( this.manager );
4028
- textureLoader.setPath( this.resourcePath || path ).setCrossOrigin( this.crossOrigin );
4029
-
4030
- let tgaLoader;
4031
-
4032
- if ( TGALoader ) {
4033
-
4034
- tgaLoader = new TGALoader( this.manager );
4035
- tgaLoader.setPath( this.resourcePath || path );
4036
-
4037
- }
4038
-
4039
- //
4040
-
4041
- const tempColor = new Color();
4042
- const animations = [];
4043
- let kinematics = {};
4044
- let count = 0;
4045
-
4046
- //
4047
-
4048
- const library = {
4049
- animations: {},
4050
- clips: {},
4051
- controllers: {},
4052
- images: {},
4053
- effects: {},
4054
- materials: {},
4055
- cameras: {},
4056
- lights: {},
4057
- geometries: {},
4058
- nodes: {},
4059
- visualScenes: {},
4060
- kinematicsModels: {},
4061
- physicsModels: {},
4062
- kinematicsScenes: {}
4063
- };
4064
-
4065
- parseLibrary( collada, 'library_animations', 'animation', parseAnimation );
4066
- parseLibrary( collada, 'library_animation_clips', 'animation_clip', parseAnimationClip );
4067
- parseLibrary( collada, 'library_controllers', 'controller', parseController );
4068
- parseLibrary( collada, 'library_images', 'image', parseImage );
4069
- parseLibrary( collada, 'library_effects', 'effect', parseEffect );
4070
- parseLibrary( collada, 'library_materials', 'material', parseMaterial );
4071
- parseLibrary( collada, 'library_cameras', 'camera', parseCamera );
4072
- parseLibrary( collada, 'library_lights', 'light', parseLight );
4073
- parseLibrary( collada, 'library_geometries', 'geometry', parseGeometry );
4074
- parseLibrary( collada, 'library_nodes', 'node', parseNode );
4075
- parseLibrary( collada, 'library_visual_scenes', 'visual_scene', parseVisualScene );
4076
- parseLibrary( collada, 'library_kinematics_models', 'kinematics_model', parseKinematicsModel );
4077
- parseLibrary( collada, 'library_physics_models', 'physics_model', parsePhysicsModel );
4078
- parseLibrary( collada, 'scene', 'instance_kinematics_scene', parseKinematicsScene );
4079
-
4080
- buildLibrary( library.animations, buildAnimation );
4081
- buildLibrary( library.clips, buildAnimationClip );
4082
- buildLibrary( library.controllers, buildController );
4083
- buildLibrary( library.images, buildImage );
4084
- buildLibrary( library.effects, buildEffect );
4085
- buildLibrary( library.materials, buildMaterial );
4086
- buildLibrary( library.cameras, buildCamera );
4087
- buildLibrary( library.lights, buildLight );
4088
- buildLibrary( library.geometries, buildGeometry );
4089
- buildLibrary( library.visualScenes, buildVisualScene );
4090
-
4091
- setupAnimations();
4092
- setupKinematics();
4093
-
4094
- const scene = parseScene( getElementsByTagName( collada, 'scene' )[ 0 ] );
4095
- scene.animations = animations;
4096
-
4097
- if ( asset.upAxis === 'Z_UP' ) {
4098
-
4099
- console.warn( 'THREE.ColladaLoader: You are loading an asset with a Z-UP coordinate system. The loader just rotates the asset to transform it into Y-UP. The vertex data are not converted, see #24289.' );
4100
- scene.rotation.set( - Math.PI / 2, 0, 0 );
4101
-
4102
- }
4103
-
4104
- scene.scale.multiplyScalar( asset.unit );
4105
-
4106
- return {
4107
- get animations() {
4108
-
4109
- console.warn( 'THREE.ColladaLoader: Please access animations over scene.animations now.' );
4110
- return animations;
4111
-
4112
- },
4113
- kinematics: kinematics,
4114
- library: library,
4115
- scene: scene
4116
- };
4117
-
4118
- }
4119
-
4120
- }
4121
-
4122
- export { ColladaLoader };