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,1089 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
4
- var __publicField = (obj, key, value) => {
5
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
6
- return value;
7
- };
8
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
9
- const THREE = require("three");
10
- class TransformControls extends THREE.Object3D {
11
- constructor(camera, domElement) {
12
- super();
13
- __publicField(this, "isTransformControls", true);
14
- __publicField(this, "visible", false);
15
- __publicField(this, "domElement");
16
- __publicField(this, "raycaster", new THREE.Raycaster());
17
- __publicField(this, "gizmo");
18
- __publicField(this, "plane");
19
- __publicField(this, "tempVector", new THREE.Vector3());
20
- __publicField(this, "tempVector2", new THREE.Vector3());
21
- __publicField(this, "tempQuaternion", new THREE.Quaternion());
22
- __publicField(this, "unit", {
23
- X: new THREE.Vector3(1, 0, 0),
24
- Y: new THREE.Vector3(0, 1, 0),
25
- Z: new THREE.Vector3(0, 0, 1)
26
- });
27
- __publicField(this, "pointStart", new THREE.Vector3());
28
- __publicField(this, "pointEnd", new THREE.Vector3());
29
- __publicField(this, "offset", new THREE.Vector3());
30
- __publicField(this, "rotationAxis", new THREE.Vector3());
31
- __publicField(this, "startNorm", new THREE.Vector3());
32
- __publicField(this, "endNorm", new THREE.Vector3());
33
- __publicField(this, "rotationAngle", 0);
34
- __publicField(this, "cameraPosition", new THREE.Vector3());
35
- __publicField(this, "cameraQuaternion", new THREE.Quaternion());
36
- __publicField(this, "cameraScale", new THREE.Vector3());
37
- __publicField(this, "parentPosition", new THREE.Vector3());
38
- __publicField(this, "parentQuaternion", new THREE.Quaternion());
39
- __publicField(this, "parentQuaternionInv", new THREE.Quaternion());
40
- __publicField(this, "parentScale", new THREE.Vector3());
41
- __publicField(this, "worldPositionStart", new THREE.Vector3());
42
- __publicField(this, "worldQuaternionStart", new THREE.Quaternion());
43
- __publicField(this, "worldScaleStart", new THREE.Vector3());
44
- __publicField(this, "worldPosition", new THREE.Vector3());
45
- __publicField(this, "worldQuaternion", new THREE.Quaternion());
46
- __publicField(this, "worldQuaternionInv", new THREE.Quaternion());
47
- __publicField(this, "worldScale", new THREE.Vector3());
48
- __publicField(this, "eye", new THREE.Vector3());
49
- __publicField(this, "positionStart", new THREE.Vector3());
50
- __publicField(this, "quaternionStart", new THREE.Quaternion());
51
- __publicField(this, "scaleStart", new THREE.Vector3());
52
- __publicField(this, "camera");
53
- __publicField(this, "object");
54
- __publicField(this, "enabled", true);
55
- __publicField(this, "axis", null);
56
- __publicField(this, "mode", "translate");
57
- __publicField(this, "translationSnap", null);
58
- __publicField(this, "rotationSnap", null);
59
- __publicField(this, "scaleSnap", null);
60
- __publicField(this, "space", "world");
61
- __publicField(this, "size", 1);
62
- __publicField(this, "dragging", false);
63
- __publicField(this, "showX", true);
64
- __publicField(this, "showY", true);
65
- __publicField(this, "showZ", true);
66
- // events
67
- __publicField(this, "changeEvent", { type: "change" });
68
- __publicField(this, "mouseDownEvent", { type: "mouseDown", mode: this.mode });
69
- __publicField(this, "mouseUpEvent", { type: "mouseUp", mode: this.mode });
70
- __publicField(this, "objectChangeEvent", { type: "objectChange" });
71
- __publicField(this, "intersectObjectWithRay", (object, raycaster, includeInvisible) => {
72
- const allIntersections = raycaster.intersectObject(object, true);
73
- for (let i = 0; i < allIntersections.length; i++) {
74
- if (allIntersections[i].object.visible || includeInvisible) {
75
- return allIntersections[i];
76
- }
77
- }
78
- return false;
79
- });
80
- // Set current object
81
- __publicField(this, "attach", (object) => {
82
- this.object = object;
83
- this.visible = true;
84
- return this;
85
- });
86
- // Detatch from object
87
- __publicField(this, "detach", () => {
88
- this.object = void 0;
89
- this.visible = false;
90
- this.axis = null;
91
- return this;
92
- });
93
- // Reset
94
- __publicField(this, "reset", () => {
95
- if (!this.enabled)
96
- return this;
97
- if (this.dragging) {
98
- if (this.object !== void 0) {
99
- this.object.position.copy(this.positionStart);
100
- this.object.quaternion.copy(this.quaternionStart);
101
- this.object.scale.copy(this.scaleStart);
102
- this.dispatchEvent(this.changeEvent);
103
- this.dispatchEvent(this.objectChangeEvent);
104
- this.pointStart.copy(this.pointEnd);
105
- }
106
- }
107
- return this;
108
- });
109
- __publicField(this, "updateMatrixWorld", () => {
110
- if (this.object !== void 0) {
111
- this.object.updateMatrixWorld();
112
- if (this.object.parent === null) {
113
- console.error("TransformControls: The attached 3D object must be a part of the scene graph.");
114
- } else {
115
- this.object.parent.matrixWorld.decompose(this.parentPosition, this.parentQuaternion, this.parentScale);
116
- }
117
- this.object.matrixWorld.decompose(this.worldPosition, this.worldQuaternion, this.worldScale);
118
- this.parentQuaternionInv.copy(this.parentQuaternion).invert();
119
- this.worldQuaternionInv.copy(this.worldQuaternion).invert();
120
- }
121
- this.camera.updateMatrixWorld();
122
- this.camera.matrixWorld.decompose(this.cameraPosition, this.cameraQuaternion, this.cameraScale);
123
- this.eye.copy(this.cameraPosition).sub(this.worldPosition).normalize();
124
- super.updateMatrixWorld();
125
- });
126
- __publicField(this, "pointerHover", (pointer) => {
127
- if (this.object === void 0 || this.dragging === true)
128
- return;
129
- this.raycaster.setFromCamera(pointer, this.camera);
130
- const intersect = this.intersectObjectWithRay(this.gizmo.picker[this.mode], this.raycaster);
131
- if (intersect) {
132
- this.axis = intersect.object.name;
133
- } else {
134
- this.axis = null;
135
- }
136
- });
137
- __publicField(this, "pointerDown", (pointer) => {
138
- if (this.object === void 0 || this.dragging === true || pointer.button !== 0)
139
- return;
140
- if (this.axis !== null) {
141
- this.raycaster.setFromCamera(pointer, this.camera);
142
- const planeIntersect = this.intersectObjectWithRay(this.plane, this.raycaster, true);
143
- if (planeIntersect) {
144
- let space = this.space;
145
- if (this.mode === "scale") {
146
- space = "local";
147
- } else if (this.axis === "E" || this.axis === "XYZE" || this.axis === "XYZ") {
148
- space = "world";
149
- }
150
- if (space === "local" && this.mode === "rotate") {
151
- const snap = this.rotationSnap;
152
- if (this.axis === "X" && snap)
153
- this.object.rotation.x = Math.round(this.object.rotation.x / snap) * snap;
154
- if (this.axis === "Y" && snap)
155
- this.object.rotation.y = Math.round(this.object.rotation.y / snap) * snap;
156
- if (this.axis === "Z" && snap)
157
- this.object.rotation.z = Math.round(this.object.rotation.z / snap) * snap;
158
- }
159
- this.object.updateMatrixWorld();
160
- if (this.object.parent) {
161
- this.object.parent.updateMatrixWorld();
162
- }
163
- this.positionStart.copy(this.object.position);
164
- this.quaternionStart.copy(this.object.quaternion);
165
- this.scaleStart.copy(this.object.scale);
166
- this.object.matrixWorld.decompose(this.worldPositionStart, this.worldQuaternionStart, this.worldScaleStart);
167
- this.pointStart.copy(planeIntersect.point).sub(this.worldPositionStart);
168
- }
169
- this.dragging = true;
170
- this.mouseDownEvent.mode = this.mode;
171
- this.dispatchEvent(this.mouseDownEvent);
172
- }
173
- });
174
- __publicField(this, "pointerMove", (pointer) => {
175
- const axis = this.axis;
176
- const mode = this.mode;
177
- const object = this.object;
178
- let space = this.space;
179
- if (mode === "scale") {
180
- space = "local";
181
- } else if (axis === "E" || axis === "XYZE" || axis === "XYZ") {
182
- space = "world";
183
- }
184
- if (object === void 0 || axis === null || this.dragging === false || pointer.button !== -1)
185
- return;
186
- this.raycaster.setFromCamera(pointer, this.camera);
187
- const planeIntersect = this.intersectObjectWithRay(this.plane, this.raycaster, true);
188
- if (!planeIntersect)
189
- return;
190
- this.pointEnd.copy(planeIntersect.point).sub(this.worldPositionStart);
191
- if (mode === "translate") {
192
- this.offset.copy(this.pointEnd).sub(this.pointStart);
193
- if (space === "local" && axis !== "XYZ") {
194
- this.offset.applyQuaternion(this.worldQuaternionInv);
195
- }
196
- if (axis.indexOf("X") === -1)
197
- this.offset.x = 0;
198
- if (axis.indexOf("Y") === -1)
199
- this.offset.y = 0;
200
- if (axis.indexOf("Z") === -1)
201
- this.offset.z = 0;
202
- if (space === "local" && axis !== "XYZ") {
203
- this.offset.applyQuaternion(this.quaternionStart).divide(this.parentScale);
204
- } else {
205
- this.offset.applyQuaternion(this.parentQuaternionInv).divide(this.parentScale);
206
- }
207
- object.position.copy(this.offset).add(this.positionStart);
208
- if (this.translationSnap) {
209
- if (space === "local") {
210
- object.position.applyQuaternion(this.tempQuaternion.copy(this.quaternionStart).invert());
211
- if (axis.search("X") !== -1) {
212
- object.position.x = Math.round(object.position.x / this.translationSnap) * this.translationSnap;
213
- }
214
- if (axis.search("Y") !== -1) {
215
- object.position.y = Math.round(object.position.y / this.translationSnap) * this.translationSnap;
216
- }
217
- if (axis.search("Z") !== -1) {
218
- object.position.z = Math.round(object.position.z / this.translationSnap) * this.translationSnap;
219
- }
220
- object.position.applyQuaternion(this.quaternionStart);
221
- }
222
- if (space === "world") {
223
- if (object.parent) {
224
- object.position.add(this.tempVector.setFromMatrixPosition(object.parent.matrixWorld));
225
- }
226
- if (axis.search("X") !== -1) {
227
- object.position.x = Math.round(object.position.x / this.translationSnap) * this.translationSnap;
228
- }
229
- if (axis.search("Y") !== -1) {
230
- object.position.y = Math.round(object.position.y / this.translationSnap) * this.translationSnap;
231
- }
232
- if (axis.search("Z") !== -1) {
233
- object.position.z = Math.round(object.position.z / this.translationSnap) * this.translationSnap;
234
- }
235
- if (object.parent) {
236
- object.position.sub(this.tempVector.setFromMatrixPosition(object.parent.matrixWorld));
237
- }
238
- }
239
- }
240
- } else if (mode === "scale") {
241
- if (axis.search("XYZ") !== -1) {
242
- let d = this.pointEnd.length() / this.pointStart.length();
243
- if (this.pointEnd.dot(this.pointStart) < 0)
244
- d *= -1;
245
- this.tempVector2.set(d, d, d);
246
- } else {
247
- this.tempVector.copy(this.pointStart);
248
- this.tempVector2.copy(this.pointEnd);
249
- this.tempVector.applyQuaternion(this.worldQuaternionInv);
250
- this.tempVector2.applyQuaternion(this.worldQuaternionInv);
251
- this.tempVector2.divide(this.tempVector);
252
- if (axis.search("X") === -1) {
253
- this.tempVector2.x = 1;
254
- }
255
- if (axis.search("Y") === -1) {
256
- this.tempVector2.y = 1;
257
- }
258
- if (axis.search("Z") === -1) {
259
- this.tempVector2.z = 1;
260
- }
261
- }
262
- object.scale.copy(this.scaleStart).multiply(this.tempVector2);
263
- if (this.scaleSnap && this.object) {
264
- if (axis.search("X") !== -1) {
265
- this.object.scale.x = Math.round(object.scale.x / this.scaleSnap) * this.scaleSnap || this.scaleSnap;
266
- }
267
- if (axis.search("Y") !== -1) {
268
- object.scale.y = Math.round(object.scale.y / this.scaleSnap) * this.scaleSnap || this.scaleSnap;
269
- }
270
- if (axis.search("Z") !== -1) {
271
- object.scale.z = Math.round(object.scale.z / this.scaleSnap) * this.scaleSnap || this.scaleSnap;
272
- }
273
- }
274
- } else if (mode === "rotate") {
275
- this.offset.copy(this.pointEnd).sub(this.pointStart);
276
- const ROTATION_SPEED = 20 / this.worldPosition.distanceTo(this.tempVector.setFromMatrixPosition(this.camera.matrixWorld));
277
- if (axis === "E") {
278
- this.rotationAxis.copy(this.eye);
279
- this.rotationAngle = this.pointEnd.angleTo(this.pointStart);
280
- this.startNorm.copy(this.pointStart).normalize();
281
- this.endNorm.copy(this.pointEnd).normalize();
282
- this.rotationAngle *= this.endNorm.cross(this.startNorm).dot(this.eye) < 0 ? 1 : -1;
283
- } else if (axis === "XYZE") {
284
- this.rotationAxis.copy(this.offset).cross(this.eye).normalize();
285
- this.rotationAngle = this.offset.dot(this.tempVector.copy(this.rotationAxis).cross(this.eye)) * ROTATION_SPEED;
286
- } else if (axis === "X" || axis === "Y" || axis === "Z") {
287
- this.rotationAxis.copy(this.unit[axis]);
288
- this.tempVector.copy(this.unit[axis]);
289
- if (space === "local") {
290
- this.tempVector.applyQuaternion(this.worldQuaternion);
291
- }
292
- this.rotationAngle = this.offset.dot(this.tempVector.cross(this.eye).normalize()) * ROTATION_SPEED;
293
- }
294
- if (this.rotationSnap) {
295
- this.rotationAngle = Math.round(this.rotationAngle / this.rotationSnap) * this.rotationSnap;
296
- }
297
- if (space === "local" && axis !== "E" && axis !== "XYZE") {
298
- object.quaternion.copy(this.quaternionStart);
299
- object.quaternion.multiply(this.tempQuaternion.setFromAxisAngle(this.rotationAxis, this.rotationAngle)).normalize();
300
- } else {
301
- this.rotationAxis.applyQuaternion(this.parentQuaternionInv);
302
- object.quaternion.copy(this.tempQuaternion.setFromAxisAngle(this.rotationAxis, this.rotationAngle));
303
- object.quaternion.multiply(this.quaternionStart).normalize();
304
- }
305
- }
306
- this.dispatchEvent(this.changeEvent);
307
- this.dispatchEvent(this.objectChangeEvent);
308
- });
309
- __publicField(this, "pointerUp", (pointer) => {
310
- if (pointer.button !== 0)
311
- return;
312
- if (this.dragging && this.axis !== null) {
313
- this.mouseUpEvent.mode = this.mode;
314
- this.dispatchEvent(this.mouseUpEvent);
315
- }
316
- this.dragging = false;
317
- this.axis = null;
318
- });
319
- __publicField(this, "getPointer", (event) => {
320
- var _a, _b;
321
- if (this.domElement && ((_a = this.domElement.ownerDocument) == null ? void 0 : _a.pointerLockElement)) {
322
- return {
323
- x: 0,
324
- y: 0,
325
- button: event.button
326
- };
327
- } else {
328
- const pointer = event.changedTouches ? event.changedTouches[0] : event;
329
- const rect = (_b = this.domElement) == null ? void 0 : _b.getBoundingClientRect();
330
- return {
331
- x: (pointer.clientX - rect.left) / rect.width * 2 - 1,
332
- y: -(pointer.clientY - rect.top) / rect.height * 2 + 1,
333
- button: event.button
334
- };
335
- }
336
- });
337
- __publicField(this, "onPointerHover", (event) => {
338
- if (!this.enabled)
339
- return;
340
- switch (event.pointerType) {
341
- case "mouse":
342
- case "pen":
343
- this.pointerHover(this.getPointer(event));
344
- break;
345
- }
346
- });
347
- __publicField(this, "onPointerDown", (event) => {
348
- if (!this.enabled || !this.domElement)
349
- return;
350
- this.domElement.style.touchAction = "none";
351
- this.domElement.ownerDocument.addEventListener("pointermove", this.onPointerMove);
352
- this.pointerHover(this.getPointer(event));
353
- this.pointerDown(this.getPointer(event));
354
- });
355
- __publicField(this, "onPointerMove", (event) => {
356
- if (!this.enabled)
357
- return;
358
- this.pointerMove(this.getPointer(event));
359
- });
360
- __publicField(this, "onPointerUp", (event) => {
361
- if (!this.enabled || !this.domElement)
362
- return;
363
- this.domElement.style.touchAction = "";
364
- this.domElement.ownerDocument.removeEventListener("pointermove", this.onPointerMove);
365
- this.pointerUp(this.getPointer(event));
366
- });
367
- __publicField(this, "getMode", () => this.mode);
368
- __publicField(this, "setMode", (mode) => {
369
- this.mode = mode;
370
- });
371
- __publicField(this, "setTranslationSnap", (translationSnap) => {
372
- this.translationSnap = translationSnap;
373
- });
374
- __publicField(this, "setRotationSnap", (rotationSnap) => {
375
- this.rotationSnap = rotationSnap;
376
- });
377
- __publicField(this, "setScaleSnap", (scaleSnap) => {
378
- this.scaleSnap = scaleSnap;
379
- });
380
- __publicField(this, "setSize", (size) => {
381
- this.size = size;
382
- });
383
- __publicField(this, "setSpace", (space) => {
384
- this.space = space;
385
- });
386
- __publicField(this, "update", () => {
387
- console.warn(
388
- "THREE.TransformControls: update function has no more functionality and therefore has been deprecated."
389
- );
390
- });
391
- __publicField(this, "connect", (domElement) => {
392
- if (domElement === document) {
393
- console.error(
394
- 'THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'
395
- );
396
- }
397
- this.domElement = domElement;
398
- this.domElement.addEventListener("pointerdown", this.onPointerDown);
399
- this.domElement.addEventListener("pointermove", this.onPointerHover);
400
- this.domElement.ownerDocument.addEventListener("pointerup", this.onPointerUp);
401
- });
402
- __publicField(this, "dispose", () => {
403
- var _a, _b, _c, _d, _e, _f;
404
- (_a = this.domElement) == null ? void 0 : _a.removeEventListener("pointerdown", this.onPointerDown);
405
- (_b = this.domElement) == null ? void 0 : _b.removeEventListener("pointermove", this.onPointerHover);
406
- (_d = (_c = this.domElement) == null ? void 0 : _c.ownerDocument) == null ? void 0 : _d.removeEventListener("pointermove", this.onPointerMove);
407
- (_f = (_e = this.domElement) == null ? void 0 : _e.ownerDocument) == null ? void 0 : _f.removeEventListener("pointerup", this.onPointerUp);
408
- this.traverse((child) => {
409
- const mesh = child;
410
- if (mesh.geometry) {
411
- mesh.geometry.dispose();
412
- }
413
- if (mesh.material) {
414
- mesh.material.dispose();
415
- }
416
- });
417
- });
418
- this.domElement = domElement;
419
- this.camera = camera;
420
- this.gizmo = new TransformControlsGizmo();
421
- this.add(this.gizmo);
422
- this.plane = new TransformControlsPlane();
423
- this.add(this.plane);
424
- const defineProperty = (propName, defaultValue) => {
425
- let propValue = defaultValue;
426
- Object.defineProperty(this, propName, {
427
- get: function() {
428
- return propValue !== void 0 ? propValue : defaultValue;
429
- },
430
- set: function(value) {
431
- if (propValue !== value) {
432
- propValue = value;
433
- this.plane[propName] = value;
434
- this.gizmo[propName] = value;
435
- this.dispatchEvent({ type: propName + "-changed", value });
436
- this.dispatchEvent(this.changeEvent);
437
- }
438
- }
439
- });
440
- this[propName] = defaultValue;
441
- this.plane[propName] = defaultValue;
442
- this.gizmo[propName] = defaultValue;
443
- };
444
- defineProperty("camera", this.camera);
445
- defineProperty("object", this.object);
446
- defineProperty("enabled", this.enabled);
447
- defineProperty("axis", this.axis);
448
- defineProperty("mode", this.mode);
449
- defineProperty("translationSnap", this.translationSnap);
450
- defineProperty("rotationSnap", this.rotationSnap);
451
- defineProperty("scaleSnap", this.scaleSnap);
452
- defineProperty("space", this.space);
453
- defineProperty("size", this.size);
454
- defineProperty("dragging", this.dragging);
455
- defineProperty("showX", this.showX);
456
- defineProperty("showY", this.showY);
457
- defineProperty("showZ", this.showZ);
458
- defineProperty("worldPosition", this.worldPosition);
459
- defineProperty("worldPositionStart", this.worldPositionStart);
460
- defineProperty("worldQuaternion", this.worldQuaternion);
461
- defineProperty("worldQuaternionStart", this.worldQuaternionStart);
462
- defineProperty("cameraPosition", this.cameraPosition);
463
- defineProperty("cameraQuaternion", this.cameraQuaternion);
464
- defineProperty("pointStart", this.pointStart);
465
- defineProperty("pointEnd", this.pointEnd);
466
- defineProperty("rotationAxis", this.rotationAxis);
467
- defineProperty("rotationAngle", this.rotationAngle);
468
- defineProperty("eye", this.eye);
469
- if (domElement !== void 0)
470
- this.connect(domElement);
471
- }
472
- }
473
- class TransformControlsGizmo extends THREE.Object3D {
474
- constructor() {
475
- super();
476
- __publicField(this, "isTransformControlsGizmo", true);
477
- __publicField(this, "type", "TransformControlsGizmo");
478
- __publicField(this, "tempVector", new THREE.Vector3(0, 0, 0));
479
- __publicField(this, "tempEuler", new THREE.Euler());
480
- __publicField(this, "alignVector", new THREE.Vector3(0, 1, 0));
481
- __publicField(this, "zeroVector", new THREE.Vector3(0, 0, 0));
482
- __publicField(this, "lookAtMatrix", new THREE.Matrix4());
483
- __publicField(this, "tempQuaternion", new THREE.Quaternion());
484
- __publicField(this, "tempQuaternion2", new THREE.Quaternion());
485
- __publicField(this, "identityQuaternion", new THREE.Quaternion());
486
- __publicField(this, "unitX", new THREE.Vector3(1, 0, 0));
487
- __publicField(this, "unitY", new THREE.Vector3(0, 1, 0));
488
- __publicField(this, "unitZ", new THREE.Vector3(0, 0, 1));
489
- __publicField(this, "gizmo");
490
- __publicField(this, "picker");
491
- __publicField(this, "helper");
492
- // these are set from parent class TransformControls
493
- __publicField(this, "rotationAxis", new THREE.Vector3());
494
- __publicField(this, "cameraPosition", new THREE.Vector3());
495
- __publicField(this, "worldPositionStart", new THREE.Vector3());
496
- __publicField(this, "worldQuaternionStart", new THREE.Quaternion());
497
- __publicField(this, "worldPosition", new THREE.Vector3());
498
- __publicField(this, "worldQuaternion", new THREE.Quaternion());
499
- __publicField(this, "eye", new THREE.Vector3());
500
- __publicField(this, "camera", null);
501
- __publicField(this, "enabled", true);
502
- __publicField(this, "axis", null);
503
- __publicField(this, "mode", "translate");
504
- __publicField(this, "space", "world");
505
- __publicField(this, "size", 1);
506
- __publicField(this, "dragging", false);
507
- __publicField(this, "showX", true);
508
- __publicField(this, "showY", true);
509
- __publicField(this, "showZ", true);
510
- // updateMatrixWorld will update transformations and appearance of individual handles
511
- __publicField(this, "updateMatrixWorld", () => {
512
- let space = this.space;
513
- if (this.mode === "scale") {
514
- space = "local";
515
- }
516
- const quaternion = space === "local" ? this.worldQuaternion : this.identityQuaternion;
517
- this.gizmo["translate"].visible = this.mode === "translate";
518
- this.gizmo["rotate"].visible = this.mode === "rotate";
519
- this.gizmo["scale"].visible = this.mode === "scale";
520
- this.helper["translate"].visible = this.mode === "translate";
521
- this.helper["rotate"].visible = this.mode === "rotate";
522
- this.helper["scale"].visible = this.mode === "scale";
523
- let handles = [];
524
- handles = handles.concat(this.picker[this.mode].children);
525
- handles = handles.concat(this.gizmo[this.mode].children);
526
- handles = handles.concat(this.helper[this.mode].children);
527
- for (let i = 0; i < handles.length; i++) {
528
- const handle = handles[i];
529
- handle.visible = true;
530
- handle.rotation.set(0, 0, 0);
531
- handle.position.copy(this.worldPosition);
532
- let factor;
533
- if (this.camera.isOrthographicCamera) {
534
- factor = (this.camera.top - this.camera.bottom) / this.camera.zoom;
535
- } else {
536
- factor = this.worldPosition.distanceTo(this.cameraPosition) * Math.min(1.9 * Math.tan(Math.PI * this.camera.fov / 360) / this.camera.zoom, 7);
537
- }
538
- handle.scale.set(1, 1, 1).multiplyScalar(factor * this.size / 7);
539
- if (handle.tag === "helper") {
540
- handle.visible = false;
541
- if (handle.name === "AXIS") {
542
- handle.position.copy(this.worldPositionStart);
543
- handle.visible = !!this.axis;
544
- if (this.axis === "X") {
545
- this.tempQuaternion.setFromEuler(this.tempEuler.set(0, 0, 0));
546
- handle.quaternion.copy(quaternion).multiply(this.tempQuaternion);
547
- if (Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(quaternion).dot(this.eye)) > 0.9) {
548
- handle.visible = false;
549
- }
550
- }
551
- if (this.axis === "Y") {
552
- this.tempQuaternion.setFromEuler(this.tempEuler.set(0, 0, Math.PI / 2));
553
- handle.quaternion.copy(quaternion).multiply(this.tempQuaternion);
554
- if (Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(quaternion).dot(this.eye)) > 0.9) {
555
- handle.visible = false;
556
- }
557
- }
558
- if (this.axis === "Z") {
559
- this.tempQuaternion.setFromEuler(this.tempEuler.set(0, Math.PI / 2, 0));
560
- handle.quaternion.copy(quaternion).multiply(this.tempQuaternion);
561
- if (Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(quaternion).dot(this.eye)) > 0.9) {
562
- handle.visible = false;
563
- }
564
- }
565
- if (this.axis === "XYZE") {
566
- this.tempQuaternion.setFromEuler(this.tempEuler.set(0, Math.PI / 2, 0));
567
- this.alignVector.copy(this.rotationAxis);
568
- handle.quaternion.setFromRotationMatrix(
569
- this.lookAtMatrix.lookAt(this.zeroVector, this.alignVector, this.unitY)
570
- );
571
- handle.quaternion.multiply(this.tempQuaternion);
572
- handle.visible = this.dragging;
573
- }
574
- if (this.axis === "E") {
575
- handle.visible = false;
576
- }
577
- } else if (handle.name === "START") {
578
- handle.position.copy(this.worldPositionStart);
579
- handle.visible = this.dragging;
580
- } else if (handle.name === "END") {
581
- handle.position.copy(this.worldPosition);
582
- handle.visible = this.dragging;
583
- } else if (handle.name === "DELTA") {
584
- handle.position.copy(this.worldPositionStart);
585
- handle.quaternion.copy(this.worldQuaternionStart);
586
- this.tempVector.set(1e-10, 1e-10, 1e-10).add(this.worldPositionStart).sub(this.worldPosition).multiplyScalar(-1);
587
- this.tempVector.applyQuaternion(this.worldQuaternionStart.clone().invert());
588
- handle.scale.copy(this.tempVector);
589
- handle.visible = this.dragging;
590
- } else {
591
- handle.quaternion.copy(quaternion);
592
- if (this.dragging) {
593
- handle.position.copy(this.worldPositionStart);
594
- } else {
595
- handle.position.copy(this.worldPosition);
596
- }
597
- if (this.axis) {
598
- handle.visible = this.axis.search(handle.name) !== -1;
599
- }
600
- }
601
- continue;
602
- }
603
- handle.quaternion.copy(quaternion);
604
- if (this.mode === "translate" || this.mode === "scale") {
605
- const AXIS_HIDE_TRESHOLD = 0.99;
606
- const PLANE_HIDE_TRESHOLD = 0.2;
607
- const AXIS_FLIP_TRESHOLD = 0;
608
- if (handle.name === "X" || handle.name === "XYZX") {
609
- if (Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(quaternion).dot(this.eye)) > AXIS_HIDE_TRESHOLD) {
610
- handle.scale.set(1e-10, 1e-10, 1e-10);
611
- handle.visible = false;
612
- }
613
- }
614
- if (handle.name === "Y" || handle.name === "XYZY") {
615
- if (Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(quaternion).dot(this.eye)) > AXIS_HIDE_TRESHOLD) {
616
- handle.scale.set(1e-10, 1e-10, 1e-10);
617
- handle.visible = false;
618
- }
619
- }
620
- if (handle.name === "Z" || handle.name === "XYZZ") {
621
- if (Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(quaternion).dot(this.eye)) > AXIS_HIDE_TRESHOLD) {
622
- handle.scale.set(1e-10, 1e-10, 1e-10);
623
- handle.visible = false;
624
- }
625
- }
626
- if (handle.name === "XY") {
627
- if (Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(quaternion).dot(this.eye)) < PLANE_HIDE_TRESHOLD) {
628
- handle.scale.set(1e-10, 1e-10, 1e-10);
629
- handle.visible = false;
630
- }
631
- }
632
- if (handle.name === "YZ") {
633
- if (Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(quaternion).dot(this.eye)) < PLANE_HIDE_TRESHOLD) {
634
- handle.scale.set(1e-10, 1e-10, 1e-10);
635
- handle.visible = false;
636
- }
637
- }
638
- if (handle.name === "XZ") {
639
- if (Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(quaternion).dot(this.eye)) < PLANE_HIDE_TRESHOLD) {
640
- handle.scale.set(1e-10, 1e-10, 1e-10);
641
- handle.visible = false;
642
- }
643
- }
644
- if (handle.name.search("X") !== -1) {
645
- if (this.alignVector.copy(this.unitX).applyQuaternion(quaternion).dot(this.eye) < AXIS_FLIP_TRESHOLD) {
646
- if (handle.tag === "fwd") {
647
- handle.visible = false;
648
- } else {
649
- handle.scale.x *= -1;
650
- }
651
- } else if (handle.tag === "bwd") {
652
- handle.visible = false;
653
- }
654
- }
655
- if (handle.name.search("Y") !== -1) {
656
- if (this.alignVector.copy(this.unitY).applyQuaternion(quaternion).dot(this.eye) < AXIS_FLIP_TRESHOLD) {
657
- if (handle.tag === "fwd") {
658
- handle.visible = false;
659
- } else {
660
- handle.scale.y *= -1;
661
- }
662
- } else if (handle.tag === "bwd") {
663
- handle.visible = false;
664
- }
665
- }
666
- if (handle.name.search("Z") !== -1) {
667
- if (this.alignVector.copy(this.unitZ).applyQuaternion(quaternion).dot(this.eye) < AXIS_FLIP_TRESHOLD) {
668
- if (handle.tag === "fwd") {
669
- handle.visible = false;
670
- } else {
671
- handle.scale.z *= -1;
672
- }
673
- } else if (handle.tag === "bwd") {
674
- handle.visible = false;
675
- }
676
- }
677
- } else if (this.mode === "rotate") {
678
- this.tempQuaternion2.copy(quaternion);
679
- this.alignVector.copy(this.eye).applyQuaternion(this.tempQuaternion.copy(quaternion).invert());
680
- if (handle.name.search("E") !== -1) {
681
- handle.quaternion.setFromRotationMatrix(this.lookAtMatrix.lookAt(this.eye, this.zeroVector, this.unitY));
682
- }
683
- if (handle.name === "X") {
684
- this.tempQuaternion.setFromAxisAngle(this.unitX, Math.atan2(-this.alignVector.y, this.alignVector.z));
685
- this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2, this.tempQuaternion);
686
- handle.quaternion.copy(this.tempQuaternion);
687
- }
688
- if (handle.name === "Y") {
689
- this.tempQuaternion.setFromAxisAngle(this.unitY, Math.atan2(this.alignVector.x, this.alignVector.z));
690
- this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2, this.tempQuaternion);
691
- handle.quaternion.copy(this.tempQuaternion);
692
- }
693
- if (handle.name === "Z") {
694
- this.tempQuaternion.setFromAxisAngle(this.unitZ, Math.atan2(this.alignVector.y, this.alignVector.x));
695
- this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2, this.tempQuaternion);
696
- handle.quaternion.copy(this.tempQuaternion);
697
- }
698
- }
699
- handle.visible = handle.visible && (handle.name.indexOf("X") === -1 || this.showX);
700
- handle.visible = handle.visible && (handle.name.indexOf("Y") === -1 || this.showY);
701
- handle.visible = handle.visible && (handle.name.indexOf("Z") === -1 || this.showZ);
702
- handle.visible = handle.visible && (handle.name.indexOf("E") === -1 || this.showX && this.showY && this.showZ);
703
- handle.material.tempOpacity = handle.material.tempOpacity || handle.material.opacity;
704
- handle.material.tempColor = handle.material.tempColor || handle.material.color.clone();
705
- handle.material.color.copy(handle.material.tempColor);
706
- handle.material.opacity = handle.material.tempOpacity;
707
- if (!this.enabled) {
708
- handle.material.opacity *= 0.5;
709
- handle.material.color.lerp(new THREE.Color(1, 1, 1), 0.5);
710
- } else if (this.axis) {
711
- if (handle.name === this.axis) {
712
- handle.material.opacity = 1;
713
- handle.material.color.lerp(new THREE.Color(1, 1, 1), 0.5);
714
- } else if (this.axis.split("").some(function(a) {
715
- return handle.name === a;
716
- })) {
717
- handle.material.opacity = 1;
718
- handle.material.color.lerp(new THREE.Color(1, 1, 1), 0.5);
719
- } else {
720
- handle.material.opacity *= 0.25;
721
- handle.material.color.lerp(new THREE.Color(1, 1, 1), 0.5);
722
- }
723
- }
724
- }
725
- super.updateMatrixWorld();
726
- });
727
- const gizmoMaterial = new THREE.MeshBasicMaterial({
728
- depthTest: false,
729
- depthWrite: false,
730
- transparent: true,
731
- side: THREE.DoubleSide,
732
- fog: false,
733
- toneMapped: false
734
- });
735
- const gizmoLineMaterial = new THREE.LineBasicMaterial({
736
- depthTest: false,
737
- depthWrite: false,
738
- transparent: true,
739
- linewidth: 1,
740
- fog: false,
741
- toneMapped: false
742
- });
743
- const matInvisible = gizmoMaterial.clone();
744
- matInvisible.opacity = 0.15;
745
- const matHelper = gizmoMaterial.clone();
746
- matHelper.opacity = 0.33;
747
- const matRed = gizmoMaterial.clone();
748
- matRed.color.set(16711680);
749
- const matGreen = gizmoMaterial.clone();
750
- matGreen.color.set(65280);
751
- const matBlue = gizmoMaterial.clone();
752
- matBlue.color.set(255);
753
- const matWhiteTransparent = gizmoMaterial.clone();
754
- matWhiteTransparent.opacity = 0.25;
755
- const matYellowTransparent = matWhiteTransparent.clone();
756
- matYellowTransparent.color.set(16776960);
757
- const matCyanTransparent = matWhiteTransparent.clone();
758
- matCyanTransparent.color.set(65535);
759
- const matMagentaTransparent = matWhiteTransparent.clone();
760
- matMagentaTransparent.color.set(16711935);
761
- const matYellow = gizmoMaterial.clone();
762
- matYellow.color.set(16776960);
763
- const matLineRed = gizmoLineMaterial.clone();
764
- matLineRed.color.set(16711680);
765
- const matLineGreen = gizmoLineMaterial.clone();
766
- matLineGreen.color.set(65280);
767
- const matLineBlue = gizmoLineMaterial.clone();
768
- matLineBlue.color.set(255);
769
- const matLineCyan = gizmoLineMaterial.clone();
770
- matLineCyan.color.set(65535);
771
- const matLineMagenta = gizmoLineMaterial.clone();
772
- matLineMagenta.color.set(16711935);
773
- const matLineYellow = gizmoLineMaterial.clone();
774
- matLineYellow.color.set(16776960);
775
- const matLineGray = gizmoLineMaterial.clone();
776
- matLineGray.color.set(7895160);
777
- const matLineYellowTransparent = matLineYellow.clone();
778
- matLineYellowTransparent.opacity = 0.25;
779
- const arrowGeometry = new THREE.CylinderGeometry(0, 0.05, 0.2, 12, 1, false);
780
- const scaleHandleGeometry = new THREE.BoxGeometry(0.125, 0.125, 0.125);
781
- const lineGeometry = new THREE.BufferGeometry();
782
- lineGeometry.setAttribute("position", new THREE.Float32BufferAttribute([0, 0, 0, 1, 0, 0], 3));
783
- const CircleGeometry = (radius, arc) => {
784
- const geometry = new THREE.BufferGeometry();
785
- const vertices = [];
786
- for (let i = 0; i <= 64 * arc; ++i) {
787
- vertices.push(0, Math.cos(i / 32 * Math.PI) * radius, Math.sin(i / 32 * Math.PI) * radius);
788
- }
789
- geometry.setAttribute("position", new THREE.Float32BufferAttribute(vertices, 3));
790
- return geometry;
791
- };
792
- const TranslateHelperGeometry = () => {
793
- const geometry = new THREE.BufferGeometry();
794
- geometry.setAttribute("position", new THREE.Float32BufferAttribute([0, 0, 0, 1, 1, 1], 3));
795
- return geometry;
796
- };
797
- const gizmoTranslate = {
798
- X: [
799
- [new THREE.Mesh(arrowGeometry, matRed), [1, 0, 0], [0, 0, -Math.PI / 2], null, "fwd"],
800
- [new THREE.Mesh(arrowGeometry, matRed), [1, 0, 0], [0, 0, Math.PI / 2], null, "bwd"],
801
- [new THREE.Line(lineGeometry, matLineRed)]
802
- ],
803
- Y: [
804
- [new THREE.Mesh(arrowGeometry, matGreen), [0, 1, 0], null, null, "fwd"],
805
- [new THREE.Mesh(arrowGeometry, matGreen), [0, 1, 0], [Math.PI, 0, 0], null, "bwd"],
806
- [new THREE.Line(lineGeometry, matLineGreen), null, [0, 0, Math.PI / 2]]
807
- ],
808
- Z: [
809
- [new THREE.Mesh(arrowGeometry, matBlue), [0, 0, 1], [Math.PI / 2, 0, 0], null, "fwd"],
810
- [new THREE.Mesh(arrowGeometry, matBlue), [0, 0, 1], [-Math.PI / 2, 0, 0], null, "bwd"],
811
- [new THREE.Line(lineGeometry, matLineBlue), null, [0, -Math.PI / 2, 0]]
812
- ],
813
- XYZ: [[new THREE.Mesh(new THREE.OctahedronGeometry(0.1, 0), matWhiteTransparent.clone()), [0, 0, 0], [0, 0, 0]]],
814
- XY: [
815
- [new THREE.Mesh(new THREE.PlaneGeometry(0.295, 0.295), matYellowTransparent.clone()), [0.15, 0.15, 0]],
816
- [new THREE.Line(lineGeometry, matLineYellow), [0.18, 0.3, 0], null, [0.125, 1, 1]],
817
- [new THREE.Line(lineGeometry, matLineYellow), [0.3, 0.18, 0], [0, 0, Math.PI / 2], [0.125, 1, 1]]
818
- ],
819
- YZ: [
820
- [new THREE.Mesh(new THREE.PlaneGeometry(0.295, 0.295), matCyanTransparent.clone()), [0, 0.15, 0.15], [0, Math.PI / 2, 0]],
821
- [new THREE.Line(lineGeometry, matLineCyan), [0, 0.18, 0.3], [0, 0, Math.PI / 2], [0.125, 1, 1]],
822
- [new THREE.Line(lineGeometry, matLineCyan), [0, 0.3, 0.18], [0, -Math.PI / 2, 0], [0.125, 1, 1]]
823
- ],
824
- XZ: [
825
- [
826
- new THREE.Mesh(new THREE.PlaneGeometry(0.295, 0.295), matMagentaTransparent.clone()),
827
- [0.15, 0, 0.15],
828
- [-Math.PI / 2, 0, 0]
829
- ],
830
- [new THREE.Line(lineGeometry, matLineMagenta), [0.18, 0, 0.3], null, [0.125, 1, 1]],
831
- [new THREE.Line(lineGeometry, matLineMagenta), [0.3, 0, 0.18], [0, -Math.PI / 2, 0], [0.125, 1, 1]]
832
- ]
833
- };
834
- const pickerTranslate = {
835
- X: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 1, 4, 1, false), matInvisible), [0.6, 0, 0], [0, 0, -Math.PI / 2]]],
836
- Y: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 1, 4, 1, false), matInvisible), [0, 0.6, 0]]],
837
- Z: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 1, 4, 1, false), matInvisible), [0, 0, 0.6], [Math.PI / 2, 0, 0]]],
838
- XYZ: [[new THREE.Mesh(new THREE.OctahedronGeometry(0.2, 0), matInvisible)]],
839
- XY: [[new THREE.Mesh(new THREE.PlaneGeometry(0.4, 0.4), matInvisible), [0.2, 0.2, 0]]],
840
- YZ: [[new THREE.Mesh(new THREE.PlaneGeometry(0.4, 0.4), matInvisible), [0, 0.2, 0.2], [0, Math.PI / 2, 0]]],
841
- XZ: [[new THREE.Mesh(new THREE.PlaneGeometry(0.4, 0.4), matInvisible), [0.2, 0, 0.2], [-Math.PI / 2, 0, 0]]]
842
- };
843
- const helperTranslate = {
844
- START: [[new THREE.Mesh(new THREE.OctahedronGeometry(0.01, 2), matHelper), null, null, null, "helper"]],
845
- END: [[new THREE.Mesh(new THREE.OctahedronGeometry(0.01, 2), matHelper), null, null, null, "helper"]],
846
- DELTA: [[new THREE.Line(TranslateHelperGeometry(), matHelper), null, null, null, "helper"]],
847
- X: [[new THREE.Line(lineGeometry, matHelper.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"]],
848
- Y: [[new THREE.Line(lineGeometry, matHelper.clone()), [0, -1e3, 0], [0, 0, Math.PI / 2], [1e6, 1, 1], "helper"]],
849
- Z: [[new THREE.Line(lineGeometry, matHelper.clone()), [0, 0, -1e3], [0, -Math.PI / 2, 0], [1e6, 1, 1], "helper"]]
850
- };
851
- const gizmoRotate = {
852
- X: [
853
- [new THREE.Line(CircleGeometry(1, 0.5), matLineRed)],
854
- [new THREE.Mesh(new THREE.OctahedronGeometry(0.04, 0), matRed), [0, 0, 0.99], null, [1, 3, 1]]
855
- ],
856
- Y: [
857
- [new THREE.Line(CircleGeometry(1, 0.5), matLineGreen), null, [0, 0, -Math.PI / 2]],
858
- [new THREE.Mesh(new THREE.OctahedronGeometry(0.04, 0), matGreen), [0, 0, 0.99], null, [3, 1, 1]]
859
- ],
860
- Z: [
861
- [new THREE.Line(CircleGeometry(1, 0.5), matLineBlue), null, [0, Math.PI / 2, 0]],
862
- [new THREE.Mesh(new THREE.OctahedronGeometry(0.04, 0), matBlue), [0.99, 0, 0], null, [1, 3, 1]]
863
- ],
864
- E: [
865
- [new THREE.Line(CircleGeometry(1.25, 1), matLineYellowTransparent), null, [0, Math.PI / 2, 0]],
866
- [
867
- new THREE.Mesh(new THREE.CylinderGeometry(0.03, 0, 0.15, 4, 1, false), matLineYellowTransparent),
868
- [1.17, 0, 0],
869
- [0, 0, -Math.PI / 2],
870
- [1, 1, 1e-3]
871
- ],
872
- [
873
- new THREE.Mesh(new THREE.CylinderGeometry(0.03, 0, 0.15, 4, 1, false), matLineYellowTransparent),
874
- [-1.17, 0, 0],
875
- [0, 0, Math.PI / 2],
876
- [1, 1, 1e-3]
877
- ],
878
- [
879
- new THREE.Mesh(new THREE.CylinderGeometry(0.03, 0, 0.15, 4, 1, false), matLineYellowTransparent),
880
- [0, -1.17, 0],
881
- [Math.PI, 0, 0],
882
- [1, 1, 1e-3]
883
- ],
884
- [
885
- new THREE.Mesh(new THREE.CylinderGeometry(0.03, 0, 0.15, 4, 1, false), matLineYellowTransparent),
886
- [0, 1.17, 0],
887
- [0, 0, 0],
888
- [1, 1, 1e-3]
889
- ]
890
- ],
891
- XYZE: [[new THREE.Line(CircleGeometry(1, 1), matLineGray), null, [0, Math.PI / 2, 0]]]
892
- };
893
- const helperRotate = {
894
- AXIS: [[new THREE.Line(lineGeometry, matHelper.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"]]
895
- };
896
- const pickerRotate = {
897
- X: [[new THREE.Mesh(new THREE.TorusGeometry(1, 0.1, 4, 24), matInvisible), [0, 0, 0], [0, -Math.PI / 2, -Math.PI / 2]]],
898
- Y: [[new THREE.Mesh(new THREE.TorusGeometry(1, 0.1, 4, 24), matInvisible), [0, 0, 0], [Math.PI / 2, 0, 0]]],
899
- Z: [[new THREE.Mesh(new THREE.TorusGeometry(1, 0.1, 4, 24), matInvisible), [0, 0, 0], [0, 0, -Math.PI / 2]]],
900
- E: [[new THREE.Mesh(new THREE.TorusGeometry(1.25, 0.1, 2, 24), matInvisible)]],
901
- XYZE: [[new THREE.Mesh(new THREE.SphereGeometry(0.7, 10, 8), matInvisible)]]
902
- };
903
- const gizmoScale = {
904
- X: [
905
- [new THREE.Mesh(scaleHandleGeometry, matRed), [0.8, 0, 0], [0, 0, -Math.PI / 2]],
906
- [new THREE.Line(lineGeometry, matLineRed), null, null, [0.8, 1, 1]]
907
- ],
908
- Y: [
909
- [new THREE.Mesh(scaleHandleGeometry, matGreen), [0, 0.8, 0]],
910
- [new THREE.Line(lineGeometry, matLineGreen), null, [0, 0, Math.PI / 2], [0.8, 1, 1]]
911
- ],
912
- Z: [
913
- [new THREE.Mesh(scaleHandleGeometry, matBlue), [0, 0, 0.8], [Math.PI / 2, 0, 0]],
914
- [new THREE.Line(lineGeometry, matLineBlue), null, [0, -Math.PI / 2, 0], [0.8, 1, 1]]
915
- ],
916
- XY: [
917
- [new THREE.Mesh(scaleHandleGeometry, matYellowTransparent), [0.85, 0.85, 0], null, [2, 2, 0.2]],
918
- [new THREE.Line(lineGeometry, matLineYellow), [0.855, 0.98, 0], null, [0.125, 1, 1]],
919
- [new THREE.Line(lineGeometry, matLineYellow), [0.98, 0.855, 0], [0, 0, Math.PI / 2], [0.125, 1, 1]]
920
- ],
921
- YZ: [
922
- [new THREE.Mesh(scaleHandleGeometry, matCyanTransparent), [0, 0.85, 0.85], null, [0.2, 2, 2]],
923
- [new THREE.Line(lineGeometry, matLineCyan), [0, 0.855, 0.98], [0, 0, Math.PI / 2], [0.125, 1, 1]],
924
- [new THREE.Line(lineGeometry, matLineCyan), [0, 0.98, 0.855], [0, -Math.PI / 2, 0], [0.125, 1, 1]]
925
- ],
926
- XZ: [
927
- [new THREE.Mesh(scaleHandleGeometry, matMagentaTransparent), [0.85, 0, 0.85], null, [2, 0.2, 2]],
928
- [new THREE.Line(lineGeometry, matLineMagenta), [0.855, 0, 0.98], null, [0.125, 1, 1]],
929
- [new THREE.Line(lineGeometry, matLineMagenta), [0.98, 0, 0.855], [0, -Math.PI / 2, 0], [0.125, 1, 1]]
930
- ],
931
- XYZX: [[new THREE.Mesh(new THREE.BoxGeometry(0.125, 0.125, 0.125), matWhiteTransparent.clone()), [1.1, 0, 0]]],
932
- XYZY: [[new THREE.Mesh(new THREE.BoxGeometry(0.125, 0.125, 0.125), matWhiteTransparent.clone()), [0, 1.1, 0]]],
933
- XYZZ: [[new THREE.Mesh(new THREE.BoxGeometry(0.125, 0.125, 0.125), matWhiteTransparent.clone()), [0, 0, 1.1]]]
934
- };
935
- const pickerScale = {
936
- X: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 0.8, 4, 1, false), matInvisible), [0.5, 0, 0], [0, 0, -Math.PI / 2]]],
937
- Y: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 0.8, 4, 1, false), matInvisible), [0, 0.5, 0]]],
938
- Z: [[new THREE.Mesh(new THREE.CylinderGeometry(0.2, 0, 0.8, 4, 1, false), matInvisible), [0, 0, 0.5], [Math.PI / 2, 0, 0]]],
939
- XY: [[new THREE.Mesh(scaleHandleGeometry, matInvisible), [0.85, 0.85, 0], null, [3, 3, 0.2]]],
940
- YZ: [[new THREE.Mesh(scaleHandleGeometry, matInvisible), [0, 0.85, 0.85], null, [0.2, 3, 3]]],
941
- XZ: [[new THREE.Mesh(scaleHandleGeometry, matInvisible), [0.85, 0, 0.85], null, [3, 0.2, 3]]],
942
- XYZX: [[new THREE.Mesh(new THREE.BoxGeometry(0.2, 0.2, 0.2), matInvisible), [1.1, 0, 0]]],
943
- XYZY: [[new THREE.Mesh(new THREE.BoxGeometry(0.2, 0.2, 0.2), matInvisible), [0, 1.1, 0]]],
944
- XYZZ: [[new THREE.Mesh(new THREE.BoxGeometry(0.2, 0.2, 0.2), matInvisible), [0, 0, 1.1]]]
945
- };
946
- const helperScale = {
947
- X: [[new THREE.Line(lineGeometry, matHelper.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"]],
948
- Y: [[new THREE.Line(lineGeometry, matHelper.clone()), [0, -1e3, 0], [0, 0, Math.PI / 2], [1e6, 1, 1], "helper"]],
949
- Z: [[new THREE.Line(lineGeometry, matHelper.clone()), [0, 0, -1e3], [0, -Math.PI / 2, 0], [1e6, 1, 1], "helper"]]
950
- };
951
- const setupGizmo = (gizmoMap) => {
952
- const gizmo = new THREE.Object3D();
953
- for (let name in gizmoMap) {
954
- for (let i = gizmoMap[name].length; i--; ) {
955
- const object = gizmoMap[name][i][0].clone();
956
- const position = gizmoMap[name][i][1];
957
- const rotation = gizmoMap[name][i][2];
958
- const scale = gizmoMap[name][i][3];
959
- const tag = gizmoMap[name][i][4];
960
- object.name = name;
961
- object.tag = tag;
962
- if (position) {
963
- object.position.set(position[0], position[1], position[2]);
964
- }
965
- if (rotation) {
966
- object.rotation.set(rotation[0], rotation[1], rotation[2]);
967
- }
968
- if (scale) {
969
- object.scale.set(scale[0], scale[1], scale[2]);
970
- }
971
- object.updateMatrix();
972
- const tempGeometry = object.geometry.clone();
973
- tempGeometry.applyMatrix4(object.matrix);
974
- object.geometry = tempGeometry;
975
- object.renderOrder = Infinity;
976
- object.position.set(0, 0, 0);
977
- object.rotation.set(0, 0, 0);
978
- object.scale.set(1, 1, 1);
979
- gizmo.add(object);
980
- }
981
- }
982
- return gizmo;
983
- };
984
- this.gizmo = {};
985
- this.picker = {};
986
- this.helper = {};
987
- this.add(this.gizmo["translate"] = setupGizmo(gizmoTranslate));
988
- this.add(this.gizmo["rotate"] = setupGizmo(gizmoRotate));
989
- this.add(this.gizmo["scale"] = setupGizmo(gizmoScale));
990
- this.add(this.picker["translate"] = setupGizmo(pickerTranslate));
991
- this.add(this.picker["rotate"] = setupGizmo(pickerRotate));
992
- this.add(this.picker["scale"] = setupGizmo(pickerScale));
993
- this.add(this.helper["translate"] = setupGizmo(helperTranslate));
994
- this.add(this.helper["rotate"] = setupGizmo(helperRotate));
995
- this.add(this.helper["scale"] = setupGizmo(helperScale));
996
- this.picker["translate"].visible = false;
997
- this.picker["rotate"].visible = false;
998
- this.picker["scale"].visible = false;
999
- }
1000
- }
1001
- class TransformControlsPlane extends THREE.Mesh {
1002
- constructor() {
1003
- super(
1004
- new THREE.PlaneGeometry(1e5, 1e5, 2, 2),
1005
- new THREE.MeshBasicMaterial({
1006
- visible: false,
1007
- wireframe: true,
1008
- side: THREE.DoubleSide,
1009
- transparent: true,
1010
- opacity: 0.1,
1011
- toneMapped: false
1012
- })
1013
- );
1014
- __publicField(this, "isTransformControlsPlane", true);
1015
- __publicField(this, "type", "TransformControlsPlane");
1016
- __publicField(this, "unitX", new THREE.Vector3(1, 0, 0));
1017
- __publicField(this, "unitY", new THREE.Vector3(0, 1, 0));
1018
- __publicField(this, "unitZ", new THREE.Vector3(0, 0, 1));
1019
- __publicField(this, "tempVector", new THREE.Vector3());
1020
- __publicField(this, "dirVector", new THREE.Vector3());
1021
- __publicField(this, "alignVector", new THREE.Vector3());
1022
- __publicField(this, "tempMatrix", new THREE.Matrix4());
1023
- __publicField(this, "identityQuaternion", new THREE.Quaternion());
1024
- // these are set from parent class TransformControls
1025
- __publicField(this, "cameraQuaternion", new THREE.Quaternion());
1026
- __publicField(this, "worldPosition", new THREE.Vector3());
1027
- __publicField(this, "worldQuaternion", new THREE.Quaternion());
1028
- __publicField(this, "eye", new THREE.Vector3());
1029
- __publicField(this, "axis", null);
1030
- __publicField(this, "mode", "translate");
1031
- __publicField(this, "space", "world");
1032
- __publicField(this, "updateMatrixWorld", () => {
1033
- let space = this.space;
1034
- this.position.copy(this.worldPosition);
1035
- if (this.mode === "scale")
1036
- space = "local";
1037
- this.unitX.set(1, 0, 0).applyQuaternion(space === "local" ? this.worldQuaternion : this.identityQuaternion);
1038
- this.unitY.set(0, 1, 0).applyQuaternion(space === "local" ? this.worldQuaternion : this.identityQuaternion);
1039
- this.unitZ.set(0, 0, 1).applyQuaternion(space === "local" ? this.worldQuaternion : this.identityQuaternion);
1040
- this.alignVector.copy(this.unitY);
1041
- switch (this.mode) {
1042
- case "translate":
1043
- case "scale":
1044
- switch (this.axis) {
1045
- case "X":
1046
- this.alignVector.copy(this.eye).cross(this.unitX);
1047
- this.dirVector.copy(this.unitX).cross(this.alignVector);
1048
- break;
1049
- case "Y":
1050
- this.alignVector.copy(this.eye).cross(this.unitY);
1051
- this.dirVector.copy(this.unitY).cross(this.alignVector);
1052
- break;
1053
- case "Z":
1054
- this.alignVector.copy(this.eye).cross(this.unitZ);
1055
- this.dirVector.copy(this.unitZ).cross(this.alignVector);
1056
- break;
1057
- case "XY":
1058
- this.dirVector.copy(this.unitZ);
1059
- break;
1060
- case "YZ":
1061
- this.dirVector.copy(this.unitX);
1062
- break;
1063
- case "XZ":
1064
- this.alignVector.copy(this.unitZ);
1065
- this.dirVector.copy(this.unitY);
1066
- break;
1067
- case "XYZ":
1068
- case "E":
1069
- this.dirVector.set(0, 0, 0);
1070
- break;
1071
- }
1072
- break;
1073
- case "rotate":
1074
- default:
1075
- this.dirVector.set(0, 0, 0);
1076
- }
1077
- if (this.dirVector.length() === 0) {
1078
- this.quaternion.copy(this.cameraQuaternion);
1079
- } else {
1080
- this.tempMatrix.lookAt(this.tempVector.set(0, 0, 0), this.dirVector, this.alignVector);
1081
- this.quaternion.setFromRotationMatrix(this.tempMatrix);
1082
- }
1083
- super.updateMatrixWorld();
1084
- });
1085
- }
1086
- }
1087
- exports.TransformControls = TransformControls;
1088
- exports.TransformControlsGizmo = TransformControlsGizmo;
1089
- exports.TransformControlsPlane = TransformControlsPlane;