@needle-tools/three 0.160.2 → 0.162.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (961) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +86 -86
  3. package/build/three.cjs +53267 -53092
  4. package/build/three.module.js +53269 -53094
  5. package/build/three.module.min.js +1 -1
  6. package/examples/fonts/LICENSE +13 -13
  7. package/examples/fonts/README.md +11 -11
  8. package/examples/fonts/droid/NOTICE +190 -190
  9. package/examples/fonts/droid/README.txt +18 -18
  10. package/examples/fonts/ttf/README.md +9 -9
  11. package/examples/jsm/Addons.js +295 -294
  12. package/examples/jsm/animation/AnimationClipCreator.js +116 -116
  13. package/examples/jsm/animation/CCDIKSolver.js +482 -482
  14. package/examples/jsm/animation/MMDAnimationHelper.js +1207 -1207
  15. package/examples/jsm/animation/MMDPhysics.js +1406 -1406
  16. package/examples/jsm/cameras/CinematicCamera.js +208 -208
  17. package/examples/jsm/capabilities/WebGL.js +108 -108
  18. package/examples/jsm/capabilities/WebGPU.js +57 -57
  19. package/examples/jsm/controls/ArcballControls.js +3224 -3224
  20. package/examples/jsm/controls/DragControls.js +282 -221
  21. package/examples/jsm/controls/FirstPersonControls.js +325 -325
  22. package/examples/jsm/controls/FlyControls.js +326 -326
  23. package/examples/jsm/controls/MapControls.js +28 -28
  24. package/examples/jsm/controls/OrbitControls.js +1548 -1521
  25. package/examples/jsm/controls/PointerLockControls.js +162 -162
  26. package/examples/jsm/controls/TrackballControls.js +828 -828
  27. package/examples/jsm/controls/TransformControls.js +1573 -1573
  28. package/examples/jsm/csm/CSM.js +384 -384
  29. package/examples/jsm/csm/CSMFrustum.js +152 -152
  30. package/examples/jsm/csm/CSMHelper.js +193 -193
  31. package/examples/jsm/csm/CSMShader.js +295 -295
  32. package/examples/jsm/curves/CurveExtras.js +422 -422
  33. package/examples/jsm/curves/NURBSCurve.js +80 -80
  34. package/examples/jsm/curves/NURBSSurface.js +52 -52
  35. package/examples/jsm/curves/NURBSUtils.js +542 -487
  36. package/examples/jsm/curves/NURBSVolume.js +62 -0
  37. package/examples/jsm/effects/AnaglyphEffect.js +154 -154
  38. package/examples/jsm/effects/AsciiEffect.js +263 -263
  39. package/examples/jsm/effects/OutlineEffect.js +539 -539
  40. package/examples/jsm/effects/ParallaxBarrierEffect.js +119 -119
  41. package/examples/jsm/effects/PeppersGhostEffect.js +153 -153
  42. package/examples/jsm/effects/StereoEffect.js +55 -55
  43. package/examples/jsm/environments/DebugEnvironment.js +52 -52
  44. package/examples/jsm/environments/RoomEnvironment.js +148 -148
  45. package/examples/jsm/exporters/DRACOExporter.js +267 -267
  46. package/examples/jsm/exporters/EXRExporter.js +579 -579
  47. package/examples/jsm/exporters/GLTFExporter.js +3321 -3311
  48. package/examples/jsm/exporters/KTX2Exporter.js +292 -292
  49. package/examples/jsm/exporters/MMDExporter.js +217 -217
  50. package/examples/jsm/exporters/OBJExporter.js +284 -284
  51. package/examples/jsm/exporters/PLYExporter.js +528 -528
  52. package/examples/jsm/exporters/STLExporter.js +199 -199
  53. package/examples/jsm/exporters/USDZExporter.js +720 -720
  54. package/examples/jsm/geometries/BoxLineGeometry.js +69 -69
  55. package/examples/jsm/geometries/ConvexGeometry.js +53 -53
  56. package/examples/jsm/geometries/DecalGeometry.js +356 -356
  57. package/examples/jsm/geometries/InstancedPointsGeometry.js +174 -174
  58. package/examples/jsm/geometries/ParametricGeometries.js +254 -254
  59. package/examples/jsm/geometries/ParametricGeometry.js +139 -139
  60. package/examples/jsm/geometries/RoundedBoxGeometry.js +155 -155
  61. package/examples/jsm/geometries/SDFGeometryGenerator.js +144 -144
  62. package/examples/jsm/geometries/TeapotGeometry.js +704 -704
  63. package/examples/jsm/geometries/TextGeometry.js +57 -57
  64. package/examples/jsm/helpers/LightProbeHelper.js +130 -130
  65. package/examples/jsm/helpers/OctreeHelper.js +73 -73
  66. package/examples/jsm/helpers/PositionalAudioHelper.js +109 -109
  67. package/examples/jsm/helpers/RectAreaLightHelper.js +85 -85
  68. package/examples/jsm/helpers/TextureHelper.js +237 -237
  69. package/examples/jsm/helpers/VertexNormalsHelper.js +96 -96
  70. package/examples/jsm/helpers/VertexTangentsHelper.js +88 -88
  71. package/examples/jsm/helpers/ViewHelper.js +333 -333
  72. package/examples/jsm/interactive/HTMLMesh.js +572 -572
  73. package/examples/jsm/interactive/InteractiveGroup.js +106 -116
  74. package/examples/jsm/interactive/SelectionBox.js +227 -227
  75. package/examples/jsm/interactive/SelectionHelper.js +104 -104
  76. package/examples/jsm/libs/ammo.wasm.js +822 -822
  77. package/examples/jsm/libs/basis/README.md +46 -46
  78. package/examples/jsm/libs/basis/basis_transcoder.js +21 -21
  79. package/examples/jsm/libs/chevrotain.module.min.js +141 -141
  80. package/examples/jsm/libs/draco/README.md +32 -32
  81. package/examples/jsm/libs/draco/draco_decoder.js +34 -34
  82. package/examples/jsm/libs/draco/draco_encoder.js +33 -33
  83. package/examples/jsm/libs/draco/draco_wasm_wrapper.js +117 -117
  84. package/examples/jsm/libs/draco/gltf/draco_decoder.js +33 -33
  85. package/examples/jsm/libs/draco/gltf/draco_encoder.js +33 -33
  86. package/examples/jsm/libs/draco/gltf/draco_wasm_wrapper.js +116 -116
  87. package/examples/jsm/libs/ecsy.module.js +1792 -1792
  88. package/examples/jsm/libs/fflate.module.js +2474 -2474
  89. package/examples/jsm/libs/ktx-parse.module.js +1 -1
  90. package/examples/jsm/libs/lil-gui.module.min.js +8 -8
  91. package/examples/jsm/libs/lottie_canvas.module.js +14849 -14849
  92. package/examples/jsm/libs/meshopt_decoder.module.js +178 -178
  93. package/examples/jsm/libs/mikktspace.module.js +128 -128
  94. package/examples/jsm/libs/mmdparser.module.js +11530 -11530
  95. package/examples/jsm/libs/motion-controllers.module.js +397 -397
  96. package/examples/jsm/libs/opentype.module.js +14506 -14506
  97. package/examples/jsm/libs/potpack.module.js +124 -124
  98. package/examples/jsm/libs/rhino3dm/rhino3dm.js +21 -8743
  99. package/examples/jsm/libs/rhino3dm/rhino3dm.module.js +15 -8748
  100. package/examples/jsm/libs/rhino3dm/rhino3dm.wasm +0 -0
  101. package/examples/jsm/libs/stats.module.js +167 -167
  102. package/examples/jsm/libs/surfaceNet.js +200 -200
  103. package/examples/jsm/libs/tween.module.js +876 -858
  104. package/examples/jsm/libs/utif.module.js +1664 -1664
  105. package/examples/jsm/libs/zstddec.module.js +1 -1
  106. package/examples/jsm/lights/IESSpotLight.js +25 -25
  107. package/examples/jsm/lights/LightProbeGenerator.js +286 -286
  108. package/examples/jsm/lights/RectAreaLightUniformsLib.js +79 -79
  109. package/examples/jsm/lines/Line2.js +19 -19
  110. package/examples/jsm/lines/LineGeometry.js +79 -79
  111. package/examples/jsm/lines/LineMaterial.js +619 -619
  112. package/examples/jsm/lines/LineSegments2.js +361 -361
  113. package/examples/jsm/lines/LineSegmentsGeometry.js +241 -241
  114. package/examples/jsm/lines/Wireframe.js +56 -56
  115. package/examples/jsm/lines/WireframeGeometry2.js +24 -24
  116. package/examples/jsm/loaders/3DMLoader.js +1764 -1772
  117. package/examples/jsm/loaders/3MFLoader.js +1478 -1478
  118. package/examples/jsm/loaders/AMFLoader.js +521 -521
  119. package/examples/jsm/loaders/BVHLoader.js +437 -437
  120. package/examples/jsm/loaders/ColladaLoader.js +4116 -4116
  121. package/examples/jsm/loaders/DDSLoader.js +318 -318
  122. package/examples/jsm/loaders/DRACOLoader.js +613 -613
  123. package/examples/jsm/loaders/EXRLoader.js +2309 -2309
  124. package/examples/jsm/loaders/FBXLoader.js +4314 -4314
  125. package/examples/jsm/loaders/FontLoader.js +183 -183
  126. package/examples/jsm/loaders/GCodeLoader.js +261 -261
  127. package/examples/jsm/loaders/GLTFLoader.js +4666 -4666
  128. package/examples/jsm/loaders/GLTFLoaderAnimationPointer.js +729 -720
  129. package/examples/jsm/loaders/HDRCubeTextureLoader.js +115 -115
  130. package/examples/jsm/loaders/IESLoader.js +337 -337
  131. package/examples/jsm/loaders/KMZLoader.js +130 -130
  132. package/examples/jsm/loaders/KTX2Loader.js +932 -932
  133. package/examples/jsm/loaders/KTXLoader.js +176 -176
  134. package/examples/jsm/loaders/LDrawLoader.js +2470 -2470
  135. package/examples/jsm/loaders/LUT3dlLoader.js +183 -183
  136. package/examples/jsm/loaders/LUTCubeLoader.js +167 -167
  137. package/examples/jsm/loaders/LUTImageLoader.js +163 -163
  138. package/examples/jsm/loaders/LWOLoader.js +1052 -1052
  139. package/examples/jsm/loaders/LogLuvLoader.js +606 -606
  140. package/examples/jsm/loaders/LottieLoader.js +77 -77
  141. package/examples/jsm/loaders/MD2Loader.js +399 -399
  142. package/examples/jsm/loaders/MDDLoader.js +102 -102
  143. package/examples/jsm/loaders/MMDLoader.js +2276 -2276
  144. package/examples/jsm/loaders/MTLLoader.js +567 -567
  145. package/examples/jsm/loaders/MaterialXLoader.js +852 -852
  146. package/examples/jsm/loaders/NRRDLoader.js +686 -686
  147. package/examples/jsm/loaders/OBJLoader.js +905 -905
  148. package/examples/jsm/loaders/PCDLoader.js +467 -467
  149. package/examples/jsm/loaders/PDBLoader.js +232 -232
  150. package/examples/jsm/loaders/PLYLoader.js +771 -771
  151. package/examples/jsm/loaders/PVRLoader.js +251 -251
  152. package/examples/jsm/loaders/RGBELoader.js +450 -450
  153. package/examples/jsm/loaders/RGBMLoader.js +1065 -1065
  154. package/examples/jsm/loaders/STLLoader.js +410 -410
  155. package/examples/jsm/loaders/SVGLoader.js +3173 -3173
  156. package/examples/jsm/loaders/TDSLoader.js +1124 -1124
  157. package/examples/jsm/loaders/TGALoader.js +517 -517
  158. package/examples/jsm/loaders/TIFFLoader.js +36 -36
  159. package/examples/jsm/loaders/TTFLoader.js +214 -214
  160. package/examples/jsm/loaders/TiltLoader.js +520 -520
  161. package/examples/jsm/loaders/USDZLoader.js +822 -822
  162. package/examples/jsm/loaders/VOXLoader.js +318 -311
  163. package/examples/jsm/loaders/VRMLLoader.js +3537 -3533
  164. package/examples/jsm/loaders/VTKLoader.js +1163 -1163
  165. package/examples/jsm/loaders/XYZLoader.js +106 -106
  166. package/examples/jsm/loaders/lwo/IFFParser.js +1214 -1214
  167. package/examples/jsm/loaders/lwo/LWO2Parser.js +414 -414
  168. package/examples/jsm/loaders/lwo/LWO3Parser.js +373 -373
  169. package/examples/jsm/materials/MeshGouraudMaterial.js +426 -426
  170. package/examples/jsm/materials/MeshPostProcessingMaterial.js +144 -144
  171. package/examples/jsm/math/Capsule.js +82 -82
  172. package/examples/jsm/math/ColorConverter.js +36 -36
  173. package/examples/jsm/math/ConvexHull.js +1271 -1271
  174. package/examples/jsm/math/ImprovedNoise.js +71 -71
  175. package/examples/jsm/math/Lut.js +204 -204
  176. package/examples/jsm/math/MeshSurfaceSampler.js +250 -250
  177. package/examples/jsm/math/OBB.js +423 -423
  178. package/examples/jsm/math/Octree.js +540 -540
  179. package/examples/jsm/math/SimplexNoise.js +444 -444
  180. package/examples/jsm/misc/ConvexObjectBreaker.js +519 -519
  181. package/examples/jsm/misc/GPUComputationRenderer.js +446 -446
  182. package/examples/jsm/misc/Gyroscope.js +66 -66
  183. package/examples/jsm/misc/MD2Character.js +276 -276
  184. package/examples/jsm/misc/MD2CharacterComplex.js +576 -576
  185. package/examples/jsm/misc/MorphAnimMesh.js +75 -75
  186. package/examples/jsm/misc/MorphBlendMesh.js +322 -322
  187. package/examples/jsm/misc/ProgressiveLightMap.js +324 -323
  188. package/examples/jsm/misc/RollerCoaster.js +566 -566
  189. package/examples/jsm/misc/Timer.js +128 -119
  190. package/examples/jsm/misc/TubePainter.js +202 -202
  191. package/examples/jsm/misc/Volume.js +473 -473
  192. package/examples/jsm/misc/VolumeSlice.js +229 -229
  193. package/examples/jsm/modifiers/CurveModifier.js +344 -344
  194. package/examples/jsm/modifiers/EdgeSplitModifier.js +279 -279
  195. package/examples/jsm/modifiers/SimplifyModifier.js +617 -617
  196. package/examples/jsm/modifiers/TessellateModifier.js +307 -307
  197. package/examples/jsm/nodes/Nodes.js +195 -189
  198. package/examples/jsm/nodes/accessors/AccessorsUtils.js +10 -0
  199. package/examples/jsm/nodes/accessors/BitangentNode.js +89 -89
  200. package/examples/jsm/nodes/accessors/BufferAttributeNode.js +127 -127
  201. package/examples/jsm/nodes/accessors/BufferNode.js +30 -30
  202. package/examples/jsm/nodes/accessors/CameraNode.js +119 -120
  203. package/examples/jsm/nodes/accessors/ClippingNode.js +144 -0
  204. package/examples/jsm/nodes/accessors/CubeTextureNode.js +61 -61
  205. package/examples/jsm/nodes/accessors/InstanceNode.js +71 -71
  206. package/examples/jsm/nodes/accessors/InstancedPointsMaterialNode.js +21 -21
  207. package/examples/jsm/nodes/accessors/MaterialNode.js +314 -314
  208. package/examples/jsm/nodes/accessors/MaterialReferenceNode.js +41 -51
  209. package/examples/jsm/nodes/accessors/ModelNode.js +33 -33
  210. package/examples/jsm/nodes/accessors/ModelViewProjectionNode.js +39 -39
  211. package/examples/jsm/nodes/accessors/MorphNode.js +245 -245
  212. package/examples/jsm/nodes/accessors/NormalNode.js +96 -96
  213. package/examples/jsm/nodes/accessors/Object3DNode.js +150 -150
  214. package/examples/jsm/nodes/accessors/PointUVNode.js +26 -26
  215. package/examples/jsm/nodes/accessors/PositionNode.js +104 -104
  216. package/examples/jsm/nodes/accessors/ReferenceNode.js +160 -102
  217. package/examples/jsm/nodes/accessors/ReflectVectorNode.js +35 -35
  218. package/examples/jsm/nodes/accessors/SceneNode.js +52 -52
  219. package/examples/jsm/nodes/accessors/SkinningNode.js +124 -103
  220. package/examples/jsm/nodes/accessors/StorageBufferNode.js +72 -54
  221. package/examples/jsm/nodes/accessors/TangentNode.js +109 -103
  222. package/examples/jsm/nodes/accessors/TextureBicubicNode.js +94 -94
  223. package/examples/jsm/nodes/accessors/TextureNode.js +367 -367
  224. package/examples/jsm/nodes/accessors/TextureSizeNode.js +35 -35
  225. package/examples/jsm/nodes/accessors/TextureStoreNode.js +82 -82
  226. package/examples/jsm/nodes/accessors/UVNode.js +47 -47
  227. package/examples/jsm/nodes/accessors/UniformsNode.js +140 -0
  228. package/examples/jsm/nodes/accessors/UserDataNode.js +29 -29
  229. package/examples/jsm/nodes/accessors/VertexColorNode.js +70 -70
  230. package/examples/jsm/nodes/code/CodeNode.js +84 -78
  231. package/examples/jsm/nodes/code/ExpressionNode.js +37 -37
  232. package/examples/jsm/nodes/code/FunctionCallNode.js +96 -96
  233. package/examples/jsm/nodes/code/FunctionNode.js +138 -138
  234. package/examples/jsm/nodes/code/ScriptableNode.js +488 -488
  235. package/examples/jsm/nodes/code/ScriptableValueNode.js +167 -167
  236. package/examples/jsm/nodes/core/AssignNode.js +128 -72
  237. package/examples/jsm/nodes/core/AttributeNode.js +108 -108
  238. package/examples/jsm/nodes/core/BypassNode.js +45 -45
  239. package/examples/jsm/nodes/core/CacheNode.js +49 -49
  240. package/examples/jsm/nodes/core/ConstNode.js +32 -32
  241. package/examples/jsm/nodes/core/ContextNode.js +61 -61
  242. package/examples/jsm/nodes/core/IndexNode.js +66 -66
  243. package/examples/jsm/nodes/core/InputNode.js +83 -83
  244. package/examples/jsm/nodes/core/LightingModel.js +17 -17
  245. package/examples/jsm/nodes/core/Node.js +493 -483
  246. package/examples/jsm/nodes/core/NodeAttribute.js +15 -15
  247. package/examples/jsm/nodes/core/NodeBuilder.js +1250 -1267
  248. package/examples/jsm/nodes/core/NodeCache.js +26 -26
  249. package/examples/jsm/nodes/core/NodeCode.js +15 -15
  250. package/examples/jsm/nodes/core/NodeFrame.js +143 -135
  251. package/examples/jsm/nodes/core/NodeFunction.js +22 -22
  252. package/examples/jsm/nodes/core/NodeFunctionInput.js +17 -17
  253. package/examples/jsm/nodes/core/NodeKeywords.js +80 -80
  254. package/examples/jsm/nodes/core/NodeParser.js +11 -11
  255. package/examples/jsm/nodes/core/NodeUniform.js +40 -40
  256. package/examples/jsm/nodes/core/NodeUtils.js +210 -210
  257. package/examples/jsm/nodes/core/NodeVar.js +14 -14
  258. package/examples/jsm/nodes/core/NodeVarying.js +17 -17
  259. package/examples/jsm/nodes/core/OutputStructNode.js +62 -62
  260. package/examples/jsm/nodes/core/ParameterNode.js +33 -33
  261. package/examples/jsm/nodes/core/PropertyNode.js +72 -72
  262. package/examples/jsm/nodes/core/StackNode.js +89 -89
  263. package/examples/jsm/nodes/core/StructTypeNode.js +24 -24
  264. package/examples/jsm/nodes/core/TempNode.js +58 -58
  265. package/examples/jsm/nodes/core/UniformGroup.js +13 -13
  266. package/examples/jsm/nodes/core/UniformGroupNode.js +36 -36
  267. package/examples/jsm/nodes/core/UniformNode.js +80 -80
  268. package/examples/jsm/nodes/core/VarNode.js +60 -60
  269. package/examples/jsm/nodes/core/VaryingNode.js +65 -65
  270. package/examples/jsm/nodes/core/constants.js +28 -27
  271. package/examples/jsm/nodes/display/AfterImageNode.js +148 -134
  272. package/examples/jsm/nodes/display/AnamorphicNode.js +148 -0
  273. package/examples/jsm/nodes/display/BlendModeNode.js +128 -99
  274. package/examples/jsm/nodes/display/BumpMapNode.js +99 -99
  275. package/examples/jsm/nodes/display/ColorAdjustmentNode.js +99 -96
  276. package/examples/jsm/nodes/display/ColorSpaceNode.js +108 -108
  277. package/examples/jsm/nodes/display/FrontFacingNode.js +27 -27
  278. package/examples/jsm/nodes/display/GaussianBlurNode.js +190 -177
  279. package/examples/jsm/nodes/display/NormalMapNode.js +106 -108
  280. package/examples/jsm/nodes/display/PassNode.js +183 -182
  281. package/examples/jsm/nodes/display/PosterizeNode.js +32 -32
  282. package/examples/jsm/nodes/display/ToneMappingNode.js +184 -184
  283. package/examples/jsm/nodes/display/ViewportDepthNode.js +97 -97
  284. package/examples/jsm/nodes/display/ViewportDepthTextureNode.js +31 -31
  285. package/examples/jsm/nodes/display/ViewportNode.js +134 -134
  286. package/examples/jsm/nodes/display/ViewportSharedTextureNode.js +31 -31
  287. package/examples/jsm/nodes/display/ViewportTextureNode.js +75 -75
  288. package/examples/jsm/nodes/fog/FogExp2Node.js +35 -35
  289. package/examples/jsm/nodes/fog/FogNode.js +38 -38
  290. package/examples/jsm/nodes/fog/FogRangeNode.js +34 -34
  291. package/examples/jsm/nodes/functions/BSDF/BRDF_GGX.js +40 -40
  292. package/examples/jsm/nodes/functions/BSDF/BRDF_Lambert.js +9 -9
  293. package/examples/jsm/nodes/functions/BSDF/BRDF_Sheen.js +57 -57
  294. package/examples/jsm/nodes/functions/BSDF/DFGApprox.js +30 -30
  295. package/examples/jsm/nodes/functions/BSDF/D_GGX.js +23 -23
  296. package/examples/jsm/nodes/functions/BSDF/EnvironmentBRDF.js +13 -13
  297. package/examples/jsm/nodes/functions/BSDF/F_Schlick.js +16 -16
  298. package/examples/jsm/nodes/functions/BSDF/Schlick_to_F0.js +21 -21
  299. package/examples/jsm/nodes/functions/BSDF/V_GGX_SmithCorrelated.js +28 -28
  300. package/examples/jsm/nodes/functions/PhongLightingModel.js +67 -67
  301. package/examples/jsm/nodes/functions/PhysicalLightingModel.js +393 -393
  302. package/examples/jsm/nodes/functions/material/getGeometryRoughness.js +13 -13
  303. package/examples/jsm/nodes/functions/material/getRoughness.js +18 -18
  304. package/examples/jsm/nodes/geometry/RangeNode.js +104 -104
  305. package/examples/jsm/nodes/gpgpu/ComputeNode.js +85 -85
  306. package/examples/jsm/nodes/lighting/AONode.js +27 -27
  307. package/examples/jsm/nodes/lighting/AmbientLightNode.js +27 -27
  308. package/examples/jsm/nodes/lighting/AnalyticLightNode.js +241 -238
  309. package/examples/jsm/nodes/lighting/DirectionalLightNode.js +40 -40
  310. package/examples/jsm/nodes/lighting/EnvironmentNode.js +181 -181
  311. package/examples/jsm/nodes/lighting/HemisphereLightNode.js +55 -55
  312. package/examples/jsm/nodes/lighting/IESSpotLightNode.js +39 -39
  313. package/examples/jsm/nodes/lighting/LightNode.js +57 -57
  314. package/examples/jsm/nodes/lighting/LightUtils.js +17 -17
  315. package/examples/jsm/nodes/lighting/LightingContextNode.js +66 -66
  316. package/examples/jsm/nodes/lighting/LightingNode.js +21 -21
  317. package/examples/jsm/nodes/lighting/LightsNode.js +188 -188
  318. package/examples/jsm/nodes/lighting/PointLightNode.js +68 -68
  319. package/examples/jsm/nodes/lighting/SpotLightNode.js +89 -89
  320. package/examples/jsm/nodes/loaders/NodeLoader.js +108 -108
  321. package/examples/jsm/nodes/loaders/NodeMaterialLoader.js +59 -59
  322. package/examples/jsm/nodes/loaders/NodeObjectLoader.js +70 -70
  323. package/examples/jsm/nodes/materials/InstancedPointsNodeMaterial.js +162 -162
  324. package/examples/jsm/nodes/materials/Line2NodeMaterial.js +436 -436
  325. package/examples/jsm/nodes/materials/LineBasicNodeMaterial.js +28 -28
  326. package/examples/jsm/nodes/materials/LineDashedNodeMaterial.js +54 -54
  327. package/examples/jsm/nodes/materials/Materials.js +16 -16
  328. package/examples/jsm/nodes/materials/MeshBasicNodeMaterial.js +28 -28
  329. package/examples/jsm/nodes/materials/MeshLambertNodeMaterial.js +34 -34
  330. package/examples/jsm/nodes/materials/MeshNormalNodeMaterial.js +40 -40
  331. package/examples/jsm/nodes/materials/MeshPhongNodeMaterial.js +65 -65
  332. package/examples/jsm/nodes/materials/MeshPhysicalNodeMaterial.js +155 -155
  333. package/examples/jsm/nodes/materials/MeshSSSNodeMaterial.js +84 -84
  334. package/examples/jsm/nodes/materials/MeshStandardNodeMaterial.js +80 -80
  335. package/examples/jsm/nodes/materials/NodeMaterial.js +601 -568
  336. package/examples/jsm/nodes/materials/PointsNodeMaterial.js +39 -39
  337. package/examples/jsm/nodes/materials/SpriteNodeMaterial.js +90 -96
  338. package/examples/jsm/nodes/materialx/DISCLAIMER.md +199 -199
  339. package/examples/jsm/nodes/materialx/MaterialXNodes.js +68 -68
  340. package/examples/jsm/nodes/materialx/lib/mx_hsv.js +130 -130
  341. package/examples/jsm/nodes/materialx/lib/mx_noise.js +1430 -1430
  342. package/examples/jsm/nodes/materialx/lib/mx_transform_color.js +29 -29
  343. package/examples/jsm/nodes/math/CondNode.js +121 -86
  344. package/examples/jsm/nodes/math/HashNode.js +34 -34
  345. package/examples/jsm/nodes/math/MathNode.js +391 -382
  346. package/examples/jsm/nodes/math/MathUtils.js +15 -0
  347. package/examples/jsm/nodes/math/OperatorNode.js +274 -266
  348. package/examples/jsm/nodes/math/TriNoise3D.js +71 -71
  349. package/examples/jsm/nodes/parsers/GLSLNodeFunction.js +152 -152
  350. package/examples/jsm/nodes/parsers/GLSLNodeParser.js +14 -14
  351. package/examples/jsm/nodes/procedural/CheckerNode.js +42 -42
  352. package/examples/jsm/nodes/shadernode/ShaderNode.js +634 -625
  353. package/examples/jsm/nodes/utils/ArrayElementNode.js +35 -41
  354. package/examples/jsm/nodes/utils/ConvertNode.js +65 -65
  355. package/examples/jsm/nodes/utils/DiscardNode.js +27 -27
  356. package/examples/jsm/nodes/utils/EquirectUVNode.js +33 -33
  357. package/examples/jsm/nodes/utils/FunctionOverloadingNode.js +95 -95
  358. package/examples/jsm/nodes/utils/JoinNode.js +61 -61
  359. package/examples/jsm/nodes/utils/LoopNode.js +200 -198
  360. package/examples/jsm/nodes/utils/MatcapUVNode.js +30 -30
  361. package/examples/jsm/nodes/utils/MaxMipLevelNode.js +46 -46
  362. package/examples/jsm/nodes/utils/OscNode.js +81 -81
  363. package/examples/jsm/nodes/utils/PackingNode.js +55 -55
  364. package/examples/jsm/nodes/utils/ReflectorNode.js +227 -0
  365. package/examples/jsm/nodes/utils/RemapNode.js +42 -42
  366. package/examples/jsm/nodes/utils/RotateNode.js +68 -43
  367. package/examples/jsm/nodes/utils/RotateUVNode.js +35 -43
  368. package/examples/jsm/nodes/utils/SetNode.js +62 -62
  369. package/examples/jsm/nodes/utils/SpecularMIPLevelNode.js +37 -37
  370. package/examples/jsm/nodes/utils/SplitNode.js +112 -112
  371. package/examples/jsm/nodes/utils/SpriteSheetUVNode.js +41 -41
  372. package/examples/jsm/nodes/utils/StorageArrayElementNode.js +91 -0
  373. package/examples/jsm/nodes/utils/TimerNode.js +94 -94
  374. package/examples/jsm/nodes/utils/TriplanarTexturesNode.js +62 -62
  375. package/examples/jsm/objects/GroundedSkybox.js +50 -50
  376. package/examples/jsm/objects/InstancedPoints.js +21 -21
  377. package/examples/jsm/objects/Lensflare.js +397 -397
  378. package/examples/jsm/objects/MarchingCubes.js +1176 -1176
  379. package/examples/jsm/objects/QuadMesh.js +66 -66
  380. package/examples/jsm/objects/Reflector.js +264 -264
  381. package/examples/jsm/objects/ReflectorForSSRPass.js +352 -352
  382. package/examples/jsm/objects/Refractor.js +327 -327
  383. package/examples/jsm/objects/ShadowMesh.js +80 -80
  384. package/examples/jsm/objects/Sky.js +219 -219
  385. package/examples/jsm/objects/Water.js +333 -333
  386. package/examples/jsm/objects/Water2.js +361 -361
  387. package/examples/jsm/offscreen/jank.js +45 -45
  388. package/examples/jsm/offscreen/offscreen.js +8 -8
  389. package/examples/jsm/offscreen/scene.js +86 -86
  390. package/examples/jsm/physics/AmmoPhysics.js +306 -306
  391. package/examples/jsm/physics/RapierPhysics.js +220 -220
  392. package/examples/jsm/postprocessing/AfterimagePass.js +104 -104
  393. package/examples/jsm/postprocessing/BloomPass.js +172 -172
  394. package/examples/jsm/postprocessing/BokehPass.js +141 -141
  395. package/examples/jsm/postprocessing/ClearPass.js +46 -46
  396. package/examples/jsm/postprocessing/CubeTexturePass.js +85 -85
  397. package/examples/jsm/postprocessing/DotScreenPass.js +65 -65
  398. package/examples/jsm/postprocessing/EffectComposer.js +231 -231
  399. package/examples/jsm/postprocessing/FilmPass.js +64 -64
  400. package/examples/jsm/postprocessing/GTAOPass.js +582 -582
  401. package/examples/jsm/postprocessing/GlitchPass.js +128 -128
  402. package/examples/jsm/postprocessing/HalftonePass.js +79 -79
  403. package/examples/jsm/postprocessing/LUTPass.js +174 -174
  404. package/examples/jsm/postprocessing/MaskPass.js +104 -104
  405. package/examples/jsm/postprocessing/OutlinePass.js +654 -654
  406. package/examples/jsm/postprocessing/OutputPass.js +97 -95
  407. package/examples/jsm/postprocessing/Pass.js +95 -95
  408. package/examples/jsm/postprocessing/RenderPass.js +99 -99
  409. package/examples/jsm/postprocessing/RenderPixelatedPass.js +235 -235
  410. package/examples/jsm/postprocessing/SAOPass.js +335 -335
  411. package/examples/jsm/postprocessing/SMAAPass.js +199 -199
  412. package/examples/jsm/postprocessing/SSAARenderPass.js +228 -228
  413. package/examples/jsm/postprocessing/SSAOPass.js +420 -420
  414. package/examples/jsm/postprocessing/SSRPass.js +641 -641
  415. package/examples/jsm/postprocessing/SavePass.js +79 -79
  416. package/examples/jsm/postprocessing/ShaderPass.js +77 -77
  417. package/examples/jsm/postprocessing/TAARenderPass.js +188 -188
  418. package/examples/jsm/postprocessing/TexturePass.js +67 -67
  419. package/examples/jsm/postprocessing/UnrealBloomPass.js +415 -415
  420. package/examples/jsm/renderers/CSS2DRenderer.js +215 -215
  421. package/examples/jsm/renderers/CSS3DRenderer.js +329 -329
  422. package/examples/jsm/renderers/Projector.js +918 -918
  423. package/examples/jsm/renderers/SVGRenderer.js +556 -556
  424. package/examples/jsm/renderers/common/Animation.js +47 -47
  425. package/examples/jsm/renderers/common/Attributes.js +75 -75
  426. package/examples/jsm/renderers/common/Backend.js +195 -193
  427. package/examples/jsm/renderers/common/Background.js +134 -134
  428. package/examples/jsm/renderers/common/Binding.js +25 -25
  429. package/examples/jsm/renderers/common/Bindings.js +173 -173
  430. package/examples/jsm/renderers/common/Buffer.js +38 -38
  431. package/examples/jsm/renderers/common/BufferUtils.js +33 -33
  432. package/examples/jsm/renderers/common/ChainMap.js +89 -89
  433. package/examples/jsm/renderers/common/ClippingContext.js +165 -0
  434. package/examples/jsm/renderers/common/Color4.js +37 -37
  435. package/examples/jsm/renderers/common/ComputePipeline.js +17 -17
  436. package/examples/jsm/renderers/common/Constants.js +14 -14
  437. package/examples/jsm/renderers/common/CubeRenderTarget.js +65 -65
  438. package/examples/jsm/renderers/common/DataMap.js +54 -54
  439. package/examples/jsm/renderers/common/Geometries.js +215 -215
  440. package/examples/jsm/renderers/common/Info.js +107 -107
  441. package/examples/jsm/renderers/common/Pipeline.js +13 -13
  442. package/examples/jsm/renderers/common/Pipelines.js +322 -322
  443. package/examples/jsm/renderers/common/PostProcessing.js +25 -25
  444. package/examples/jsm/renderers/common/ProgrammableStage.js +20 -20
  445. package/examples/jsm/renderers/common/RenderContext.js +43 -41
  446. package/examples/jsm/renderers/common/RenderContexts.js +63 -74
  447. package/examples/jsm/renderers/common/RenderList.js +186 -186
  448. package/examples/jsm/renderers/common/RenderLists.js +38 -38
  449. package/examples/jsm/renderers/common/RenderObject.js +221 -178
  450. package/examples/jsm/renderers/common/RenderObjects.js +93 -91
  451. package/examples/jsm/renderers/common/RenderPipeline.js +16 -16
  452. package/examples/jsm/renderers/common/Renderer.js +1304 -1062
  453. package/examples/jsm/renderers/common/SampledTexture.js +83 -83
  454. package/examples/jsm/renderers/common/Sampler.js +18 -18
  455. package/examples/jsm/renderers/common/StorageBuffer.js +17 -17
  456. package/examples/jsm/renderers/common/StorageBufferAttribute.js +17 -21
  457. package/examples/jsm/renderers/common/StorageInstancedBufferAttribute.js +17 -0
  458. package/examples/jsm/renderers/common/StorageTexture.js +20 -20
  459. package/examples/jsm/renderers/common/Textures.js +344 -354
  460. package/examples/jsm/renderers/common/Uniform.js +140 -140
  461. package/examples/jsm/renderers/common/UniformBuffer.js +15 -15
  462. package/examples/jsm/renderers/common/UniformsGroup.js +301 -299
  463. package/examples/jsm/renderers/common/nodes/NodeBuilderState.js +44 -44
  464. package/examples/jsm/renderers/common/nodes/NodeSampledTexture.js +49 -49
  465. package/examples/jsm/renderers/common/nodes/NodeSampler.js +15 -15
  466. package/examples/jsm/renderers/common/nodes/NodeStorageBuffer.js +23 -0
  467. package/examples/jsm/renderers/common/nodes/NodeUniform.js +135 -135
  468. package/examples/jsm/renderers/common/nodes/NodeUniformBuffer.js +23 -0
  469. package/examples/jsm/renderers/common/nodes/NodeUniformsGroup.js +44 -44
  470. package/examples/jsm/renderers/common/nodes/Nodes.js +496 -495
  471. package/examples/jsm/renderers/webgl/WebGLBackend.js +1382 -1290
  472. package/examples/jsm/renderers/webgl/nodes/GLSLNodeBuilder.js +804 -679
  473. package/examples/jsm/renderers/webgl/utils/WebGLAttributeUtils.js +258 -252
  474. package/examples/jsm/renderers/webgl/utils/WebGLCapabilities.js +36 -36
  475. package/examples/jsm/renderers/webgl/utils/WebGLConstants.js +11 -11
  476. package/examples/jsm/renderers/webgl/utils/WebGLExtensions.js +36 -36
  477. package/examples/jsm/renderers/webgl/utils/WebGLState.js +738 -738
  478. package/examples/jsm/renderers/webgl/utils/WebGLTextureUtils.js +694 -647
  479. package/examples/jsm/renderers/webgl/utils/WebGLUtils.js +285 -284
  480. package/examples/jsm/renderers/webgl-legacy/nodes/GLSL1NodeBuilder.js +320 -320
  481. package/examples/jsm/renderers/webgl-legacy/nodes/SlotNode.js +26 -26
  482. package/examples/jsm/renderers/webgl-legacy/nodes/WebGLNodeBuilder.js +794 -794
  483. package/examples/jsm/renderers/webgl-legacy/nodes/WebGLNodes.js +51 -51
  484. package/examples/jsm/renderers/webgpu/WebGPUBackend.js +1322 -1321
  485. package/examples/jsm/renderers/webgpu/WebGPURenderer.js +53 -53
  486. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeBuilder.js +1078 -1098
  487. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeFunction.js +104 -104
  488. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeParser.js +14 -14
  489. package/examples/jsm/renderers/webgpu/utils/WebGPUAttributeUtils.js +293 -287
  490. package/examples/jsm/renderers/webgpu/utils/WebGPUBindingUtils.js +244 -244
  491. package/examples/jsm/renderers/webgpu/utils/WebGPUConstants.js +324 -324
  492. package/examples/jsm/renderers/webgpu/utils/WebGPUPipelineUtils.js +591 -570
  493. package/examples/jsm/renderers/webgpu/utils/WebGPUTexturePassUtils.js +285 -285
  494. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureUtils.js +1040 -1040
  495. package/examples/jsm/renderers/webgpu/utils/WebGPUUtils.js +93 -93
  496. package/examples/jsm/shaders/ACESFilmicToneMappingShader.js +89 -89
  497. package/examples/jsm/shaders/AfterimageShader.js +58 -58
  498. package/examples/jsm/shaders/BasicShader.js +29 -29
  499. package/examples/jsm/shaders/BleachBypassShader.js +62 -62
  500. package/examples/jsm/shaders/BlendShader.js +49 -49
  501. package/examples/jsm/shaders/BokehShader.js +145 -145
  502. package/examples/jsm/shaders/BokehShader2.js +397 -397
  503. package/examples/jsm/shaders/BrightnessContrastShader.js +56 -56
  504. package/examples/jsm/shaders/ColorCorrectionShader.js +52 -52
  505. package/examples/jsm/shaders/ColorifyShader.js +51 -51
  506. package/examples/jsm/shaders/ConvolutionShader.js +103 -103
  507. package/examples/jsm/shaders/CopyShader.js +45 -45
  508. package/examples/jsm/shaders/DOFMipMapShader.js +56 -56
  509. package/examples/jsm/shaders/DepthLimitedBlurShader.js +171 -171
  510. package/examples/jsm/shaders/DigitalGlitch.js +101 -101
  511. package/examples/jsm/shaders/DotScreenShader.js +70 -70
  512. package/examples/jsm/shaders/ExposureShader.js +44 -44
  513. package/examples/jsm/shaders/FXAAShader.js +288 -288
  514. package/examples/jsm/shaders/FilmShader.js +59 -59
  515. package/examples/jsm/shaders/FocusShader.js +89 -89
  516. package/examples/jsm/shaders/FreiChenShader.js +96 -96
  517. package/examples/jsm/shaders/GTAOShader.js +424 -424
  518. package/examples/jsm/shaders/GammaCorrectionShader.js +43 -43
  519. package/examples/jsm/shaders/GodRaysShader.js +321 -321
  520. package/examples/jsm/shaders/HalftoneShader.js +312 -312
  521. package/examples/jsm/shaders/HorizontalBlurShader.js +59 -59
  522. package/examples/jsm/shaders/HorizontalTiltShiftShader.js +63 -63
  523. package/examples/jsm/shaders/HueSaturationShader.js +67 -67
  524. package/examples/jsm/shaders/KaleidoShader.js +58 -58
  525. package/examples/jsm/shaders/LuminosityHighPassShader.js +66 -66
  526. package/examples/jsm/shaders/LuminosityShader.js +48 -48
  527. package/examples/jsm/shaders/MMDToonShader.js +134 -134
  528. package/examples/jsm/shaders/MirrorShader.js +56 -56
  529. package/examples/jsm/shaders/NormalMapShader.js +55 -55
  530. package/examples/jsm/shaders/OutputShader.js +85 -81
  531. package/examples/jsm/shaders/PoissonDenoiseShader.js +226 -226
  532. package/examples/jsm/shaders/RGBShiftShader.js +54 -54
  533. package/examples/jsm/shaders/SAOShader.js +179 -179
  534. package/examples/jsm/shaders/SMAAShader.js +466 -466
  535. package/examples/jsm/shaders/SSAOShader.js +300 -300
  536. package/examples/jsm/shaders/SSRShader.js +370 -370
  537. package/examples/jsm/shaders/SepiaShader.js +52 -52
  538. package/examples/jsm/shaders/SobelOperatorShader.js +92 -92
  539. package/examples/jsm/shaders/SubsurfaceScatteringShader.js +90 -90
  540. package/examples/jsm/shaders/TechnicolorShader.js +45 -45
  541. package/examples/jsm/shaders/ToonShader.js +326 -326
  542. package/examples/jsm/shaders/TriangleBlurShader.js +74 -74
  543. package/examples/jsm/shaders/UnpackDepthRGBAShader.js +47 -47
  544. package/examples/jsm/shaders/VelocityShader.js +130 -130
  545. package/examples/jsm/shaders/VerticalBlurShader.js +59 -59
  546. package/examples/jsm/shaders/VerticalTiltShiftShader.js +63 -63
  547. package/examples/jsm/shaders/VignetteShader.js +51 -51
  548. package/examples/jsm/shaders/VolumeShader.js +289 -289
  549. package/examples/jsm/shaders/WaterRefractionShader.js +95 -95
  550. package/examples/jsm/textures/FlakesTexture.js +40 -40
  551. package/examples/jsm/transpiler/AST.js +270 -270
  552. package/examples/jsm/transpiler/GLSLDecoder.js +941 -941
  553. package/examples/jsm/transpiler/ShaderToyDecoder.js +49 -49
  554. package/examples/jsm/transpiler/TSLEncoder.js +715 -715
  555. package/examples/jsm/transpiler/Transpiler.js +18 -18
  556. package/examples/jsm/utils/BufferGeometryUtils.js +1371 -1371
  557. package/examples/jsm/utils/CameraUtils.js +73 -73
  558. package/examples/jsm/utils/GPUStatsPanel.js +128 -128
  559. package/examples/jsm/utils/GeometryCompressionUtils.js +639 -639
  560. package/examples/jsm/utils/GeometryUtils.js +221 -221
  561. package/examples/jsm/utils/LDrawUtils.js +202 -202
  562. package/examples/jsm/utils/PackedPhongMaterial.js +178 -178
  563. package/examples/jsm/utils/SceneUtils.js +254 -254
  564. package/examples/jsm/utils/ShadowMapViewer.js +210 -210
  565. package/examples/jsm/utils/SkeletonUtils.js +424 -413
  566. package/examples/jsm/utils/SortUtils.js +160 -160
  567. package/examples/jsm/utils/TextureUtils.js +98 -98
  568. package/examples/jsm/utils/UVsDebug.js +165 -165
  569. package/examples/jsm/utils/WorkerPool.js +102 -102
  570. package/examples/jsm/webxr/ARButton.js +232 -232
  571. package/examples/jsm/webxr/OculusHandModel.js +109 -109
  572. package/examples/jsm/webxr/OculusHandPointerModel.js +416 -416
  573. package/examples/jsm/webxr/Text2D.js +38 -38
  574. package/examples/jsm/webxr/VRButton.js +233 -225
  575. package/examples/jsm/webxr/XRButton.js +223 -224
  576. package/examples/jsm/webxr/XRControllerModelFactory.js +323 -315
  577. package/examples/jsm/webxr/XREstimatedLight.js +223 -223
  578. package/examples/jsm/webxr/XRHandMeshModel.js +116 -116
  579. package/examples/jsm/webxr/XRHandModelFactory.js +105 -105
  580. package/examples/jsm/webxr/XRHandPrimitiveModel.js +105 -105
  581. package/examples/jsm/webxr/XRPlanes.js +100 -100
  582. package/package.json +4 -4
  583. package/src/Three.Legacy.js +21 -1
  584. package/src/Three.js +183 -184
  585. package/src/animation/AnimationAction.js +700 -700
  586. package/src/animation/AnimationClip.js +473 -473
  587. package/src/animation/AnimationMixer.js +770 -770
  588. package/src/animation/AnimationObjectGroup.js +387 -387
  589. package/src/animation/AnimationUtils.js +356 -356
  590. package/src/animation/KeyframeTrack.js +462 -462
  591. package/src/animation/PropertyBinding.js +719 -719
  592. package/src/animation/PropertyMixer.js +318 -318
  593. package/src/animation/tracks/BooleanKeyframeTrack.js +19 -19
  594. package/src/animation/tracks/ColorKeyframeTrack.js +15 -15
  595. package/src/animation/tracks/NumberKeyframeTrack.js +12 -12
  596. package/src/animation/tracks/QuaternionKeyframeTrack.js +23 -23
  597. package/src/animation/tracks/StringKeyframeTrack.js +15 -15
  598. package/src/animation/tracks/VectorKeyframeTrack.js +12 -12
  599. package/src/audio/Audio.js +400 -400
  600. package/src/audio/AudioAnalyser.js +40 -40
  601. package/src/audio/AudioContext.js +25 -25
  602. package/src/audio/AudioListener.js +140 -140
  603. package/src/audio/PositionalAudio.js +146 -146
  604. package/src/cameras/ArrayCamera.js +17 -17
  605. package/src/cameras/Camera.js +69 -69
  606. package/src/cameras/CubeCamera.js +173 -173
  607. package/src/cameras/OrthographicCamera.js +136 -136
  608. package/src/cameras/PerspectiveCamera.js +268 -268
  609. package/src/cameras/StereoCamera.js +100 -100
  610. package/src/constants.js +217 -216
  611. package/src/core/BufferAttribute.js +639 -650
  612. package/src/core/BufferGeometry.js +1073 -1079
  613. package/src/core/Clock.js +74 -74
  614. package/src/core/EventDispatcher.js +87 -87
  615. package/src/core/GLBufferAttribute.js +60 -60
  616. package/src/core/InstancedBufferAttribute.js +39 -39
  617. package/src/core/InstancedBufferGeometry.js +40 -40
  618. package/src/core/InstancedInterleavedBuffer.js +48 -48
  619. package/src/core/InterleavedBuffer.js +166 -166
  620. package/src/core/InterleavedBufferAttribute.js +351 -351
  621. package/src/core/Layers.js +60 -60
  622. package/src/core/Object3D.js +1019 -1008
  623. package/src/core/Raycaster.js +124 -110
  624. package/src/core/RenderTarget.js +154 -131
  625. package/src/core/Uniform.js +17 -17
  626. package/src/core/UniformsGroup.js +98 -98
  627. package/src/extras/DataUtils.js +176 -176
  628. package/src/extras/Earcut.js +789 -789
  629. package/src/extras/ImageUtils.js +129 -129
  630. package/src/extras/PMREMGenerator.js +912 -910
  631. package/src/extras/ShapeUtils.js +92 -92
  632. package/src/extras/core/Curve.js +416 -416
  633. package/src/extras/core/CurvePath.js +255 -255
  634. package/src/extras/core/Interpolations.js +79 -79
  635. package/src/extras/core/Path.js +196 -196
  636. package/src/extras/core/Shape.js +102 -102
  637. package/src/extras/core/ShapePath.js +291 -291
  638. package/src/extras/curves/ArcCurve.js +17 -17
  639. package/src/extras/curves/CatmullRomCurve3.js +255 -255
  640. package/src/extras/curves/CubicBezierCurve.js +78 -78
  641. package/src/extras/curves/CubicBezierCurve3.js +79 -79
  642. package/src/extras/curves/Curves.js +10 -10
  643. package/src/extras/curves/EllipseCurve.js +156 -156
  644. package/src/extras/curves/LineCurve.js +92 -92
  645. package/src/extras/curves/LineCurve3.js +92 -92
  646. package/src/extras/curves/QuadraticBezierCurve.js +74 -74
  647. package/src/extras/curves/QuadraticBezierCurve3.js +75 -75
  648. package/src/extras/curves/SplineCurve.js +97 -97
  649. package/src/geometries/BoxGeometry.js +180 -180
  650. package/src/geometries/CapsuleGeometry.js +33 -33
  651. package/src/geometries/CircleGeometry.js +101 -101
  652. package/src/geometries/ConeGeometry.js +31 -31
  653. package/src/geometries/CylinderGeometry.js +286 -286
  654. package/src/geometries/DodecahedronGeometry.js +66 -66
  655. package/src/geometries/EdgesGeometry.js +152 -152
  656. package/src/geometries/ExtrudeGeometry.js +814 -814
  657. package/src/geometries/Geometries.js +21 -21
  658. package/src/geometries/IcosahedronGeometry.js +42 -42
  659. package/src/geometries/LatheGeometry.js +189 -189
  660. package/src/geometries/OctahedronGeometry.js +37 -37
  661. package/src/geometries/PlaneGeometry.js +98 -98
  662. package/src/geometries/PolyhedronGeometry.js +319 -319
  663. package/src/geometries/RingGeometry.js +128 -128
  664. package/src/geometries/ShapeGeometry.js +195 -195
  665. package/src/geometries/SphereGeometry.js +137 -137
  666. package/src/geometries/TetrahedronGeometry.js +34 -34
  667. package/src/geometries/TorusGeometry.js +120 -120
  668. package/src/geometries/TorusKnotGeometry.js +167 -167
  669. package/src/geometries/TubeGeometry.js +203 -203
  670. package/src/geometries/WireframeGeometry.js +147 -147
  671. package/src/helpers/ArrowHelper.js +114 -114
  672. package/src/helpers/AxesHelper.js +68 -68
  673. package/src/helpers/Box3Helper.js +55 -55
  674. package/src/helpers/BoxHelper.js +113 -113
  675. package/src/helpers/CameraHelper.js +269 -269
  676. package/src/helpers/DirectionalLightHelper.js +93 -93
  677. package/src/helpers/GridHelper.js +56 -56
  678. package/src/helpers/HemisphereLightHelper.js +88 -88
  679. package/src/helpers/PlaneHelper.js +63 -63
  680. package/src/helpers/PointLightHelper.js +92 -92
  681. package/src/helpers/PolarGridHelper.js +96 -96
  682. package/src/helpers/SkeletonHelper.js +128 -128
  683. package/src/helpers/SpotLightHelper.js +111 -94
  684. package/src/lights/AmbientLight.js +17 -17
  685. package/src/lights/DirectionalLight.js +43 -43
  686. package/src/lights/DirectionalLightShadow.js +16 -16
  687. package/src/lights/HemisphereLight.js +34 -34
  688. package/src/lights/Light.js +58 -58
  689. package/src/lights/LightProbe.js +47 -47
  690. package/src/lights/LightShadow.js +147 -147
  691. package/src/lights/PointLight.js +57 -57
  692. package/src/lights/PointLightShadow.js +96 -96
  693. package/src/lights/RectAreaLight.js +56 -56
  694. package/src/lights/SpotLight.js +71 -71
  695. package/src/lights/SpotLightShadow.js +50 -50
  696. package/src/loaders/AnimationLoader.js +66 -66
  697. package/src/loaders/AudioLoader.js +66 -66
  698. package/src/loaders/BufferGeometryLoader.js +217 -217
  699. package/src/loaders/Cache.js +42 -42
  700. package/src/loaders/CompressedTextureLoader.js +134 -134
  701. package/src/loaders/CubeTextureLoader.js +58 -58
  702. package/src/loaders/DataTextureLoader.js +131 -135
  703. package/src/loaders/FileLoader.js +284 -284
  704. package/src/loaders/ImageBitmapLoader.js +123 -123
  705. package/src/loaders/ImageLoader.js +91 -91
  706. package/src/loaders/Loader.js +72 -72
  707. package/src/loaders/LoaderUtils.js +75 -75
  708. package/src/loaders/LoadingManager.js +142 -142
  709. package/src/loaders/MaterialLoader.js +373 -372
  710. package/src/loaders/ObjectLoader.js +1149 -1148
  711. package/src/loaders/TextureLoader.js +41 -41
  712. package/src/materials/LineBasicMaterial.js +49 -53
  713. package/src/materials/LineDashedMaterial.js +35 -35
  714. package/src/materials/Material.js +523 -522
  715. package/src/materials/Materials.js +39 -39
  716. package/src/materials/MeshBasicMaterial.js +84 -85
  717. package/src/materials/MeshDepthMaterial.js +54 -54
  718. package/src/materials/MeshDistanceMaterial.js +43 -43
  719. package/src/materials/MeshLambertMaterial.js +119 -120
  720. package/src/materials/MeshMatcapMaterial.js +81 -85
  721. package/src/materials/MeshNormalMaterial.js +61 -61
  722. package/src/materials/MeshPhongMaterial.js +123 -124
  723. package/src/materials/MeshPhysicalMaterial.js +224 -224
  724. package/src/materials/MeshStandardMaterial.js +127 -128
  725. package/src/materials/MeshToonMaterial.js +102 -106
  726. package/src/materials/PointsMaterial.js +50 -54
  727. package/src/materials/RawShaderMaterial.js +17 -17
  728. package/src/materials/ShaderMaterial.js +189 -190
  729. package/src/materials/ShadowMaterial.js +37 -37
  730. package/src/materials/SpriteMaterial.js +54 -54
  731. package/src/math/Box2.js +204 -204
  732. package/src/math/Box3.js +534 -534
  733. package/src/math/Color.js +623 -623
  734. package/src/math/ColorManagement.js +139 -139
  735. package/src/math/Cylindrical.js +61 -61
  736. package/src/math/Euler.js +315 -315
  737. package/src/math/Frustum.js +186 -186
  738. package/src/math/Interpolant.js +241 -241
  739. package/src/math/Line3.js +115 -115
  740. package/src/math/MathUtils.js +363 -363
  741. package/src/math/Matrix3.js +388 -388
  742. package/src/math/Matrix4.js +915 -915
  743. package/src/math/Plane.js +205 -205
  744. package/src/math/Quaternion.js +686 -685
  745. package/src/math/Ray.js +493 -493
  746. package/src/math/Sphere.js +245 -245
  747. package/src/math/Spherical.js +86 -86
  748. package/src/math/SphericalHarmonics3.js +243 -243
  749. package/src/math/Triangle.js +311 -311
  750. package/src/math/Vector2.js +480 -480
  751. package/src/math/Vector3.js +724 -724
  752. package/src/math/Vector4.js +644 -644
  753. package/src/math/interpolants/CubicInterpolant.js +150 -150
  754. package/src/math/interpolants/DiscreteInterpolant.js +26 -26
  755. package/src/math/interpolants/LinearInterpolant.js +38 -38
  756. package/src/math/interpolants/QuaternionLinearInterpolant.js +39 -39
  757. package/src/objects/BatchedMesh.js +1019 -1019
  758. package/src/objects/Bone.js +17 -17
  759. package/src/objects/Group.js +17 -17
  760. package/src/objects/InstancedMesh.js +267 -214
  761. package/src/objects/LOD.js +214 -214
  762. package/src/objects/Line.js +222 -222
  763. package/src/objects/LineLoop.js +17 -17
  764. package/src/objects/LineSegments.js +55 -55
  765. package/src/objects/Mesh.js +428 -429
  766. package/src/objects/Points.js +166 -166
  767. package/src/objects/Skeleton.js +277 -277
  768. package/src/objects/SkinnedMesh.js +257 -257
  769. package/src/objects/Sprite.js +181 -181
  770. package/src/renderers/WebGL1Renderer.js +7 -7
  771. package/src/renderers/WebGL3DRenderTarget.js +22 -22
  772. package/src/renderers/WebGLArrayRenderTarget.js +22 -22
  773. package/src/renderers/WebGLCubeRenderTarget.js +146 -155
  774. package/src/renderers/WebGLRenderTarget.js +15 -15
  775. package/src/renderers/WebGLRenderer.js +2615 -2631
  776. package/src/renderers/shaders/ShaderChunk/alphahash_fragment.glsl.js +7 -7
  777. package/src/renderers/shaders/ShaderChunk/alphahash_pars_fragment.glsl.js +68 -68
  778. package/src/renderers/shaders/ShaderChunk/alphamap_fragment.glsl.js +7 -7
  779. package/src/renderers/shaders/ShaderChunk/alphamap_pars_fragment.glsl.js +7 -7
  780. package/src/renderers/shaders/ShaderChunk/alphatest_fragment.glsl.js +16 -16
  781. package/src/renderers/shaders/ShaderChunk/alphatest_pars_fragment.glsl.js +5 -5
  782. package/src/renderers/shaders/ShaderChunk/aomap_fragment.glsl.js +26 -26
  783. package/src/renderers/shaders/ShaderChunk/aomap_pars_fragment.glsl.js +8 -8
  784. package/src/renderers/shaders/ShaderChunk/batching_pars_vertex.glsl.js +19 -19
  785. package/src/renderers/shaders/ShaderChunk/batching_vertex.glsl.js +5 -5
  786. package/src/renderers/shaders/ShaderChunk/begin_vertex.glsl.js +9 -9
  787. package/src/renderers/shaders/ShaderChunk/beginnormal_vertex.glsl.js +9 -9
  788. package/src/renderers/shaders/ShaderChunk/bsdfs.glsl.js +33 -33
  789. package/src/renderers/shaders/ShaderChunk/bumpmap_pars_fragment.glsl.js +43 -43
  790. package/src/renderers/shaders/ShaderChunk/clearcoat_normal_fragment_begin.glsl.js +7 -7
  791. package/src/renderers/shaders/ShaderChunk/clearcoat_normal_fragment_maps.glsl.js +10 -10
  792. package/src/renderers/shaders/ShaderChunk/clearcoat_pars_fragment.glsl.js +21 -21
  793. package/src/renderers/shaders/ShaderChunk/clipping_planes_fragment.glsl.js +78 -78
  794. package/src/renderers/shaders/ShaderChunk/clipping_planes_pars_fragment.glsl.js +9 -9
  795. package/src/renderers/shaders/ShaderChunk/clipping_planes_pars_vertex.glsl.js +7 -7
  796. package/src/renderers/shaders/ShaderChunk/clipping_planes_vertex.glsl.js +7 -7
  797. package/src/renderers/shaders/ShaderChunk/color_fragment.glsl.js +11 -11
  798. package/src/renderers/shaders/ShaderChunk/color_pars_fragment.glsl.js +11 -11
  799. package/src/renderers/shaders/ShaderChunk/color_pars_vertex.glsl.js +11 -11
  800. package/src/renderers/shaders/ShaderChunk/color_vertex.glsl.js +23 -23
  801. package/src/renderers/shaders/ShaderChunk/colorspace_fragment.glsl.js +3 -3
  802. package/src/renderers/shaders/ShaderChunk/colorspace_pars_fragment.glsl.js +44 -44
  803. package/src/renderers/shaders/ShaderChunk/common.glsl.js +147 -147
  804. package/src/renderers/shaders/ShaderChunk/cube_uv_reflection_fragment.glsl.js +186 -186
  805. package/src/renderers/shaders/ShaderChunk/default_fragment.glsl.js +5 -5
  806. package/src/renderers/shaders/ShaderChunk/default_vertex.glsl.js +5 -5
  807. package/src/renderers/shaders/ShaderChunk/defaultnormal_vertex.glsl.js +63 -63
  808. package/src/renderers/shaders/ShaderChunk/displacementmap_pars_vertex.glsl.js +9 -9
  809. package/src/renderers/shaders/ShaderChunk/displacementmap_vertex.glsl.js +7 -7
  810. package/src/renderers/shaders/ShaderChunk/dithering_fragment.glsl.js +7 -7
  811. package/src/renderers/shaders/ShaderChunk/dithering_pars_fragment.glsl.js +20 -20
  812. package/src/renderers/shaders/ShaderChunk/emissivemap_fragment.glsl.js +9 -9
  813. package/src/renderers/shaders/ShaderChunk/emissivemap_pars_fragment.glsl.js +7 -7
  814. package/src/renderers/shaders/ShaderChunk/envmap_common_pars_fragment.glsl.js +15 -14
  815. package/src/renderers/shaders/ShaderChunk/envmap_fragment.glsl.js +62 -62
  816. package/src/renderers/shaders/ShaderChunk/envmap_pars_fragment.glsl.js +21 -21
  817. package/src/renderers/shaders/ShaderChunk/envmap_pars_vertex.glsl.js +22 -22
  818. package/src/renderers/shaders/ShaderChunk/envmap_physical_pars_fragment.glsl.js +69 -69
  819. package/src/renderers/shaders/ShaderChunk/envmap_vertex.glsl.js +37 -37
  820. package/src/renderers/shaders/ShaderChunk/fog_fragment.glsl.js +17 -17
  821. package/src/renderers/shaders/ShaderChunk/fog_pars_fragment.glsl.js +19 -19
  822. package/src/renderers/shaders/ShaderChunk/fog_pars_vertex.glsl.js +7 -7
  823. package/src/renderers/shaders/ShaderChunk/fog_vertex.glsl.js +7 -7
  824. package/src/renderers/shaders/ShaderChunk/gradientmap_pars_fragment.glsl.js +27 -27
  825. package/src/renderers/shaders/ShaderChunk/iridescence_fragment.glsl.js +120 -120
  826. package/src/renderers/shaders/ShaderChunk/iridescence_pars_fragment.glsl.js +14 -14
  827. package/src/renderers/shaders/ShaderChunk/lightmap_fragment.glsl.js +10 -10
  828. package/src/renderers/shaders/ShaderChunk/lightmap_pars_fragment.glsl.js +8 -8
  829. package/src/renderers/shaders/ShaderChunk/lights_fragment_begin.glsl.js +202 -202
  830. package/src/renderers/shaders/ShaderChunk/lights_fragment_end.glsl.js +13 -13
  831. package/src/renderers/shaders/ShaderChunk/lights_fragment_maps.glsl.js +40 -40
  832. package/src/renderers/shaders/ShaderChunk/lights_lambert_fragment.glsl.js +5 -5
  833. package/src/renderers/shaders/ShaderChunk/lights_lambert_pars_fragment.glsl.js +28 -28
  834. package/src/renderers/shaders/ShaderChunk/lights_pars_begin.glsl.js +228 -228
  835. package/src/renderers/shaders/ShaderChunk/lights_phong_fragment.glsl.js +7 -7
  836. package/src/renderers/shaders/ShaderChunk/lights_phong_pars_fragment.glsl.js +32 -32
  837. package/src/renderers/shaders/ShaderChunk/lights_physical_fragment.glsl.js +151 -151
  838. package/src/renderers/shaders/ShaderChunk/lights_physical_pars_fragment.glsl.js +562 -562
  839. package/src/renderers/shaders/ShaderChunk/lights_toon_fragment.glsl.js +4 -4
  840. package/src/renderers/shaders/ShaderChunk/lights_toon_pars_fragment.glsl.js +26 -26
  841. package/src/renderers/shaders/ShaderChunk/logdepthbuf_fragment.glsl.js +9 -9
  842. package/src/renderers/shaders/ShaderChunk/logdepthbuf_pars_fragment.glsl.js +9 -9
  843. package/src/renderers/shaders/ShaderChunk/logdepthbuf_pars_vertex.glsl.js +16 -16
  844. package/src/renderers/shaders/ShaderChunk/logdepthbuf_vertex.glsl.js +22 -22
  845. package/src/renderers/shaders/ShaderChunk/map_fragment.glsl.js +21 -21
  846. package/src/renderers/shaders/ShaderChunk/map_pars_fragment.glsl.js +11 -11
  847. package/src/renderers/shaders/ShaderChunk/map_particle_fragment.glsl.js +27 -27
  848. package/src/renderers/shaders/ShaderChunk/map_particle_pars_fragment.glsl.js +27 -27
  849. package/src/renderers/shaders/ShaderChunk/metalnessmap_fragment.glsl.js +12 -12
  850. package/src/renderers/shaders/ShaderChunk/metalnessmap_pars_fragment.glsl.js +7 -7
  851. package/src/renderers/shaders/ShaderChunk/morphcolor_vertex.glsl.js +24 -24
  852. package/src/renderers/shaders/ShaderChunk/morphinstance_vertex.glsl.js +14 -0
  853. package/src/renderers/shaders/ShaderChunk/morphnormal_vertex.glsl.js +27 -27
  854. package/src/renderers/shaders/ShaderChunk/morphtarget_pars_vertex.glsl.js +47 -38
  855. package/src/renderers/shaders/ShaderChunk/morphtarget_vertex.glsl.js +36 -36
  856. package/src/renderers/shaders/ShaderChunk/normal_fragment_begin.glsl.js +76 -76
  857. package/src/renderers/shaders/ShaderChunk/normal_fragment_maps.glsl.js +33 -33
  858. package/src/renderers/shaders/ShaderChunk/normal_pars_fragment.glsl.js +14 -14
  859. package/src/renderers/shaders/ShaderChunk/normal_pars_vertex.glsl.js +14 -14
  860. package/src/renderers/shaders/ShaderChunk/normal_vertex.glsl.js +14 -14
  861. package/src/renderers/shaders/ShaderChunk/normalmap_pars_fragment.glsl.js +43 -43
  862. package/src/renderers/shaders/ShaderChunk/opaque_fragment.glsl.js +11 -11
  863. package/src/renderers/shaders/ShaderChunk/packing.glsl.js +68 -68
  864. package/src/renderers/shaders/ShaderChunk/premultiplied_alpha_fragment.glsl.js +8 -8
  865. package/src/renderers/shaders/ShaderChunk/project_vertex.glsl.js +19 -19
  866. package/src/renderers/shaders/ShaderChunk/roughnessmap_fragment.glsl.js +12 -12
  867. package/src/renderers/shaders/ShaderChunk/roughnessmap_pars_fragment.glsl.js +7 -7
  868. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_fragment.glsl.js +314 -314
  869. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_vertex.glsl.js +68 -68
  870. package/src/renderers/shaders/ShaderChunk/shadowmap_vertex.glsl.js +68 -68
  871. package/src/renderers/shaders/ShaderChunk/shadowmask_pars_fragment.glsl.js +66 -66
  872. package/src/renderers/shaders/ShaderChunk/skinbase_vertex.glsl.js +10 -10
  873. package/src/renderers/shaders/ShaderChunk/skinning_pars_vertex.glsl.js +25 -25
  874. package/src/renderers/shaders/ShaderChunk/skinning_vertex.glsl.js +15 -15
  875. package/src/renderers/shaders/ShaderChunk/skinnormal_vertex.glsl.js +20 -20
  876. package/src/renderers/shaders/ShaderChunk/specularmap_fragment.glsl.js +14 -14
  877. package/src/renderers/shaders/ShaderChunk/specularmap_pars_fragment.glsl.js +7 -7
  878. package/src/renderers/shaders/ShaderChunk/tonemapping_fragment.glsl.js +7 -7
  879. package/src/renderers/shaders/ShaderChunk/tonemapping_pars_fragment.glsl.js +192 -169
  880. package/src/renderers/shaders/ShaderChunk/transmission_fragment.glsl.js +36 -36
  881. package/src/renderers/shaders/ShaderChunk/transmission_pars_fragment.glsl.js +201 -201
  882. package/src/renderers/shaders/ShaderChunk/uv_pars_fragment.glsl.js +119 -119
  883. package/src/renderers/shaders/ShaderChunk/uv_pars_vertex.glsl.js +145 -145
  884. package/src/renderers/shaders/ShaderChunk/uv_vertex.glsl.js +122 -122
  885. package/src/renderers/shaders/ShaderChunk/worldpos_vertex.glsl.js +21 -21
  886. package/src/renderers/shaders/ShaderChunk.js +272 -274
  887. package/src/renderers/shaders/ShaderLib/background.glsl.js +40 -40
  888. package/src/renderers/shaders/ShaderLib/backgroundCube.glsl.js +63 -62
  889. package/src/renderers/shaders/ShaderLib/cube.glsl.js +36 -36
  890. package/src/renderers/shaders/ShaderLib/depth.glsl.js +97 -95
  891. package/src/renderers/shaders/ShaderLib/distanceRGBA.glsl.js +78 -76
  892. package/src/renderers/shaders/ShaderLib/equirect.glsl.js +35 -35
  893. package/src/renderers/shaders/ShaderLib/linedashed.glsl.js +76 -77
  894. package/src/renderers/shaders/ShaderLib/meshbasic.glsl.js +116 -117
  895. package/src/renderers/shaders/ShaderLib/meshlambert.glsl.js +125 -126
  896. package/src/renderers/shaders/ShaderLib/meshmatcap.glsl.js +112 -113
  897. package/src/renderers/shaders/ShaderLib/meshnormal.glsl.js +87 -89
  898. package/src/renderers/shaders/ShaderLib/meshphong.glsl.js +127 -128
  899. package/src/renderers/shaders/ShaderLib/meshphysical.glsl.js +225 -226
  900. package/src/renderers/shaders/ShaderLib/meshtoon.glsl.js +119 -120
  901. package/src/renderers/shaders/ShaderLib/points.glsl.js +87 -88
  902. package/src/renderers/shaders/ShaderLib/shadow.glsl.js +58 -57
  903. package/src/renderers/shaders/ShaderLib/sprite.glsl.js +81 -81
  904. package/src/renderers/shaders/ShaderLib/vsm.glsl.js +53 -53
  905. package/src/renderers/shaders/ShaderLib.js +360 -367
  906. package/src/renderers/shaders/UniformsLib.js +231 -236
  907. package/src/renderers/shaders/UniformsUtils.js +104 -104
  908. package/src/renderers/webgl/WebGLAnimation.js +53 -53
  909. package/src/renderers/webgl/WebGLAttributes.js +229 -229
  910. package/src/renderers/webgl/WebGLBackground.js +257 -239
  911. package/src/renderers/webgl/WebGLBindingStates.js +631 -631
  912. package/src/renderers/webgl/WebGLBufferRenderer.js +92 -92
  913. package/src/renderers/webgl/WebGLCapabilities.js +120 -120
  914. package/src/renderers/webgl/WebGLClipping.js +171 -171
  915. package/src/renderers/webgl/WebGLCubeMaps.js +99 -99
  916. package/src/renderers/webgl/WebGLCubeUVMaps.js +132 -132
  917. package/src/renderers/webgl/WebGLExtensions.js +97 -97
  918. package/src/renderers/webgl/WebGLGeometries.js +211 -211
  919. package/src/renderers/webgl/WebGLIndexedBufferRenderer.js +102 -102
  920. package/src/renderers/webgl/WebGLInfo.js +71 -71
  921. package/src/renderers/webgl/WebGLLights.js +590 -590
  922. package/src/renderers/webgl/WebGLMaterials.js +590 -576
  923. package/src/renderers/webgl/WebGLMorphtargets.js +307 -300
  924. package/src/renderers/webgl/WebGLObjects.js +92 -92
  925. package/src/renderers/webgl/WebGLProgram.js +1120 -1112
  926. package/src/renderers/webgl/WebGLPrograms.js +664 -663
  927. package/src/renderers/webgl/WebGLProperties.js +48 -48
  928. package/src/renderers/webgl/WebGLRenderLists.js +238 -238
  929. package/src/renderers/webgl/WebGLRenderStates.js +107 -107
  930. package/src/renderers/webgl/WebGLShader.js +12 -12
  931. package/src/renderers/webgl/WebGLShaderCache.js +124 -124
  932. package/src/renderers/webgl/WebGLShadowMap.js +424 -424
  933. package/src/renderers/webgl/WebGLState.js +1318 -1328
  934. package/src/renderers/webgl/WebGLTextures.js +2213 -2117
  935. package/src/renderers/webgl/WebGLUniforms.js +1156 -1156
  936. package/src/renderers/webgl/WebGLUniformsGroups.js +392 -392
  937. package/src/renderers/webgl/WebGLUtils.js +283 -283
  938. package/src/renderers/webxr/WebXRController.js +343 -343
  939. package/src/renderers/webxr/WebXRDepthSensing.js +105 -0
  940. package/src/renderers/webxr/WebXRManager.js +824 -840
  941. package/src/scenes/Fog.js +38 -38
  942. package/src/scenes/FogExp2.js +35 -35
  943. package/src/scenes/Scene.js +71 -63
  944. package/src/textures/CanvasTexture.js +17 -17
  945. package/src/textures/CompressedArrayTexture.js +18 -18
  946. package/src/textures/CompressedCubeTexture.js +19 -19
  947. package/src/textures/CompressedTexture.js +28 -28
  948. package/src/textures/CubeTexture.js +33 -33
  949. package/src/textures/Data3DTexture.js +35 -35
  950. package/src/textures/DataArrayTexture.js +27 -27
  951. package/src/textures/DataTexture.js +22 -22
  952. package/src/textures/DepthTexture.js +58 -58
  953. package/src/textures/FramebufferTexture.js +23 -23
  954. package/src/textures/Source.js +128 -127
  955. package/src/textures/Texture.js +310 -338
  956. package/src/textures/VideoTexture.js +55 -55
  957. package/src/utils.js +91 -91
  958. package/examples/jsm/nodes/core/ArrayUniformNode.js +0 -26
  959. package/src/renderers/WebGLMultipleRenderTargets.js +0 -82
  960. package/src/renderers/shaders/ShaderChunk/occlusion_fragment.glsl.js +0 -20
  961. package/src/renderers/shaders/ShaderChunk/occlusion_pars_fragment.glsl.js +0 -97
