three-stdlib 2.24.2 → 2.25.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (540) hide show
  1. package/controls/OrbitControls.d.ts +2 -0
  2. package/index.cjs +116401 -611
  3. package/index.js +116037 -263
  4. package/package.json +17 -4
  5. package/_polyfill/CapsuleGeometry.cjs +0 -22
  6. package/_polyfill/CapsuleGeometry.js +0 -22
  7. package/_polyfill/CompressedArrayTexture.cjs +0 -12
  8. package/_polyfill/CompressedArrayTexture.js +0 -12
  9. package/_polyfill/Data3DTexture.cjs +0 -17
  10. package/_polyfill/Data3DTexture.js +0 -17
  11. package/animation/AnimationClipCreator.cjs +0 -56
  12. package/animation/AnimationClipCreator.js +0 -56
  13. package/animation/CCDIKSolver.cjs +0 -269
  14. package/animation/CCDIKSolver.js +0 -269
  15. package/animation/MMDAnimationHelper.cjs +0 -688
  16. package/animation/MMDAnimationHelper.js +0 -688
  17. package/animation/MMDPhysics.cjs +0 -830
  18. package/animation/MMDPhysics.js +0 -830
  19. package/cameras/CinematicCamera.cjs +0 -131
  20. package/cameras/CinematicCamera.js +0 -131
  21. package/controls/ArcballControls.cjs +0 -2033
  22. package/controls/ArcballControls.js +0 -2033
  23. package/controls/DeviceOrientationControls.cjs +0 -85
  24. package/controls/DeviceOrientationControls.js +0 -85
  25. package/controls/DragControls.cjs +0 -182
  26. package/controls/DragControls.js +0 -182
  27. package/controls/FirstPersonControls.cjs +0 -229
  28. package/controls/FirstPersonControls.js +0 -229
  29. package/controls/FlyControls.cjs +0 -248
  30. package/controls/FlyControls.js +0 -248
  31. package/controls/OrbitControls.cjs +0 -787
  32. package/controls/OrbitControls.js +0 -787
  33. package/controls/PointerLockControls.cjs +0 -103
  34. package/controls/PointerLockControls.js +0 -103
  35. package/controls/TrackballControls.cjs +0 -502
  36. package/controls/TrackballControls.js +0 -502
  37. package/controls/TransformControls.cjs +0 -1089
  38. package/controls/TransformControls.js +0 -1089
  39. package/controls/experimental/CameraControls.cjs +0 -736
  40. package/controls/experimental/CameraControls.js +0 -736
  41. package/csm/CSM.cjs +0 -244
  42. package/csm/CSM.js +0 -244
  43. package/csm/CSMFrustum.cjs +0 -75
  44. package/csm/CSMFrustum.js +0 -75
  45. package/csm/CSMHelper.cjs +0 -114
  46. package/csm/CSMHelper.js +0 -114
  47. package/csm/CSMShader.cjs +0 -261
  48. package/csm/CSMShader.js +0 -261
  49. package/curves/CurveExtras.cjs +0 -214
  50. package/curves/CurveExtras.js +0 -214
  51. package/curves/NURBSCurve.cjs +0 -35
  52. package/curves/NURBSCurve.js +0 -35
  53. package/curves/NURBSSurface.cjs +0 -28
  54. package/curves/NURBSSurface.js +0 -28
  55. package/curves/NURBSUtils.cjs +0 -226
  56. package/curves/NURBSUtils.js +0 -226
  57. package/deprecated/Geometry.cjs +0 -971
  58. package/deprecated/Geometry.js +0 -971
  59. package/effects/AnaglyphEffect.cjs +0 -102
  60. package/effects/AnaglyphEffect.js +0 -102
  61. package/effects/AsciiEffect.cjs +0 -155
  62. package/effects/AsciiEffect.js +0 -155
  63. package/effects/OutlineEffect.cjs +0 -275
  64. package/effects/OutlineEffect.js +0 -275
  65. package/effects/ParallaxBarrierEffect.cjs +0 -65
  66. package/effects/ParallaxBarrierEffect.js +0 -65
  67. package/effects/PeppersGhostEffect.cjs +0 -88
  68. package/effects/PeppersGhostEffect.js +0 -88
  69. package/effects/StereoEffect.cjs +0 -35
  70. package/effects/StereoEffect.js +0 -35
  71. package/environments/RoomEnvironment.cjs +0 -95
  72. package/environments/RoomEnvironment.js +0 -78
  73. package/exporters/ColladaExporter.cjs +0 -331
  74. package/exporters/ColladaExporter.js +0 -331
  75. package/exporters/DRACOExporter.cjs +0 -141
  76. package/exporters/DRACOExporter.js +0 -141
  77. package/exporters/GLTFExporter.cjs +0 -1909
  78. package/exporters/GLTFExporter.js +0 -1909
  79. package/exporters/MMDExporter.cjs +0 -131
  80. package/exporters/MMDExporter.js +0 -131
  81. package/exporters/OBJExporter.cjs +0 -181
  82. package/exporters/OBJExporter.js +0 -181
  83. package/exporters/PLYExporter.cjs +0 -280
  84. package/exporters/PLYExporter.js +0 -280
  85. package/exporters/STLExporter.cjs +0 -146
  86. package/exporters/STLExporter.js +0 -146
  87. package/exporters/USDZExporter.cjs +0 -340
  88. package/exporters/USDZExporter.js +0 -340
  89. package/geometries/BoxLineGeometry.cjs +0 -45
  90. package/geometries/BoxLineGeometry.js +0 -45
  91. package/geometries/ConvexGeometry.cjs +0 -26
  92. package/geometries/ConvexGeometry.js +0 -26
  93. package/geometries/DecalGeometry.cjs +0 -184
  94. package/geometries/DecalGeometry.js +0 -184
  95. package/geometries/LightningStrike.cjs +0 -553
  96. package/geometries/LightningStrike.js +0 -553
  97. package/geometries/ParametricGeometries.cjs +0 -130
  98. package/geometries/ParametricGeometries.js +0 -130
  99. package/geometries/ParametricGeometry.cjs +0 -63
  100. package/geometries/ParametricGeometry.js +0 -63
  101. package/geometries/RoundedBoxGeometry.cjs +0 -91
  102. package/geometries/RoundedBoxGeometry.js +0 -91
  103. package/geometries/TeapotGeometry.cjs +0 -1563
  104. package/geometries/TeapotGeometry.js +0 -1563
  105. package/geometries/TextGeometry.cjs +0 -27
  106. package/geometries/TextGeometry.js +0 -27
  107. package/helpers/LightProbeHelper.cjs +0 -73
  108. package/helpers/LightProbeHelper.js +0 -73
  109. package/helpers/PositionalAudioHelper.cjs +0 -68
  110. package/helpers/PositionalAudioHelper.js +0 -68
  111. package/helpers/RectAreaLightHelper.cjs +0 -44
  112. package/helpers/RectAreaLightHelper.js +0 -44
  113. package/helpers/VertexNormalsHelper.cjs +0 -47
  114. package/helpers/VertexNormalsHelper.js +0 -47
  115. package/helpers/VertexTangentsHelper.cjs +0 -43
  116. package/helpers/VertexTangentsHelper.js +0 -43
  117. package/interactive/HTMLMesh.cjs +0 -325
  118. package/interactive/HTMLMesh.js +0 -325
  119. package/interactive/InteractiveGroup.cjs +0 -68
  120. package/interactive/InteractiveGroup.js +0 -68
  121. package/interactive/SelectionBox.cjs +0 -134
  122. package/interactive/SelectionBox.js +0 -134
  123. package/interactive/SelectionHelper.cjs +0 -51
  124. package/interactive/SelectionHelper.js +0 -51
  125. package/libs/MeshoptDecoder.cjs +0 -221
  126. package/libs/MeshoptDecoder.js +0 -221
  127. package/libs/MotionControllers.cjs +0 -325
  128. package/libs/MotionControllers.js +0 -325
  129. package/lights/LightProbeGenerator.cjs +0 -145
  130. package/lights/LightProbeGenerator.js +0 -145
  131. package/lights/RectAreaLightUniformsLib.cjs +0 -32846
  132. package/lights/RectAreaLightUniformsLib.js +0 -32846
  133. package/lines/Line2.cjs +0 -13
  134. package/lines/Line2.js +0 -13
  135. package/lines/LineGeometry.cjs +0 -44
  136. package/lines/LineGeometry.js +0 -44
  137. package/lines/LineMaterial.cjs +0 -547
  138. package/lines/LineMaterial.js +0 -547
  139. package/lines/LineSegments2.cjs +0 -203
  140. package/lines/LineSegments2.js +0 -203
  141. package/lines/LineSegmentsGeometry.cjs +0 -124
  142. package/lines/LineSegmentsGeometry.js +0 -124
  143. package/lines/Wireframe.cjs +0 -32
  144. package/lines/Wireframe.js +0 -32
  145. package/lines/WireframeGeometry2.cjs +0 -13
  146. package/lines/WireframeGeometry2.js +0 -13
  147. package/loaders/3DMLoader.cjs +0 -803
  148. package/loaders/3DMLoader.js +0 -803
  149. package/loaders/3MFLoader.cjs +0 -854
  150. package/loaders/3MFLoader.js +0 -854
  151. package/loaders/AMFLoader.cjs +0 -284
  152. package/loaders/AMFLoader.js +0 -284
  153. package/loaders/AssimpLoader.cjs +0 -1434
  154. package/loaders/AssimpLoader.js +0 -1434
  155. package/loaders/BVHLoader.cjs +0 -207
  156. package/loaders/BVHLoader.js +0 -207
  157. package/loaders/BasisTextureLoader.cjs +0 -489
  158. package/loaders/BasisTextureLoader.js +0 -489
  159. package/loaders/ColladaLoader.cjs +0 -2405
  160. package/loaders/ColladaLoader.js +0 -2405
  161. package/loaders/DDSLoader.cjs +0 -148
  162. package/loaders/DDSLoader.js +0 -148
  163. package/loaders/DRACOLoader.cjs +0 -341
  164. package/loaders/DRACOLoader.js +0 -341
  165. package/loaders/EXRLoader.cjs +0 -1356
  166. package/loaders/EXRLoader.js +0 -1356
  167. package/loaders/FBXLoader.cjs +0 -2457
  168. package/loaders/FBXLoader.js +0 -2457
  169. package/loaders/FontLoader.cjs +0 -123
  170. package/loaders/FontLoader.js +0 -123
  171. package/loaders/GCodeLoader.cjs +0 -141
  172. package/loaders/GCodeLoader.js +0 -141
  173. package/loaders/GLTFLoader.cjs +0 -2504
  174. package/loaders/GLTFLoader.js +0 -2504
  175. package/loaders/HDRCubeTextureLoader.cjs +0 -75
  176. package/loaders/HDRCubeTextureLoader.js +0 -75
  177. package/loaders/KMZLoader.cjs +0 -75
  178. package/loaders/KMZLoader.js +0 -75
  179. package/loaders/KTX2Loader.cjs +0 -480
  180. package/loaders/KTX2Loader.js +0 -480
  181. package/loaders/KTXLoader.cjs +0 -93
  182. package/loaders/KTXLoader.js +0 -93
  183. package/loaders/LDrawLoader.cjs +0 -1424
  184. package/loaders/LDrawLoader.js +0 -1424
  185. package/loaders/LUT3dlLoader.cjs +0 -103
  186. package/loaders/LUT3dlLoader.js +0 -103
  187. package/loaders/LUTCubeLoader.cjs +0 -107
  188. package/loaders/LUTCubeLoader.js +0 -107
  189. package/loaders/LWOLoader.cjs +0 -645
  190. package/loaders/LWOLoader.js +0 -645
  191. package/loaders/LottieLoader.cjs +0 -47
  192. package/loaders/LottieLoader.js +0 -47
  193. package/loaders/MD2Loader.cjs +0 -359
  194. package/loaders/MD2Loader.js +0 -359
  195. package/loaders/MDDLoader.cjs +0 -58
  196. package/loaders/MDDLoader.js +0 -58
  197. package/loaders/MMDLoader.cjs +0 -1121
  198. package/loaders/MMDLoader.js +0 -1121
  199. package/loaders/MTLLoader.cjs +0 -304
  200. package/loaders/MTLLoader.js +0 -304
  201. package/loaders/NRRDLoader.cjs +0 -401
  202. package/loaders/NRRDLoader.js +0 -401
  203. package/loaders/OBJLoader.cjs +0 -487
  204. package/loaders/OBJLoader.js +0 -487
  205. package/loaders/PCDLoader.cjs +0 -248
  206. package/loaders/PCDLoader.js +0 -248
  207. package/loaders/PDBLoader.cjs +0 -247
  208. package/loaders/PDBLoader.js +0 -247
  209. package/loaders/PLYLoader.cjs +0 -317
  210. package/loaders/PLYLoader.js +0 -317
  211. package/loaders/PRWMLoader.cjs +0 -160
  212. package/loaders/PRWMLoader.js +0 -160
  213. package/loaders/PVRLoader.cjs +0 -131
  214. package/loaders/PVRLoader.js +0 -131
  215. package/loaders/RGBELoader.cjs +0 -252
  216. package/loaders/RGBELoader.js +0 -252
  217. package/loaders/RGBMLoader.cjs +0 -1004
  218. package/loaders/RGBMLoader.js +0 -1004
  219. package/loaders/STLLoader.cjs +0 -190
  220. package/loaders/STLLoader.js +0 -190
  221. package/loaders/SVGLoader.cjs +0 -1712
  222. package/loaders/SVGLoader.js +0 -1712
  223. package/loaders/TDSLoader.cjs +0 -650
  224. package/loaders/TDSLoader.js +0 -650
  225. package/loaders/TGALoader.cjs +0 -285
  226. package/loaders/TGALoader.js +0 -285
  227. package/loaders/TTFLoader.cjs +0 -131
  228. package/loaders/TTFLoader.js +0 -131
  229. package/loaders/TiltLoader.cjs +0 -375
  230. package/loaders/TiltLoader.js +0 -375
  231. package/loaders/VOXLoader.cjs +0 -432
  232. package/loaders/VOXLoader.js +0 -432
  233. package/loaders/VRMLLoader.cjs +0 -2105
  234. package/loaders/VRMLLoader.js +0 -2105
  235. package/loaders/VRMLoader.cjs +0 -38
  236. package/loaders/VRMLoader.js +0 -38
  237. package/loaders/VTKLoader.cjs +0 -648
  238. package/loaders/VTKLoader.js +0 -648
  239. package/loaders/XLoader.cjs +0 -1258
  240. package/loaders/XLoader.js +0 -1258
  241. package/loaders/XYZLoader.cjs +0 -60
  242. package/loaders/XYZLoader.js +0 -60
  243. package/loaders/lwo/IFFParser.cjs +0 -743
  244. package/loaders/lwo/IFFParser.js +0 -743
  245. package/loaders/lwo/LWO2Parser.cjs +0 -312
  246. package/loaders/lwo/LWO2Parser.js +0 -312
  247. package/loaders/lwo/LWO3Parser.cjs +0 -282
  248. package/loaders/lwo/LWO3Parser.js +0 -282
  249. package/math/Capsule.cjs +0 -98
  250. package/math/Capsule.js +0 -98
  251. package/math/ColorConverter.cjs +0 -42
  252. package/math/ColorConverter.js +0 -42
  253. package/math/ConvexHull.cjs +0 -596
  254. package/math/ConvexHull.js +0 -596
  255. package/math/ImprovedNoise.cjs +0 -304
  256. package/math/ImprovedNoise.js +0 -304
  257. package/math/Lut.cjs +0 -137
  258. package/math/Lut.js +0 -137
  259. package/math/MeshSurfaceSampler.cjs +0 -103
  260. package/math/MeshSurfaceSampler.js +0 -103
  261. package/math/OBB.cjs +0 -242
  262. package/math/OBB.js +0 -242
  263. package/math/Octree.cjs +0 -273
  264. package/math/Octree.js +0 -273
  265. package/math/SimplexNoise.cjs +0 -440
  266. package/math/SimplexNoise.js +0 -440
  267. package/misc/ConvexObjectBreaker.cjs +0 -292
  268. package/misc/ConvexObjectBreaker.js +0 -292
  269. package/misc/GPUComputationRenderer.cjs +0 -205
  270. package/misc/GPUComputationRenderer.js +0 -205
  271. package/misc/Gyroscope.cjs +0 -33
  272. package/misc/Gyroscope.js +0 -33
  273. package/misc/MD2Character.cjs +0 -167
  274. package/misc/MD2Character.js +0 -167
  275. package/misc/MD2CharacterComplex.cjs +0 -332
  276. package/misc/MD2CharacterComplex.js +0 -332
  277. package/misc/MorphAnimMesh.cjs +0 -40
  278. package/misc/MorphAnimMesh.js +0 -40
  279. package/misc/MorphBlendMesh.cjs +0 -179
  280. package/misc/MorphBlendMesh.js +0 -179
  281. package/misc/ProgressiveLightmap.cjs +0 -186
  282. package/misc/ProgressiveLightmap.js +0 -186
  283. package/misc/RollerCoaster.cjs +0 -353
  284. package/misc/RollerCoaster.js +0 -353
  285. package/misc/Timer.cjs +0 -101
  286. package/misc/Timer.js +0 -101
  287. package/misc/TubePainter.cjs +0 -123
  288. package/misc/TubePainter.js +0 -123
  289. package/misc/Volume.cjs +0 -305
  290. package/misc/Volume.js +0 -305
  291. package/misc/VolumeSlice.cjs +0 -114
  292. package/misc/VolumeSlice.js +0 -114
  293. package/misc/WebGL.cjs +0 -74
  294. package/misc/WebGL.js +0 -74
  295. package/modifiers/CurveModifier.cjs +0 -232
  296. package/modifiers/CurveModifier.js +0 -232
  297. package/modifiers/EdgeSplitModifier.cjs +0 -167
  298. package/modifiers/EdgeSplitModifier.js +0 -168
  299. package/modifiers/SimplifyModifier.cjs +0 -301
  300. package/modifiers/SimplifyModifier.js +0 -301
  301. package/modifiers/TessellateModifier.cjs +0 -214
  302. package/modifiers/TessellateModifier.js +0 -214
  303. package/objects/GroundProjectedEnv.cjs +0 -134
  304. package/objects/GroundProjectedEnv.js +0 -134
  305. package/objects/Lensflare.cjs +0 -291
  306. package/objects/Lensflare.js +0 -291
  307. package/objects/LightningStorm.cjs +0 -110
  308. package/objects/LightningStorm.js +0 -110
  309. package/objects/MarchingCubes.cjs +0 -4809
  310. package/objects/MarchingCubes.js +0 -4809
  311. package/objects/Reflector.cjs +0 -202
  312. package/objects/Reflector.js +0 -202
  313. package/objects/ReflectorForSSRPass.cjs +0 -260
  314. package/objects/ReflectorForSSRPass.js +0 -260
  315. package/objects/ReflectorRTT.cjs +0 -10
  316. package/objects/ReflectorRTT.js +0 -10
  317. package/objects/Refractor.cjs +0 -215
  318. package/objects/Refractor.js +0 -215
  319. package/objects/ShadowMesh.cjs +0 -45
  320. package/objects/ShadowMesh.js +0 -45
  321. package/objects/Sky.cjs +0 -200
  322. package/objects/Sky.js +0 -200
  323. package/objects/Water.cjs +0 -242
  324. package/objects/Water.js +0 -242
  325. package/objects/Water2.cjs +0 -256
  326. package/objects/Water2.js +0 -256
  327. package/physics/AmmoPhysics.cjs +0 -166
  328. package/physics/AmmoPhysics.js +0 -166
  329. package/postprocessing/AdaptiveToneMappingPass.cjs +0 -218
  330. package/postprocessing/AdaptiveToneMappingPass.js +0 -218
  331. package/postprocessing/AfterimagePass.cjs +0 -68
  332. package/postprocessing/AfterimagePass.js +0 -68
  333. package/postprocessing/BloomPass.cjs +0 -109
  334. package/postprocessing/BloomPass.js +0 -109
  335. package/postprocessing/BokehPass.cjs +0 -90
  336. package/postprocessing/BokehPass.js +0 -90
  337. package/postprocessing/ClearPass.cjs +0 -36
  338. package/postprocessing/ClearPass.js +0 -36
  339. package/postprocessing/CubeTexturePass.cjs +0 -53
  340. package/postprocessing/CubeTexturePass.js +0 -53
  341. package/postprocessing/DotScreenPass.cjs +0 -49
  342. package/postprocessing/DotScreenPass.js +0 -49
  343. package/postprocessing/EffectComposer.cjs +0 -157
  344. package/postprocessing/EffectComposer.js +0 -157
  345. package/postprocessing/FilmPass.cjs +0 -51
  346. package/postprocessing/FilmPass.js +0 -51
  347. package/postprocessing/GlitchPass.cjs +0 -84
  348. package/postprocessing/GlitchPass.js +0 -84
  349. package/postprocessing/HalftonePass.cjs +0 -53
  350. package/postprocessing/HalftonePass.js +0 -53
  351. package/postprocessing/LUTPass.cjs +0 -142
  352. package/postprocessing/LUTPass.js +0 -142
  353. package/postprocessing/MaskPass.cjs +0 -69
  354. package/postprocessing/MaskPass.js +0 -69
  355. package/postprocessing/OutlinePass.cjs +0 -479
  356. package/postprocessing/OutlinePass.js +0 -479
  357. package/postprocessing/Pass.cjs +0 -48
  358. package/postprocessing/Pass.js +0 -48
  359. package/postprocessing/RenderPass.cjs +0 -59
  360. package/postprocessing/RenderPass.js +0 -59
  361. package/postprocessing/RenderPixelatedPass.cjs +0 -199
  362. package/postprocessing/RenderPixelatedPass.js +0 -199
  363. package/postprocessing/SAOPass.cjs +0 -288
  364. package/postprocessing/SAOPass.js +0 -288
  365. package/postprocessing/SMAAPass.cjs +0 -112
  366. package/postprocessing/SMAAPass.js +0 -112
  367. package/postprocessing/SSAARenderPass.cjs +0 -189
  368. package/postprocessing/SSAARenderPass.js +0 -189
  369. package/postprocessing/SSAOPass.cjs +0 -272
  370. package/postprocessing/SSAOPass.js +0 -272
  371. package/postprocessing/SSRPass.cjs +0 -411
  372. package/postprocessing/SSRPass.js +0 -411
  373. package/postprocessing/SavePass.cjs +0 -38
  374. package/postprocessing/SavePass.js +0 -38
  375. package/postprocessing/ShaderPass.cjs +0 -49
  376. package/postprocessing/ShaderPass.js +0 -49
  377. package/postprocessing/TAARenderPass.cjs +0 -174
  378. package/postprocessing/TAARenderPass.js +0 -174
  379. package/postprocessing/TexturePass.cjs +0 -42
  380. package/postprocessing/TexturePass.js +0 -42
  381. package/postprocessing/UnrealBloomPass.cjs +0 -277
  382. package/postprocessing/UnrealBloomPass.js +0 -277
  383. package/postprocessing/WaterPass.cjs +0 -72
  384. package/postprocessing/WaterPass.js +0 -72
  385. package/renderers/CSS2DRenderer.cjs +0 -122
  386. package/renderers/CSS2DRenderer.js +0 -122
  387. package/renderers/CSS3DRenderer.cjs +0 -167
  388. package/renderers/CSS3DRenderer.js +0 -167
  389. package/renderers/Projector.cjs +0 -499
  390. package/renderers/Projector.js +0 -499
  391. package/renderers/SVGRenderer.cjs +0 -311
  392. package/renderers/SVGRenderer.js +0 -311
  393. package/shaders/ACESFilmicToneMappingShader.cjs +0 -55
  394. package/shaders/ACESFilmicToneMappingShader.js +0 -55
  395. package/shaders/AfterimageShader.cjs +0 -32
  396. package/shaders/AfterimageShader.js +0 -32
  397. package/shaders/BasicShader.cjs +0 -12
  398. package/shaders/BasicShader.js +0 -12
  399. package/shaders/BleachBypassShader.cjs +0 -35
  400. package/shaders/BleachBypassShader.js +0 -35
  401. package/shaders/BlendShader.cjs +0 -30
  402. package/shaders/BlendShader.js +0 -30
  403. package/shaders/BokehShader.cjs +0 -109
  404. package/shaders/BokehShader.js +0 -109
  405. package/shaders/BokehShader2.cjs +0 -269
  406. package/shaders/BokehShader2.js +0 -269
  407. package/shaders/BrightnessContrastShader.cjs +0 -32
  408. package/shaders/BrightnessContrastShader.js +0 -32
  409. package/shaders/ColorCorrectionShader.cjs +0 -30
  410. package/shaders/ColorCorrectionShader.js +0 -30
  411. package/shaders/ColorifyShader.cjs +0 -28
  412. package/shaders/ColorifyShader.js +0 -28
  413. package/shaders/ConvolutionShader.cjs +0 -55
  414. package/shaders/ConvolutionShader.js +0 -55
  415. package/shaders/CopyShader.cjs +0 -25
  416. package/shaders/CopyShader.js +0 -25
  417. package/shaders/DOFMipMapShader.cjs +0 -32
  418. package/shaders/DOFMipMapShader.js +0 -32
  419. package/shaders/DepthLimitedBlurShader.cjs +0 -114
  420. package/shaders/DepthLimitedBlurShader.js +0 -114
  421. package/shaders/DigitalGlitch.cjs +0 -85
  422. package/shaders/DigitalGlitch.js +0 -85
  423. package/shaders/DotScreenShader.cjs +0 -39
  424. package/shaders/DotScreenShader.js +0 -39
  425. package/shaders/FXAAShader.cjs +0 -1098
  426. package/shaders/FXAAShader.js +0 -1098
  427. package/shaders/FilmShader.cjs +0 -53
  428. package/shaders/FilmShader.js +0 -53
  429. package/shaders/FocusShader.cjs +0 -55
  430. package/shaders/FocusShader.js +0 -55
  431. package/shaders/FreiChenShader.cjs +0 -64
  432. package/shaders/FreiChenShader.js +0 -64
  433. package/shaders/FresnelShader.cjs +0 -47
  434. package/shaders/FresnelShader.js +0 -47
  435. package/shaders/GammaCorrectionShader.cjs +0 -23
  436. package/shaders/GammaCorrectionShader.js +0 -23
  437. package/shaders/GodRaysShader.cjs +0 -183
  438. package/shaders/GodRaysShader.js +0 -183
  439. package/shaders/HalftoneShader.cjs +0 -228
  440. package/shaders/HalftoneShader.js +0 -228
  441. package/shaders/HorizontalBlurShader.cjs +0 -49
  442. package/shaders/HorizontalBlurShader.js +0 -49
  443. package/shaders/HorizontalTiltShiftShader.cjs +0 -37
  444. package/shaders/HorizontalTiltShiftShader.js +0 -37
  445. package/shaders/HueSaturationShader.cjs +0 -43
  446. package/shaders/HueSaturationShader.js +0 -43
  447. package/shaders/KaleidoShader.cjs +0 -34
  448. package/shaders/KaleidoShader.js +0 -34
  449. package/shaders/LuminosityHighPassShader.cjs +0 -37
  450. package/shaders/LuminosityHighPassShader.js +0 -37
  451. package/shaders/LuminosityShader.cjs +0 -25
  452. package/shaders/LuminosityShader.js +0 -25
  453. package/shaders/MirrorShader.cjs +0 -35
  454. package/shaders/MirrorShader.js +0 -35
  455. package/shaders/NormalMapShader.cjs +0 -31
  456. package/shaders/NormalMapShader.js +0 -31
  457. package/shaders/ParallaxShader.cjs +0 -133
  458. package/shaders/ParallaxShader.js +0 -133
  459. package/shaders/PixelShader.cjs +0 -28
  460. package/shaders/PixelShader.js +0 -28
  461. package/shaders/RGBShiftShader.cjs +0 -30
  462. package/shaders/RGBShiftShader.js +0 -30
  463. package/shaders/SAOShader.cjs +0 -144
  464. package/shaders/SAOShader.js +0 -144
  465. package/shaders/SMAAShader.cjs +0 -358
  466. package/shaders/SMAAShader.js +0 -358
  467. package/shaders/SSAOShader.cjs +0 -182
  468. package/shaders/SSAOShader.js +0 -182
  469. package/shaders/SSRShader.cjs +0 -342
  470. package/shaders/SSRShader.js +0 -342
  471. package/shaders/SepiaShader.cjs +0 -29
  472. package/shaders/SepiaShader.js +0 -29
  473. package/shaders/SobelOperatorShader.cjs +0 -54
  474. package/shaders/SobelOperatorShader.js +0 -54
  475. package/shaders/SubsurfaceScatteringShader.cjs +0 -98
  476. package/shaders/SubsurfaceScatteringShader.js +0 -98
  477. package/shaders/TechnicolorShader.cjs +0 -24
  478. package/shaders/TechnicolorShader.js +0 -24
  479. package/shaders/ToneMapShader.cjs +0 -51
  480. package/shaders/ToneMapShader.js +0 -51
  481. package/shaders/ToonShader.cjs +0 -188
  482. package/shaders/ToonShader.js +0 -188
  483. package/shaders/TriangleBlurShader.cjs +0 -37
  484. package/shaders/TriangleBlurShader.js +0 -37
  485. package/shaders/UnpackDepthRGBAShader.cjs +0 -26
  486. package/shaders/UnpackDepthRGBAShader.js +0 -26
  487. package/shaders/VerticalBlurShader.cjs +0 -50
  488. package/shaders/VerticalBlurShader.js +0 -50
  489. package/shaders/VerticalTiltShiftShader.cjs +0 -37
  490. package/shaders/VerticalTiltShiftShader.js +0 -37
  491. package/shaders/VignetteShader.cjs +0 -38
  492. package/shaders/VignetteShader.js +0 -38
  493. package/shaders/VolumeShader.cjs +0 -225
  494. package/shaders/VolumeShader.js +0 -225
  495. package/shaders/WaterRefractionShader.cjs +0 -59
  496. package/shaders/WaterRefractionShader.js +0 -59
  497. package/shaders/types.cjs +0 -1
  498. package/shaders/types.js +0 -1
  499. package/textures/FlakesTexture.cjs +0 -30
  500. package/textures/FlakesTexture.js +0 -30
  501. package/types/helpers.cjs +0 -4
  502. package/types/helpers.js +0 -4
  503. package/utils/BufferGeometryUtils.cjs +0 -636
  504. package/utils/BufferGeometryUtils.js +0 -636
  505. package/utils/GeometryCompressionUtils.cjs +0 -573
  506. package/utils/GeometryCompressionUtils.js +0 -573
  507. package/utils/GeometryUtils.cjs +0 -109
  508. package/utils/GeometryUtils.js +0 -109
  509. package/utils/RoughnessMipmapper.cjs +0 -223
  510. package/utils/RoughnessMipmapper.js +0 -223
  511. package/utils/SceneUtils.cjs +0 -36
  512. package/utils/SceneUtils.js +0 -36
  513. package/utils/ShadowMapViewer.cjs +0 -111
  514. package/utils/ShadowMapViewer.js +0 -111
  515. package/utils/SkeletonUtils.cjs +0 -211
  516. package/utils/SkeletonUtils.js +0 -211
  517. package/utils/UVsDebug.cjs +0 -80
  518. package/utils/UVsDebug.js +0 -80
  519. package/utils/WorkerPool.cjs +0 -62
  520. package/utils/WorkerPool.js +0 -62
  521. package/webxr/ARButton.cjs +0 -119
  522. package/webxr/ARButton.js +0 -119
  523. package/webxr/OculusHandModel.cjs +0 -82
  524. package/webxr/OculusHandModel.js +0 -82
  525. package/webxr/OculusHandPointerModel.cjs +0 -241
  526. package/webxr/OculusHandPointerModel.js +0 -224
  527. package/webxr/Text2D.cjs +0 -48
  528. package/webxr/Text2D.js +0 -31
  529. package/webxr/VRButton.cjs +0 -111
  530. package/webxr/VRButton.js +0 -111
  531. package/webxr/XRControllerModelFactory.cjs +0 -174
  532. package/webxr/XRControllerModelFactory.js +0 -174
  533. package/webxr/XREstimatedLight.cjs +0 -126
  534. package/webxr/XREstimatedLight.js +0 -126
  535. package/webxr/XRHandMeshModel.cjs +0 -82
  536. package/webxr/XRHandMeshModel.js +0 -82
  537. package/webxr/XRHandModelFactory.cjs +0 -61
  538. package/webxr/XRHandModelFactory.js +0 -61
  539. package/webxr/XRHandPrimitiveModel.cjs +0 -68
  540. package/webxr/XRHandPrimitiveModel.js +0 -68
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const THREE = require("three");
4
- const NURBSUtils = require("./NURBSUtils.cjs");
5
- class NURBSCurve extends THREE.Curve {
6
- constructor(degree, knots, controlPoints, startKnot, endKnot) {
7
- super();
8
- this.degree = degree;
9
- this.knots = knots;
10
- this.controlPoints = [];
11
- this.startKnot = startKnot || 0;
12
- this.endKnot = endKnot || this.knots.length - 1;
13
- for (let i = 0; i < controlPoints.length; ++i) {
14
- const point = controlPoints[i];
15
- this.controlPoints[i] = new THREE.Vector4(point.x, point.y, point.z, point.w);
16
- }
17
- }
18
- getPoint(t, optionalTarget) {
19
- const point = optionalTarget || new THREE.Vector3();
20
- const u = this.knots[this.startKnot] + t * (this.knots[this.endKnot] - this.knots[this.startKnot]);
21
- const hpoint = NURBSUtils.calcBSplinePoint(this.degree, this.knots, this.controlPoints, u);
22
- if (hpoint.w != 1) {
23
- hpoint.divideScalar(hpoint.w);
24
- }
25
- return point.set(hpoint.x, hpoint.y, hpoint.z);
26
- }
27
- getTangent(t, optionalTarget) {
28
- const tangent = optionalTarget || new THREE.Vector3();
29
- const u = this.knots[0] + t * (this.knots[this.knots.length - 1] - this.knots[0]);
30
- const ders = NURBSUtils.calcNURBSDerivatives(this.degree, this.knots, this.controlPoints, u, 1);
31
- tangent.copy(ders[1]).normalize();
32
- return tangent;
33
- }
34
- }
35
- exports.NURBSCurve = NURBSCurve;
@@ -1,35 +0,0 @@
1
- import { Curve, Vector4, Vector3 } from "three";
2
- import { calcBSplinePoint, calcNURBSDerivatives } from "./NURBSUtils.js";
3
- class NURBSCurve extends Curve {
4
- constructor(degree, knots, controlPoints, startKnot, endKnot) {
5
- super();
6
- this.degree = degree;
7
- this.knots = knots;
8
- this.controlPoints = [];
9
- this.startKnot = startKnot || 0;
10
- this.endKnot = endKnot || this.knots.length - 1;
11
- for (let i = 0; i < controlPoints.length; ++i) {
12
- const point = controlPoints[i];
13
- this.controlPoints[i] = new Vector4(point.x, point.y, point.z, point.w);
14
- }
15
- }
16
- getPoint(t, optionalTarget) {
17
- const point = optionalTarget || new Vector3();
18
- const u = this.knots[this.startKnot] + t * (this.knots[this.endKnot] - this.knots[this.startKnot]);
19
- const hpoint = calcBSplinePoint(this.degree, this.knots, this.controlPoints, u);
20
- if (hpoint.w != 1) {
21
- hpoint.divideScalar(hpoint.w);
22
- }
23
- return point.set(hpoint.x, hpoint.y, hpoint.z);
24
- }
25
- getTangent(t, optionalTarget) {
26
- const tangent = optionalTarget || new Vector3();
27
- const u = this.knots[0] + t * (this.knots[this.knots.length - 1] - this.knots[0]);
28
- const ders = calcNURBSDerivatives(this.degree, this.knots, this.controlPoints, u, 1);
29
- tangent.copy(ders[1]).normalize();
30
- return tangent;
31
- }
32
- }
33
- export {
34
- NURBSCurve
35
- };
@@ -1,28 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const THREE = require("three");
4
- const NURBSUtils = require("./NURBSUtils.cjs");
5
- class NURBSSurface {
6
- constructor(degree1, degree2, knots1, knots2, controlPoints) {
7
- this.degree1 = degree1;
8
- this.degree2 = degree2;
9
- this.knots1 = knots1;
10
- this.knots2 = knots2;
11
- this.controlPoints = [];
12
- const len1 = knots1.length - degree1 - 1;
13
- const len2 = knots2.length - degree2 - 1;
14
- for (let i = 0; i < len1; ++i) {
15
- this.controlPoints[i] = [];
16
- for (let j = 0; j < len2; ++j) {
17
- const point = controlPoints[i][j];
18
- this.controlPoints[i][j] = new THREE.Vector4(point.x, point.y, point.z, point.w);
19
- }
20
- }
21
- }
22
- getPoint(t1, t2, target) {
23
- const u = this.knots1[0] + t1 * (this.knots1[this.knots1.length - 1] - this.knots1[0]);
24
- const v = this.knots2[0] + t2 * (this.knots2[this.knots2.length - 1] - this.knots2[0]);
25
- NURBSUtils.calcSurfacePoint(this.degree1, this.degree2, this.knots1, this.knots2, this.controlPoints, u, v, target);
26
- }
27
- }
28
- exports.NURBSSurface = NURBSSurface;
@@ -1,28 +0,0 @@
1
- import { Vector4 } from "three";
2
- import { calcSurfacePoint } from "./NURBSUtils.js";
3
- class NURBSSurface {
4
- constructor(degree1, degree2, knots1, knots2, controlPoints) {
5
- this.degree1 = degree1;
6
- this.degree2 = degree2;
7
- this.knots1 = knots1;
8
- this.knots2 = knots2;
9
- this.controlPoints = [];
10
- const len1 = knots1.length - degree1 - 1;
11
- const len2 = knots2.length - degree2 - 1;
12
- for (let i = 0; i < len1; ++i) {
13
- this.controlPoints[i] = [];
14
- for (let j = 0; j < len2; ++j) {
15
- const point = controlPoints[i][j];
16
- this.controlPoints[i][j] = new Vector4(point.x, point.y, point.z, point.w);
17
- }
18
- }
19
- }
20
- getPoint(t1, t2, target) {
21
- const u = this.knots1[0] + t1 * (this.knots1[this.knots1.length - 1] - this.knots1[0]);
22
- const v = this.knots2[0] + t2 * (this.knots2[this.knots2.length - 1] - this.knots2[0]);
23
- calcSurfacePoint(this.degree1, this.degree2, this.knots1, this.knots2, this.controlPoints, u, v, target);
24
- }
25
- }
26
- export {
27
- NURBSSurface
28
- };
@@ -1,226 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const THREE = require("three");
4
- function findSpan(p, u, U) {
5
- const n = U.length - p - 1;
6
- if (u >= U[n]) {
7
- return n - 1;
8
- }
9
- if (u <= U[p]) {
10
- return p;
11
- }
12
- let low = p;
13
- let high = n;
14
- let mid = Math.floor((low + high) / 2);
15
- while (u < U[mid] || u >= U[mid + 1]) {
16
- if (u < U[mid]) {
17
- high = mid;
18
- } else {
19
- low = mid;
20
- }
21
- mid = Math.floor((low + high) / 2);
22
- }
23
- return mid;
24
- }
25
- function calcBasisFunctions(span, u, p, U) {
26
- const N = [];
27
- const left = [];
28
- const right = [];
29
- N[0] = 1;
30
- for (let j = 1; j <= p; ++j) {
31
- left[j] = u - U[span + 1 - j];
32
- right[j] = U[span + j] - u;
33
- let saved = 0;
34
- for (let r = 0; r < j; ++r) {
35
- const rv = right[r + 1];
36
- const lv = left[j - r];
37
- const temp = N[r] / (rv + lv);
38
- N[r] = saved + rv * temp;
39
- saved = lv * temp;
40
- }
41
- N[j] = saved;
42
- }
43
- return N;
44
- }
45
- function calcBSplinePoint(p, U, P, u) {
46
- const span = findSpan(p, u, U);
47
- const N = calcBasisFunctions(span, u, p, U);
48
- const C = new THREE.Vector4(0, 0, 0, 0);
49
- for (let j = 0; j <= p; ++j) {
50
- const point = P[span - p + j];
51
- const Nj = N[j];
52
- const wNj = point.w * Nj;
53
- C.x += point.x * wNj;
54
- C.y += point.y * wNj;
55
- C.z += point.z * wNj;
56
- C.w += point.w * Nj;
57
- }
58
- return C;
59
- }
60
- function calcBasisFunctionDerivatives(span, u, p, n, U) {
61
- const zeroArr = [];
62
- for (let i = 0; i <= p; ++i)
63
- zeroArr[i] = 0;
64
- const ders = [];
65
- for (let i = 0; i <= n; ++i)
66
- ders[i] = zeroArr.slice(0);
67
- const ndu = [];
68
- for (let i = 0; i <= p; ++i)
69
- ndu[i] = zeroArr.slice(0);
70
- ndu[0][0] = 1;
71
- const left = zeroArr.slice(0);
72
- const right = zeroArr.slice(0);
73
- for (let j = 1; j <= p; ++j) {
74
- left[j] = u - U[span + 1 - j];
75
- right[j] = U[span + j] - u;
76
- let saved = 0;
77
- for (let r2 = 0; r2 < j; ++r2) {
78
- const rv = right[r2 + 1];
79
- const lv = left[j - r2];
80
- ndu[j][r2] = rv + lv;
81
- const temp = ndu[r2][j - 1] / ndu[j][r2];
82
- ndu[r2][j] = saved + rv * temp;
83
- saved = lv * temp;
84
- }
85
- ndu[j][j] = saved;
86
- }
87
- for (let j = 0; j <= p; ++j) {
88
- ders[0][j] = ndu[j][p];
89
- }
90
- for (let r2 = 0; r2 <= p; ++r2) {
91
- let s1 = 0;
92
- let s2 = 1;
93
- const a = [];
94
- for (let i = 0; i <= p; ++i) {
95
- a[i] = zeroArr.slice(0);
96
- }
97
- a[0][0] = 1;
98
- for (let k = 1; k <= n; ++k) {
99
- let d = 0;
100
- const rk = r2 - k;
101
- const pk = p - k;
102
- if (r2 >= k) {
103
- a[s2][0] = a[s1][0] / ndu[pk + 1][rk];
104
- d = a[s2][0] * ndu[rk][pk];
105
- }
106
- const j1 = rk >= -1 ? 1 : -rk;
107
- const j2 = r2 - 1 <= pk ? k - 1 : p - r2;
108
- for (let j3 = j1; j3 <= j2; ++j3) {
109
- a[s2][j3] = (a[s1][j3] - a[s1][j3 - 1]) / ndu[pk + 1][rk + j3];
110
- d += a[s2][j3] * ndu[rk + j3][pk];
111
- }
112
- if (r2 <= pk) {
113
- a[s2][k] = -a[s1][k - 1] / ndu[pk + 1][r2];
114
- d += a[s2][k] * ndu[r2][pk];
115
- }
116
- ders[k][r2] = d;
117
- const j = s1;
118
- s1 = s2;
119
- s2 = j;
120
- }
121
- }
122
- let r = p;
123
- for (let k = 1; k <= n; ++k) {
124
- for (let j = 0; j <= p; ++j) {
125
- ders[k][j] *= r;
126
- }
127
- r *= p - k;
128
- }
129
- return ders;
130
- }
131
- function calcBSplineDerivatives(p, U, P, u, nd) {
132
- const du = nd < p ? nd : p;
133
- const CK = [];
134
- const span = findSpan(p, u, U);
135
- const nders = calcBasisFunctionDerivatives(span, u, p, du, U);
136
- const Pw = [];
137
- for (let i = 0; i < P.length; ++i) {
138
- const point = P[i].clone();
139
- const w = point.w;
140
- point.x *= w;
141
- point.y *= w;
142
- point.z *= w;
143
- Pw[i] = point;
144
- }
145
- for (let k = 0; k <= du; ++k) {
146
- const point = Pw[span - p].clone().multiplyScalar(nders[k][0]);
147
- for (let j = 1; j <= p; ++j) {
148
- point.add(Pw[span - p + j].clone().multiplyScalar(nders[k][j]));
149
- }
150
- CK[k] = point;
151
- }
152
- for (let k = du + 1; k <= nd + 1; ++k) {
153
- CK[k] = new THREE.Vector4(0, 0, 0);
154
- }
155
- return CK;
156
- }
157
- function calcKoverI(k, i) {
158
- let nom = 1;
159
- for (let j = 2; j <= k; ++j) {
160
- nom *= j;
161
- }
162
- let denom = 1;
163
- for (let j = 2; j <= i; ++j) {
164
- denom *= j;
165
- }
166
- for (let j = 2; j <= k - i; ++j) {
167
- denom *= j;
168
- }
169
- return nom / denom;
170
- }
171
- function calcRationalCurveDerivatives(Pders) {
172
- const nd = Pders.length;
173
- const Aders = [];
174
- const wders = [];
175
- for (let i = 0; i < nd; ++i) {
176
- const point = Pders[i];
177
- Aders[i] = new THREE.Vector3(point.x, point.y, point.z);
178
- wders[i] = point.w;
179
- }
180
- const CK = [];
181
- for (let k = 0; k < nd; ++k) {
182
- const v = Aders[k].clone();
183
- for (let i = 1; i <= k; ++i) {
184
- v.sub(CK[k - i].clone().multiplyScalar(calcKoverI(k, i) * wders[i]));
185
- }
186
- CK[k] = v.divideScalar(wders[0]);
187
- }
188
- return CK;
189
- }
190
- function calcNURBSDerivatives(p, U, P, u, nd) {
191
- const Pders = calcBSplineDerivatives(p, U, P, u, nd);
192
- return calcRationalCurveDerivatives(Pders);
193
- }
194
- function calcSurfacePoint(p, q, U, V, P, u, v, target) {
195
- const uspan = findSpan(p, u, U);
196
- const vspan = findSpan(q, v, V);
197
- const Nu = calcBasisFunctions(uspan, u, p, U);
198
- const Nv = calcBasisFunctions(vspan, v, q, V);
199
- const temp = [];
200
- for (let l = 0; l <= q; ++l) {
201
- temp[l] = new THREE.Vector4(0, 0, 0, 0);
202
- for (let k = 0; k <= p; ++k) {
203
- const point = P[uspan - p + k][vspan - q + l].clone();
204
- const w = point.w;
205
- point.x *= w;
206
- point.y *= w;
207
- point.z *= w;
208
- temp[l].add(point.multiplyScalar(Nu[k]));
209
- }
210
- }
211
- const Sw = new THREE.Vector4(0, 0, 0, 0);
212
- for (let l = 0; l <= q; ++l) {
213
- Sw.add(temp[l].multiplyScalar(Nv[l]));
214
- }
215
- Sw.divideScalar(Sw.w);
216
- target.set(Sw.x, Sw.y, Sw.z);
217
- }
218
- exports.calcBSplineDerivatives = calcBSplineDerivatives;
219
- exports.calcBSplinePoint = calcBSplinePoint;
220
- exports.calcBasisFunctionDerivatives = calcBasisFunctionDerivatives;
221
- exports.calcBasisFunctions = calcBasisFunctions;
222
- exports.calcKoverI = calcKoverI;
223
- exports.calcNURBSDerivatives = calcNURBSDerivatives;
224
- exports.calcRationalCurveDerivatives = calcRationalCurveDerivatives;
225
- exports.calcSurfacePoint = calcSurfacePoint;
226
- exports.findSpan = findSpan;
@@ -1,226 +0,0 @@
1
- import { Vector4, Vector3 } from "three";
2
- function findSpan(p, u, U) {
3
- const n = U.length - p - 1;
4
- if (u >= U[n]) {
5
- return n - 1;
6
- }
7
- if (u <= U[p]) {
8
- return p;
9
- }
10
- let low = p;
11
- let high = n;
12
- let mid = Math.floor((low + high) / 2);
13
- while (u < U[mid] || u >= U[mid + 1]) {
14
- if (u < U[mid]) {
15
- high = mid;
16
- } else {
17
- low = mid;
18
- }
19
- mid = Math.floor((low + high) / 2);
20
- }
21
- return mid;
22
- }
23
- function calcBasisFunctions(span, u, p, U) {
24
- const N = [];
25
- const left = [];
26
- const right = [];
27
- N[0] = 1;
28
- for (let j = 1; j <= p; ++j) {
29
- left[j] = u - U[span + 1 - j];
30
- right[j] = U[span + j] - u;
31
- let saved = 0;
32
- for (let r = 0; r < j; ++r) {
33
- const rv = right[r + 1];
34
- const lv = left[j - r];
35
- const temp = N[r] / (rv + lv);
36
- N[r] = saved + rv * temp;
37
- saved = lv * temp;
38
- }
39
- N[j] = saved;
40
- }
41
- return N;
42
- }
43
- function calcBSplinePoint(p, U, P, u) {
44
- const span = findSpan(p, u, U);
45
- const N = calcBasisFunctions(span, u, p, U);
46
- const C = new Vector4(0, 0, 0, 0);
47
- for (let j = 0; j <= p; ++j) {
48
- const point = P[span - p + j];
49
- const Nj = N[j];
50
- const wNj = point.w * Nj;
51
- C.x += point.x * wNj;
52
- C.y += point.y * wNj;
53
- C.z += point.z * wNj;
54
- C.w += point.w * Nj;
55
- }
56
- return C;
57
- }
58
- function calcBasisFunctionDerivatives(span, u, p, n, U) {
59
- const zeroArr = [];
60
- for (let i = 0; i <= p; ++i)
61
- zeroArr[i] = 0;
62
- const ders = [];
63
- for (let i = 0; i <= n; ++i)
64
- ders[i] = zeroArr.slice(0);
65
- const ndu = [];
66
- for (let i = 0; i <= p; ++i)
67
- ndu[i] = zeroArr.slice(0);
68
- ndu[0][0] = 1;
69
- const left = zeroArr.slice(0);
70
- const right = zeroArr.slice(0);
71
- for (let j = 1; j <= p; ++j) {
72
- left[j] = u - U[span + 1 - j];
73
- right[j] = U[span + j] - u;
74
- let saved = 0;
75
- for (let r2 = 0; r2 < j; ++r2) {
76
- const rv = right[r2 + 1];
77
- const lv = left[j - r2];
78
- ndu[j][r2] = rv + lv;
79
- const temp = ndu[r2][j - 1] / ndu[j][r2];
80
- ndu[r2][j] = saved + rv * temp;
81
- saved = lv * temp;
82
- }
83
- ndu[j][j] = saved;
84
- }
85
- for (let j = 0; j <= p; ++j) {
86
- ders[0][j] = ndu[j][p];
87
- }
88
- for (let r2 = 0; r2 <= p; ++r2) {
89
- let s1 = 0;
90
- let s2 = 1;
91
- const a = [];
92
- for (let i = 0; i <= p; ++i) {
93
- a[i] = zeroArr.slice(0);
94
- }
95
- a[0][0] = 1;
96
- for (let k = 1; k <= n; ++k) {
97
- let d = 0;
98
- const rk = r2 - k;
99
- const pk = p - k;
100
- if (r2 >= k) {
101
- a[s2][0] = a[s1][0] / ndu[pk + 1][rk];
102
- d = a[s2][0] * ndu[rk][pk];
103
- }
104
- const j1 = rk >= -1 ? 1 : -rk;
105
- const j2 = r2 - 1 <= pk ? k - 1 : p - r2;
106
- for (let j3 = j1; j3 <= j2; ++j3) {
107
- a[s2][j3] = (a[s1][j3] - a[s1][j3 - 1]) / ndu[pk + 1][rk + j3];
108
- d += a[s2][j3] * ndu[rk + j3][pk];
109
- }
110
- if (r2 <= pk) {
111
- a[s2][k] = -a[s1][k - 1] / ndu[pk + 1][r2];
112
- d += a[s2][k] * ndu[r2][pk];
113
- }
114
- ders[k][r2] = d;
115
- const j = s1;
116
- s1 = s2;
117
- s2 = j;
118
- }
119
- }
120
- let r = p;
121
- for (let k = 1; k <= n; ++k) {
122
- for (let j = 0; j <= p; ++j) {
123
- ders[k][j] *= r;
124
- }
125
- r *= p - k;
126
- }
127
- return ders;
128
- }
129
- function calcBSplineDerivatives(p, U, P, u, nd) {
130
- const du = nd < p ? nd : p;
131
- const CK = [];
132
- const span = findSpan(p, u, U);
133
- const nders = calcBasisFunctionDerivatives(span, u, p, du, U);
134
- const Pw = [];
135
- for (let i = 0; i < P.length; ++i) {
136
- const point = P[i].clone();
137
- const w = point.w;
138
- point.x *= w;
139
- point.y *= w;
140
- point.z *= w;
141
- Pw[i] = point;
142
- }
143
- for (let k = 0; k <= du; ++k) {
144
- const point = Pw[span - p].clone().multiplyScalar(nders[k][0]);
145
- for (let j = 1; j <= p; ++j) {
146
- point.add(Pw[span - p + j].clone().multiplyScalar(nders[k][j]));
147
- }
148
- CK[k] = point;
149
- }
150
- for (let k = du + 1; k <= nd + 1; ++k) {
151
- CK[k] = new Vector4(0, 0, 0);
152
- }
153
- return CK;
154
- }
155
- function calcKoverI(k, i) {
156
- let nom = 1;
157
- for (let j = 2; j <= k; ++j) {
158
- nom *= j;
159
- }
160
- let denom = 1;
161
- for (let j = 2; j <= i; ++j) {
162
- denom *= j;
163
- }
164
- for (let j = 2; j <= k - i; ++j) {
165
- denom *= j;
166
- }
167
- return nom / denom;
168
- }
169
- function calcRationalCurveDerivatives(Pders) {
170
- const nd = Pders.length;
171
- const Aders = [];
172
- const wders = [];
173
- for (let i = 0; i < nd; ++i) {
174
- const point = Pders[i];
175
- Aders[i] = new Vector3(point.x, point.y, point.z);
176
- wders[i] = point.w;
177
- }
178
- const CK = [];
179
- for (let k = 0; k < nd; ++k) {
180
- const v = Aders[k].clone();
181
- for (let i = 1; i <= k; ++i) {
182
- v.sub(CK[k - i].clone().multiplyScalar(calcKoverI(k, i) * wders[i]));
183
- }
184
- CK[k] = v.divideScalar(wders[0]);
185
- }
186
- return CK;
187
- }
188
- function calcNURBSDerivatives(p, U, P, u, nd) {
189
- const Pders = calcBSplineDerivatives(p, U, P, u, nd);
190
- return calcRationalCurveDerivatives(Pders);
191
- }
192
- function calcSurfacePoint(p, q, U, V, P, u, v, target) {
193
- const uspan = findSpan(p, u, U);
194
- const vspan = findSpan(q, v, V);
195
- const Nu = calcBasisFunctions(uspan, u, p, U);
196
- const Nv = calcBasisFunctions(vspan, v, q, V);
197
- const temp = [];
198
- for (let l = 0; l <= q; ++l) {
199
- temp[l] = new Vector4(0, 0, 0, 0);
200
- for (let k = 0; k <= p; ++k) {
201
- const point = P[uspan - p + k][vspan - q + l].clone();
202
- const w = point.w;
203
- point.x *= w;
204
- point.y *= w;
205
- point.z *= w;
206
- temp[l].add(point.multiplyScalar(Nu[k]));
207
- }
208
- }
209
- const Sw = new Vector4(0, 0, 0, 0);
210
- for (let l = 0; l <= q; ++l) {
211
- Sw.add(temp[l].multiplyScalar(Nv[l]));
212
- }
213
- Sw.divideScalar(Sw.w);
214
- target.set(Sw.x, Sw.y, Sw.z);
215
- }
216
- export {
217
- calcBSplineDerivatives,
218
- calcBSplinePoint,
219
- calcBasisFunctionDerivatives,
220
- calcBasisFunctions,
221
- calcKoverI,
222
- calcNURBSDerivatives,
223
- calcRationalCurveDerivatives,
224
- calcSurfacePoint,
225
- findSpan
226
- };