three-stdlib 2.25.0 → 2.26.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/controls/OrbitControls.d.ts +1 -0
- package/index.cjs +116465 -611
- package/index.js +116101 -263
- package/package.json +17 -4
- package/_polyfill/CapsuleGeometry.cjs +0 -22
- package/_polyfill/CapsuleGeometry.js +0 -22
- package/_polyfill/CompressedArrayTexture.cjs +0 -12
- package/_polyfill/CompressedArrayTexture.js +0 -12
- package/_polyfill/Data3DTexture.cjs +0 -17
- package/_polyfill/Data3DTexture.js +0 -17
- package/animation/AnimationClipCreator.cjs +0 -56
- package/animation/AnimationClipCreator.js +0 -56
- package/animation/CCDIKSolver.cjs +0 -269
- package/animation/CCDIKSolver.js +0 -269
- package/animation/MMDAnimationHelper.cjs +0 -688
- package/animation/MMDAnimationHelper.js +0 -688
- package/animation/MMDPhysics.cjs +0 -830
- package/animation/MMDPhysics.js +0 -830
- package/cameras/CinematicCamera.cjs +0 -131
- package/cameras/CinematicCamera.js +0 -131
- package/controls/ArcballControls.cjs +0 -2033
- package/controls/ArcballControls.js +0 -2033
- package/controls/DeviceOrientationControls.cjs +0 -85
- package/controls/DeviceOrientationControls.js +0 -85
- package/controls/DragControls.cjs +0 -182
- package/controls/DragControls.js +0 -182
- package/controls/FirstPersonControls.cjs +0 -229
- package/controls/FirstPersonControls.js +0 -229
- package/controls/FlyControls.cjs +0 -248
- package/controls/FlyControls.js +0 -248
- package/controls/OrbitControls.cjs +0 -791
- package/controls/OrbitControls.js +0 -791
- package/controls/PointerLockControls.cjs +0 -103
- package/controls/PointerLockControls.js +0 -103
- package/controls/TrackballControls.cjs +0 -502
- package/controls/TrackballControls.js +0 -502
- package/controls/TransformControls.cjs +0 -1089
- package/controls/TransformControls.js +0 -1089
- package/controls/experimental/CameraControls.cjs +0 -736
- package/controls/experimental/CameraControls.js +0 -736
- package/csm/CSM.cjs +0 -244
- package/csm/CSM.js +0 -244
- package/csm/CSMFrustum.cjs +0 -75
- package/csm/CSMFrustum.js +0 -75
- package/csm/CSMHelper.cjs +0 -114
- package/csm/CSMHelper.js +0 -114
- package/csm/CSMShader.cjs +0 -261
- package/csm/CSMShader.js +0 -261
- package/curves/CurveExtras.cjs +0 -214
- package/curves/CurveExtras.js +0 -214
- package/curves/NURBSCurve.cjs +0 -35
- package/curves/NURBSCurve.js +0 -35
- package/curves/NURBSSurface.cjs +0 -28
- package/curves/NURBSSurface.js +0 -28
- package/curves/NURBSUtils.cjs +0 -226
- package/curves/NURBSUtils.js +0 -226
- package/deprecated/Geometry.cjs +0 -971
- package/deprecated/Geometry.js +0 -971
- package/effects/AnaglyphEffect.cjs +0 -102
- package/effects/AnaglyphEffect.js +0 -102
- package/effects/AsciiEffect.cjs +0 -155
- package/effects/AsciiEffect.js +0 -155
- package/effects/OutlineEffect.cjs +0 -275
- package/effects/OutlineEffect.js +0 -275
- package/effects/ParallaxBarrierEffect.cjs +0 -65
- package/effects/ParallaxBarrierEffect.js +0 -65
- package/effects/PeppersGhostEffect.cjs +0 -88
- package/effects/PeppersGhostEffect.js +0 -88
- package/effects/StereoEffect.cjs +0 -35
- package/effects/StereoEffect.js +0 -35
- package/environments/RoomEnvironment.cjs +0 -95
- package/environments/RoomEnvironment.js +0 -78
- package/exporters/ColladaExporter.cjs +0 -331
- package/exporters/ColladaExporter.js +0 -331
- package/exporters/DRACOExporter.cjs +0 -141
- package/exporters/DRACOExporter.js +0 -141
- package/exporters/GLTFExporter.cjs +0 -1909
- package/exporters/GLTFExporter.js +0 -1909
- package/exporters/MMDExporter.cjs +0 -131
- package/exporters/MMDExporter.js +0 -131
- package/exporters/OBJExporter.cjs +0 -181
- package/exporters/OBJExporter.js +0 -181
- package/exporters/PLYExporter.cjs +0 -280
- package/exporters/PLYExporter.js +0 -280
- package/exporters/STLExporter.cjs +0 -146
- package/exporters/STLExporter.js +0 -146
- package/exporters/USDZExporter.cjs +0 -340
- package/exporters/USDZExporter.js +0 -340
- package/geometries/BoxLineGeometry.cjs +0 -45
- package/geometries/BoxLineGeometry.js +0 -45
- package/geometries/ConvexGeometry.cjs +0 -26
- package/geometries/ConvexGeometry.js +0 -26
- package/geometries/DecalGeometry.cjs +0 -184
- package/geometries/DecalGeometry.js +0 -184
- package/geometries/LightningStrike.cjs +0 -553
- package/geometries/LightningStrike.js +0 -553
- package/geometries/ParametricGeometries.cjs +0 -130
- package/geometries/ParametricGeometries.js +0 -130
- package/geometries/ParametricGeometry.cjs +0 -63
- package/geometries/ParametricGeometry.js +0 -63
- package/geometries/RoundedBoxGeometry.cjs +0 -91
- package/geometries/RoundedBoxGeometry.js +0 -91
- package/geometries/TeapotGeometry.cjs +0 -1563
- package/geometries/TeapotGeometry.js +0 -1563
- package/geometries/TextGeometry.cjs +0 -27
- package/geometries/TextGeometry.js +0 -27
- package/helpers/LightProbeHelper.cjs +0 -73
- package/helpers/LightProbeHelper.js +0 -73
- package/helpers/PositionalAudioHelper.cjs +0 -68
- package/helpers/PositionalAudioHelper.js +0 -68
- package/helpers/RectAreaLightHelper.cjs +0 -44
- package/helpers/RectAreaLightHelper.js +0 -44
- package/helpers/VertexNormalsHelper.cjs +0 -47
- package/helpers/VertexNormalsHelper.js +0 -47
- package/helpers/VertexTangentsHelper.cjs +0 -43
- package/helpers/VertexTangentsHelper.js +0 -43
- package/interactive/HTMLMesh.cjs +0 -325
- package/interactive/HTMLMesh.js +0 -325
- package/interactive/InteractiveGroup.cjs +0 -68
- package/interactive/InteractiveGroup.js +0 -68
- package/interactive/SelectionBox.cjs +0 -134
- package/interactive/SelectionBox.js +0 -134
- package/interactive/SelectionHelper.cjs +0 -51
- package/interactive/SelectionHelper.js +0 -51
- package/libs/MeshoptDecoder.cjs +0 -221
- package/libs/MeshoptDecoder.js +0 -221
- package/libs/MotionControllers.cjs +0 -325
- package/libs/MotionControllers.js +0 -325
- package/lights/LightProbeGenerator.cjs +0 -145
- package/lights/LightProbeGenerator.js +0 -145
- package/lights/RectAreaLightUniformsLib.cjs +0 -32846
- package/lights/RectAreaLightUniformsLib.js +0 -32846
- package/lines/Line2.cjs +0 -13
- package/lines/Line2.js +0 -13
- package/lines/LineGeometry.cjs +0 -44
- package/lines/LineGeometry.js +0 -44
- package/lines/LineMaterial.cjs +0 -547
- package/lines/LineMaterial.js +0 -547
- package/lines/LineSegments2.cjs +0 -203
- package/lines/LineSegments2.js +0 -203
- package/lines/LineSegmentsGeometry.cjs +0 -124
- package/lines/LineSegmentsGeometry.js +0 -124
- package/lines/Wireframe.cjs +0 -32
- package/lines/Wireframe.js +0 -32
- package/lines/WireframeGeometry2.cjs +0 -13
- package/lines/WireframeGeometry2.js +0 -13
- package/loaders/3DMLoader.cjs +0 -803
- package/loaders/3DMLoader.js +0 -803
- package/loaders/3MFLoader.cjs +0 -854
- package/loaders/3MFLoader.js +0 -854
- package/loaders/AMFLoader.cjs +0 -284
- package/loaders/AMFLoader.js +0 -284
- package/loaders/AssimpLoader.cjs +0 -1434
- package/loaders/AssimpLoader.js +0 -1434
- package/loaders/BVHLoader.cjs +0 -207
- package/loaders/BVHLoader.js +0 -207
- package/loaders/BasisTextureLoader.cjs +0 -489
- package/loaders/BasisTextureLoader.js +0 -489
- package/loaders/ColladaLoader.cjs +0 -2405
- package/loaders/ColladaLoader.js +0 -2405
- package/loaders/DDSLoader.cjs +0 -148
- package/loaders/DDSLoader.js +0 -148
- package/loaders/DRACOLoader.cjs +0 -341
- package/loaders/DRACOLoader.js +0 -341
- package/loaders/EXRLoader.cjs +0 -1356
- package/loaders/EXRLoader.js +0 -1356
- package/loaders/FBXLoader.cjs +0 -2457
- package/loaders/FBXLoader.js +0 -2457
- package/loaders/FontLoader.cjs +0 -123
- package/loaders/FontLoader.js +0 -123
- package/loaders/GCodeLoader.cjs +0 -141
- package/loaders/GCodeLoader.js +0 -141
- package/loaders/GLTFLoader.cjs +0 -2504
- package/loaders/GLTFLoader.js +0 -2504
- package/loaders/HDRCubeTextureLoader.cjs +0 -75
- package/loaders/HDRCubeTextureLoader.js +0 -75
- package/loaders/KMZLoader.cjs +0 -75
- package/loaders/KMZLoader.js +0 -75
- package/loaders/KTX2Loader.cjs +0 -480
- package/loaders/KTX2Loader.js +0 -480
- package/loaders/KTXLoader.cjs +0 -93
- package/loaders/KTXLoader.js +0 -93
- package/loaders/LDrawLoader.cjs +0 -1424
- package/loaders/LDrawLoader.js +0 -1424
- package/loaders/LUT3dlLoader.cjs +0 -103
- package/loaders/LUT3dlLoader.js +0 -103
- package/loaders/LUTCubeLoader.cjs +0 -107
- package/loaders/LUTCubeLoader.js +0 -107
- package/loaders/LWOLoader.cjs +0 -645
- package/loaders/LWOLoader.js +0 -645
- package/loaders/LottieLoader.cjs +0 -47
- package/loaders/LottieLoader.js +0 -47
- package/loaders/MD2Loader.cjs +0 -359
- package/loaders/MD2Loader.js +0 -359
- package/loaders/MDDLoader.cjs +0 -58
- package/loaders/MDDLoader.js +0 -58
- package/loaders/MMDLoader.cjs +0 -1121
- package/loaders/MMDLoader.js +0 -1121
- package/loaders/MTLLoader.cjs +0 -304
- package/loaders/MTLLoader.js +0 -304
- package/loaders/NRRDLoader.cjs +0 -401
- package/loaders/NRRDLoader.js +0 -401
- package/loaders/OBJLoader.cjs +0 -487
- package/loaders/OBJLoader.js +0 -487
- package/loaders/PCDLoader.cjs +0 -248
- package/loaders/PCDLoader.js +0 -248
- package/loaders/PDBLoader.cjs +0 -247
- package/loaders/PDBLoader.js +0 -247
- package/loaders/PLYLoader.cjs +0 -317
- package/loaders/PLYLoader.js +0 -317
- package/loaders/PRWMLoader.cjs +0 -160
- package/loaders/PRWMLoader.js +0 -160
- package/loaders/PVRLoader.cjs +0 -131
- package/loaders/PVRLoader.js +0 -131
- package/loaders/RGBELoader.cjs +0 -252
- package/loaders/RGBELoader.js +0 -252
- package/loaders/RGBMLoader.cjs +0 -1004
- package/loaders/RGBMLoader.js +0 -1004
- package/loaders/STLLoader.cjs +0 -190
- package/loaders/STLLoader.js +0 -190
- package/loaders/SVGLoader.cjs +0 -1712
- package/loaders/SVGLoader.js +0 -1712
- package/loaders/TDSLoader.cjs +0 -650
- package/loaders/TDSLoader.js +0 -650
- package/loaders/TGALoader.cjs +0 -285
- package/loaders/TGALoader.js +0 -285
- package/loaders/TTFLoader.cjs +0 -131
- package/loaders/TTFLoader.js +0 -131
- package/loaders/TiltLoader.cjs +0 -375
- package/loaders/TiltLoader.js +0 -375
- package/loaders/VOXLoader.cjs +0 -432
- package/loaders/VOXLoader.js +0 -432
- package/loaders/VRMLLoader.cjs +0 -2105
- package/loaders/VRMLLoader.js +0 -2105
- package/loaders/VRMLoader.cjs +0 -38
- package/loaders/VRMLoader.js +0 -38
- package/loaders/VTKLoader.cjs +0 -648
- package/loaders/VTKLoader.js +0 -648
- package/loaders/XLoader.cjs +0 -1258
- package/loaders/XLoader.js +0 -1258
- package/loaders/XYZLoader.cjs +0 -60
- package/loaders/XYZLoader.js +0 -60
- package/loaders/lwo/IFFParser.cjs +0 -743
- package/loaders/lwo/IFFParser.js +0 -743
- package/loaders/lwo/LWO2Parser.cjs +0 -312
- package/loaders/lwo/LWO2Parser.js +0 -312
- package/loaders/lwo/LWO3Parser.cjs +0 -282
- package/loaders/lwo/LWO3Parser.js +0 -282
- package/math/Capsule.cjs +0 -98
- package/math/Capsule.js +0 -98
- package/math/ColorConverter.cjs +0 -42
- package/math/ColorConverter.js +0 -42
- package/math/ConvexHull.cjs +0 -596
- package/math/ConvexHull.js +0 -596
- package/math/ImprovedNoise.cjs +0 -304
- package/math/ImprovedNoise.js +0 -304
- package/math/Lut.cjs +0 -137
- package/math/Lut.js +0 -137
- package/math/MeshSurfaceSampler.cjs +0 -103
- package/math/MeshSurfaceSampler.js +0 -103
- package/math/OBB.cjs +0 -242
- package/math/OBB.js +0 -242
- package/math/Octree.cjs +0 -273
- package/math/Octree.js +0 -273
- package/math/SimplexNoise.cjs +0 -440
- package/math/SimplexNoise.js +0 -440
- package/misc/ConvexObjectBreaker.cjs +0 -292
- package/misc/ConvexObjectBreaker.js +0 -292
- package/misc/GPUComputationRenderer.cjs +0 -205
- package/misc/GPUComputationRenderer.js +0 -205
- package/misc/Gyroscope.cjs +0 -33
- package/misc/Gyroscope.js +0 -33
- package/misc/MD2Character.cjs +0 -167
- package/misc/MD2Character.js +0 -167
- package/misc/MD2CharacterComplex.cjs +0 -332
- package/misc/MD2CharacterComplex.js +0 -332
- package/misc/MorphAnimMesh.cjs +0 -40
- package/misc/MorphAnimMesh.js +0 -40
- package/misc/MorphBlendMesh.cjs +0 -179
- package/misc/MorphBlendMesh.js +0 -179
- package/misc/ProgressiveLightmap.cjs +0 -186
- package/misc/ProgressiveLightmap.js +0 -186
- package/misc/RollerCoaster.cjs +0 -353
- package/misc/RollerCoaster.js +0 -353
- package/misc/Timer.cjs +0 -101
- package/misc/Timer.js +0 -101
- package/misc/TubePainter.cjs +0 -123
- package/misc/TubePainter.js +0 -123
- package/misc/Volume.cjs +0 -305
- package/misc/Volume.js +0 -305
- package/misc/VolumeSlice.cjs +0 -114
- package/misc/VolumeSlice.js +0 -114
- package/misc/WebGL.cjs +0 -74
- package/misc/WebGL.js +0 -74
- package/modifiers/CurveModifier.cjs +0 -232
- package/modifiers/CurveModifier.js +0 -232
- package/modifiers/EdgeSplitModifier.cjs +0 -167
- package/modifiers/EdgeSplitModifier.js +0 -168
- package/modifiers/SimplifyModifier.cjs +0 -301
- package/modifiers/SimplifyModifier.js +0 -301
- package/modifiers/TessellateModifier.cjs +0 -214
- package/modifiers/TessellateModifier.js +0 -214
- package/objects/GroundProjectedEnv.cjs +0 -134
- package/objects/GroundProjectedEnv.js +0 -134
- package/objects/Lensflare.cjs +0 -291
- package/objects/Lensflare.js +0 -291
- package/objects/LightningStorm.cjs +0 -110
- package/objects/LightningStorm.js +0 -110
- package/objects/MarchingCubes.cjs +0 -4809
- package/objects/MarchingCubes.js +0 -4809
- package/objects/Reflector.cjs +0 -202
- package/objects/Reflector.js +0 -202
- package/objects/ReflectorForSSRPass.cjs +0 -260
- package/objects/ReflectorForSSRPass.js +0 -260
- package/objects/ReflectorRTT.cjs +0 -10
- package/objects/ReflectorRTT.js +0 -10
- package/objects/Refractor.cjs +0 -215
- package/objects/Refractor.js +0 -215
- package/objects/ShadowMesh.cjs +0 -45
- package/objects/ShadowMesh.js +0 -45
- package/objects/Sky.cjs +0 -200
- package/objects/Sky.js +0 -200
- package/objects/Water.cjs +0 -242
- package/objects/Water.js +0 -242
- package/objects/Water2.cjs +0 -256
- package/objects/Water2.js +0 -256
- package/physics/AmmoPhysics.cjs +0 -166
- package/physics/AmmoPhysics.js +0 -166
- package/postprocessing/AdaptiveToneMappingPass.cjs +0 -218
- package/postprocessing/AdaptiveToneMappingPass.js +0 -218
- package/postprocessing/AfterimagePass.cjs +0 -68
- package/postprocessing/AfterimagePass.js +0 -68
- package/postprocessing/BloomPass.cjs +0 -109
- package/postprocessing/BloomPass.js +0 -109
- package/postprocessing/BokehPass.cjs +0 -90
- package/postprocessing/BokehPass.js +0 -90
- package/postprocessing/ClearPass.cjs +0 -36
- package/postprocessing/ClearPass.js +0 -36
- package/postprocessing/CubeTexturePass.cjs +0 -53
- package/postprocessing/CubeTexturePass.js +0 -53
- package/postprocessing/DotScreenPass.cjs +0 -49
- package/postprocessing/DotScreenPass.js +0 -49
- package/postprocessing/EffectComposer.cjs +0 -157
- package/postprocessing/EffectComposer.js +0 -157
- package/postprocessing/FilmPass.cjs +0 -51
- package/postprocessing/FilmPass.js +0 -51
- package/postprocessing/GlitchPass.cjs +0 -84
- package/postprocessing/GlitchPass.js +0 -84
- package/postprocessing/HalftonePass.cjs +0 -53
- package/postprocessing/HalftonePass.js +0 -53
- package/postprocessing/LUTPass.cjs +0 -142
- package/postprocessing/LUTPass.js +0 -142
- package/postprocessing/MaskPass.cjs +0 -69
- package/postprocessing/MaskPass.js +0 -69
- package/postprocessing/OutlinePass.cjs +0 -479
- package/postprocessing/OutlinePass.js +0 -479
- package/postprocessing/Pass.cjs +0 -48
- package/postprocessing/Pass.js +0 -48
- package/postprocessing/RenderPass.cjs +0 -59
- package/postprocessing/RenderPass.js +0 -59
- package/postprocessing/RenderPixelatedPass.cjs +0 -199
- package/postprocessing/RenderPixelatedPass.js +0 -199
- package/postprocessing/SAOPass.cjs +0 -288
- package/postprocessing/SAOPass.js +0 -288
- package/postprocessing/SMAAPass.cjs +0 -112
- package/postprocessing/SMAAPass.js +0 -112
- package/postprocessing/SSAARenderPass.cjs +0 -189
- package/postprocessing/SSAARenderPass.js +0 -189
- package/postprocessing/SSAOPass.cjs +0 -272
- package/postprocessing/SSAOPass.js +0 -272
- package/postprocessing/SSRPass.cjs +0 -411
- package/postprocessing/SSRPass.js +0 -411
- package/postprocessing/SavePass.cjs +0 -38
- package/postprocessing/SavePass.js +0 -38
- package/postprocessing/ShaderPass.cjs +0 -49
- package/postprocessing/ShaderPass.js +0 -49
- package/postprocessing/TAARenderPass.cjs +0 -174
- package/postprocessing/TAARenderPass.js +0 -174
- package/postprocessing/TexturePass.cjs +0 -42
- package/postprocessing/TexturePass.js +0 -42
- package/postprocessing/UnrealBloomPass.cjs +0 -277
- package/postprocessing/UnrealBloomPass.js +0 -277
- package/postprocessing/WaterPass.cjs +0 -72
- package/postprocessing/WaterPass.js +0 -72
- package/renderers/CSS2DRenderer.cjs +0 -122
- package/renderers/CSS2DRenderer.js +0 -122
- package/renderers/CSS3DRenderer.cjs +0 -167
- package/renderers/CSS3DRenderer.js +0 -167
- package/renderers/Projector.cjs +0 -499
- package/renderers/Projector.js +0 -499
- package/renderers/SVGRenderer.cjs +0 -311
- package/renderers/SVGRenderer.js +0 -311
- package/shaders/ACESFilmicToneMappingShader.cjs +0 -55
- package/shaders/ACESFilmicToneMappingShader.js +0 -55
- package/shaders/AfterimageShader.cjs +0 -32
- package/shaders/AfterimageShader.js +0 -32
- package/shaders/BasicShader.cjs +0 -12
- package/shaders/BasicShader.js +0 -12
- package/shaders/BleachBypassShader.cjs +0 -35
- package/shaders/BleachBypassShader.js +0 -35
- package/shaders/BlendShader.cjs +0 -30
- package/shaders/BlendShader.js +0 -30
- package/shaders/BokehShader.cjs +0 -109
- package/shaders/BokehShader.js +0 -109
- package/shaders/BokehShader2.cjs +0 -269
- package/shaders/BokehShader2.js +0 -269
- package/shaders/BrightnessContrastShader.cjs +0 -32
- package/shaders/BrightnessContrastShader.js +0 -32
- package/shaders/ColorCorrectionShader.cjs +0 -30
- package/shaders/ColorCorrectionShader.js +0 -30
- package/shaders/ColorifyShader.cjs +0 -28
- package/shaders/ColorifyShader.js +0 -28
- package/shaders/ConvolutionShader.cjs +0 -55
- package/shaders/ConvolutionShader.js +0 -55
- package/shaders/CopyShader.cjs +0 -25
- package/shaders/CopyShader.js +0 -25
- package/shaders/DOFMipMapShader.cjs +0 -32
- package/shaders/DOFMipMapShader.js +0 -32
- package/shaders/DepthLimitedBlurShader.cjs +0 -114
- package/shaders/DepthLimitedBlurShader.js +0 -114
- package/shaders/DigitalGlitch.cjs +0 -85
- package/shaders/DigitalGlitch.js +0 -85
- package/shaders/DotScreenShader.cjs +0 -39
- package/shaders/DotScreenShader.js +0 -39
- package/shaders/FXAAShader.cjs +0 -1098
- package/shaders/FXAAShader.js +0 -1098
- package/shaders/FilmShader.cjs +0 -53
- package/shaders/FilmShader.js +0 -53
- package/shaders/FocusShader.cjs +0 -55
- package/shaders/FocusShader.js +0 -55
- package/shaders/FreiChenShader.cjs +0 -64
- package/shaders/FreiChenShader.js +0 -64
- package/shaders/FresnelShader.cjs +0 -47
- package/shaders/FresnelShader.js +0 -47
- package/shaders/GammaCorrectionShader.cjs +0 -23
- package/shaders/GammaCorrectionShader.js +0 -23
- package/shaders/GodRaysShader.cjs +0 -183
- package/shaders/GodRaysShader.js +0 -183
- package/shaders/HalftoneShader.cjs +0 -228
- package/shaders/HalftoneShader.js +0 -228
- package/shaders/HorizontalBlurShader.cjs +0 -49
- package/shaders/HorizontalBlurShader.js +0 -49
- package/shaders/HorizontalTiltShiftShader.cjs +0 -37
- package/shaders/HorizontalTiltShiftShader.js +0 -37
- package/shaders/HueSaturationShader.cjs +0 -43
- package/shaders/HueSaturationShader.js +0 -43
- package/shaders/KaleidoShader.cjs +0 -34
- package/shaders/KaleidoShader.js +0 -34
- package/shaders/LuminosityHighPassShader.cjs +0 -37
- package/shaders/LuminosityHighPassShader.js +0 -37
- package/shaders/LuminosityShader.cjs +0 -25
- package/shaders/LuminosityShader.js +0 -25
- package/shaders/MirrorShader.cjs +0 -35
- package/shaders/MirrorShader.js +0 -35
- package/shaders/NormalMapShader.cjs +0 -31
- package/shaders/NormalMapShader.js +0 -31
- package/shaders/ParallaxShader.cjs +0 -133
- package/shaders/ParallaxShader.js +0 -133
- package/shaders/PixelShader.cjs +0 -28
- package/shaders/PixelShader.js +0 -28
- package/shaders/RGBShiftShader.cjs +0 -30
- package/shaders/RGBShiftShader.js +0 -30
- package/shaders/SAOShader.cjs +0 -144
- package/shaders/SAOShader.js +0 -144
- package/shaders/SMAAShader.cjs +0 -358
- package/shaders/SMAAShader.js +0 -358
- package/shaders/SSAOShader.cjs +0 -182
- package/shaders/SSAOShader.js +0 -182
- package/shaders/SSRShader.cjs +0 -342
- package/shaders/SSRShader.js +0 -342
- package/shaders/SepiaShader.cjs +0 -29
- package/shaders/SepiaShader.js +0 -29
- package/shaders/SobelOperatorShader.cjs +0 -54
- package/shaders/SobelOperatorShader.js +0 -54
- package/shaders/SubsurfaceScatteringShader.cjs +0 -98
- package/shaders/SubsurfaceScatteringShader.js +0 -98
- package/shaders/TechnicolorShader.cjs +0 -24
- package/shaders/TechnicolorShader.js +0 -24
- package/shaders/ToneMapShader.cjs +0 -51
- package/shaders/ToneMapShader.js +0 -51
- package/shaders/ToonShader.cjs +0 -188
- package/shaders/ToonShader.js +0 -188
- package/shaders/TriangleBlurShader.cjs +0 -37
- package/shaders/TriangleBlurShader.js +0 -37
- package/shaders/UnpackDepthRGBAShader.cjs +0 -26
- package/shaders/UnpackDepthRGBAShader.js +0 -26
- package/shaders/VerticalBlurShader.cjs +0 -50
- package/shaders/VerticalBlurShader.js +0 -50
- package/shaders/VerticalTiltShiftShader.cjs +0 -37
- package/shaders/VerticalTiltShiftShader.js +0 -37
- package/shaders/VignetteShader.cjs +0 -38
- package/shaders/VignetteShader.js +0 -38
- package/shaders/VolumeShader.cjs +0 -225
- package/shaders/VolumeShader.js +0 -225
- package/shaders/WaterRefractionShader.cjs +0 -59
- package/shaders/WaterRefractionShader.js +0 -59
- package/shaders/types.cjs +0 -1
- package/shaders/types.js +0 -1
- package/textures/FlakesTexture.cjs +0 -30
- package/textures/FlakesTexture.js +0 -30
- package/types/helpers.cjs +0 -4
- package/types/helpers.js +0 -4
- package/utils/BufferGeometryUtils.cjs +0 -636
- package/utils/BufferGeometryUtils.js +0 -636
- package/utils/GeometryCompressionUtils.cjs +0 -573
- package/utils/GeometryCompressionUtils.js +0 -573
- package/utils/GeometryUtils.cjs +0 -109
- package/utils/GeometryUtils.js +0 -109
- package/utils/RoughnessMipmapper.cjs +0 -223
- package/utils/RoughnessMipmapper.js +0 -223
- package/utils/SceneUtils.cjs +0 -36
- package/utils/SceneUtils.js +0 -36
- package/utils/ShadowMapViewer.cjs +0 -111
- package/utils/ShadowMapViewer.js +0 -111
- package/utils/SkeletonUtils.cjs +0 -211
- package/utils/SkeletonUtils.js +0 -211
- package/utils/UVsDebug.cjs +0 -80
- package/utils/UVsDebug.js +0 -80
- package/utils/WorkerPool.cjs +0 -62
- package/utils/WorkerPool.js +0 -62
- package/webxr/ARButton.cjs +0 -119
- package/webxr/ARButton.js +0 -119
- package/webxr/OculusHandModel.cjs +0 -82
- package/webxr/OculusHandModel.js +0 -82
- package/webxr/OculusHandPointerModel.cjs +0 -241
- package/webxr/OculusHandPointerModel.js +0 -224
- package/webxr/Text2D.cjs +0 -48
- package/webxr/Text2D.js +0 -31
- package/webxr/VRButton.cjs +0 -111
- package/webxr/VRButton.js +0 -111
- package/webxr/XRControllerModelFactory.cjs +0 -174
- package/webxr/XRControllerModelFactory.js +0 -174
- package/webxr/XREstimatedLight.cjs +0 -126
- package/webxr/XREstimatedLight.js +0 -126
- package/webxr/XRHandMeshModel.cjs +0 -82
- package/webxr/XRHandMeshModel.js +0 -82
- package/webxr/XRHandModelFactory.cjs +0 -61
- package/webxr/XRHandModelFactory.js +0 -61
- package/webxr/XRHandPrimitiveModel.cjs +0 -68
- package/webxr/XRHandPrimitiveModel.js +0 -68
package/loaders/LDrawLoader.js
DELETED
|
@@ -1,1424 +0,0 @@
|
|
|
1
|
-
import { Vector3, ShaderMaterial, UniformsUtils, UniformsLib, Color, REVISION, LineSegments, Ray, FileLoader, Matrix4, Group, BufferGeometry, BufferAttribute, Mesh, Loader, MeshStandardMaterial, LineBasicMaterial } from "three";
|
|
2
|
-
const FINISH_TYPE_DEFAULT = 0;
|
|
3
|
-
const FINISH_TYPE_CHROME = 1;
|
|
4
|
-
const FINISH_TYPE_PEARLESCENT = 2;
|
|
5
|
-
const FINISH_TYPE_RUBBER = 3;
|
|
6
|
-
const FINISH_TYPE_MATTE_METALLIC = 4;
|
|
7
|
-
const FINISH_TYPE_METAL = 5;
|
|
8
|
-
const FILE_LOCATION_AS_IS = 0;
|
|
9
|
-
const FILE_LOCATION_TRY_PARTS = 1;
|
|
10
|
-
const FILE_LOCATION_TRY_P = 2;
|
|
11
|
-
const FILE_LOCATION_TRY_MODELS = 3;
|
|
12
|
-
const FILE_LOCATION_TRY_RELATIVE = 4;
|
|
13
|
-
const FILE_LOCATION_TRY_ABSOLUTE = 5;
|
|
14
|
-
const FILE_LOCATION_NOT_FOUND = 6;
|
|
15
|
-
const MAIN_COLOUR_CODE = "16";
|
|
16
|
-
const MAIN_EDGE_COLOUR_CODE = "24";
|
|
17
|
-
const _tempVec0 = /* @__PURE__ */ new Vector3();
|
|
18
|
-
const _tempVec1 = /* @__PURE__ */ new Vector3();
|
|
19
|
-
class LDrawConditionalLineMaterial extends ShaderMaterial {
|
|
20
|
-
constructor(parameters) {
|
|
21
|
-
super({
|
|
22
|
-
uniforms: UniformsUtils.merge([
|
|
23
|
-
UniformsLib.fog,
|
|
24
|
-
{
|
|
25
|
-
diffuse: {
|
|
26
|
-
value: new Color()
|
|
27
|
-
},
|
|
28
|
-
opacity: {
|
|
29
|
-
value: 1
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
]),
|
|
33
|
-
vertexShader: (
|
|
34
|
-
/* glsl */
|
|
35
|
-
`
|
|
36
|
-
attribute vec3 control0;
|
|
37
|
-
attribute vec3 control1;
|
|
38
|
-
attribute vec3 direction;
|
|
39
|
-
varying float discardFlag;
|
|
40
|
-
|
|
41
|
-
#include <common>
|
|
42
|
-
#include <color_pars_vertex>
|
|
43
|
-
#include <fog_pars_vertex>
|
|
44
|
-
#include <logdepthbuf_pars_vertex>
|
|
45
|
-
#include <clipping_planes_pars_vertex>
|
|
46
|
-
|
|
47
|
-
void main() {
|
|
48
|
-
#include <color_vertex>
|
|
49
|
-
|
|
50
|
-
vec4 mvPosition = modelViewMatrix * vec4(position, 1.0);
|
|
51
|
-
gl_Position = projectionMatrix * mvPosition;
|
|
52
|
-
|
|
53
|
-
// Transform the line segment ends and control points into camera clip space
|
|
54
|
-
vec4 c0 = projectionMatrix * modelViewMatrix * vec4(control0, 1.0);
|
|
55
|
-
vec4 c1 = projectionMatrix * modelViewMatrix * vec4(control1, 1.0);
|
|
56
|
-
vec4 p0 = projectionMatrix * modelViewMatrix * vec4(position, 1.0);
|
|
57
|
-
vec4 p1 = projectionMatrix * modelViewMatrix * vec4(position + direction, 1.0);
|
|
58
|
-
|
|
59
|
-
c0.xy /= c0.w;
|
|
60
|
-
c1.xy /= c1.w;
|
|
61
|
-
p0.xy /= p0.w;
|
|
62
|
-
p1.xy /= p1.w;
|
|
63
|
-
|
|
64
|
-
// Get the direction of the segment and an orthogonal vector
|
|
65
|
-
vec2 dir = p1.xy - p0.xy;
|
|
66
|
-
vec2 norm = vec2(-dir.y, dir.x);
|
|
67
|
-
|
|
68
|
-
// Get control point directions from the line
|
|
69
|
-
vec2 c0dir = c0.xy - p1.xy;
|
|
70
|
-
vec2 c1dir = c1.xy - p1.xy;
|
|
71
|
-
|
|
72
|
-
// If the vectors to the controls points are pointed in different directions away
|
|
73
|
-
// from the line segment then the line should not be drawn.
|
|
74
|
-
float d0 = dot(normalize(norm), normalize(c0dir));
|
|
75
|
-
float d1 = dot(normalize(norm), normalize(c1dir));
|
|
76
|
-
discardFlag = float(sign(d0) != sign(d1));
|
|
77
|
-
|
|
78
|
-
#include <logdepthbuf_vertex>
|
|
79
|
-
#include <clipping_planes_vertex>
|
|
80
|
-
#include <fog_vertex>
|
|
81
|
-
}
|
|
82
|
-
`
|
|
83
|
-
),
|
|
84
|
-
fragmentShader: (
|
|
85
|
-
/* glsl */
|
|
86
|
-
`
|
|
87
|
-
uniform vec3 diffuse;
|
|
88
|
-
uniform float opacity;
|
|
89
|
-
varying float discardFlag;
|
|
90
|
-
|
|
91
|
-
#include <common>
|
|
92
|
-
#include <color_pars_fragment>
|
|
93
|
-
#include <fog_pars_fragment>
|
|
94
|
-
#include <logdepthbuf_pars_fragment>
|
|
95
|
-
#include <clipping_planes_pars_fragment>
|
|
96
|
-
|
|
97
|
-
void main() {
|
|
98
|
-
if (discardFlag > 0.5) discard;
|
|
99
|
-
|
|
100
|
-
#include <clipping_planes_fragment>
|
|
101
|
-
vec3 outgoingLight = vec3(0.0);
|
|
102
|
-
vec4 diffuseColor = vec4(diffuse, opacity);
|
|
103
|
-
#include <logdepthbuf_fragment>
|
|
104
|
-
#include <color_fragment>
|
|
105
|
-
outgoingLight = diffuseColor.rgb; // simple shader
|
|
106
|
-
gl_FragColor = vec4(outgoingLight, diffuseColor.a);
|
|
107
|
-
#include <tonemapping_fragment>
|
|
108
|
-
#include <${parseInt(REVISION.replace(/\D+/g, "")) >= 154 ? "colorspace_fragment" : "encodings_fragment"}>
|
|
109
|
-
#include <fog_fragment>
|
|
110
|
-
#include <premultiplied_alpha_fragment>
|
|
111
|
-
}
|
|
112
|
-
`
|
|
113
|
-
)
|
|
114
|
-
});
|
|
115
|
-
Object.defineProperties(this, {
|
|
116
|
-
opacity: {
|
|
117
|
-
get: function() {
|
|
118
|
-
return this.uniforms.opacity.value;
|
|
119
|
-
},
|
|
120
|
-
set: function(value) {
|
|
121
|
-
this.uniforms.opacity.value = value;
|
|
122
|
-
}
|
|
123
|
-
},
|
|
124
|
-
color: {
|
|
125
|
-
get: function() {
|
|
126
|
-
return this.uniforms.diffuse.value;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
this.setValues(parameters);
|
|
131
|
-
this.isLDrawConditionalLineMaterial = true;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
class ConditionalLineSegments extends LineSegments {
|
|
135
|
-
constructor(geometry, material) {
|
|
136
|
-
super(geometry, material);
|
|
137
|
-
this.isConditionalLine = true;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
function generateFaceNormals(faces) {
|
|
141
|
-
for (let i = 0, l = faces.length; i < l; i++) {
|
|
142
|
-
const face = faces[i];
|
|
143
|
-
const vertices = face.vertices;
|
|
144
|
-
const v0 = vertices[0];
|
|
145
|
-
const v1 = vertices[1];
|
|
146
|
-
const v2 = vertices[2];
|
|
147
|
-
_tempVec0.subVectors(v1, v0);
|
|
148
|
-
_tempVec1.subVectors(v2, v1);
|
|
149
|
-
face.faceNormal = new Vector3().crossVectors(_tempVec0, _tempVec1).normalize();
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
const _ray = /* @__PURE__ */ new Ray();
|
|
153
|
-
function smoothNormals(faces, lineSegments, checkSubSegments = false) {
|
|
154
|
-
const hashMultiplier = (1 + 1e-10) * 100;
|
|
155
|
-
function hashVertex(v) {
|
|
156
|
-
const x = ~~(v.x * hashMultiplier);
|
|
157
|
-
const y = ~~(v.y * hashMultiplier);
|
|
158
|
-
const z = ~~(v.z * hashMultiplier);
|
|
159
|
-
return `${x},${y},${z}`;
|
|
160
|
-
}
|
|
161
|
-
function hashEdge(v0, v1) {
|
|
162
|
-
return `${hashVertex(v0)}_${hashVertex(v1)}`;
|
|
163
|
-
}
|
|
164
|
-
function toNormalizedRay(v0, v1, targetRay) {
|
|
165
|
-
targetRay.direction.subVectors(v1, v0).normalize();
|
|
166
|
-
const scalar = v0.dot(targetRay.direction);
|
|
167
|
-
targetRay.origin.copy(v0).addScaledVector(targetRay.direction, -scalar);
|
|
168
|
-
return targetRay;
|
|
169
|
-
}
|
|
170
|
-
function hashRay(ray) {
|
|
171
|
-
return hashEdge(ray.origin, ray.direction);
|
|
172
|
-
}
|
|
173
|
-
const hardEdges = /* @__PURE__ */ new Set();
|
|
174
|
-
const hardEdgeRays = /* @__PURE__ */ new Map();
|
|
175
|
-
const halfEdgeList = {};
|
|
176
|
-
const normals = [];
|
|
177
|
-
for (let i = 0, l = lineSegments.length; i < l; i++) {
|
|
178
|
-
const ls = lineSegments[i];
|
|
179
|
-
const vertices = ls.vertices;
|
|
180
|
-
const v0 = vertices[0];
|
|
181
|
-
const v1 = vertices[1];
|
|
182
|
-
hardEdges.add(hashEdge(v0, v1));
|
|
183
|
-
hardEdges.add(hashEdge(v1, v0));
|
|
184
|
-
if (checkSubSegments) {
|
|
185
|
-
const ray = toNormalizedRay(v0, v1, new Ray());
|
|
186
|
-
const rh1 = hashRay(ray);
|
|
187
|
-
if (!hardEdgeRays.has(rh1)) {
|
|
188
|
-
toNormalizedRay(v1, v0, ray);
|
|
189
|
-
const rh2 = hashRay(ray);
|
|
190
|
-
const info2 = {
|
|
191
|
-
ray,
|
|
192
|
-
distances: []
|
|
193
|
-
};
|
|
194
|
-
hardEdgeRays.set(rh1, info2);
|
|
195
|
-
hardEdgeRays.set(rh2, info2);
|
|
196
|
-
}
|
|
197
|
-
const info = hardEdgeRays.get(rh1);
|
|
198
|
-
let d0 = info.ray.direction.dot(v0);
|
|
199
|
-
let d1 = info.ray.direction.dot(v1);
|
|
200
|
-
if (d0 > d1) {
|
|
201
|
-
;
|
|
202
|
-
[d0, d1] = [d1, d0];
|
|
203
|
-
}
|
|
204
|
-
info.distances.push(d0, d1);
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
for (let i = 0, l = faces.length; i < l; i++) {
|
|
208
|
-
const tri = faces[i];
|
|
209
|
-
const vertices = tri.vertices;
|
|
210
|
-
const vertCount = vertices.length;
|
|
211
|
-
for (let i2 = 0; i2 < vertCount; i2++) {
|
|
212
|
-
const index = i2;
|
|
213
|
-
const next = (i2 + 1) % vertCount;
|
|
214
|
-
const v0 = vertices[index];
|
|
215
|
-
const v1 = vertices[next];
|
|
216
|
-
const hash = hashEdge(v0, v1);
|
|
217
|
-
if (hardEdges.has(hash)) {
|
|
218
|
-
continue;
|
|
219
|
-
}
|
|
220
|
-
if (checkSubSegments) {
|
|
221
|
-
toNormalizedRay(v0, v1, _ray);
|
|
222
|
-
const rayHash = hashRay(_ray);
|
|
223
|
-
if (hardEdgeRays.has(rayHash)) {
|
|
224
|
-
const info2 = hardEdgeRays.get(rayHash);
|
|
225
|
-
const { ray, distances } = info2;
|
|
226
|
-
let d0 = ray.direction.dot(v0);
|
|
227
|
-
let d1 = ray.direction.dot(v1);
|
|
228
|
-
if (d0 > d1) {
|
|
229
|
-
;
|
|
230
|
-
[d0, d1] = [d1, d0];
|
|
231
|
-
}
|
|
232
|
-
let found = false;
|
|
233
|
-
for (let i3 = 0, l2 = distances.length; i3 < l2; i3 += 2) {
|
|
234
|
-
if (d0 >= distances[i3] && d1 <= distances[i3 + 1]) {
|
|
235
|
-
found = true;
|
|
236
|
-
break;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
if (found) {
|
|
240
|
-
continue;
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
}
|
|
244
|
-
const info = {
|
|
245
|
-
index,
|
|
246
|
-
tri
|
|
247
|
-
};
|
|
248
|
-
halfEdgeList[hash] = info;
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
while (true) {
|
|
252
|
-
let halfEdge = null;
|
|
253
|
-
for (const key in halfEdgeList) {
|
|
254
|
-
halfEdge = halfEdgeList[key];
|
|
255
|
-
break;
|
|
256
|
-
}
|
|
257
|
-
if (halfEdge === null) {
|
|
258
|
-
break;
|
|
259
|
-
}
|
|
260
|
-
const queue = [halfEdge];
|
|
261
|
-
while (queue.length > 0) {
|
|
262
|
-
const tri = queue.pop().tri;
|
|
263
|
-
const vertices = tri.vertices;
|
|
264
|
-
const vertNormals = tri.normals;
|
|
265
|
-
const faceNormal = tri.faceNormal;
|
|
266
|
-
const vertCount = vertices.length;
|
|
267
|
-
for (let i2 = 0; i2 < vertCount; i2++) {
|
|
268
|
-
const index = i2;
|
|
269
|
-
const next = (i2 + 1) % vertCount;
|
|
270
|
-
const v0 = vertices[index];
|
|
271
|
-
const v1 = vertices[next];
|
|
272
|
-
const hash = hashEdge(v0, v1);
|
|
273
|
-
delete halfEdgeList[hash];
|
|
274
|
-
const reverseHash = hashEdge(v1, v0);
|
|
275
|
-
const otherInfo = halfEdgeList[reverseHash];
|
|
276
|
-
if (otherInfo) {
|
|
277
|
-
const otherTri = otherInfo.tri;
|
|
278
|
-
const otherIndex = otherInfo.index;
|
|
279
|
-
const otherNormals = otherTri.normals;
|
|
280
|
-
const otherVertCount = otherNormals.length;
|
|
281
|
-
const otherFaceNormal = otherTri.faceNormal;
|
|
282
|
-
if (Math.abs(otherTri.faceNormal.dot(tri.faceNormal)) < 0.25) {
|
|
283
|
-
continue;
|
|
284
|
-
}
|
|
285
|
-
if (reverseHash in halfEdgeList) {
|
|
286
|
-
queue.push(otherInfo);
|
|
287
|
-
delete halfEdgeList[reverseHash];
|
|
288
|
-
}
|
|
289
|
-
const otherNext = (otherIndex + 1) % otherVertCount;
|
|
290
|
-
if (vertNormals[index] && otherNormals[otherNext] && vertNormals[index] !== otherNormals[otherNext]) {
|
|
291
|
-
otherNormals[otherNext].norm.add(vertNormals[index].norm);
|
|
292
|
-
vertNormals[index].norm = otherNormals[otherNext].norm;
|
|
293
|
-
}
|
|
294
|
-
let sharedNormal1 = vertNormals[index] || otherNormals[otherNext];
|
|
295
|
-
if (sharedNormal1 === null) {
|
|
296
|
-
sharedNormal1 = { norm: new Vector3() };
|
|
297
|
-
normals.push(sharedNormal1.norm);
|
|
298
|
-
}
|
|
299
|
-
if (vertNormals[index] === null) {
|
|
300
|
-
vertNormals[index] = sharedNormal1;
|
|
301
|
-
sharedNormal1.norm.add(faceNormal);
|
|
302
|
-
}
|
|
303
|
-
if (otherNormals[otherNext] === null) {
|
|
304
|
-
otherNormals[otherNext] = sharedNormal1;
|
|
305
|
-
sharedNormal1.norm.add(otherFaceNormal);
|
|
306
|
-
}
|
|
307
|
-
if (vertNormals[next] && otherNormals[otherIndex] && vertNormals[next] !== otherNormals[otherIndex]) {
|
|
308
|
-
otherNormals[otherIndex].norm.add(vertNormals[next].norm);
|
|
309
|
-
vertNormals[next].norm = otherNormals[otherIndex].norm;
|
|
310
|
-
}
|
|
311
|
-
let sharedNormal2 = vertNormals[next] || otherNormals[otherIndex];
|
|
312
|
-
if (sharedNormal2 === null) {
|
|
313
|
-
sharedNormal2 = { norm: new Vector3() };
|
|
314
|
-
normals.push(sharedNormal2.norm);
|
|
315
|
-
}
|
|
316
|
-
if (vertNormals[next] === null) {
|
|
317
|
-
vertNormals[next] = sharedNormal2;
|
|
318
|
-
sharedNormal2.norm.add(faceNormal);
|
|
319
|
-
}
|
|
320
|
-
if (otherNormals[otherIndex] === null) {
|
|
321
|
-
otherNormals[otherIndex] = sharedNormal2;
|
|
322
|
-
sharedNormal2.norm.add(otherFaceNormal);
|
|
323
|
-
}
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
for (let i = 0, l = normals.length; i < l; i++) {
|
|
329
|
-
normals[i].normalize();
|
|
330
|
-
}
|
|
331
|
-
}
|
|
332
|
-
function isPartType(type) {
|
|
333
|
-
return type === "Part" || type === "Unofficial_Part";
|
|
334
|
-
}
|
|
335
|
-
function isPrimitiveType(type) {
|
|
336
|
-
return /primitive/i.test(type) || type === "Subpart";
|
|
337
|
-
}
|
|
338
|
-
class LineParser {
|
|
339
|
-
constructor(line, lineNumber) {
|
|
340
|
-
this.line = line;
|
|
341
|
-
this.lineLength = line.length;
|
|
342
|
-
this.currentCharIndex = 0;
|
|
343
|
-
this.currentChar = " ";
|
|
344
|
-
this.lineNumber = lineNumber;
|
|
345
|
-
}
|
|
346
|
-
seekNonSpace() {
|
|
347
|
-
while (this.currentCharIndex < this.lineLength) {
|
|
348
|
-
this.currentChar = this.line.charAt(this.currentCharIndex);
|
|
349
|
-
if (this.currentChar !== " " && this.currentChar !== " ") {
|
|
350
|
-
return;
|
|
351
|
-
}
|
|
352
|
-
this.currentCharIndex++;
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
getToken() {
|
|
356
|
-
const pos0 = this.currentCharIndex++;
|
|
357
|
-
while (this.currentCharIndex < this.lineLength) {
|
|
358
|
-
this.currentChar = this.line.charAt(this.currentCharIndex);
|
|
359
|
-
if (this.currentChar === " " || this.currentChar === " ") {
|
|
360
|
-
break;
|
|
361
|
-
}
|
|
362
|
-
this.currentCharIndex++;
|
|
363
|
-
}
|
|
364
|
-
const pos1 = this.currentCharIndex;
|
|
365
|
-
this.seekNonSpace();
|
|
366
|
-
return this.line.substring(pos0, pos1);
|
|
367
|
-
}
|
|
368
|
-
getVector() {
|
|
369
|
-
return new Vector3(parseFloat(this.getToken()), parseFloat(this.getToken()), parseFloat(this.getToken()));
|
|
370
|
-
}
|
|
371
|
-
getRemainingString() {
|
|
372
|
-
return this.line.substring(this.currentCharIndex, this.lineLength);
|
|
373
|
-
}
|
|
374
|
-
isAtTheEnd() {
|
|
375
|
-
return this.currentCharIndex >= this.lineLength;
|
|
376
|
-
}
|
|
377
|
-
setToEnd() {
|
|
378
|
-
this.currentCharIndex = this.lineLength;
|
|
379
|
-
}
|
|
380
|
-
getLineNumberString() {
|
|
381
|
-
return this.lineNumber >= 0 ? " at line " + this.lineNumber : "";
|
|
382
|
-
}
|
|
383
|
-
}
|
|
384
|
-
class LDrawParsedCache {
|
|
385
|
-
constructor(loader) {
|
|
386
|
-
this.loader = loader;
|
|
387
|
-
this._cache = {};
|
|
388
|
-
}
|
|
389
|
-
cloneResult(original) {
|
|
390
|
-
const result = {};
|
|
391
|
-
result.faces = original.faces.map((face) => {
|
|
392
|
-
return {
|
|
393
|
-
colorCode: face.colorCode,
|
|
394
|
-
material: face.material,
|
|
395
|
-
vertices: face.vertices.map((v) => v.clone()),
|
|
396
|
-
normals: face.normals.map(() => null),
|
|
397
|
-
faceNormal: null
|
|
398
|
-
};
|
|
399
|
-
});
|
|
400
|
-
result.conditionalSegments = original.conditionalSegments.map((face) => {
|
|
401
|
-
return {
|
|
402
|
-
colorCode: face.colorCode,
|
|
403
|
-
material: face.material,
|
|
404
|
-
vertices: face.vertices.map((v) => v.clone()),
|
|
405
|
-
controlPoints: face.controlPoints.map((v) => v.clone())
|
|
406
|
-
};
|
|
407
|
-
});
|
|
408
|
-
result.lineSegments = original.lineSegments.map((face) => {
|
|
409
|
-
return {
|
|
410
|
-
colorCode: face.colorCode,
|
|
411
|
-
material: face.material,
|
|
412
|
-
vertices: face.vertices.map((v) => v.clone())
|
|
413
|
-
};
|
|
414
|
-
});
|
|
415
|
-
result.type = original.type;
|
|
416
|
-
result.category = original.category;
|
|
417
|
-
result.keywords = original.keywords;
|
|
418
|
-
result.subobjects = original.subobjects;
|
|
419
|
-
result.totalFaces = original.totalFaces;
|
|
420
|
-
result.startingConstructionStep = original.startingConstructionStep;
|
|
421
|
-
result.materials = original.materials;
|
|
422
|
-
result.group = null;
|
|
423
|
-
return result;
|
|
424
|
-
}
|
|
425
|
-
async fetchData(fileName) {
|
|
426
|
-
let triedLowerCase = false;
|
|
427
|
-
let locationState = FILE_LOCATION_AS_IS;
|
|
428
|
-
while (locationState !== FILE_LOCATION_NOT_FOUND) {
|
|
429
|
-
let subobjectURL = fileName;
|
|
430
|
-
switch (locationState) {
|
|
431
|
-
case FILE_LOCATION_AS_IS:
|
|
432
|
-
locationState = locationState + 1;
|
|
433
|
-
break;
|
|
434
|
-
case FILE_LOCATION_TRY_PARTS:
|
|
435
|
-
subobjectURL = "parts/" + subobjectURL;
|
|
436
|
-
locationState = locationState + 1;
|
|
437
|
-
break;
|
|
438
|
-
case FILE_LOCATION_TRY_P:
|
|
439
|
-
subobjectURL = "p/" + subobjectURL;
|
|
440
|
-
locationState = locationState + 1;
|
|
441
|
-
break;
|
|
442
|
-
case FILE_LOCATION_TRY_MODELS:
|
|
443
|
-
subobjectURL = "models/" + subobjectURL;
|
|
444
|
-
locationState = locationState + 1;
|
|
445
|
-
break;
|
|
446
|
-
case FILE_LOCATION_TRY_RELATIVE:
|
|
447
|
-
subobjectURL = fileName.substring(0, fileName.lastIndexOf("/") + 1) + subobjectURL;
|
|
448
|
-
locationState = locationState + 1;
|
|
449
|
-
break;
|
|
450
|
-
case FILE_LOCATION_TRY_ABSOLUTE:
|
|
451
|
-
if (triedLowerCase) {
|
|
452
|
-
locationState = FILE_LOCATION_NOT_FOUND;
|
|
453
|
-
} else {
|
|
454
|
-
fileName = fileName.toLowerCase();
|
|
455
|
-
subobjectURL = fileName;
|
|
456
|
-
triedLowerCase = true;
|
|
457
|
-
locationState = FILE_LOCATION_AS_IS;
|
|
458
|
-
}
|
|
459
|
-
break;
|
|
460
|
-
}
|
|
461
|
-
const loader = this.loader;
|
|
462
|
-
const fileLoader = new FileLoader(loader.manager);
|
|
463
|
-
fileLoader.setPath(loader.partsLibraryPath);
|
|
464
|
-
fileLoader.setRequestHeader(loader.requestHeader);
|
|
465
|
-
fileLoader.setWithCredentials(loader.withCredentials);
|
|
466
|
-
try {
|
|
467
|
-
const text = await fileLoader.loadAsync(subobjectURL);
|
|
468
|
-
return text;
|
|
469
|
-
} catch (e) {
|
|
470
|
-
continue;
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
throw new Error('LDrawLoader: Subobject "' + fileName + '" could not be loaded.');
|
|
474
|
-
}
|
|
475
|
-
parse(text, fileName = null) {
|
|
476
|
-
const loader = this.loader;
|
|
477
|
-
const faces = [];
|
|
478
|
-
const lineSegments = [];
|
|
479
|
-
const conditionalSegments = [];
|
|
480
|
-
const subobjects = [];
|
|
481
|
-
const materials = {};
|
|
482
|
-
const getLocalMaterial = (colorCode) => {
|
|
483
|
-
return materials[colorCode] || null;
|
|
484
|
-
};
|
|
485
|
-
let type = "Model";
|
|
486
|
-
let category = null;
|
|
487
|
-
let keywords = null;
|
|
488
|
-
let totalFaces = 0;
|
|
489
|
-
if (text.indexOf("\r\n") !== -1) {
|
|
490
|
-
text = text.replace(/\r\n/g, "\n");
|
|
491
|
-
}
|
|
492
|
-
const lines = text.split("\n");
|
|
493
|
-
const numLines = lines.length;
|
|
494
|
-
let parsingEmbeddedFiles = false;
|
|
495
|
-
let currentEmbeddedFileName = null;
|
|
496
|
-
let currentEmbeddedText = null;
|
|
497
|
-
let bfcCertified = false;
|
|
498
|
-
let bfcCCW = true;
|
|
499
|
-
let bfcInverted = false;
|
|
500
|
-
let bfcCull = true;
|
|
501
|
-
let startingConstructionStep = false;
|
|
502
|
-
for (let lineIndex = 0; lineIndex < numLines; lineIndex++) {
|
|
503
|
-
const line = lines[lineIndex];
|
|
504
|
-
if (line.length === 0)
|
|
505
|
-
continue;
|
|
506
|
-
if (parsingEmbeddedFiles) {
|
|
507
|
-
if (line.startsWith("0 FILE ")) {
|
|
508
|
-
this.setData(currentEmbeddedFileName, currentEmbeddedText);
|
|
509
|
-
currentEmbeddedFileName = line.substring(7);
|
|
510
|
-
currentEmbeddedText = "";
|
|
511
|
-
} else {
|
|
512
|
-
currentEmbeddedText += line + "\n";
|
|
513
|
-
}
|
|
514
|
-
continue;
|
|
515
|
-
}
|
|
516
|
-
const lp = new LineParser(line, lineIndex + 1);
|
|
517
|
-
lp.seekNonSpace();
|
|
518
|
-
if (lp.isAtTheEnd()) {
|
|
519
|
-
continue;
|
|
520
|
-
}
|
|
521
|
-
const lineType = lp.getToken();
|
|
522
|
-
let material;
|
|
523
|
-
let colorCode;
|
|
524
|
-
let segment;
|
|
525
|
-
let ccw;
|
|
526
|
-
let doubleSided;
|
|
527
|
-
let v0, v1, v2, v3, c0, c1;
|
|
528
|
-
switch (lineType) {
|
|
529
|
-
case "0":
|
|
530
|
-
const meta = lp.getToken();
|
|
531
|
-
if (meta) {
|
|
532
|
-
switch (meta) {
|
|
533
|
-
case "!LDRAW_ORG":
|
|
534
|
-
type = lp.getToken();
|
|
535
|
-
break;
|
|
536
|
-
case "!COLOUR":
|
|
537
|
-
material = loader.parseColorMetaDirective(lp);
|
|
538
|
-
if (material) {
|
|
539
|
-
materials[material.userData.code] = material;
|
|
540
|
-
} else {
|
|
541
|
-
console.warn("LDrawLoader: Error parsing material" + lp.getLineNumberString());
|
|
542
|
-
}
|
|
543
|
-
break;
|
|
544
|
-
case "!CATEGORY":
|
|
545
|
-
category = lp.getToken();
|
|
546
|
-
break;
|
|
547
|
-
case "!KEYWORDS":
|
|
548
|
-
const newKeywords = lp.getRemainingString().split(",");
|
|
549
|
-
if (newKeywords.length > 0) {
|
|
550
|
-
if (!keywords) {
|
|
551
|
-
keywords = [];
|
|
552
|
-
}
|
|
553
|
-
newKeywords.forEach(function(keyword) {
|
|
554
|
-
keywords.push(keyword.trim());
|
|
555
|
-
});
|
|
556
|
-
}
|
|
557
|
-
break;
|
|
558
|
-
case "FILE":
|
|
559
|
-
if (lineIndex > 0) {
|
|
560
|
-
parsingEmbeddedFiles = true;
|
|
561
|
-
currentEmbeddedFileName = lp.getRemainingString();
|
|
562
|
-
currentEmbeddedText = "";
|
|
563
|
-
bfcCertified = false;
|
|
564
|
-
bfcCCW = true;
|
|
565
|
-
}
|
|
566
|
-
break;
|
|
567
|
-
case "BFC":
|
|
568
|
-
while (!lp.isAtTheEnd()) {
|
|
569
|
-
const token = lp.getToken();
|
|
570
|
-
switch (token) {
|
|
571
|
-
case "CERTIFY":
|
|
572
|
-
case "NOCERTIFY":
|
|
573
|
-
bfcCertified = token === "CERTIFY";
|
|
574
|
-
bfcCCW = true;
|
|
575
|
-
break;
|
|
576
|
-
case "CW":
|
|
577
|
-
case "CCW":
|
|
578
|
-
bfcCCW = token === "CCW";
|
|
579
|
-
break;
|
|
580
|
-
case "INVERTNEXT":
|
|
581
|
-
bfcInverted = true;
|
|
582
|
-
break;
|
|
583
|
-
case "CLIP":
|
|
584
|
-
case "NOCLIP":
|
|
585
|
-
bfcCull = token === "CLIP";
|
|
586
|
-
break;
|
|
587
|
-
default:
|
|
588
|
-
console.warn('THREE.LDrawLoader: BFC directive "' + token + '" is unknown.');
|
|
589
|
-
break;
|
|
590
|
-
}
|
|
591
|
-
}
|
|
592
|
-
break;
|
|
593
|
-
case "STEP":
|
|
594
|
-
startingConstructionStep = true;
|
|
595
|
-
break;
|
|
596
|
-
default:
|
|
597
|
-
break;
|
|
598
|
-
}
|
|
599
|
-
}
|
|
600
|
-
break;
|
|
601
|
-
case "1":
|
|
602
|
-
colorCode = lp.getToken();
|
|
603
|
-
material = getLocalMaterial(colorCode);
|
|
604
|
-
const posX = parseFloat(lp.getToken());
|
|
605
|
-
const posY = parseFloat(lp.getToken());
|
|
606
|
-
const posZ = parseFloat(lp.getToken());
|
|
607
|
-
const m0 = parseFloat(lp.getToken());
|
|
608
|
-
const m1 = parseFloat(lp.getToken());
|
|
609
|
-
const m2 = parseFloat(lp.getToken());
|
|
610
|
-
const m3 = parseFloat(lp.getToken());
|
|
611
|
-
const m4 = parseFloat(lp.getToken());
|
|
612
|
-
const m5 = parseFloat(lp.getToken());
|
|
613
|
-
const m6 = parseFloat(lp.getToken());
|
|
614
|
-
const m7 = parseFloat(lp.getToken());
|
|
615
|
-
const m8 = parseFloat(lp.getToken());
|
|
616
|
-
const matrix = new Matrix4().set(m0, m1, m2, posX, m3, m4, m5, posY, m6, m7, m8, posZ, 0, 0, 0, 1);
|
|
617
|
-
let fileName2 = lp.getRemainingString().trim().replace(/\\/g, "/");
|
|
618
|
-
if (loader.fileMap[fileName2]) {
|
|
619
|
-
fileName2 = loader.fileMap[fileName2];
|
|
620
|
-
} else {
|
|
621
|
-
if (fileName2.startsWith("s/")) {
|
|
622
|
-
fileName2 = "parts/" + fileName2;
|
|
623
|
-
} else if (fileName2.startsWith("48/")) {
|
|
624
|
-
fileName2 = "p/" + fileName2;
|
|
625
|
-
}
|
|
626
|
-
}
|
|
627
|
-
subobjects.push({
|
|
628
|
-
material,
|
|
629
|
-
colorCode,
|
|
630
|
-
matrix,
|
|
631
|
-
fileName: fileName2,
|
|
632
|
-
inverted: bfcInverted,
|
|
633
|
-
startingConstructionStep
|
|
634
|
-
});
|
|
635
|
-
bfcInverted = false;
|
|
636
|
-
break;
|
|
637
|
-
case "2":
|
|
638
|
-
colorCode = lp.getToken();
|
|
639
|
-
material = getLocalMaterial(colorCode);
|
|
640
|
-
v0 = lp.getVector();
|
|
641
|
-
v1 = lp.getVector();
|
|
642
|
-
segment = {
|
|
643
|
-
material,
|
|
644
|
-
colorCode,
|
|
645
|
-
vertices: [v0, v1]
|
|
646
|
-
};
|
|
647
|
-
lineSegments.push(segment);
|
|
648
|
-
break;
|
|
649
|
-
case "5":
|
|
650
|
-
colorCode = lp.getToken();
|
|
651
|
-
material = getLocalMaterial(colorCode);
|
|
652
|
-
v0 = lp.getVector();
|
|
653
|
-
v1 = lp.getVector();
|
|
654
|
-
c0 = lp.getVector();
|
|
655
|
-
c1 = lp.getVector();
|
|
656
|
-
segment = {
|
|
657
|
-
material,
|
|
658
|
-
colorCode,
|
|
659
|
-
vertices: [v0, v1],
|
|
660
|
-
controlPoints: [c0, c1]
|
|
661
|
-
};
|
|
662
|
-
conditionalSegments.push(segment);
|
|
663
|
-
break;
|
|
664
|
-
case "3":
|
|
665
|
-
colorCode = lp.getToken();
|
|
666
|
-
material = getLocalMaterial(colorCode);
|
|
667
|
-
ccw = bfcCCW;
|
|
668
|
-
doubleSided = !bfcCertified || !bfcCull;
|
|
669
|
-
if (ccw === true) {
|
|
670
|
-
v0 = lp.getVector();
|
|
671
|
-
v1 = lp.getVector();
|
|
672
|
-
v2 = lp.getVector();
|
|
673
|
-
} else {
|
|
674
|
-
v2 = lp.getVector();
|
|
675
|
-
v1 = lp.getVector();
|
|
676
|
-
v0 = lp.getVector();
|
|
677
|
-
}
|
|
678
|
-
faces.push({
|
|
679
|
-
material,
|
|
680
|
-
colorCode,
|
|
681
|
-
faceNormal: null,
|
|
682
|
-
vertices: [v0, v1, v2],
|
|
683
|
-
normals: [null, null, null]
|
|
684
|
-
});
|
|
685
|
-
totalFaces++;
|
|
686
|
-
if (doubleSided === true) {
|
|
687
|
-
faces.push({
|
|
688
|
-
material,
|
|
689
|
-
colorCode,
|
|
690
|
-
faceNormal: null,
|
|
691
|
-
vertices: [v2, v1, v0],
|
|
692
|
-
normals: [null, null, null]
|
|
693
|
-
});
|
|
694
|
-
totalFaces++;
|
|
695
|
-
}
|
|
696
|
-
break;
|
|
697
|
-
case "4":
|
|
698
|
-
colorCode = lp.getToken();
|
|
699
|
-
material = getLocalMaterial(colorCode);
|
|
700
|
-
ccw = bfcCCW;
|
|
701
|
-
doubleSided = !bfcCertified || !bfcCull;
|
|
702
|
-
if (ccw === true) {
|
|
703
|
-
v0 = lp.getVector();
|
|
704
|
-
v1 = lp.getVector();
|
|
705
|
-
v2 = lp.getVector();
|
|
706
|
-
v3 = lp.getVector();
|
|
707
|
-
} else {
|
|
708
|
-
v3 = lp.getVector();
|
|
709
|
-
v2 = lp.getVector();
|
|
710
|
-
v1 = lp.getVector();
|
|
711
|
-
v0 = lp.getVector();
|
|
712
|
-
}
|
|
713
|
-
faces.push({
|
|
714
|
-
material,
|
|
715
|
-
colorCode,
|
|
716
|
-
faceNormal: null,
|
|
717
|
-
vertices: [v0, v1, v2, v3],
|
|
718
|
-
normals: [null, null, null, null]
|
|
719
|
-
});
|
|
720
|
-
totalFaces += 2;
|
|
721
|
-
if (doubleSided === true) {
|
|
722
|
-
faces.push({
|
|
723
|
-
material,
|
|
724
|
-
colorCode,
|
|
725
|
-
faceNormal: null,
|
|
726
|
-
vertices: [v3, v2, v1, v0],
|
|
727
|
-
normals: [null, null, null, null]
|
|
728
|
-
});
|
|
729
|
-
totalFaces += 2;
|
|
730
|
-
}
|
|
731
|
-
break;
|
|
732
|
-
default:
|
|
733
|
-
throw new Error('LDrawLoader: Unknown line type "' + lineType + '"' + lp.getLineNumberString() + ".");
|
|
734
|
-
}
|
|
735
|
-
}
|
|
736
|
-
if (parsingEmbeddedFiles) {
|
|
737
|
-
this.setData(currentEmbeddedFileName, currentEmbeddedText);
|
|
738
|
-
}
|
|
739
|
-
return {
|
|
740
|
-
faces,
|
|
741
|
-
conditionalSegments,
|
|
742
|
-
lineSegments,
|
|
743
|
-
type,
|
|
744
|
-
category,
|
|
745
|
-
keywords,
|
|
746
|
-
subobjects,
|
|
747
|
-
totalFaces,
|
|
748
|
-
startingConstructionStep,
|
|
749
|
-
materials,
|
|
750
|
-
fileName,
|
|
751
|
-
group: null
|
|
752
|
-
};
|
|
753
|
-
}
|
|
754
|
-
// returns an (optionally cloned) instance of the data
|
|
755
|
-
getData(fileName, clone = true) {
|
|
756
|
-
const key = fileName.toLowerCase();
|
|
757
|
-
const result = this._cache[key];
|
|
758
|
-
if (result === null || result instanceof Promise) {
|
|
759
|
-
return null;
|
|
760
|
-
}
|
|
761
|
-
if (clone) {
|
|
762
|
-
return this.cloneResult(result);
|
|
763
|
-
} else {
|
|
764
|
-
return result;
|
|
765
|
-
}
|
|
766
|
-
}
|
|
767
|
-
// kicks off a fetch and parse of the requested data if it hasn't already been loaded. Returns when
|
|
768
|
-
// the data is ready to use and can be retrieved synchronously with "getData".
|
|
769
|
-
async ensureDataLoaded(fileName) {
|
|
770
|
-
const key = fileName.toLowerCase();
|
|
771
|
-
if (!(key in this._cache)) {
|
|
772
|
-
this._cache[key] = this.fetchData(fileName).then((text) => {
|
|
773
|
-
const info = this.parse(text, fileName);
|
|
774
|
-
this._cache[key] = info;
|
|
775
|
-
return info;
|
|
776
|
-
});
|
|
777
|
-
}
|
|
778
|
-
await this._cache[key];
|
|
779
|
-
}
|
|
780
|
-
// sets the data in the cache from parsed data
|
|
781
|
-
setData(fileName, text) {
|
|
782
|
-
const key = fileName.toLowerCase();
|
|
783
|
-
this._cache[key] = this.parse(text, fileName);
|
|
784
|
-
}
|
|
785
|
-
}
|
|
786
|
-
function getMaterialFromCode(colorCode, parentColorCode, materialHierarchy, forEdge) {
|
|
787
|
-
const isPassthrough = !forEdge && colorCode === MAIN_COLOUR_CODE || forEdge && colorCode === MAIN_EDGE_COLOUR_CODE;
|
|
788
|
-
if (isPassthrough) {
|
|
789
|
-
colorCode = parentColorCode;
|
|
790
|
-
}
|
|
791
|
-
return materialHierarchy[colorCode] || null;
|
|
792
|
-
}
|
|
793
|
-
class LDrawPartsGeometryCache {
|
|
794
|
-
constructor(loader) {
|
|
795
|
-
this.loader = loader;
|
|
796
|
-
this.parseCache = new LDrawParsedCache(loader);
|
|
797
|
-
this._cache = {};
|
|
798
|
-
}
|
|
799
|
-
// Convert the given file information into a mesh by processing subobjects.
|
|
800
|
-
async processIntoMesh(info) {
|
|
801
|
-
const loader = this.loader;
|
|
802
|
-
const parseCache = this.parseCache;
|
|
803
|
-
const faceMaterials = /* @__PURE__ */ new Set();
|
|
804
|
-
const processInfoSubobjects = async (info2, subobject = null) => {
|
|
805
|
-
const subobjects = info2.subobjects;
|
|
806
|
-
const promises = [];
|
|
807
|
-
for (let i = 0, l = subobjects.length; i < l; i++) {
|
|
808
|
-
const subobject2 = subobjects[i];
|
|
809
|
-
const promise = parseCache.ensureDataLoaded(subobject2.fileName).then(() => {
|
|
810
|
-
const subobjectInfo = parseCache.getData(subobject2.fileName, false);
|
|
811
|
-
if (!isPrimitiveType(subobjectInfo.type)) {
|
|
812
|
-
return this.loadModel(subobject2.fileName).catch((error) => {
|
|
813
|
-
console.warn(error);
|
|
814
|
-
return null;
|
|
815
|
-
});
|
|
816
|
-
}
|
|
817
|
-
return processInfoSubobjects(parseCache.getData(subobject2.fileName), subobject2);
|
|
818
|
-
});
|
|
819
|
-
promises.push(promise);
|
|
820
|
-
}
|
|
821
|
-
const group2 = new Group();
|
|
822
|
-
group2.userData.category = info2.category;
|
|
823
|
-
group2.userData.keywords = info2.keywords;
|
|
824
|
-
info2.group = group2;
|
|
825
|
-
const subobjectInfos = await Promise.all(promises);
|
|
826
|
-
for (let i = 0, l = subobjectInfos.length; i < l; i++) {
|
|
827
|
-
const subobject2 = info2.subobjects[i];
|
|
828
|
-
const subobjectInfo = subobjectInfos[i];
|
|
829
|
-
if (subobjectInfo === null) {
|
|
830
|
-
continue;
|
|
831
|
-
}
|
|
832
|
-
if (subobjectInfo.isGroup) {
|
|
833
|
-
const subobjectGroup = subobjectInfo;
|
|
834
|
-
subobject2.matrix.decompose(subobjectGroup.position, subobjectGroup.quaternion, subobjectGroup.scale);
|
|
835
|
-
subobjectGroup.userData.startingConstructionStep = subobject2.startingConstructionStep;
|
|
836
|
-
subobjectGroup.name = subobject2.fileName;
|
|
837
|
-
loader.applyMaterialsToMesh(subobjectGroup, subobject2.colorCode, info2.materials);
|
|
838
|
-
group2.add(subobjectGroup);
|
|
839
|
-
continue;
|
|
840
|
-
}
|
|
841
|
-
if (subobjectInfo.group.children.length) {
|
|
842
|
-
group2.add(subobjectInfo.group);
|
|
843
|
-
}
|
|
844
|
-
const parentLineSegments = info2.lineSegments;
|
|
845
|
-
const parentConditionalSegments = info2.conditionalSegments;
|
|
846
|
-
const parentFaces = info2.faces;
|
|
847
|
-
const lineSegments = subobjectInfo.lineSegments;
|
|
848
|
-
const conditionalSegments = subobjectInfo.conditionalSegments;
|
|
849
|
-
const faces = subobjectInfo.faces;
|
|
850
|
-
const matrix = subobject2.matrix;
|
|
851
|
-
const inverted = subobject2.inverted;
|
|
852
|
-
const matrixScaleInverted = matrix.determinant() < 0;
|
|
853
|
-
const colorCode = subobject2.colorCode;
|
|
854
|
-
const lineColorCode = colorCode === MAIN_COLOUR_CODE ? MAIN_EDGE_COLOUR_CODE : colorCode;
|
|
855
|
-
for (let i2 = 0, l2 = lineSegments.length; i2 < l2; i2++) {
|
|
856
|
-
const ls = lineSegments[i2];
|
|
857
|
-
const vertices = ls.vertices;
|
|
858
|
-
vertices[0].applyMatrix4(matrix);
|
|
859
|
-
vertices[1].applyMatrix4(matrix);
|
|
860
|
-
ls.colorCode = ls.colorCode === MAIN_EDGE_COLOUR_CODE ? lineColorCode : ls.colorCode;
|
|
861
|
-
ls.material = ls.material || getMaterialFromCode(ls.colorCode, ls.colorCode, info2.materials, true);
|
|
862
|
-
parentLineSegments.push(ls);
|
|
863
|
-
}
|
|
864
|
-
for (let i2 = 0, l2 = conditionalSegments.length; i2 < l2; i2++) {
|
|
865
|
-
const os = conditionalSegments[i2];
|
|
866
|
-
const vertices = os.vertices;
|
|
867
|
-
const controlPoints = os.controlPoints;
|
|
868
|
-
vertices[0].applyMatrix4(matrix);
|
|
869
|
-
vertices[1].applyMatrix4(matrix);
|
|
870
|
-
controlPoints[0].applyMatrix4(matrix);
|
|
871
|
-
controlPoints[1].applyMatrix4(matrix);
|
|
872
|
-
os.colorCode = os.colorCode === MAIN_EDGE_COLOUR_CODE ? lineColorCode : os.colorCode;
|
|
873
|
-
os.material = os.material || getMaterialFromCode(os.colorCode, os.colorCode, info2.materials, true);
|
|
874
|
-
parentConditionalSegments.push(os);
|
|
875
|
-
}
|
|
876
|
-
for (let i2 = 0, l2 = faces.length; i2 < l2; i2++) {
|
|
877
|
-
const tri = faces[i2];
|
|
878
|
-
const vertices = tri.vertices;
|
|
879
|
-
for (let i3 = 0, l3 = vertices.length; i3 < l3; i3++) {
|
|
880
|
-
vertices[i3].applyMatrix4(matrix);
|
|
881
|
-
}
|
|
882
|
-
tri.colorCode = tri.colorCode === MAIN_COLOUR_CODE ? colorCode : tri.colorCode;
|
|
883
|
-
tri.material = tri.material || getMaterialFromCode(tri.colorCode, colorCode, info2.materials, false);
|
|
884
|
-
faceMaterials.add(tri.colorCode);
|
|
885
|
-
if (matrixScaleInverted !== inverted) {
|
|
886
|
-
vertices.reverse();
|
|
887
|
-
}
|
|
888
|
-
parentFaces.push(tri);
|
|
889
|
-
}
|
|
890
|
-
info2.totalFaces += subobjectInfo.totalFaces;
|
|
891
|
-
}
|
|
892
|
-
if (subobject) {
|
|
893
|
-
loader.applyMaterialsToMesh(group2, subobject.colorCode, info2.materials);
|
|
894
|
-
}
|
|
895
|
-
return info2;
|
|
896
|
-
};
|
|
897
|
-
for (let i = 0, l = info.faces; i < l; i++) {
|
|
898
|
-
faceMaterials.add(info.faces[i].colorCode);
|
|
899
|
-
}
|
|
900
|
-
await processInfoSubobjects(info);
|
|
901
|
-
if (loader.smoothNormals) {
|
|
902
|
-
const checkSubSegments = faceMaterials.size > 1;
|
|
903
|
-
generateFaceNormals(info.faces);
|
|
904
|
-
smoothNormals(info.faces, info.lineSegments, checkSubSegments);
|
|
905
|
-
}
|
|
906
|
-
const group = info.group;
|
|
907
|
-
if (info.faces.length > 0) {
|
|
908
|
-
group.add(createObject(info.faces, 3, false, info.totalFaces));
|
|
909
|
-
}
|
|
910
|
-
if (info.lineSegments.length > 0) {
|
|
911
|
-
group.add(createObject(info.lineSegments, 2));
|
|
912
|
-
}
|
|
913
|
-
if (info.conditionalSegments.length > 0) {
|
|
914
|
-
group.add(createObject(info.conditionalSegments, 2, true));
|
|
915
|
-
}
|
|
916
|
-
return group;
|
|
917
|
-
}
|
|
918
|
-
hasCachedModel(fileName) {
|
|
919
|
-
return fileName !== null && fileName.toLowerCase() in this._cache;
|
|
920
|
-
}
|
|
921
|
-
async getCachedModel(fileName) {
|
|
922
|
-
if (fileName !== null && this.hasCachedModel(fileName)) {
|
|
923
|
-
const key = fileName.toLowerCase();
|
|
924
|
-
const group = await this._cache[key];
|
|
925
|
-
return group.clone();
|
|
926
|
-
} else {
|
|
927
|
-
return null;
|
|
928
|
-
}
|
|
929
|
-
}
|
|
930
|
-
// Loads and parses the model with the given file name. Returns a cached copy if available.
|
|
931
|
-
async loadModel(fileName) {
|
|
932
|
-
const parseCache = this.parseCache;
|
|
933
|
-
const key = fileName.toLowerCase();
|
|
934
|
-
if (this.hasCachedModel(fileName)) {
|
|
935
|
-
return this.getCachedModel(fileName);
|
|
936
|
-
} else {
|
|
937
|
-
await parseCache.ensureDataLoaded(fileName);
|
|
938
|
-
const info = parseCache.getData(fileName);
|
|
939
|
-
const promise = this.processIntoMesh(info);
|
|
940
|
-
if (this.hasCachedModel(fileName)) {
|
|
941
|
-
return this.getCachedModel(fileName);
|
|
942
|
-
}
|
|
943
|
-
if (isPartType(info.type)) {
|
|
944
|
-
this._cache[key] = promise;
|
|
945
|
-
}
|
|
946
|
-
const group = await promise;
|
|
947
|
-
return group.clone();
|
|
948
|
-
}
|
|
949
|
-
}
|
|
950
|
-
// parses the given model text into a renderable object. Returns cached copy if available.
|
|
951
|
-
async parseModel(text) {
|
|
952
|
-
const parseCache = this.parseCache;
|
|
953
|
-
const info = parseCache.parse(text);
|
|
954
|
-
if (isPartType(info.type) && this.hasCachedModel(info.fileName)) {
|
|
955
|
-
return this.getCachedModel(info.fileName);
|
|
956
|
-
}
|
|
957
|
-
return this.processIntoMesh(info);
|
|
958
|
-
}
|
|
959
|
-
}
|
|
960
|
-
function sortByMaterial(a, b) {
|
|
961
|
-
if (a.colorCode === b.colorCode) {
|
|
962
|
-
return 0;
|
|
963
|
-
}
|
|
964
|
-
if (a.colorCode < b.colorCode) {
|
|
965
|
-
return -1;
|
|
966
|
-
}
|
|
967
|
-
return 1;
|
|
968
|
-
}
|
|
969
|
-
function createObject(elements, elementSize, isConditionalSegments = false, totalElements = null) {
|
|
970
|
-
elements.sort(sortByMaterial);
|
|
971
|
-
if (totalElements === null) {
|
|
972
|
-
totalElements = elements.length;
|
|
973
|
-
}
|
|
974
|
-
const positions = new Float32Array(elementSize * totalElements * 3);
|
|
975
|
-
const normals = elementSize === 3 ? new Float32Array(elementSize * totalElements * 3) : null;
|
|
976
|
-
const materials = [];
|
|
977
|
-
const quadArray = new Array(6);
|
|
978
|
-
const bufferGeometry = new BufferGeometry();
|
|
979
|
-
let prevMaterial = null;
|
|
980
|
-
let index0 = 0;
|
|
981
|
-
let numGroupVerts = 0;
|
|
982
|
-
let offset = 0;
|
|
983
|
-
for (let iElem = 0, nElem = elements.length; iElem < nElem; iElem++) {
|
|
984
|
-
const elem = elements[iElem];
|
|
985
|
-
let vertices = elem.vertices;
|
|
986
|
-
if (vertices.length === 4) {
|
|
987
|
-
quadArray[0] = vertices[0];
|
|
988
|
-
quadArray[1] = vertices[1];
|
|
989
|
-
quadArray[2] = vertices[2];
|
|
990
|
-
quadArray[3] = vertices[0];
|
|
991
|
-
quadArray[4] = vertices[2];
|
|
992
|
-
quadArray[5] = vertices[3];
|
|
993
|
-
vertices = quadArray;
|
|
994
|
-
}
|
|
995
|
-
for (let j = 0, l = vertices.length; j < l; j++) {
|
|
996
|
-
const v = vertices[j];
|
|
997
|
-
const index = offset + j * 3;
|
|
998
|
-
positions[index + 0] = v.x;
|
|
999
|
-
positions[index + 1] = v.y;
|
|
1000
|
-
positions[index + 2] = v.z;
|
|
1001
|
-
}
|
|
1002
|
-
if (elementSize === 3) {
|
|
1003
|
-
if (!elem.faceNormal) {
|
|
1004
|
-
const v0 = vertices[0];
|
|
1005
|
-
const v1 = vertices[1];
|
|
1006
|
-
const v2 = vertices[2];
|
|
1007
|
-
_tempVec0.subVectors(v1, v0);
|
|
1008
|
-
_tempVec1.subVectors(v2, v1);
|
|
1009
|
-
elem.faceNormal = new Vector3().crossVectors(_tempVec0, _tempVec1).normalize();
|
|
1010
|
-
}
|
|
1011
|
-
let elemNormals = elem.normals;
|
|
1012
|
-
if (elemNormals.length === 4) {
|
|
1013
|
-
quadArray[0] = elemNormals[0];
|
|
1014
|
-
quadArray[1] = elemNormals[1];
|
|
1015
|
-
quadArray[2] = elemNormals[2];
|
|
1016
|
-
quadArray[3] = elemNormals[0];
|
|
1017
|
-
quadArray[4] = elemNormals[2];
|
|
1018
|
-
quadArray[5] = elemNormals[3];
|
|
1019
|
-
elemNormals = quadArray;
|
|
1020
|
-
}
|
|
1021
|
-
for (let j = 0, l = elemNormals.length; j < l; j++) {
|
|
1022
|
-
let n = elem.faceNormal;
|
|
1023
|
-
if (elemNormals[j]) {
|
|
1024
|
-
n = elemNormals[j].norm;
|
|
1025
|
-
}
|
|
1026
|
-
const index = offset + j * 3;
|
|
1027
|
-
normals[index + 0] = n.x;
|
|
1028
|
-
normals[index + 1] = n.y;
|
|
1029
|
-
normals[index + 2] = n.z;
|
|
1030
|
-
}
|
|
1031
|
-
}
|
|
1032
|
-
if (prevMaterial !== elem.colorCode) {
|
|
1033
|
-
if (prevMaterial !== null) {
|
|
1034
|
-
bufferGeometry.addGroup(index0, numGroupVerts, materials.length - 1);
|
|
1035
|
-
}
|
|
1036
|
-
const material = elem.material;
|
|
1037
|
-
if (material !== null) {
|
|
1038
|
-
if (elementSize === 3) {
|
|
1039
|
-
materials.push(material);
|
|
1040
|
-
} else if (elementSize === 2) {
|
|
1041
|
-
if (material !== null) {
|
|
1042
|
-
if (isConditionalSegments) {
|
|
1043
|
-
materials.push(material.userData.edgeMaterial.userData.conditionalEdgeMaterial);
|
|
1044
|
-
} else {
|
|
1045
|
-
materials.push(material.userData.edgeMaterial);
|
|
1046
|
-
}
|
|
1047
|
-
} else {
|
|
1048
|
-
materials.push(null);
|
|
1049
|
-
}
|
|
1050
|
-
}
|
|
1051
|
-
} else {
|
|
1052
|
-
materials.push(elem.colorCode);
|
|
1053
|
-
}
|
|
1054
|
-
prevMaterial = elem.colorCode;
|
|
1055
|
-
index0 = offset / 3;
|
|
1056
|
-
numGroupVerts = vertices.length;
|
|
1057
|
-
} else {
|
|
1058
|
-
numGroupVerts += vertices.length;
|
|
1059
|
-
}
|
|
1060
|
-
offset += 3 * vertices.length;
|
|
1061
|
-
}
|
|
1062
|
-
if (numGroupVerts > 0) {
|
|
1063
|
-
bufferGeometry.addGroup(index0, Infinity, materials.length - 1);
|
|
1064
|
-
}
|
|
1065
|
-
bufferGeometry.setAttribute("position", new BufferAttribute(positions, 3));
|
|
1066
|
-
if (normals !== null) {
|
|
1067
|
-
bufferGeometry.setAttribute("normal", new BufferAttribute(normals, 3));
|
|
1068
|
-
}
|
|
1069
|
-
let object3d = null;
|
|
1070
|
-
if (elementSize === 2) {
|
|
1071
|
-
if (isConditionalSegments) {
|
|
1072
|
-
object3d = new ConditionalLineSegments(bufferGeometry, materials.length === 1 ? materials[0] : materials);
|
|
1073
|
-
} else {
|
|
1074
|
-
object3d = new LineSegments(bufferGeometry, materials.length === 1 ? materials[0] : materials);
|
|
1075
|
-
}
|
|
1076
|
-
} else if (elementSize === 3) {
|
|
1077
|
-
object3d = new Mesh(bufferGeometry, materials.length === 1 ? materials[0] : materials);
|
|
1078
|
-
}
|
|
1079
|
-
if (isConditionalSegments) {
|
|
1080
|
-
object3d.isConditionalLine = true;
|
|
1081
|
-
const controlArray0 = new Float32Array(elements.length * 3 * 2);
|
|
1082
|
-
const controlArray1 = new Float32Array(elements.length * 3 * 2);
|
|
1083
|
-
const directionArray = new Float32Array(elements.length * 3 * 2);
|
|
1084
|
-
for (let i = 0, l = elements.length; i < l; i++) {
|
|
1085
|
-
const os = elements[i];
|
|
1086
|
-
const vertices = os.vertices;
|
|
1087
|
-
const controlPoints = os.controlPoints;
|
|
1088
|
-
const c0 = controlPoints[0];
|
|
1089
|
-
const c1 = controlPoints[1];
|
|
1090
|
-
const v0 = vertices[0];
|
|
1091
|
-
const v1 = vertices[1];
|
|
1092
|
-
const index = i * 3 * 2;
|
|
1093
|
-
controlArray0[index + 0] = c0.x;
|
|
1094
|
-
controlArray0[index + 1] = c0.y;
|
|
1095
|
-
controlArray0[index + 2] = c0.z;
|
|
1096
|
-
controlArray0[index + 3] = c0.x;
|
|
1097
|
-
controlArray0[index + 4] = c0.y;
|
|
1098
|
-
controlArray0[index + 5] = c0.z;
|
|
1099
|
-
controlArray1[index + 0] = c1.x;
|
|
1100
|
-
controlArray1[index + 1] = c1.y;
|
|
1101
|
-
controlArray1[index + 2] = c1.z;
|
|
1102
|
-
controlArray1[index + 3] = c1.x;
|
|
1103
|
-
controlArray1[index + 4] = c1.y;
|
|
1104
|
-
controlArray1[index + 5] = c1.z;
|
|
1105
|
-
directionArray[index + 0] = v1.x - v0.x;
|
|
1106
|
-
directionArray[index + 1] = v1.y - v0.y;
|
|
1107
|
-
directionArray[index + 2] = v1.z - v0.z;
|
|
1108
|
-
directionArray[index + 3] = v1.x - v0.x;
|
|
1109
|
-
directionArray[index + 4] = v1.y - v0.y;
|
|
1110
|
-
directionArray[index + 5] = v1.z - v0.z;
|
|
1111
|
-
}
|
|
1112
|
-
bufferGeometry.setAttribute("control0", new BufferAttribute(controlArray0, 3, false));
|
|
1113
|
-
bufferGeometry.setAttribute("control1", new BufferAttribute(controlArray1, 3, false));
|
|
1114
|
-
bufferGeometry.setAttribute("direction", new BufferAttribute(directionArray, 3, false));
|
|
1115
|
-
}
|
|
1116
|
-
return object3d;
|
|
1117
|
-
}
|
|
1118
|
-
class LDrawLoader extends Loader {
|
|
1119
|
-
constructor(manager) {
|
|
1120
|
-
super(manager);
|
|
1121
|
-
this.materials = [];
|
|
1122
|
-
this.materialLibrary = {};
|
|
1123
|
-
this.partsCache = new LDrawPartsGeometryCache(this);
|
|
1124
|
-
this.fileMap = {};
|
|
1125
|
-
this.setMaterials([]);
|
|
1126
|
-
this.smoothNormals = true;
|
|
1127
|
-
this.partsLibraryPath = "";
|
|
1128
|
-
}
|
|
1129
|
-
setPartsLibraryPath(path) {
|
|
1130
|
-
this.partsLibraryPath = path;
|
|
1131
|
-
return this;
|
|
1132
|
-
}
|
|
1133
|
-
async preloadMaterials(url) {
|
|
1134
|
-
const fileLoader = new FileLoader(this.manager);
|
|
1135
|
-
fileLoader.setPath(this.path);
|
|
1136
|
-
fileLoader.setRequestHeader(this.requestHeader);
|
|
1137
|
-
fileLoader.setWithCredentials(this.withCredentials);
|
|
1138
|
-
const text = await fileLoader.loadAsync(url);
|
|
1139
|
-
const colorLineRegex = /^0 !COLOUR/;
|
|
1140
|
-
const lines = text.split(/[\n\r]/g);
|
|
1141
|
-
const materials = [];
|
|
1142
|
-
for (let i = 0, l = lines.length; i < l; i++) {
|
|
1143
|
-
const line = lines[i];
|
|
1144
|
-
if (colorLineRegex.test(line)) {
|
|
1145
|
-
const directive = line.replace(colorLineRegex, "");
|
|
1146
|
-
const material = this.parseColorMetaDirective(new LineParser(directive));
|
|
1147
|
-
materials.push(material);
|
|
1148
|
-
}
|
|
1149
|
-
}
|
|
1150
|
-
this.setMaterials(materials);
|
|
1151
|
-
}
|
|
1152
|
-
load(url, onLoad, onProgress, onError) {
|
|
1153
|
-
const fileLoader = new FileLoader(this.manager);
|
|
1154
|
-
fileLoader.setPath(this.path);
|
|
1155
|
-
fileLoader.setRequestHeader(this.requestHeader);
|
|
1156
|
-
fileLoader.setWithCredentials(this.withCredentials);
|
|
1157
|
-
fileLoader.load(
|
|
1158
|
-
url,
|
|
1159
|
-
(text) => {
|
|
1160
|
-
this.partsCache.parseModel(text, this.materialLibrary).then((group) => {
|
|
1161
|
-
this.applyMaterialsToMesh(group, MAIN_COLOUR_CODE, this.materialLibrary, true);
|
|
1162
|
-
this.computeConstructionSteps(group);
|
|
1163
|
-
onLoad(group);
|
|
1164
|
-
}).catch(onError);
|
|
1165
|
-
},
|
|
1166
|
-
onProgress,
|
|
1167
|
-
onError
|
|
1168
|
-
);
|
|
1169
|
-
}
|
|
1170
|
-
parse(text, onLoad) {
|
|
1171
|
-
this.partsCache.parseModel(text, this.materialLibrary).then((group) => {
|
|
1172
|
-
this.computeConstructionSteps(group);
|
|
1173
|
-
onLoad(group);
|
|
1174
|
-
});
|
|
1175
|
-
}
|
|
1176
|
-
setMaterials(materials) {
|
|
1177
|
-
this.materialLibrary = {};
|
|
1178
|
-
this.materials = [];
|
|
1179
|
-
for (let i = 0, l = materials.length; i < l; i++) {
|
|
1180
|
-
this.addMaterial(materials[i]);
|
|
1181
|
-
}
|
|
1182
|
-
this.addMaterial(this.parseColorMetaDirective(new LineParser("Main_Colour CODE 16 VALUE #FF8080 EDGE #333333")));
|
|
1183
|
-
this.addMaterial(this.parseColorMetaDirective(new LineParser("Edge_Colour CODE 24 VALUE #A0A0A0 EDGE #333333")));
|
|
1184
|
-
return this;
|
|
1185
|
-
}
|
|
1186
|
-
setFileMap(fileMap) {
|
|
1187
|
-
this.fileMap = fileMap;
|
|
1188
|
-
return this;
|
|
1189
|
-
}
|
|
1190
|
-
addMaterial(material) {
|
|
1191
|
-
const matLib = this.materialLibrary;
|
|
1192
|
-
if (!matLib[material.userData.code]) {
|
|
1193
|
-
this.materials.push(material);
|
|
1194
|
-
matLib[material.userData.code] = material;
|
|
1195
|
-
}
|
|
1196
|
-
return this;
|
|
1197
|
-
}
|
|
1198
|
-
getMaterial(colorCode) {
|
|
1199
|
-
if (colorCode.startsWith("0x2")) {
|
|
1200
|
-
const color = colorCode.substring(3);
|
|
1201
|
-
return this.parseColorMetaDirective(
|
|
1202
|
-
new LineParser("Direct_Color_" + color + " CODE -1 VALUE #" + color + " EDGE #" + color)
|
|
1203
|
-
);
|
|
1204
|
-
}
|
|
1205
|
-
return this.materialLibrary[colorCode] || null;
|
|
1206
|
-
}
|
|
1207
|
-
// Applies the appropriate materials to a prebuilt hierarchy of geometry. Assumes that color codes are present
|
|
1208
|
-
// in the material array if they need to be filled in.
|
|
1209
|
-
applyMaterialsToMesh(group, parentColorCode, materialHierarchy, finalMaterialPass = false) {
|
|
1210
|
-
const loader = this;
|
|
1211
|
-
const parentIsPassthrough = parentColorCode === MAIN_COLOUR_CODE;
|
|
1212
|
-
group.traverse((c) => {
|
|
1213
|
-
if (c.isMesh || c.isLineSegments) {
|
|
1214
|
-
if (Array.isArray(c.material)) {
|
|
1215
|
-
for (let i = 0, l = c.material.length; i < l; i++) {
|
|
1216
|
-
if (!c.material[i].isMaterial) {
|
|
1217
|
-
c.material[i] = getMaterial(c, c.material[i]);
|
|
1218
|
-
}
|
|
1219
|
-
}
|
|
1220
|
-
} else if (!c.material.isMaterial) {
|
|
1221
|
-
c.material = getMaterial(c, c.material);
|
|
1222
|
-
}
|
|
1223
|
-
}
|
|
1224
|
-
});
|
|
1225
|
-
function getMaterial(c, colorCode) {
|
|
1226
|
-
if (parentIsPassthrough && !(colorCode in materialHierarchy) && !finalMaterialPass) {
|
|
1227
|
-
return colorCode;
|
|
1228
|
-
}
|
|
1229
|
-
const forEdge = c.isLineSegments || c.isConditionalLine;
|
|
1230
|
-
const isPassthrough = !forEdge && colorCode === MAIN_COLOUR_CODE || forEdge && colorCode === MAIN_EDGE_COLOUR_CODE;
|
|
1231
|
-
if (isPassthrough) {
|
|
1232
|
-
colorCode = parentColorCode;
|
|
1233
|
-
}
|
|
1234
|
-
let material = null;
|
|
1235
|
-
if (colorCode in materialHierarchy) {
|
|
1236
|
-
material = materialHierarchy[colorCode];
|
|
1237
|
-
} else if (finalMaterialPass) {
|
|
1238
|
-
material = loader.getMaterial(colorCode);
|
|
1239
|
-
if (material === null) {
|
|
1240
|
-
throw new Error(`LDrawLoader: Material properties for code ${colorCode} not available.`);
|
|
1241
|
-
}
|
|
1242
|
-
} else {
|
|
1243
|
-
return colorCode;
|
|
1244
|
-
}
|
|
1245
|
-
if (c.isLineSegments) {
|
|
1246
|
-
material = material.userData.edgeMaterial;
|
|
1247
|
-
if (c.isConditionalLine) {
|
|
1248
|
-
material = material.userData.conditionalEdgeMaterial;
|
|
1249
|
-
}
|
|
1250
|
-
}
|
|
1251
|
-
return material;
|
|
1252
|
-
}
|
|
1253
|
-
}
|
|
1254
|
-
getMainMaterial() {
|
|
1255
|
-
return this.getMaterial(MAIN_COLOUR_CODE);
|
|
1256
|
-
}
|
|
1257
|
-
getMainEdgeMaterial() {
|
|
1258
|
-
return this.getMaterial(MAIN_EDGE_COLOUR_CODE);
|
|
1259
|
-
}
|
|
1260
|
-
parseColorMetaDirective(lineParser) {
|
|
1261
|
-
let code = null;
|
|
1262
|
-
let color = 16711935;
|
|
1263
|
-
let edgeColor = 16711935;
|
|
1264
|
-
let alpha = 1;
|
|
1265
|
-
let isTransparent = false;
|
|
1266
|
-
let luminance = 0;
|
|
1267
|
-
let finishType = FINISH_TYPE_DEFAULT;
|
|
1268
|
-
let edgeMaterial = null;
|
|
1269
|
-
const name = lineParser.getToken();
|
|
1270
|
-
if (!name) {
|
|
1271
|
-
throw new Error(
|
|
1272
|
-
'LDrawLoader: Material name was expected after "!COLOUR tag' + lineParser.getLineNumberString() + "."
|
|
1273
|
-
);
|
|
1274
|
-
}
|
|
1275
|
-
let token = null;
|
|
1276
|
-
while (true) {
|
|
1277
|
-
token = lineParser.getToken();
|
|
1278
|
-
if (!token) {
|
|
1279
|
-
break;
|
|
1280
|
-
}
|
|
1281
|
-
switch (token.toUpperCase()) {
|
|
1282
|
-
case "CODE":
|
|
1283
|
-
code = lineParser.getToken();
|
|
1284
|
-
break;
|
|
1285
|
-
case "VALUE":
|
|
1286
|
-
color = lineParser.getToken();
|
|
1287
|
-
if (color.startsWith("0x")) {
|
|
1288
|
-
color = "#" + color.substring(2);
|
|
1289
|
-
} else if (!color.startsWith("#")) {
|
|
1290
|
-
throw new Error(
|
|
1291
|
-
"LDrawLoader: Invalid color while parsing material" + lineParser.getLineNumberString() + "."
|
|
1292
|
-
);
|
|
1293
|
-
}
|
|
1294
|
-
break;
|
|
1295
|
-
case "EDGE":
|
|
1296
|
-
edgeColor = lineParser.getToken();
|
|
1297
|
-
if (edgeColor.startsWith("0x")) {
|
|
1298
|
-
edgeColor = "#" + edgeColor.substring(2);
|
|
1299
|
-
} else if (!edgeColor.startsWith("#")) {
|
|
1300
|
-
edgeMaterial = this.getMaterial(edgeColor);
|
|
1301
|
-
if (!edgeMaterial) {
|
|
1302
|
-
throw new Error(
|
|
1303
|
-
"LDrawLoader: Invalid edge color while parsing material" + lineParser.getLineNumberString() + "."
|
|
1304
|
-
);
|
|
1305
|
-
}
|
|
1306
|
-
edgeMaterial = edgeMaterial.userData.edgeMaterial;
|
|
1307
|
-
}
|
|
1308
|
-
break;
|
|
1309
|
-
case "ALPHA":
|
|
1310
|
-
alpha = parseInt(lineParser.getToken());
|
|
1311
|
-
if (isNaN(alpha)) {
|
|
1312
|
-
throw new Error(
|
|
1313
|
-
"LDrawLoader: Invalid alpha value in material definition" + lineParser.getLineNumberString() + "."
|
|
1314
|
-
);
|
|
1315
|
-
}
|
|
1316
|
-
alpha = Math.max(0, Math.min(1, alpha / 255));
|
|
1317
|
-
if (alpha < 1) {
|
|
1318
|
-
isTransparent = true;
|
|
1319
|
-
}
|
|
1320
|
-
break;
|
|
1321
|
-
case "LUMINANCE":
|
|
1322
|
-
luminance = parseInt(lineParser.getToken());
|
|
1323
|
-
if (isNaN(luminance)) {
|
|
1324
|
-
throw new Error(
|
|
1325
|
-
"LDrawLoader: Invalid luminance value in material definition" + LineParser.getLineNumberString() + "."
|
|
1326
|
-
);
|
|
1327
|
-
}
|
|
1328
|
-
luminance = Math.max(0, Math.min(1, luminance / 255));
|
|
1329
|
-
break;
|
|
1330
|
-
case "CHROME":
|
|
1331
|
-
finishType = FINISH_TYPE_CHROME;
|
|
1332
|
-
break;
|
|
1333
|
-
case "PEARLESCENT":
|
|
1334
|
-
finishType = FINISH_TYPE_PEARLESCENT;
|
|
1335
|
-
break;
|
|
1336
|
-
case "RUBBER":
|
|
1337
|
-
finishType = FINISH_TYPE_RUBBER;
|
|
1338
|
-
break;
|
|
1339
|
-
case "MATTE_METALLIC":
|
|
1340
|
-
finishType = FINISH_TYPE_MATTE_METALLIC;
|
|
1341
|
-
break;
|
|
1342
|
-
case "METAL":
|
|
1343
|
-
finishType = FINISH_TYPE_METAL;
|
|
1344
|
-
break;
|
|
1345
|
-
case "MATERIAL":
|
|
1346
|
-
lineParser.setToEnd();
|
|
1347
|
-
break;
|
|
1348
|
-
default:
|
|
1349
|
-
throw new Error(
|
|
1350
|
-
'LDrawLoader: Unknown token "' + token + '" while parsing material' + lineParser.getLineNumberString() + "."
|
|
1351
|
-
);
|
|
1352
|
-
}
|
|
1353
|
-
}
|
|
1354
|
-
let material = null;
|
|
1355
|
-
switch (finishType) {
|
|
1356
|
-
case FINISH_TYPE_DEFAULT:
|
|
1357
|
-
material = new MeshStandardMaterial({ color, roughness: 0.3, metalness: 0 });
|
|
1358
|
-
break;
|
|
1359
|
-
case FINISH_TYPE_PEARLESCENT:
|
|
1360
|
-
material = new MeshStandardMaterial({ color, roughness: 0.3, metalness: 0.25 });
|
|
1361
|
-
break;
|
|
1362
|
-
case FINISH_TYPE_CHROME:
|
|
1363
|
-
material = new MeshStandardMaterial({ color, roughness: 0, metalness: 1 });
|
|
1364
|
-
break;
|
|
1365
|
-
case FINISH_TYPE_RUBBER:
|
|
1366
|
-
material = new MeshStandardMaterial({ color, roughness: 0.9, metalness: 0 });
|
|
1367
|
-
break;
|
|
1368
|
-
case FINISH_TYPE_MATTE_METALLIC:
|
|
1369
|
-
material = new MeshStandardMaterial({ color, roughness: 0.8, metalness: 0.4 });
|
|
1370
|
-
break;
|
|
1371
|
-
case FINISH_TYPE_METAL:
|
|
1372
|
-
material = new MeshStandardMaterial({ color, roughness: 0.2, metalness: 0.85 });
|
|
1373
|
-
break;
|
|
1374
|
-
default:
|
|
1375
|
-
break;
|
|
1376
|
-
}
|
|
1377
|
-
material.transparent = isTransparent;
|
|
1378
|
-
material.premultipliedAlpha = true;
|
|
1379
|
-
material.opacity = alpha;
|
|
1380
|
-
material.depthWrite = !isTransparent;
|
|
1381
|
-
material.polygonOffset = true;
|
|
1382
|
-
material.polygonOffsetFactor = 1;
|
|
1383
|
-
if (luminance !== 0) {
|
|
1384
|
-
material.emissive.set(material.color).multiplyScalar(luminance);
|
|
1385
|
-
}
|
|
1386
|
-
if (!edgeMaterial) {
|
|
1387
|
-
edgeMaterial = new LineBasicMaterial({
|
|
1388
|
-
color: edgeColor,
|
|
1389
|
-
transparent: isTransparent,
|
|
1390
|
-
opacity: alpha,
|
|
1391
|
-
depthWrite: !isTransparent
|
|
1392
|
-
});
|
|
1393
|
-
edgeMaterial.userData.code = code;
|
|
1394
|
-
edgeMaterial.name = name + " - Edge";
|
|
1395
|
-
edgeMaterial.userData.conditionalEdgeMaterial = new LDrawConditionalLineMaterial({
|
|
1396
|
-
fog: true,
|
|
1397
|
-
transparent: isTransparent,
|
|
1398
|
-
depthWrite: !isTransparent,
|
|
1399
|
-
color: edgeColor,
|
|
1400
|
-
opacity: alpha
|
|
1401
|
-
});
|
|
1402
|
-
}
|
|
1403
|
-
material.userData.code = code;
|
|
1404
|
-
material.name = name;
|
|
1405
|
-
material.userData.edgeMaterial = edgeMaterial;
|
|
1406
|
-
this.addMaterial(material);
|
|
1407
|
-
return material;
|
|
1408
|
-
}
|
|
1409
|
-
computeConstructionSteps(model) {
|
|
1410
|
-
let stepNumber = 0;
|
|
1411
|
-
model.traverse((c) => {
|
|
1412
|
-
if (c.isGroup) {
|
|
1413
|
-
if (c.userData.startingConstructionStep) {
|
|
1414
|
-
stepNumber++;
|
|
1415
|
-
}
|
|
1416
|
-
c.userData.constructionStep = stepNumber;
|
|
1417
|
-
}
|
|
1418
|
-
});
|
|
1419
|
-
model.userData.numConstructionSteps = stepNumber + 1;
|
|
1420
|
-
}
|
|
1421
|
-
}
|
|
1422
|
-
export {
|
|
1423
|
-
LDrawLoader
|
|
1424
|
-
};
|