@@ -1,1290 +1,1382 @@
1
- import { WebGLCoordinateSystem } from 'three';
2
-
3
- import GLSLNodeBuilder from './nodes/GLSLNodeBuilder.js';
4
- import Backend from '../common/Backend.js';
5
-
6
- import WebGLAttributeUtils from './utils/WebGLAttributeUtils.js';
7
- import WebGLState from './utils/WebGLState.js';
8
- import WebGLUtils from './utils/WebGLUtils.js';
9
- import WebGLTextureUtils from './utils/WebGLTextureUtils.js';
10
- import WebGLExtensions from './utils/WebGLExtensions.js';
11
- import WebGLCapabilities from './utils/WebGLCapabilities.js';
12
- import { GLFeatureName } from './utils/WebGLConstants.js';
13
-
14
- //
15
-
16
- class WebGLBackend extends Backend {
17
-
18
- constructor( parameters = {} ) {
19
-
20
- super( parameters );
21
-
22
- this.isWebGLBackend = true;
23
-
24
- }
25
-
26
- init( renderer ) {
27
-
28
- super.init( renderer );
29
-
30
- //
31
-
32
- const parameters = this.parameters;
33
-
34
- const glContext = ( parameters.context !== undefined ) ? parameters.context : renderer.domElement.getContext( 'webgl2' );
35
-
36
- this.gl = glContext;
37
-
38
- this.extensions = new WebGLExtensions( this );
39
- this.capabilities = new WebGLCapabilities( this );
40
- this.attributeUtils = new WebGLAttributeUtils( this );
41
- this.textureUtils = new WebGLTextureUtils( this );
42
- this.state = new WebGLState( this );
43
- this.utils = new WebGLUtils( this );
44
-
45
- this.vaoCache = {};
46
- this.transformFeedbackCache = {};
47
- this.discard = false;
48
-
49
- this.extensions.get( 'EXT_color_buffer_float' );
50
- this._currentContext = null;
51
-
52
- }
53
-
54
- get coordinateSystem() {
55
-
56
- return WebGLCoordinateSystem;
57
-
58
- }
59
-
60
- async getArrayBufferAsync( attribute ) {
61
-
62
- return await this.attributeUtils.getArrayBufferAsync( attribute );
63
-
64
- }
65
-
66
- getContext() {
67
-
68
- return this.gl;
69
-
70
- }
71
-
72
- beginRender( renderContext ) {
73
-
74
- const { gl } = this;
75
- const renderContextData = this.get( renderContext );
76
-
77
- //
78
-
79
- //
80
-
81
- renderContextData.previousContext = this._currentContext;
82
- this._currentContext = renderContext;
83
-
84
- this._setFramebuffer( renderContext );
85
-
86
- this.clear( renderContext.clearColor, renderContext.clearDepth, renderContext.clearStencil, renderContext );
87
-
88
- //
89
- if ( renderContext.viewport ) {
90
-
91
- this.updateViewport( renderContext );
92
-
93
- } else {
94
-
95
- gl.viewport( 0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight );
96
-
97
- }
98
-
99
- const occlusionQueryCount = renderContext.occlusionQueryCount;
100
-
101
- if ( occlusionQueryCount > 0 ) {
102
-
103
- // Get a reference to the array of objects with queries. The renderContextData property
104
- // can be changed by another render pass before the async reading of all previous queries complete
105
- renderContextData.currentOcclusionQueries = renderContextData.occlusionQueries;
106
- renderContextData.currentOcclusionQueryObjects = renderContextData.occlusionQueryObjects;
107
-
108
- renderContextData.lastOcclusionObject = null;
109
- renderContextData.occlusionQueries = new Array( occlusionQueryCount );
110
- renderContextData.occlusionQueryObjects = new Array( occlusionQueryCount );
111
- renderContextData.occlusionQueryIndex = 0;
112
-
113
- }
114
-
115
- }
116
-
117
- finishRender( renderContext ) {
118
-
119
- const { gl, state } = this;
120
- const renderContextData = this.get( renderContext );
121
- const previousContext = renderContextData.previousContext;
122
-
123
- const textures = renderContext.textures;
124
-
125
- if ( textures !== null ) {
126
-
127
- for ( let i = 0; i < textures.length; i ++ ) {
128
-
129
- const texture = textures[ i ];
130
-
131
- if ( texture.generateMipmaps ) {
132
-
133
- this.generateMipmaps( texture );
134
-
135
- }
136
-
137
- }
138
-
139
- }
140
-
141
- this._currentContext = previousContext;
142
-
143
-
144
- if ( renderContext.textures !== null && renderContext.renderTarget ) {
145
-
146
- const renderTargetContextData = this.get( renderContext.renderTarget );
147
-
148
- const { samples } = renderContext.renderTarget;
149
- const fb = renderTargetContextData.framebuffer;
150
-
151
- const mask = gl.COLOR_BUFFER_BIT;
152
-
153
- if ( samples > 0 ) {
154
-
155
- const msaaFrameBuffer = renderTargetContextData.msaaFrameBuffer;
156
-
157
- const textures = renderContext.textures;
158
-
159
- state.bindFramebuffer( gl.READ_FRAMEBUFFER, msaaFrameBuffer );
160
- state.bindFramebuffer( gl.DRAW_FRAMEBUFFER, fb );
161
-
162
- for ( let i = 0; i < textures.length; i ++ ) {
163
-
164
- // TODO Add support for MRT
165
-
166
- gl.blitFramebuffer( 0, 0, renderContext.width, renderContext.height, 0, 0, renderContext.width, renderContext.height, mask, gl.NEAREST );
167
-
168
- gl.invalidateFramebuffer( gl.READ_FRAMEBUFFER, renderTargetContextData.invalidationArray );
169
-
170
- }
171
-
172
- }
173
-
174
-
175
- }
176
-
177
- if ( previousContext !== null ) {
178
-
179
- this._setFramebuffer( previousContext );
180
-
181
- if ( previousContext.viewport ) {
182
-
183
- this.updateViewport( previousContext );
184
-
185
- } else {
186
-
187
- const gl = this.gl;
188
-
189
- gl.viewport( 0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight );
190
-
191
- }
192
-
193
- }
194
-
195
- const occlusionQueryCount = renderContext.occlusionQueryCount;
196
-
197
- if ( occlusionQueryCount > 0 ) {
198
-
199
- const renderContextData = this.get( renderContext );
200
-
201
- if ( occlusionQueryCount > renderContextData.occlusionQueryIndex ) {
202
-
203
- const { gl } = this;
204
-
205
- gl.endQuery( gl.ANY_SAMPLES_PASSED );
206
-
207
- }
208
-
209
- this.resolveOccludedAsync( renderContext );
210
-
211
- }
212
-
213
-
214
- }
215
-
216
- resolveOccludedAsync( renderContext ) {
217
-
218
- const renderContextData = this.get( renderContext );
219
-
220
- // handle occlusion query results
221
-
222
- const { currentOcclusionQueries, currentOcclusionQueryObjects } = renderContextData;
223
-
224
- if ( currentOcclusionQueries && currentOcclusionQueryObjects ) {
225
-
226
- const occluded = new WeakSet();
227
- const { gl } = this;
228
-
229
- renderContextData.currentOcclusionQueryObjects = null;
230
- renderContextData.currentOcclusionQueries = null;
231
-
232
- const check = () => {
233
-
234
- let completed = 0;
235
-
236
- // check all queries and requeue as appropriate
237
- for ( let i = 0; i < currentOcclusionQueries.length; i ++ ) {
238
-
239
- const query = currentOcclusionQueries[ i ];
240
-
241
- if ( query === null ) continue;
242
-
243
- if ( gl.getQueryParameter( query, gl.QUERY_RESULT_AVAILABLE ) ) {
244
-
245
- if ( gl.getQueryParameter( query, gl.QUERY_RESULT ) > 0 ) occluded.add( currentOcclusionQueryObjects[ i ] );
246
-
247
- currentOcclusionQueries[ i ] = null;
248
- gl.deleteQuery( query );
249
-
250
- completed ++;
251
-
252
- }
253
-
254
- }
255
-
256
- if ( completed < currentOcclusionQueries.length ) {
257
-
258
- requestAnimationFrame( check );
259
-
260
- } else {
261
-
262
- renderContextData.occluded = occluded;
263
-
264
- }
265
-
266
- };
267
-
268
- check();
269
-
270
- }
271
-
272
- }
273
-
274
- isOccluded( renderContext, object ) {
275
-
276
- const renderContextData = this.get( renderContext );
277
-
278
- return renderContextData.occluded && renderContextData.occluded.has( object );
279
-
280
- }
281
-
282
- updateViewport( renderContext ) {
283
-
284
- const gl = this.gl;
285
- const { x, y, width, height } = renderContext.viewportValue;
286
-
287
- gl.viewport( x, y, width, height );
288
-
289
- }
290
-
291
- clear( color, depth, stencil, descriptor = null ) {
292
-
293
- const { gl } = this;
294
-
295
- if ( descriptor === null ) {
296
-
297
- descriptor = {
298
- textures: null,
299
- clearColorValue: this.getClearColor()
300
- };
301
-
302
- }
303
-
304
- //
305
-
306
- let clear = 0;
307
-
308
- if ( color ) clear |= gl.COLOR_BUFFER_BIT;
309
- if ( depth ) clear |= gl.DEPTH_BUFFER_BIT;
310
- if ( stencil ) clear |= gl.STENCIL_BUFFER_BIT;
311
-
312
- if ( clear !== 0 ) {
313
-
314
- const clearColor = descriptor.clearColorValue;
315
-
316
- if ( depth ) this.state.setDepthMask( true );
317
-
318
- if ( descriptor.textures === null ) {
319
-
320
- gl.clearColor( clearColor.r, clearColor.g, clearColor.b, clearColor.a );
321
- gl.clear( clear );
322
-
323
- } else {
324
-
325
- if ( color ) {
326
-
327
- for ( let i = 0; i < descriptor.textures.length; i ++ ) {
328
-
329
- gl.clearBufferfv( gl.COLOR, i, [ clearColor.r, clearColor.g, clearColor.b, clearColor.a ] );
330
-
331
- }
332
-
333
- }
334
-
335
- if ( depth && stencil ) {
336
-
337
- gl.clearBufferfi( gl.DEPTH_STENCIL, 0, 1, 0 );
338
-
339
- } else if ( depth ) {
340
-
341
- gl.clearBufferfv( gl.DEPTH, 0, [ 1.0 ] );
342
-
343
- } else if ( stencil ) {
344
-
345
- gl.clearBufferiv( gl.STENCIL, 0, [ 0 ] );
346
-
347
- }
348
-
349
- }
350
-
351
- }
352
-
353
- }
354
-
355
- beginCompute( /*computeGroup*/ ) {
356
-
357
- const gl = this.gl;
358
-
359
- gl.bindFramebuffer( gl.FRAMEBUFFER, null );
360
-
361
- }
362
-
363
- compute( computeGroup, computeNode, bindings, pipeline ) {
364
-
365
- const gl = this.gl;
366
-
367
- if ( ! this.discard ) {
368
-
369
- // required here to handle async behaviour of render.compute()
370
- gl.enable( gl.RASTERIZER_DISCARD );
371
- this.discard = true;
372
- }
373
-
374
- const { programGPU, transformBuffers, attributes } = this.get( pipeline );
375
-
376
- const vaoKey = this._getVaoKey( null, attributes );
377
-
378
- let vaoGPU = this.vaoCache[ vaoKey ];
379
-
380
- if ( vaoGPU === undefined ) {
381
-
382
- this._createVao( null, attributes );
383
-
384
- } else {
385
-
386
- gl.bindVertexArray( vaoGPU );
387
-
388
- }
389
-
390
- gl.useProgram( programGPU );
391
-
392
- this._bindUniforms( bindings );
393
-
394
- const transformFeedbackGPU = this._getTransformFeedback( transformBuffers );
395
-
396
- gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, transformFeedbackGPU );
397
- gl.beginTransformFeedback( gl.POINTS );
398
-
399
- gl.drawArraysInstanced( gl.POINTS, 0, 1, computeNode.count );
400
-
401
- gl.endTransformFeedback();
402
- gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, null );
403
-
404
- // switch active buffers
405
- for ( let i = 0; i < transformBuffers.length; i ++ ) {
406
-
407
- transformBuffers[ i ].switchBuffers();
408
-
409
- }
410
-
411
- }
412
-
413
- finishCompute( /*computeGroup*/ ) {
414
-
415
- const gl = this.gl;
416
-
417
- this.discard = false;
418
-
419
- gl.disable( gl.RASTERIZER_DISCARD );
420
-
421
- }
422
-
423
- draw( renderObject, info ) {
424
-
425
- const { pipeline, material, context } = renderObject;
426
- const { programGPU } = this.get( pipeline );
427
-
428
- const { gl, state } = this;
429
-
430
- const contextData = this.get( context );
431
-
432
- //
433
-
434
- this._bindUniforms( renderObject.getBindings() );
435
-
436
- state.setMaterial( material );
437
-
438
- gl.useProgram( programGPU );
439
-
440
- //
441
-
442
- let vaoGPU = renderObject.staticVao;
443
-
444
- if ( vaoGPU === undefined ) {
445
-
446
- const vaoKey = this._getVaoKey( renderObject.getIndex(), renderObject.getAttributes() );
447
-
448
- vaoGPU = this.vaoCache[ vaoKey ];
449
-
450
- if ( vaoGPU === undefined ) {
451
-
452
- let staticVao;
453
-
454
- ( { vaoGPU, staticVao } = this._createVao( renderObject.getIndex(), renderObject.getAttributes() ) );
455
-
456
- if ( staticVao ) renderObject.staticVao = vaoGPU;
457
-
458
- }
459
-
460
- }
461
-
462
- gl.bindVertexArray( vaoGPU );
463
-
464
- //
465
-
466
- const index = renderObject.getIndex();
467
-
468
- const object = renderObject.object;
469
- const geometry = renderObject.geometry;
470
- const drawRange = geometry.drawRange;
471
- const firstVertex = drawRange.start;
472
-
473
- //
474
-
475
- const lastObject = contextData.lastOcclusionObject;
476
-
477
- if ( lastObject !== object && lastObject !== undefined ) {
478
-
479
- if ( lastObject !== null && lastObject.occlusionTest === true ) {
480
-
481
- gl.endQuery( gl.ANY_SAMPLES_PASSED );
482
-
483
- contextData.occlusionQueryIndex ++;
484
-
485
- }
486
-
487
- if ( object.occlusionTest === true ) {
488
-
489
- const query = gl.createQuery();
490
-
491
- gl.beginQuery( gl.ANY_SAMPLES_PASSED, query );
492
-
493
- contextData.occlusionQueries[ contextData.occlusionQueryIndex ] = query;
494
- contextData.occlusionQueryObjects[ contextData.occlusionQueryIndex ] = object;
495
-
496
- }
497
-
498
- contextData.lastOcclusionObject = object;
499
-
500
- }
501
-
502
- //
503
-
504
- let mode;
505
- if ( object.isPoints ) mode = gl.POINTS;
506
- else if ( object.isLineSegments ) mode = gl.LINES;
507
- else if ( object.isLine ) mode = gl.LINE_STRIP;
508
- else if ( object.isLineLoop ) mode = gl.LINE_LOOP;
509
- else {
510
-
511
- if ( material.wireframe === true ) {
512
-
513
- state.setLineWidth( material.wireframeLinewidth * this.renderer.getPixelRatio() );
514
- mode = gl.LINES;
515
-
516
- } else {
517
-
518
- mode = gl.TRIANGLES;
519
-
520
- }
521
-
522
- }
523
-
524
- //
525
-
526
- const instanceCount = this.getInstanceCount( renderObject );
527
-
528
- if ( index !== null ) {
529
-
530
- const indexData = this.get( index );
531
- const indexCount = ( drawRange.count !== Infinity ) ? drawRange.count : index.count;
532
-
533
- if ( instanceCount > 1 ) {
534
-
535
- gl.drawElementsInstanced( mode, index.count, indexData.type, firstVertex, instanceCount );
536
-
537
- } else {
538
-
539
- gl.drawElements( mode, index.count, indexData.type, firstVertex );
540
-
541
- }
542
-
543
- info.update( object, indexCount, 1 );
544
-
545
- } else {
546
-
547
- const positionAttribute = geometry.attributes.position;
548
- const vertexCount = ( drawRange.count !== Infinity ) ? drawRange.count : positionAttribute.count;
549
-
550
- if ( instanceCount > 1 ) {
551
-
552
- gl.drawArraysInstanced( mode, 0, vertexCount, instanceCount );
553
-
554
- } else {
555
-
556
- gl.drawArrays( mode, 0, vertexCount );
557
-
558
- }
559
-
560
- //gl.drawArrays( mode, vertexCount, gl.UNSIGNED_SHORT, firstVertex );
561
-
562
- info.update( object, vertexCount, 1 );
563
-
564
- }
565
-
566
- //
567
-
568
- gl.bindVertexArray( null );
569
-
570
- }
571
-
572
- needsRenderUpdate( /*renderObject*/ ) {
573
-
574
- return false;
575
-
576
- }
577
-
578
- getRenderCacheKey( renderObject ) {
579
-
580
- return renderObject.id;
581
-
582
- }
583
-
584
- // textures
585
-
586
- createDefaultTexture( texture ) {
587
-
588
- this.textureUtils.createDefaultTexture( texture );
589
-
590
- }
591
-
592
- createTexture( texture, options ) {
593
-
594
- this.textureUtils.createTexture( texture, options );
595
-
596
- }
597
-
598
- updateTexture( texture, options ) {
599
-
600
- this.textureUtils.updateTexture( texture, options );
601
-
602
- }
603
-
604
- generateMipmaps( texture ) {
605
-
606
- this.textureUtils.generateMipmaps( texture );
607
-
608
- }
609
-
610
-
611
- destroyTexture( texture ) {
612
-
613
- this.textureUtils.destroyTexture( texture );
614
-
615
- }
616
-
617
- copyTextureToBuffer( texture, x, y, width, height ) {
618
-
619
- return this.textureUtils.copyTextureToBuffer( texture, x, y, width, height );
620
-
621
- }
622
-
623
- createSampler( /*texture*/ ) {
624
-
625
- //console.warn( 'Abstract class.' );
626
-
627
- }
628
-
629
- destroySampler() {}
630
-
631
- // node builder
632
-
633
- createNodeBuilder( object, renderer, scene = null ) {
634
-
635
- return new GLSLNodeBuilder( object, renderer, scene );
636
-
637
- }
638
-
639
- // program
640
-
641
- createProgram( program ) {
642
-
643
- const gl = this.gl;
644
- const { stage, code } = program;
645
-
646
- const shader = stage === 'fragment' ? gl.createShader( gl.FRAGMENT_SHADER ) : gl.createShader( gl.VERTEX_SHADER );
647
-
648
- gl.shaderSource( shader, code );
649
- gl.compileShader( shader );
650
-
651
- this.set( program, {
652
- shaderGPU: shader
653
- } );
654
-
655
- }
656
-
657
- destroyProgram( /*program*/ ) {
658
-
659
- console.warn( 'Abstract class.' );
660
-
661
- }
662
-
663
- createRenderPipeline( renderObject ) {
664
-
665
- const gl = this.gl;
666
- const pipeline = renderObject.pipeline;
667
-
668
- // Program
669
-
670
- const { fragmentProgram, vertexProgram } = pipeline;
671
-
672
- const programGPU = gl.createProgram();
673
-
674
- const fragmentShader = this.get( fragmentProgram ).shaderGPU;
675
- const vertexShader = this.get( vertexProgram ).shaderGPU;
676
-
677
- gl.attachShader( programGPU, fragmentShader );
678
- gl.attachShader( programGPU, vertexShader );
679
- gl.linkProgram( programGPU );
680
-
681
- if ( gl.getProgramParameter( programGPU, gl.LINK_STATUS ) === false ) {
682
-
683
- console.error( 'THREE.WebGLBackend:', gl.getProgramInfoLog( programGPU ) );
684
-
685
- console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( fragmentShader ) );
686
- console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( vertexShader ) );
687
-
688
- }
689
-
690
- gl.useProgram( programGPU );
691
-
692
- // Bindings
693
-
694
- this._setupBindings( renderObject.getBindings(), programGPU );
695
-
696
- //
697
-
698
- this.set( pipeline, {
699
- programGPU
700
- } );
701
-
702
- }
703
-
704
- createComputePipeline( computePipeline, bindings ) {
705
-
706
- const gl = this.gl;
707
-
708
- // Program
709
-
710
- const fragmentProgram = {
711
- stage: 'fragment',
712
- code: "#version 300 es\nprecision highp float;\nvoid main() {}"
713
- };
714
-
715
- this.createProgram( fragmentProgram );
716
-
717
- const { computeProgram } = computePipeline;
718
-
719
- const programGPU = gl.createProgram();
720
-
721
- const fragmentShader = this.get( fragmentProgram ).shaderGPU;
722
- const vertexShader = this.get( computeProgram ).shaderGPU;
723
-
724
- const transforms = computeProgram.transforms;
725
-
726
- const transformVaryingNames = [];
727
- const transformAttributeNodes = [];
728
-
729
- for ( let i = 0; i < transforms.length; i ++ ) {
730
-
731
- const transform = transforms[ i ];
732
-
733
- transformVaryingNames.push( transform.varyingName );
734
- transformAttributeNodes.push( transform.attributeNode );
735
-
736
- }
737
-
738
- gl.attachShader( programGPU, fragmentShader );
739
- gl.attachShader( programGPU, vertexShader );
740
-
741
- gl.transformFeedbackVaryings(
742
- programGPU,
743
- transformVaryingNames,
744
- gl.SEPARATE_ATTRIBS,
745
- );
746
-
747
- gl.linkProgram( programGPU );
748
-
749
- if ( gl.getProgramParameter( programGPU, gl.LINK_STATUS ) === false ) {
750
-
751
- console.error( 'THREE.WebGLBackend:', gl.getProgramInfoLog( programGPU ) );
752
-
753
- console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( fragmentShader ) );
754
- console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( vertexShader ) );
755
-
756
- }
757
-
758
- gl.useProgram( programGPU );
759
-
760
- // Bindings
761
-
762
- this.createBindings( bindings );
763
-
764
- this._setupBindings( bindings, programGPU );
765
-
766
- const attributeNodes = computeProgram.attributes;
767
- const attributes = [];
768
- const transformBuffers = [];
769
-
770
- for ( let i = 0; i < attributeNodes.length; i ++ ) {
771
-
772
- const attribute = attributeNodes[ i ].node.attribute;
773
-
774
- attributes.push( attribute );
775
-
776
- if ( ! this.has( attribute ) ) this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
777
-
778
- }
779
-
780
- for ( let i = 0; i < transformAttributeNodes.length; i ++ ) {
781
-
782
- const attribute = transformAttributeNodes[ i ].attribute;
783
-
784
- if ( ! this.has( attribute ) ) this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
785
-
786
- const attributeData = this.get( attribute );
787
-
788
- transformBuffers.push( attributeData );
789
-
790
- }
791
-
792
- //
793
-
794
- this.set( computePipeline, {
795
- programGPU,
796
- transformBuffers,
797
- attributes
798
- } );
799
-
800
- }
801
-
802
- createBindings( bindings ) {
803
-
804
- this.updateBindings( bindings );
805
-
806
- }
807
-
808
- updateBindings( bindings ) {
809
-
810
- const { gl } = this;
811
-
812
- let groupIndex = 0;
813
- let textureIndex = 0;
814
-
815
- for ( const binding of bindings ) {
816
-
817
- if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
818
-
819
- const bufferGPU = gl.createBuffer();
820
- const data = binding.buffer;
821
-
822
- gl.bindBuffer( gl.UNIFORM_BUFFER, bufferGPU );
823
- gl.bufferData( gl.UNIFORM_BUFFER, data, gl.DYNAMIC_DRAW );
824
- gl.bindBufferBase( gl.UNIFORM_BUFFER, groupIndex, bufferGPU );
825
-
826
- this.set( binding, {
827
- index: groupIndex ++,
828
- bufferGPU
829
- } );
830
-
831
- } else if ( binding.isSampledTexture ) {
832
-
833
- const { textureGPU, glTextureType } = this.get( binding.texture );
834
-
835
- this.set( binding, {
836
- index: textureIndex ++,
837
- textureGPU,
838
- glTextureType
839
- } );
840
-
841
- }
842
-
843
- }
844
-
845
- }
846
-
847
- updateBinding( binding ) {
848
-
849
- const gl = this.gl;
850
-
851
- if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
852
-
853
- const bindingData = this.get( binding );
854
- const bufferGPU = bindingData.bufferGPU;
855
- const data = binding.buffer;
856
-
857
- gl.bindBuffer( gl.UNIFORM_BUFFER, bufferGPU );
858
- gl.bufferData( gl.UNIFORM_BUFFER, data, gl.DYNAMIC_DRAW );
859
-
860
- }
861
-
862
- }
863
-
864
- // attributes
865
-
866
- createIndexAttribute( attribute ) {
867
-
868
- const gl = this.gl;
869
-
870
- this.attributeUtils.createAttribute( attribute, gl.ELEMENT_ARRAY_BUFFER );
871
-
872
- }
873
-
874
- createAttribute( attribute ) {
875
-
876
- if ( this.has( attribute ) ) return;
877
-
878
- const gl = this.gl;
879
-
880
- this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
881
-
882
- }
883
-
884
- createStorageAttribute( attribute ) {
885
-
886
- //console.warn( 'Abstract class.' );
887
-
888
- }
889
-
890
- updateAttribute( attribute ) {
891
-
892
- this.attributeUtils.updateAttribute( attribute );
893
-
894
- }
895
-
896
- destroyAttribute( attribute ) {
897
-
898
- this.attributeUtils.destroyAttribute( attribute );
899
-
900
- }
901
-
902
- updateSize() {
903
-
904
- //console.warn( 'Abstract class.' );
905
-
906
- }
907
-
908
- async hasFeatureAsync( name ) {
909
-
910
- return this.hasFeature( name );
911
-
912
- }
913
-
914
- hasFeature( name ) {
915
-
916
- const keysMatching = Object.keys( GLFeatureName ).filter( key => GLFeatureName[ key ] === name );
917
-
918
- const extensions = this.extensions;
919
-
920
- for ( let i = 0; i < keysMatching.length; i ++ ) {
921
-
922
-
923
- if ( extensions.has( keysMatching[ i ] ) ) return true;
924
-
925
- }
926
-
927
- return false;
928
-
929
- }
930
-
931
-
932
- getMaxAnisotropy() {
933
-
934
- return this.capabilities.getMaxAnisotropy();
935
-
936
- }
937
-
938
- copyFramebufferToTexture( texture, renderContext ) {
939
-
940
- this.textureUtils.copyFramebufferToTexture( texture, renderContext );
941
-
942
- }
943
-
944
- _setFramebuffer( renderContext ) {
945
-
946
- const { gl, state } = this;
947
-
948
- let currentFrameBuffer = null;
949
-
950
- if ( renderContext.textures !== null ) {
951
-
952
- const renderTarget = renderContext.renderTarget;
953
- const renderTargetContextData = this.get( renderTarget );
954
- const { samples, depthBuffer, stencilBuffer } = renderTarget;
955
- const cubeFace = this.renderer._activeCubeFace;
956
- const isCube = renderTarget.isWebGLCubeRenderTarget === true;
957
-
958
- let msaaFb = renderTargetContextData.msaaFrameBuffer;
959
- let depthRenderbuffer = renderTargetContextData.depthRenderbuffer;
960
-
961
- let fb;
962
-
963
- if ( isCube ) {
964
-
965
- if ( renderTargetContextData.cubeFramebuffers === undefined ) {
966
-
967
- renderTargetContextData.cubeFramebuffers = [];
968
-
969
- }
970
-
971
- fb = renderTargetContextData.cubeFramebuffers[ cubeFace ];
972
-
973
- } else {
974
-
975
- fb = renderTargetContextData.framebuffer;
976
-
977
- }
978
-
979
- if ( fb === undefined ) {
980
-
981
- fb = gl.createFramebuffer();
982
-
983
- state.bindFramebuffer( gl.FRAMEBUFFER, fb );
984
-
985
- const textures = renderContext.textures;
986
-
987
- if ( isCube ) {
988
-
989
- renderTargetContextData.cubeFramebuffers[ cubeFace ] = fb;
990
- const { textureGPU } = this.get( textures[ 0 ] );
991
-
992
- gl.framebufferTexture2D( gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + cubeFace, textureGPU, 0 );
993
-
994
- } else {
995
-
996
- for ( let i = 0; i < textures.length; i ++ ) {
997
-
998
- const texture = textures[ i ];
999
- const textureData = this.get( texture );
1000
- textureData.renderTarget = renderContext.renderTarget;
1001
-
1002
- const attachment = gl.COLOR_ATTACHMENT0 + i;
1003
-
1004
- gl.framebufferTexture2D( gl.FRAMEBUFFER, attachment, gl.TEXTURE_2D, textureData.textureGPU, 0 );
1005
-
1006
- }
1007
-
1008
- renderTargetContextData.framebuffer = fb;
1009
-
1010
- state.drawBuffers( renderContext, fb );
1011
-
1012
- }
1013
-
1014
- if ( renderContext.depthTexture !== null ) {
1015
-
1016
- const textureData = this.get( renderContext.depthTexture );
1017
- const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1018
-
1019
- gl.framebufferTexture2D( gl.FRAMEBUFFER, depthStyle, gl.TEXTURE_2D, textureData.textureGPU, 0 );
1020
-
1021
- }
1022
-
1023
- }
1024
-
1025
- if ( samples > 0 ) {
1026
-
1027
- if ( msaaFb === undefined ) {
1028
-
1029
- const invalidationArray = [];
1030
-
1031
- msaaFb = gl.createFramebuffer();
1032
-
1033
- state.bindFramebuffer( gl.FRAMEBUFFER, msaaFb );
1034
-
1035
- const msaaRenderbuffers = [];
1036
-
1037
- const textures = renderContext.textures;
1038
-
1039
- for ( let i = 0; i < textures.length; i ++ ) {
1040
-
1041
-
1042
- msaaRenderbuffers[ i ] = gl.createRenderbuffer();
1043
-
1044
- gl.bindRenderbuffer( gl.RENDERBUFFER, msaaRenderbuffers[ i ] );
1045
-
1046
- invalidationArray.push( gl.COLOR_ATTACHMENT0 + i );
1047
-
1048
- if ( depthBuffer ) {
1049
-
1050
- const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1051
- invalidationArray.push( depthStyle );
1052
-
1053
- }
1054
-
1055
- const texture = renderContext.textures[ i ];
1056
- const textureData = this.get( texture );
1057
-
1058
- gl.renderbufferStorageMultisample( gl.RENDERBUFFER, samples, textureData.glInternalFormat, renderContext.width, renderContext.height );
1059
- gl.framebufferRenderbuffer( gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0 + i, gl.RENDERBUFFER, msaaRenderbuffers[ i ] );
1060
-
1061
-
1062
- }
1063
-
1064
- renderTargetContextData.msaaFrameBuffer = msaaFb;
1065
- renderTargetContextData.msaaRenderbuffers = msaaRenderbuffers;
1066
-
1067
- if ( depthRenderbuffer === undefined ) {
1068
-
1069
- depthRenderbuffer = gl.createRenderbuffer();
1070
- this.textureUtils.setupRenderBufferStorage( depthRenderbuffer, renderContext );
1071
-
1072
- renderTargetContextData.depthRenderbuffer = depthRenderbuffer;
1073
-
1074
- const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1075
- invalidationArray.push( depthStyle );
1076
-
1077
- }
1078
-
1079
- renderTargetContextData.invalidationArray = invalidationArray;
1080
-
1081
- }
1082
-
1083
- currentFrameBuffer = renderTargetContextData.msaaFrameBuffer;
1084
-
1085
- } else {
1086
-
1087
- currentFrameBuffer = fb;
1088
-
1089
- }
1090
-
1091
- }
1092
-
1093
- state.bindFramebuffer( gl.FRAMEBUFFER, currentFrameBuffer );
1094
-
1095
- }
1096
-
1097
-
1098
- _getVaoKey( index, attributes ) {
1099
-
1100
- let key = [];
1101
-
1102
- if ( index !== null ) {
1103
-
1104
- const indexData = this.get( index );
1105
-
1106
- key += ':' + indexData.id;
1107
-
1108
- }
1109
-
1110
- for ( let i = 0; i < attributes.length; i ++ ) {
1111
-
1112
- const attributeData = this.get( attributes[ i ] );
1113
-
1114
- key += ':' + attributeData.id;
1115
-
1116
- }
1117
-
1118
- return key;
1119
-
1120
- }
1121
-
1122
- _createVao( index, attributes ) {
1123
-
1124
- const { gl } = this;
1125
-
1126
- const vaoGPU = gl.createVertexArray();
1127
- let key = '';
1128
-
1129
- let staticVao = true;
1130
-
1131
- gl.bindVertexArray( vaoGPU );
1132
-
1133
- if ( index !== null ) {
1134
-
1135
- const indexData = this.get( index );
1136
-
1137
- gl.bindBuffer( gl.ELEMENT_ARRAY_BUFFER, indexData.bufferGPU );
1138
-
1139
- key += ':' + indexData.id;
1140
-
1141
- }
1142
-
1143
- for ( let i = 0; i < attributes.length; i ++ ) {
1144
-
1145
- const attribute = attributes[ i ];
1146
- const attributeData = this.get( attribute );
1147
-
1148
- key += ':' + attributeData.id;
1149
-
1150
- gl.bindBuffer( gl.ARRAY_BUFFER, attributeData.bufferGPU );
1151
- gl.enableVertexAttribArray( i );
1152
-
1153
- if ( attribute.isStorageBufferAttribute ) staticVao = false;
1154
-
1155
- let stride, offset;
1156
-
1157
- if ( attribute.isInterleavedBufferAttribute === true ) {
1158
-
1159
- stride = attribute.data.stride * attributeData.bytesPerElement;
1160
- offset = attribute.offset * attributeData.bytesPerElement;
1161
-
1162
- } else {
1163
-
1164
- stride = 0;
1165
- offset = 0;
1166
-
1167
- }
1168
-
1169
- if ( attributeData.isInteger ) {
1170
-
1171
- gl.vertexAttribIPointer( i, attribute.itemSize, attributeData.type, stride, offset );
1172
-
1173
- } else {
1174
-
1175
- gl.vertexAttribPointer( i, attribute.itemSize, attributeData.type, attribute.normalized, stride, offset );
1176
-
1177
- }
1178
-
1179
- if ( attribute.isInstancedBufferAttribute && ! attribute.isInterleavedBufferAttribute ) {
1180
-
1181
- gl.vertexAttribDivisor( i, attribute.meshPerAttribute );
1182
-
1183
- } else if ( attribute.isInterleavedBufferAttribute && attribute.data.isInstancedInterleavedBuffer ) {
1184
-
1185
- gl.vertexAttribDivisor( i, attribute.data.meshPerAttribute );
1186
-
1187
- }
1188
-
1189
- }
1190
-
1191
- gl.bindBuffer( gl.ARRAY_BUFFER, null );
1192
-
1193
- this.vaoCache[ key ] = vaoGPU;
1194
-
1195
- return { vaoGPU, staticVao };
1196
-
1197
- }
1198
-
1199
- _getTransformFeedback( transformBuffers ) {
1200
-
1201
- let key = '';
1202
-
1203
- for ( let i = 0; i < transformBuffers.length; i ++ ) {
1204
-
1205
- key += ':' + transformBuffers[ i ].id;
1206
-
1207
- }
1208
-
1209
- let transformFeedbackGPU = this.transformFeedbackCache[ key ];
1210
-
1211
- if ( transformFeedbackGPU !== undefined ) {
1212
-
1213
- return transformFeedbackGPU;
1214
-
1215
- }
1216
-
1217
- const gl = this.gl;
1218
-
1219
- transformFeedbackGPU = gl.createTransformFeedback();
1220
-
1221
- gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, transformFeedbackGPU );
1222
-
1223
- for ( let i = 0; i < transformBuffers.length; i ++ ) {
1224
-
1225
- const attributeData = transformBuffers[ i ];
1226
-
1227
- gl.bindBufferBase( gl.TRANSFORM_FEEDBACK_BUFFER, i, attributeData.transformBuffer );
1228
-
1229
- }
1230
-
1231
- gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, null );
1232
-
1233
- this.transformFeedbackCache[ key ] = transformFeedbackGPU;
1234
-
1235
- return transformFeedbackGPU;
1236
-
1237
- }
1238
-
1239
-
1240
- _setupBindings( bindings, programGPU ) {
1241
-
1242
- const gl = this.gl;
1243
-
1244
- for ( const binding of bindings ) {
1245
-
1246
- const bindingData = this.get( binding );
1247
- const index = bindingData.index;
1248
-
1249
- if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
1250
-
1251
- const location = gl.getUniformBlockIndex( programGPU, binding.name );
1252
- gl.uniformBlockBinding( programGPU, location, index );
1253
-
1254
- } else if ( binding.isSampledTexture ) {
1255
-
1256
- const location = gl.getUniformLocation( programGPU, binding.name );
1257
- gl.uniform1i( location, index );
1258
-
1259
- }
1260
-
1261
- }
1262
-
1263
- }
1264
-
1265
- _bindUniforms( bindings ) {
1266
-
1267
- const { gl, state } = this;
1268
-
1269
- for ( const binding of bindings ) {
1270
-
1271
- const bindingData = this.get( binding );
1272
- const index = bindingData.index;
1273
-
1274
- if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
1275
-
1276
- gl.bindBufferBase( gl.UNIFORM_BUFFER, index, bindingData.bufferGPU );
1277
-
1278
- } else if ( binding.isSampledTexture ) {
1279
-
1280
- state.bindTexture( bindingData.glTextureType, bindingData.textureGPU, gl.TEXTURE0 + index );
1281
-
1282
- }
1283
-
1284
- }
1285
-
1286
- }
1287
-
1288
- }
1289
-
1290
- export default WebGLBackend;
1
+ import { WebGLCoordinateSystem } from 'three';
2
+
3
+ import GLSLNodeBuilder from './nodes/GLSLNodeBuilder.js';
4
+ import Backend from '../common/Backend.js';
5
+
6
+ import WebGLAttributeUtils from './utils/WebGLAttributeUtils.js';
7
+ import WebGLState from './utils/WebGLState.js';
8
+ import WebGLUtils from './utils/WebGLUtils.js';
9
+ import WebGLTextureUtils from './utils/WebGLTextureUtils.js';
10
+ import WebGLExtensions from './utils/WebGLExtensions.js';
11
+ import WebGLCapabilities from './utils/WebGLCapabilities.js';
12
+ import { GLFeatureName } from './utils/WebGLConstants.js';
13
+
14
+ //
15
+
16
+ class WebGLBackend extends Backend {
17
+
18
+ constructor( parameters = {} ) {
19
+
20
+ super( parameters );
21
+
22
+ this.isWebGLBackend = true;
23
+
24
+ }
25
+
26
+ init( renderer ) {
27
+
28
+ super.init( renderer );
29
+
30
+ //
31
+
32
+ const parameters = this.parameters;
33
+
34
+ const glContext = ( parameters.context !== undefined ) ? parameters.context : renderer.domElement.getContext( 'webgl2' );
35
+
36
+ this.gl = glContext;
37
+
38
+ this.extensions = new WebGLExtensions( this );
39
+ this.capabilities = new WebGLCapabilities( this );
40
+ this.attributeUtils = new WebGLAttributeUtils( this );
41
+ this.textureUtils = new WebGLTextureUtils( this );
42
+ this.state = new WebGLState( this );
43
+ this.utils = new WebGLUtils( this );
44
+
45
+ this.vaoCache = {};
46
+ this.transformFeedbackCache = {};
47
+ this.discard = false;
48
+
49
+ this.extensions.get( 'EXT_color_buffer_float' );
50
+ this.parallel = this.extensions.get( 'KHR_parallel_shader_compile' );
51
+ this._currentContext = null;
52
+
53
+ }
54
+
55
+ get coordinateSystem() {
56
+
57
+ return WebGLCoordinateSystem;
58
+
59
+ }
60
+
61
+ async getArrayBufferAsync( attribute ) {
62
+
63
+ return await this.attributeUtils.getArrayBufferAsync( attribute );
64
+
65
+ }
66
+
67
+ getContext() {
68
+
69
+ return this.gl;
70
+
71
+ }
72
+
73
+ beginRender( renderContext ) {
74
+
75
+ const { gl } = this;
76
+ const renderContextData = this.get( renderContext );
77
+
78
+ //
79
+
80
+ //
81
+
82
+ renderContextData.previousContext = this._currentContext;
83
+ this._currentContext = renderContext;
84
+
85
+ this._setFramebuffer( renderContext );
86
+
87
+ this.clear( renderContext.clearColor, renderContext.clearDepth, renderContext.clearStencil, renderContext, false );
88
+
89
+ //
90
+ if ( renderContext.viewport ) {
91
+
92
+ this.updateViewport( renderContext );
93
+
94
+ } else {
95
+
96
+ gl.viewport( 0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight );
97
+
98
+ }
99
+
100
+ if ( renderContext.scissor ) {
101
+
102
+ const { x, y, width, height } = renderContext.scissorValue;
103
+
104
+ gl.scissor( x, y, width, height );
105
+
106
+ }
107
+
108
+ const occlusionQueryCount = renderContext.occlusionQueryCount;
109
+
110
+ if ( occlusionQueryCount > 0 ) {
111
+
112
+ // Get a reference to the array of objects with queries. The renderContextData property
113
+ // can be changed by another render pass before the async reading of all previous queries complete
114
+ renderContextData.currentOcclusionQueries = renderContextData.occlusionQueries;
115
+ renderContextData.currentOcclusionQueryObjects = renderContextData.occlusionQueryObjects;
116
+
117
+ renderContextData.lastOcclusionObject = null;
118
+ renderContextData.occlusionQueries = new Array( occlusionQueryCount );
119
+ renderContextData.occlusionQueryObjects = new Array( occlusionQueryCount );
120
+ renderContextData.occlusionQueryIndex = 0;
121
+
122
+ }
123
+
124
+ }
125
+
126
+ finishRender( renderContext ) {
127
+
128
+ const { gl, state } = this;
129
+ const renderContextData = this.get( renderContext );
130
+ const previousContext = renderContextData.previousContext;
131
+
132
+ const textures = renderContext.textures;
133
+
134
+ if ( textures !== null ) {
135
+
136
+ for ( let i = 0; i < textures.length; i ++ ) {
137
+
138
+ const texture = textures[ i ];
139
+
140
+ if ( texture.generateMipmaps ) {
141
+
142
+ this.generateMipmaps( texture );
143
+
144
+ }
145
+
146
+ }
147
+
148
+ }
149
+
150
+ this._currentContext = previousContext;
151
+
152
+
153
+ if ( renderContext.textures !== null && renderContext.renderTarget ) {
154
+
155
+ const renderTargetContextData = this.get( renderContext.renderTarget );
156
+
157
+ const { samples } = renderContext.renderTarget;
158
+ const fb = renderTargetContextData.framebuffer;
159
+
160
+ const mask = gl.COLOR_BUFFER_BIT;
161
+
162
+ if ( samples > 0 ) {
163
+
164
+ const msaaFrameBuffer = renderTargetContextData.msaaFrameBuffer;
165
+
166
+ const textures = renderContext.textures;
167
+
168
+ state.bindFramebuffer( gl.READ_FRAMEBUFFER, msaaFrameBuffer );
169
+ state.bindFramebuffer( gl.DRAW_FRAMEBUFFER, fb );
170
+
171
+ for ( let i = 0; i < textures.length; i ++ ) {
172
+
173
+ // TODO Add support for MRT
174
+
175
+ gl.blitFramebuffer( 0, 0, renderContext.width, renderContext.height, 0, 0, renderContext.width, renderContext.height, mask, gl.NEAREST );
176
+
177
+ gl.invalidateFramebuffer( gl.READ_FRAMEBUFFER, renderTargetContextData.invalidationArray );
178
+
179
+ }
180
+
181
+ }
182
+
183
+
184
+ }
185
+
186
+ if ( previousContext !== null ) {
187
+
188
+ this._setFramebuffer( previousContext );
189
+
190
+ if ( previousContext.viewport ) {
191
+
192
+ this.updateViewport( previousContext );
193
+
194
+ } else {
195
+
196
+ const gl = this.gl;
197
+
198
+ gl.viewport( 0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight );
199
+
200
+ }
201
+
202
+ }
203
+
204
+ const occlusionQueryCount = renderContext.occlusionQueryCount;
205
+
206
+ if ( occlusionQueryCount > 0 ) {
207
+
208
+ const renderContextData = this.get( renderContext );
209
+
210
+ if ( occlusionQueryCount > renderContextData.occlusionQueryIndex ) {
211
+
212
+ const { gl } = this;
213
+
214
+ gl.endQuery( gl.ANY_SAMPLES_PASSED );
215
+
216
+ }
217
+
218
+ this.resolveOccludedAsync( renderContext );
219
+
220
+ }
221
+
222
+
223
+ }
224
+
225
+ resolveOccludedAsync( renderContext ) {
226
+
227
+ const renderContextData = this.get( renderContext );
228
+
229
+ // handle occlusion query results
230
+
231
+ const { currentOcclusionQueries, currentOcclusionQueryObjects } = renderContextData;
232
+
233
+ if ( currentOcclusionQueries && currentOcclusionQueryObjects ) {
234
+
235
+ const occluded = new WeakSet();
236
+ const { gl } = this;
237
+
238
+ renderContextData.currentOcclusionQueryObjects = null;
239
+ renderContextData.currentOcclusionQueries = null;
240
+
241
+ const check = () => {
242
+
243
+ let completed = 0;
244
+
245
+ // check all queries and requeue as appropriate
246
+ for ( let i = 0; i < currentOcclusionQueries.length; i ++ ) {
247
+
248
+ const query = currentOcclusionQueries[ i ];
249
+
250
+ if ( query === null ) continue;
251
+
252
+ if ( gl.getQueryParameter( query, gl.QUERY_RESULT_AVAILABLE ) ) {
253
+
254
+ if ( gl.getQueryParameter( query, gl.QUERY_RESULT ) > 0 ) occluded.add( currentOcclusionQueryObjects[ i ] );
255
+
256
+ currentOcclusionQueries[ i ] = null;
257
+ gl.deleteQuery( query );
258
+
259
+ completed ++;
260
+
261
+ }
262
+
263
+ }
264
+
265
+ if ( completed < currentOcclusionQueries.length ) {
266
+
267
+ requestAnimationFrame( check );
268
+
269
+ } else {
270
+
271
+ renderContextData.occluded = occluded;
272
+
273
+ }
274
+
275
+ };
276
+
277
+ check();
278
+
279
+ }
280
+
281
+ }
282
+
283
+ isOccluded( renderContext, object ) {
284
+
285
+ const renderContextData = this.get( renderContext );
286
+
287
+ return renderContextData.occluded && renderContextData.occluded.has( object );
288
+
289
+ }
290
+
291
+ updateViewport( renderContext ) {
292
+
293
+ const gl = this.gl;
294
+ const { x, y, width, height } = renderContext.viewportValue;
295
+
296
+ gl.viewport( x, y, width, height );
297
+
298
+ }
299
+
300
+ setScissorTest( boolean ) {
301
+
302
+ const gl = this.gl;
303
+
304
+ if ( boolean ) {
305
+
306
+ gl.enable( gl.SCISSOR_TEST );
307
+
308
+ } else {
309
+
310
+ gl.disable( gl.SCISSOR_TEST );
311
+
312
+ }
313
+
314
+ }
315
+
316
+ clear( color, depth, stencil, descriptor = null, setFrameBuffer = true ) {
317
+
318
+ const { gl } = this;
319
+
320
+ if ( descriptor === null ) {
321
+
322
+ descriptor = {
323
+ textures: null,
324
+ clearColorValue: this.getClearColor()
325
+ };
326
+
327
+ }
328
+
329
+ //
330
+
331
+ let clear = 0;
332
+
333
+ if ( color ) clear |= gl.COLOR_BUFFER_BIT;
334
+ if ( depth ) clear |= gl.DEPTH_BUFFER_BIT;
335
+ if ( stencil ) clear |= gl.STENCIL_BUFFER_BIT;
336
+
337
+ if ( clear !== 0 ) {
338
+
339
+ const clearColor = descriptor.clearColorValue || this.getClearColor();
340
+
341
+ if ( depth ) this.state.setDepthMask( true );
342
+
343
+ if ( descriptor.textures === null ) {
344
+
345
+ gl.clearColor( clearColor.r, clearColor.g, clearColor.b, clearColor.a );
346
+ gl.clear( clear );
347
+
348
+ } else {
349
+
350
+ if ( setFrameBuffer ) this._setFramebuffer( descriptor );
351
+
352
+ if ( color ) {
353
+
354
+ for ( let i = 0; i < descriptor.textures.length; i ++ ) {
355
+
356
+ gl.clearBufferfv( gl.COLOR, i, [ clearColor.r, clearColor.g, clearColor.b, clearColor.a ] );
357
+
358
+ }
359
+
360
+ }
361
+
362
+ if ( depth && stencil ) {
363
+
364
+ gl.clearBufferfi( gl.DEPTH_STENCIL, 0, 1, 0 );
365
+
366
+ } else if ( depth ) {
367
+
368
+ gl.clearBufferfv( gl.DEPTH, 0, [ 1.0 ] );
369
+
370
+ } else if ( stencil ) {
371
+
372
+ gl.clearBufferiv( gl.STENCIL, 0, [ 0 ] );
373
+
374
+ }
375
+
376
+ }
377
+
378
+ }
379
+
380
+ }
381
+
382
+ beginCompute( /*computeGroup*/ ) {
383
+
384
+ const gl = this.gl;
385
+
386
+ gl.bindFramebuffer( gl.FRAMEBUFFER, null );
387
+
388
+ }
389
+
390
+ compute( computeGroup, computeNode, bindings, pipeline ) {
391
+
392
+ const gl = this.gl;
393
+
394
+ if ( ! this.discard ) {
395
+
396
+ // required here to handle async behaviour of render.compute()
397
+ gl.enable( gl.RASTERIZER_DISCARD );
398
+ this.discard = true;
399
+
400
+ }
401
+
402
+ const { programGPU, transformBuffers, attributes } = this.get( pipeline );
403
+
404
+ const vaoKey = this._getVaoKey( null, attributes );
405
+
406
+ const vaoGPU = this.vaoCache[ vaoKey ];
407
+
408
+ if ( vaoGPU === undefined ) {
409
+
410
+ this._createVao( null, attributes );
411
+
412
+ } else {
413
+
414
+ gl.bindVertexArray( vaoGPU );
415
+
416
+ }
417
+
418
+ gl.useProgram( programGPU );
419
+
420
+ this._bindUniforms( bindings );
421
+
422
+ const transformFeedbackGPU = this._getTransformFeedback( transformBuffers );
423
+
424
+ gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, transformFeedbackGPU );
425
+ gl.beginTransformFeedback( gl.POINTS );
426
+
427
+ if ( attributes[ 0 ].isStorageInstancedBufferAttribute ) {
428
+
429
+ gl.drawArraysInstanced( gl.POINTS, 0, 1, computeNode.count );
430
+
431
+ } else {
432
+
433
+ gl.drawArrays( gl.POINTS, 0, computeNode.count );
434
+
435
+ }
436
+
437
+ gl.endTransformFeedback();
438
+ gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, null );
439
+
440
+ // switch active buffers
441
+
442
+ for ( let i = 0; i < transformBuffers.length; i ++ ) {
443
+
444
+ const dualAttributeData = transformBuffers[ i ];
445
+
446
+ if ( dualAttributeData.pbo ) {
447
+
448
+ this.textureUtils.copyBufferToTexture( dualAttributeData.transformBuffer, dualAttributeData.pbo );
449
+
450
+ }
451
+
452
+ dualAttributeData.switchBuffers();
453
+
454
+
455
+ }
456
+
457
+ }
458
+
459
+ finishCompute( /*computeGroup*/ ) {
460
+
461
+ const gl = this.gl;
462
+
463
+ this.discard = false;
464
+
465
+ gl.disable( gl.RASTERIZER_DISCARD );
466
+
467
+ }
468
+
469
+ draw( renderObject, info ) {
470
+
471
+ const { pipeline, material, context } = renderObject;
472
+ const { programGPU } = this.get( pipeline );
473
+
474
+ const { gl, state } = this;
475
+
476
+ const contextData = this.get( context );
477
+
478
+ //
479
+
480
+ this._bindUniforms( renderObject.getBindings() );
481
+
482
+ state.setMaterial( material );
483
+
484
+ gl.useProgram( programGPU );
485
+
486
+ //
487
+
488
+ let vaoGPU = renderObject.staticVao;
489
+
490
+ if ( vaoGPU === undefined ) {
491
+
492
+ const vaoKey = this._getVaoKey( renderObject.getIndex(), renderObject.getAttributes() );
493
+
494
+ vaoGPU = this.vaoCache[ vaoKey ];
495
+
496
+ if ( vaoGPU === undefined ) {
497
+
498
+ let staticVao;
499
+
500
+ ( { vaoGPU, staticVao } = this._createVao( renderObject.getIndex(), renderObject.getAttributes() ) );
501
+
502
+ if ( staticVao ) renderObject.staticVao = vaoGPU;
503
+
504
+ }
505
+
506
+ }
507
+
508
+ gl.bindVertexArray( vaoGPU );
509
+
510
+ //
511
+
512
+ const index = renderObject.getIndex();
513
+
514
+ const object = renderObject.object;
515
+ const geometry = renderObject.geometry;
516
+ const drawRange = geometry.drawRange;
517
+ const firstVertex = drawRange.start;
518
+
519
+ //
520
+
521
+ const lastObject = contextData.lastOcclusionObject;
522
+
523
+ if ( lastObject !== object && lastObject !== undefined ) {
524
+
525
+ if ( lastObject !== null && lastObject.occlusionTest === true ) {
526
+
527
+ gl.endQuery( gl.ANY_SAMPLES_PASSED );
528
+
529
+ contextData.occlusionQueryIndex ++;
530
+
531
+ }
532
+
533
+ if ( object.occlusionTest === true ) {
534
+
535
+ const query = gl.createQuery();
536
+
537
+ gl.beginQuery( gl.ANY_SAMPLES_PASSED, query );
538
+
539
+ contextData.occlusionQueries[ contextData.occlusionQueryIndex ] = query;
540
+ contextData.occlusionQueryObjects[ contextData.occlusionQueryIndex ] = object;
541
+
542
+ }
543
+
544
+ contextData.lastOcclusionObject = object;
545
+
546
+ }
547
+
548
+ //
549
+
550
+ let mode;
551
+ if ( object.isPoints ) mode = gl.POINTS;
552
+ else if ( object.isLineSegments ) mode = gl.LINES;
553
+ else if ( object.isLine ) mode = gl.LINE_STRIP;
554
+ else if ( object.isLineLoop ) mode = gl.LINE_LOOP;
555
+ else {
556
+
557
+ if ( material.wireframe === true ) {
558
+
559
+ state.setLineWidth( material.wireframeLinewidth * this.renderer.getPixelRatio() );
560
+ mode = gl.LINES;
561
+
562
+ } else {
563
+
564
+ mode = gl.TRIANGLES;
565
+
566
+ }
567
+
568
+ }
569
+
570
+ //
571
+
572
+ const instanceCount = this.getInstanceCount( renderObject );
573
+
574
+ if ( index !== null ) {
575
+
576
+ const indexData = this.get( index );
577
+ const indexCount = ( drawRange.count !== Infinity ) ? drawRange.count : index.count;
578
+
579
+ if ( instanceCount > 1 ) {
580
+
581
+ gl.drawElementsInstanced( mode, index.count, indexData.type, firstVertex, instanceCount );
582
+
583
+ } else {
584
+
585
+ gl.drawElements( mode, index.count, indexData.type, firstVertex );
586
+
587
+ }
588
+
589
+ info.update( object, indexCount, 1 );
590
+
591
+ } else {
592
+
593
+ const positionAttribute = geometry.attributes.position;
594
+ const vertexCount = ( drawRange.count !== Infinity ) ? drawRange.count : positionAttribute.count;
595
+
596
+ if ( instanceCount > 1 ) {
597
+
598
+ gl.drawArraysInstanced( mode, 0, vertexCount, instanceCount );
599
+
600
+ } else {
601
+
602
+ gl.drawArrays( mode, 0, vertexCount );
603
+
604
+ }
605
+
606
+ //gl.drawArrays( mode, vertexCount, gl.UNSIGNED_SHORT, firstVertex );
607
+
608
+ info.update( object, vertexCount, 1 );
609
+
610
+ }
611
+
612
+ //
613
+
614
+ gl.bindVertexArray( null );
615
+
616
+ }
617
+
618
+ needsRenderUpdate( /*renderObject*/ ) {
619
+
620
+ return false;
621
+
622
+ }
623
+
624
+ getRenderCacheKey( renderObject ) {
625
+
626
+ return renderObject.id;
627
+
628
+ }
629
+
630
+ // textures
631
+
632
+ createDefaultTexture( texture ) {
633
+
634
+ this.textureUtils.createDefaultTexture( texture );
635
+
636
+ }
637
+
638
+ createTexture( texture, options ) {
639
+
640
+ this.textureUtils.createTexture( texture, options );
641
+
642
+ }
643
+
644
+ updateTexture( texture, options ) {
645
+
646
+ this.textureUtils.updateTexture( texture, options );
647
+
648
+ }
649
+
650
+ generateMipmaps( texture ) {
651
+
652
+ this.textureUtils.generateMipmaps( texture );
653
+
654
+ }
655
+
656
+
657
+ destroyTexture( texture ) {
658
+
659
+ this.textureUtils.destroyTexture( texture );
660
+
661
+ }
662
+
663
+ copyTextureToBuffer( texture, x, y, width, height ) {
664
+
665
+ return this.textureUtils.copyTextureToBuffer( texture, x, y, width, height );
666
+
667
+ }
668
+
669
+ createSampler( /*texture*/ ) {
670
+
671
+ //console.warn( 'Abstract class.' );
672
+
673
+ }
674
+
675
+ destroySampler() {}
676
+
677
+ // node builder
678
+
679
+ createNodeBuilder( object, renderer, scene = null ) {
680
+
681
+ return new GLSLNodeBuilder( object, renderer, scene );
682
+
683
+ }
684
+
685
+ // program
686
+
687
+ createProgram( program ) {
688
+
689
+ const gl = this.gl;
690
+ const { stage, code } = program;
691
+
692
+ const shader = stage === 'fragment' ? gl.createShader( gl.FRAGMENT_SHADER ) : gl.createShader( gl.VERTEX_SHADER );
693
+
694
+ gl.shaderSource( shader, code );
695
+ gl.compileShader( shader );
696
+
697
+ this.set( program, {
698
+ shaderGPU: shader
699
+ } );
700
+
701
+ }
702
+
703
+ destroyProgram( /*program*/ ) {
704
+
705
+ console.warn( 'Abstract class.' );
706
+
707
+ }
708
+
709
+ createRenderPipeline( renderObject, promises ) {
710
+
711
+ const gl = this.gl;
712
+ const pipeline = renderObject.pipeline;
713
+
714
+ // Program
715
+
716
+ const { fragmentProgram, vertexProgram } = pipeline;
717
+
718
+ const programGPU = gl.createProgram();
719
+
720
+ const fragmentShader = this.get( fragmentProgram ).shaderGPU;
721
+ const vertexShader = this.get( vertexProgram ).shaderGPU;
722
+
723
+ gl.attachShader( programGPU, fragmentShader );
724
+ gl.attachShader( programGPU, vertexShader );
725
+ gl.linkProgram( programGPU );
726
+
727
+ this.set( pipeline, {
728
+ programGPU,
729
+ fragmentShader,
730
+ vertexShader
731
+ } );
732
+
733
+ if ( promises !== null && this.parallel ) {
734
+
735
+ const p = new Promise( ( resolve /*, reject*/ ) => {
736
+
737
+ const parallel = this.parallel;
738
+ const checkStatus = () => {
739
+
740
+ if ( gl.getProgramParameter( programGPU, parallel.COMPLETION_STATUS_KHR ) ) {
741
+
742
+ this._completeCompile( renderObject, pipeline );
743
+ resolve();
744
+
745
+ } else {
746
+
747
+ requestAnimationFrame( checkStatus );
748
+
749
+ }
750
+
751
+ };
752
+
753
+ checkStatus();
754
+
755
+ } );
756
+
757
+ promises.push( p );
758
+
759
+ return;
760
+
761
+ }
762
+
763
+ this._completeCompile( renderObject, pipeline );
764
+
765
+ }
766
+
767
+ _completeCompile( renderObject, pipeline ) {
768
+
769
+ const gl = this.gl;
770
+ const pipelineData = this.get( pipeline );
771
+ const { programGPU, fragmentShader, vertexShader } = pipelineData;
772
+
773
+ if ( gl.getProgramParameter( programGPU, gl.LINK_STATUS ) === false ) {
774
+
775
+ console.error( 'THREE.WebGLBackend:', gl.getProgramInfoLog( programGPU ) );
776
+
777
+ console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( fragmentShader ) );
778
+ console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( vertexShader ) );
779
+
780
+ }
781
+
782
+ gl.useProgram( programGPU );
783
+
784
+ // Bindings
785
+
786
+ this._setupBindings( renderObject.getBindings(), programGPU );
787
+
788
+ //
789
+
790
+ this.set( pipeline, {
791
+ programGPU
792
+ } );
793
+
794
+ }
795
+
796
+ createComputePipeline( computePipeline, bindings ) {
797
+
798
+ const gl = this.gl;
799
+
800
+ // Program
801
+
802
+ const fragmentProgram = {
803
+ stage: 'fragment',
804
+ code: '#version 300 es\nprecision highp float;\nvoid main() {}'
805
+ };
806
+
807
+ this.createProgram( fragmentProgram );
808
+
809
+ const { computeProgram } = computePipeline;
810
+
811
+ const programGPU = gl.createProgram();
812
+
813
+ const fragmentShader = this.get( fragmentProgram ).shaderGPU;
814
+ const vertexShader = this.get( computeProgram ).shaderGPU;
815
+
816
+ const transforms = computeProgram.transforms;
817
+
818
+ const transformVaryingNames = [];
819
+ const transformAttributeNodes = [];
820
+
821
+ for ( let i = 0; i < transforms.length; i ++ ) {
822
+
823
+ const transform = transforms[ i ];
824
+
825
+ transformVaryingNames.push( transform.varyingName );
826
+ transformAttributeNodes.push( transform.attributeNode );
827
+
828
+ }
829
+
830
+ gl.attachShader( programGPU, fragmentShader );
831
+ gl.attachShader( programGPU, vertexShader );
832
+
833
+ gl.transformFeedbackVaryings(
834
+ programGPU,
835
+ transformVaryingNames,
836
+ gl.SEPARATE_ATTRIBS,
837
+ );
838
+
839
+ gl.linkProgram( programGPU );
840
+
841
+ if ( gl.getProgramParameter( programGPU, gl.LINK_STATUS ) === false ) {
842
+
843
+ console.error( 'THREE.WebGLBackend:', gl.getProgramInfoLog( programGPU ) );
844
+
845
+ console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( fragmentShader ) );
846
+ console.error( 'THREE.WebGLBackend:', gl.getShaderInfoLog( vertexShader ) );
847
+
848
+ }
849
+
850
+ gl.useProgram( programGPU );
851
+
852
+ // Bindings
853
+
854
+ this.createBindings( bindings );
855
+
856
+ this._setupBindings( bindings, programGPU );
857
+
858
+ const attributeNodes = computeProgram.attributes;
859
+ const attributes = [];
860
+ const transformBuffers = [];
861
+
862
+ for ( let i = 0; i < attributeNodes.length; i ++ ) {
863
+
864
+ const attribute = attributeNodes[ i ].node.attribute;
865
+
866
+ attributes.push( attribute );
867
+
868
+ if ( ! this.has( attribute ) ) this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
869
+
870
+ }
871
+
872
+ for ( let i = 0; i < transformAttributeNodes.length; i ++ ) {
873
+
874
+ const attribute = transformAttributeNodes[ i ].attribute;
875
+
876
+ if ( ! this.has( attribute ) ) this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
877
+
878
+ const attributeData = this.get( attribute );
879
+
880
+ transformBuffers.push( attributeData );
881
+
882
+ }
883
+
884
+ //
885
+
886
+ this.set( computePipeline, {
887
+ programGPU,
888
+ transformBuffers,
889
+ attributes
890
+ } );
891
+
892
+ }
893
+
894
+ createBindings( bindings ) {
895
+
896
+ this.updateBindings( bindings );
897
+
898
+ }
899
+
900
+ updateBindings( bindings ) {
901
+
902
+ const { gl } = this;
903
+
904
+ let groupIndex = 0;
905
+ let textureIndex = 0;
906
+
907
+ for ( const binding of bindings ) {
908
+
909
+ if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
910
+
911
+ const bufferGPU = gl.createBuffer();
912
+ const data = binding.buffer;
913
+
914
+ gl.bindBuffer( gl.UNIFORM_BUFFER, bufferGPU );
915
+ gl.bufferData( gl.UNIFORM_BUFFER, data, gl.DYNAMIC_DRAW );
916
+ gl.bindBufferBase( gl.UNIFORM_BUFFER, groupIndex, bufferGPU );
917
+
918
+ this.set( binding, {
919
+ index: groupIndex ++,
920
+ bufferGPU
921
+ } );
922
+
923
+ } else if ( binding.isSampledTexture ) {
924
+
925
+ const { textureGPU, glTextureType } = this.get( binding.texture );
926
+
927
+ this.set( binding, {
928
+ index: textureIndex ++,
929
+ textureGPU,
930
+ glTextureType
931
+ } );
932
+
933
+ }
934
+
935
+ }
936
+
937
+ }
938
+
939
+ updateBinding( binding ) {
940
+
941
+ const gl = this.gl;
942
+
943
+ if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
944
+
945
+ const bindingData = this.get( binding );
946
+ const bufferGPU = bindingData.bufferGPU;
947
+ const data = binding.buffer;
948
+
949
+ gl.bindBuffer( gl.UNIFORM_BUFFER, bufferGPU );
950
+ gl.bufferData( gl.UNIFORM_BUFFER, data, gl.DYNAMIC_DRAW );
951
+
952
+ }
953
+
954
+ }
955
+
956
+ // attributes
957
+
958
+ createIndexAttribute( attribute ) {
959
+
960
+ const gl = this.gl;
961
+
962
+ this.attributeUtils.createAttribute( attribute, gl.ELEMENT_ARRAY_BUFFER );
963
+
964
+ }
965
+
966
+ createAttribute( attribute ) {
967
+
968
+ if ( this.has( attribute ) ) return;
969
+
970
+ const gl = this.gl;
971
+
972
+ this.attributeUtils.createAttribute( attribute, gl.ARRAY_BUFFER );
973
+
974
+ }
975
+
976
+ createStorageAttribute( attribute ) {
977
+
978
+ //console.warn( 'Abstract class.' );
979
+
980
+ }
981
+
982
+ updateAttribute( attribute ) {
983
+
984
+ this.attributeUtils.updateAttribute( attribute );
985
+
986
+ }
987
+
988
+ destroyAttribute( attribute ) {
989
+
990
+ this.attributeUtils.destroyAttribute( attribute );
991
+
992
+ }
993
+
994
+ updateSize() {
995
+
996
+ //console.warn( 'Abstract class.' );
997
+
998
+ }
999
+
1000
+ async hasFeatureAsync( name ) {
1001
+
1002
+ return this.hasFeature( name );
1003
+
1004
+ }
1005
+
1006
+ hasFeature( name ) {
1007
+
1008
+ const keysMatching = Object.keys( GLFeatureName ).filter( key => GLFeatureName[ key ] === name );
1009
+
1010
+ const extensions = this.extensions;
1011
+
1012
+ for ( let i = 0; i < keysMatching.length; i ++ ) {
1013
+
1014
+
1015
+ if ( extensions.has( keysMatching[ i ] ) ) return true;
1016
+
1017
+ }
1018
+
1019
+ return false;
1020
+
1021
+ }
1022
+
1023
+
1024
+ getMaxAnisotropy() {
1025
+
1026
+ return this.capabilities.getMaxAnisotropy();
1027
+
1028
+ }
1029
+
1030
+ copyFramebufferToTexture( texture, renderContext ) {
1031
+
1032
+ this.textureUtils.copyFramebufferToTexture( texture, renderContext );
1033
+
1034
+ }
1035
+
1036
+ _setFramebuffer( renderContext ) {
1037
+
1038
+ const { gl, state } = this;
1039
+
1040
+ let currentFrameBuffer = null;
1041
+
1042
+ if ( renderContext.textures !== null ) {
1043
+
1044
+ const renderTarget = renderContext.renderTarget;
1045
+ const renderTargetContextData = this.get( renderTarget );
1046
+ const { samples, depthBuffer, stencilBuffer } = renderTarget;
1047
+ const cubeFace = this.renderer._activeCubeFace;
1048
+ const isCube = renderTarget.isWebGLCubeRenderTarget === true;
1049
+
1050
+ let msaaFb = renderTargetContextData.msaaFrameBuffer;
1051
+ let depthRenderbuffer = renderTargetContextData.depthRenderbuffer;
1052
+
1053
+ let fb;
1054
+
1055
+ if ( isCube ) {
1056
+
1057
+ if ( renderTargetContextData.cubeFramebuffers === undefined ) {
1058
+
1059
+ renderTargetContextData.cubeFramebuffers = [];
1060
+
1061
+ }
1062
+
1063
+ fb = renderTargetContextData.cubeFramebuffers[ cubeFace ];
1064
+
1065
+ } else {
1066
+
1067
+ fb = renderTargetContextData.framebuffer;
1068
+
1069
+ }
1070
+
1071
+ if ( fb === undefined ) {
1072
+
1073
+ fb = gl.createFramebuffer();
1074
+
1075
+ state.bindFramebuffer( gl.FRAMEBUFFER, fb );
1076
+
1077
+ const textures = renderContext.textures;
1078
+
1079
+ if ( isCube ) {
1080
+
1081
+ renderTargetContextData.cubeFramebuffers[ cubeFace ] = fb;
1082
+ const { textureGPU } = this.get( textures[ 0 ] );
1083
+
1084
+ gl.framebufferTexture2D( gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + cubeFace, textureGPU, 0 );
1085
+
1086
+ } else {
1087
+
1088
+ for ( let i = 0; i < textures.length; i ++ ) {
1089
+
1090
+ const texture = textures[ i ];
1091
+ const textureData = this.get( texture );
1092
+ textureData.renderTarget = renderContext.renderTarget;
1093
+
1094
+ const attachment = gl.COLOR_ATTACHMENT0 + i;
1095
+
1096
+ gl.framebufferTexture2D( gl.FRAMEBUFFER, attachment, gl.TEXTURE_2D, textureData.textureGPU, 0 );
1097
+
1098
+ }
1099
+
1100
+ renderTargetContextData.framebuffer = fb;
1101
+
1102
+ state.drawBuffers( renderContext, fb );
1103
+
1104
+ }
1105
+
1106
+ if ( renderContext.depthTexture !== null ) {
1107
+
1108
+ const textureData = this.get( renderContext.depthTexture );
1109
+ const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1110
+
1111
+ gl.framebufferTexture2D( gl.FRAMEBUFFER, depthStyle, gl.TEXTURE_2D, textureData.textureGPU, 0 );
1112
+
1113
+ }
1114
+
1115
+ }
1116
+
1117
+ if ( samples > 0 ) {
1118
+
1119
+ if ( msaaFb === undefined ) {
1120
+
1121
+ const invalidationArray = [];
1122
+
1123
+ msaaFb = gl.createFramebuffer();
1124
+
1125
+ state.bindFramebuffer( gl.FRAMEBUFFER, msaaFb );
1126
+
1127
+ const msaaRenderbuffers = [];
1128
+
1129
+ const textures = renderContext.textures;
1130
+
1131
+ for ( let i = 0; i < textures.length; i ++ ) {
1132
+
1133
+
1134
+ msaaRenderbuffers[ i ] = gl.createRenderbuffer();
1135
+
1136
+ gl.bindRenderbuffer( gl.RENDERBUFFER, msaaRenderbuffers[ i ] );
1137
+
1138
+ invalidationArray.push( gl.COLOR_ATTACHMENT0 + i );
1139
+
1140
+ if ( depthBuffer ) {
1141
+
1142
+ const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1143
+ invalidationArray.push( depthStyle );
1144
+
1145
+ }
1146
+
1147
+ const texture = renderContext.textures[ i ];
1148
+ const textureData = this.get( texture );
1149
+
1150
+ gl.renderbufferStorageMultisample( gl.RENDERBUFFER, samples, textureData.glInternalFormat, renderContext.width, renderContext.height );
1151
+ gl.framebufferRenderbuffer( gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0 + i, gl.RENDERBUFFER, msaaRenderbuffers[ i ] );
1152
+
1153
+
1154
+ }
1155
+
1156
+ renderTargetContextData.msaaFrameBuffer = msaaFb;
1157
+ renderTargetContextData.msaaRenderbuffers = msaaRenderbuffers;
1158
+
1159
+ if ( depthRenderbuffer === undefined ) {
1160
+
1161
+ depthRenderbuffer = gl.createRenderbuffer();
1162
+ this.textureUtils.setupRenderBufferStorage( depthRenderbuffer, renderContext );
1163
+
1164
+ renderTargetContextData.depthRenderbuffer = depthRenderbuffer;
1165
+
1166
+ const depthStyle = stencilBuffer ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;
1167
+ invalidationArray.push( depthStyle );
1168
+
1169
+ }
1170
+
1171
+ renderTargetContextData.invalidationArray = invalidationArray;
1172
+
1173
+ }
1174
+
1175
+ currentFrameBuffer = renderTargetContextData.msaaFrameBuffer;
1176
+
1177
+ } else {
1178
+
1179
+ currentFrameBuffer = fb;
1180
+
1181
+ }
1182
+
1183
+ }
1184
+
1185
+ state.bindFramebuffer( gl.FRAMEBUFFER, currentFrameBuffer );
1186
+
1187
+ }
1188
+
1189
+
1190
+ _getVaoKey( index, attributes ) {
1191
+
1192
+ let key = [];
1193
+
1194
+ if ( index !== null ) {
1195
+
1196
+ const indexData = this.get( index );
1197
+
1198
+ key += ':' + indexData.id;
1199
+
1200
+ }
1201
+
1202
+ for ( let i = 0; i < attributes.length; i ++ ) {
1203
+
1204
+ const attributeData = this.get( attributes[ i ] );
1205
+
1206
+ key += ':' + attributeData.id;
1207
+
1208
+ }
1209
+
1210
+ return key;
1211
+
1212
+ }
1213
+
1214
+ _createVao( index, attributes ) {
1215
+
1216
+ const { gl } = this;
1217
+
1218
+ const vaoGPU = gl.createVertexArray();
1219
+ let key = '';
1220
+
1221
+ let staticVao = true;
1222
+
1223
+ gl.bindVertexArray( vaoGPU );
1224
+
1225
+ if ( index !== null ) {
1226
+
1227
+ const indexData = this.get( index );
1228
+
1229
+ gl.bindBuffer( gl.ELEMENT_ARRAY_BUFFER, indexData.bufferGPU );
1230
+
1231
+ key += ':' + indexData.id;
1232
+
1233
+ }
1234
+
1235
+ for ( let i = 0; i < attributes.length; i ++ ) {
1236
+
1237
+ const attribute = attributes[ i ];
1238
+ const attributeData = this.get( attribute );
1239
+
1240
+ key += ':' + attributeData.id;
1241
+
1242
+ gl.bindBuffer( gl.ARRAY_BUFFER, attributeData.bufferGPU );
1243
+ gl.enableVertexAttribArray( i );
1244
+
1245
+ if ( attribute.isStorageBufferAttribute || attribute.isStorageInstancedBufferAttribute ) staticVao = false;
1246
+
1247
+ let stride, offset;
1248
+
1249
+ if ( attribute.isInterleavedBufferAttribute === true ) {
1250
+
1251
+ stride = attribute.data.stride * attributeData.bytesPerElement;
1252
+ offset = attribute.offset * attributeData.bytesPerElement;
1253
+
1254
+ } else {
1255
+
1256
+ stride = 0;
1257
+ offset = 0;
1258
+
1259
+ }
1260
+
1261
+ if ( attributeData.isInteger ) {
1262
+
1263
+ gl.vertexAttribIPointer( i, attribute.itemSize, attributeData.type, stride, offset );
1264
+
1265
+ } else {
1266
+
1267
+ gl.vertexAttribPointer( i, attribute.itemSize, attributeData.type, attribute.normalized, stride, offset );
1268
+
1269
+ }
1270
+
1271
+ if ( attribute.isInstancedBufferAttribute && ! attribute.isInterleavedBufferAttribute ) {
1272
+
1273
+ gl.vertexAttribDivisor( i, attribute.meshPerAttribute );
1274
+
1275
+ } else if ( attribute.isInterleavedBufferAttribute && attribute.data.isInstancedInterleavedBuffer ) {
1276
+
1277
+ gl.vertexAttribDivisor( i, attribute.data.meshPerAttribute );
1278
+
1279
+ }
1280
+
1281
+ }
1282
+
1283
+ gl.bindBuffer( gl.ARRAY_BUFFER, null );
1284
+
1285
+ this.vaoCache[ key ] = vaoGPU;
1286
+
1287
+ return { vaoGPU, staticVao };
1288
+
1289
+ }
1290
+
1291
+ _getTransformFeedback( transformBuffers ) {
1292
+
1293
+ let key = '';
1294
+
1295
+ for ( let i = 0; i < transformBuffers.length; i ++ ) {
1296
+
1297
+ key += ':' + transformBuffers[ i ].id;
1298
+
1299
+ }
1300
+
1301
+ let transformFeedbackGPU = this.transformFeedbackCache[ key ];
1302
+
1303
+ if ( transformFeedbackGPU !== undefined ) {
1304
+
1305
+ return transformFeedbackGPU;
1306
+
1307
+ }
1308
+
1309
+ const gl = this.gl;
1310
+
1311
+ transformFeedbackGPU = gl.createTransformFeedback();
1312
+
1313
+ gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, transformFeedbackGPU );
1314
+
1315
+ for ( let i = 0; i < transformBuffers.length; i ++ ) {
1316
+
1317
+ const attributeData = transformBuffers[ i ];
1318
+
1319
+ gl.bindBufferBase( gl.TRANSFORM_FEEDBACK_BUFFER, i, attributeData.transformBuffer );
1320
+
1321
+ }
1322
+
1323
+ gl.bindTransformFeedback( gl.TRANSFORM_FEEDBACK, null );
1324
+
1325
+ this.transformFeedbackCache[ key ] = transformFeedbackGPU;
1326
+
1327
+ return transformFeedbackGPU;
1328
+
1329
+ }
1330
+
1331
+
1332
+ _setupBindings( bindings, programGPU ) {
1333
+
1334
+ const gl = this.gl;
1335
+
1336
+ for ( const binding of bindings ) {
1337
+
1338
+ const bindingData = this.get( binding );
1339
+ const index = bindingData.index;
1340
+
1341
+ if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
1342
+
1343
+ const location = gl.getUniformBlockIndex( programGPU, binding.name );
1344
+ gl.uniformBlockBinding( programGPU, location, index );
1345
+
1346
+ } else if ( binding.isSampledTexture ) {
1347
+
1348
+ const location = gl.getUniformLocation( programGPU, binding.name );
1349
+ gl.uniform1i( location, index );
1350
+
1351
+ }
1352
+
1353
+ }
1354
+
1355
+ }
1356
+
1357
+ _bindUniforms( bindings ) {
1358
+
1359
+ const { gl, state } = this;
1360
+
1361
+ for ( const binding of bindings ) {
1362
+
1363
+ const bindingData = this.get( binding );
1364
+ const index = bindingData.index;
1365
+
1366
+ if ( binding.isUniformsGroup || binding.isUniformBuffer ) {
1367
+
1368
+ gl.bindBufferBase( gl.UNIFORM_BUFFER, index, bindingData.bufferGPU );
1369
+
1370
+ } else if ( binding.isSampledTexture ) {
1371
+
1372
+ state.bindTexture( bindingData.glTextureType, bindingData.textureGPU, gl.TEXTURE0 + index );
1373
+
1374
+ }
1375
+
1376
+ }
1377
+
1378
+ }
1379
+
1380
+ }
1381
+
1382
+ export default WebGLBackend;