three-stdlib 2.25.0 → 2.25.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (539) hide show
  1. package/index.cjs +116401 -611
  2. package/index.js +116037 -263
  3. package/package.json +17 -4
  4. package/_polyfill/CapsuleGeometry.cjs +0 -22
  5. package/_polyfill/CapsuleGeometry.js +0 -22
  6. package/_polyfill/CompressedArrayTexture.cjs +0 -12
  7. package/_polyfill/CompressedArrayTexture.js +0 -12
  8. package/_polyfill/Data3DTexture.cjs +0 -17
  9. package/_polyfill/Data3DTexture.js +0 -17
  10. package/animation/AnimationClipCreator.cjs +0 -56
  11. package/animation/AnimationClipCreator.js +0 -56
  12. package/animation/CCDIKSolver.cjs +0 -269
  13. package/animation/CCDIKSolver.js +0 -269
  14. package/animation/MMDAnimationHelper.cjs +0 -688
  15. package/animation/MMDAnimationHelper.js +0 -688
  16. package/animation/MMDPhysics.cjs +0 -830
  17. package/animation/MMDPhysics.js +0 -830
  18. package/cameras/CinematicCamera.cjs +0 -131
  19. package/cameras/CinematicCamera.js +0 -131
  20. package/controls/ArcballControls.cjs +0 -2033
  21. package/controls/ArcballControls.js +0 -2033
  22. package/controls/DeviceOrientationControls.cjs +0 -85
  23. package/controls/DeviceOrientationControls.js +0 -85
  24. package/controls/DragControls.cjs +0 -182
  25. package/controls/DragControls.js +0 -182
  26. package/controls/FirstPersonControls.cjs +0 -229
  27. package/controls/FirstPersonControls.js +0 -229
  28. package/controls/FlyControls.cjs +0 -248
  29. package/controls/FlyControls.js +0 -248
  30. package/controls/OrbitControls.cjs +0 -791
  31. package/controls/OrbitControls.js +0 -791
  32. package/controls/PointerLockControls.cjs +0 -103
  33. package/controls/PointerLockControls.js +0 -103
  34. package/controls/TrackballControls.cjs +0 -502
  35. package/controls/TrackballControls.js +0 -502
  36. package/controls/TransformControls.cjs +0 -1089
  37. package/controls/TransformControls.js +0 -1089
  38. package/controls/experimental/CameraControls.cjs +0 -736
  39. package/controls/experimental/CameraControls.js +0 -736
  40. package/csm/CSM.cjs +0 -244
  41. package/csm/CSM.js +0 -244
  42. package/csm/CSMFrustum.cjs +0 -75
  43. package/csm/CSMFrustum.js +0 -75
  44. package/csm/CSMHelper.cjs +0 -114
  45. package/csm/CSMHelper.js +0 -114
  46. package/csm/CSMShader.cjs +0 -261
  47. package/csm/CSMShader.js +0 -261
  48. package/curves/CurveExtras.cjs +0 -214
  49. package/curves/CurveExtras.js +0 -214
  50. package/curves/NURBSCurve.cjs +0 -35
  51. package/curves/NURBSCurve.js +0 -35
  52. package/curves/NURBSSurface.cjs +0 -28
  53. package/curves/NURBSSurface.js +0 -28
  54. package/curves/NURBSUtils.cjs +0 -226
  55. package/curves/NURBSUtils.js +0 -226
  56. package/deprecated/Geometry.cjs +0 -971
  57. package/deprecated/Geometry.js +0 -971
  58. package/effects/AnaglyphEffect.cjs +0 -102
  59. package/effects/AnaglyphEffect.js +0 -102
  60. package/effects/AsciiEffect.cjs +0 -155
  61. package/effects/AsciiEffect.js +0 -155
  62. package/effects/OutlineEffect.cjs +0 -275
  63. package/effects/OutlineEffect.js +0 -275
  64. package/effects/ParallaxBarrierEffect.cjs +0 -65
  65. package/effects/ParallaxBarrierEffect.js +0 -65
  66. package/effects/PeppersGhostEffect.cjs +0 -88
  67. package/effects/PeppersGhostEffect.js +0 -88
  68. package/effects/StereoEffect.cjs +0 -35
  69. package/effects/StereoEffect.js +0 -35
  70. package/environments/RoomEnvironment.cjs +0 -95
  71. package/environments/RoomEnvironment.js +0 -78
  72. package/exporters/ColladaExporter.cjs +0 -331
  73. package/exporters/ColladaExporter.js +0 -331
  74. package/exporters/DRACOExporter.cjs +0 -141
  75. package/exporters/DRACOExporter.js +0 -141
  76. package/exporters/GLTFExporter.cjs +0 -1909
  77. package/exporters/GLTFExporter.js +0 -1909
  78. package/exporters/MMDExporter.cjs +0 -131
  79. package/exporters/MMDExporter.js +0 -131
  80. package/exporters/OBJExporter.cjs +0 -181
  81. package/exporters/OBJExporter.js +0 -181
  82. package/exporters/PLYExporter.cjs +0 -280
  83. package/exporters/PLYExporter.js +0 -280
  84. package/exporters/STLExporter.cjs +0 -146
  85. package/exporters/STLExporter.js +0 -146
  86. package/exporters/USDZExporter.cjs +0 -340
  87. package/exporters/USDZExporter.js +0 -340
  88. package/geometries/BoxLineGeometry.cjs +0 -45
  89. package/geometries/BoxLineGeometry.js +0 -45
  90. package/geometries/ConvexGeometry.cjs +0 -26
  91. package/geometries/ConvexGeometry.js +0 -26
  92. package/geometries/DecalGeometry.cjs +0 -184
  93. package/geometries/DecalGeometry.js +0 -184
  94. package/geometries/LightningStrike.cjs +0 -553
  95. package/geometries/LightningStrike.js +0 -553
  96. package/geometries/ParametricGeometries.cjs +0 -130
  97. package/geometries/ParametricGeometries.js +0 -130
  98. package/geometries/ParametricGeometry.cjs +0 -63
  99. package/geometries/ParametricGeometry.js +0 -63
  100. package/geometries/RoundedBoxGeometry.cjs +0 -91
  101. package/geometries/RoundedBoxGeometry.js +0 -91
  102. package/geometries/TeapotGeometry.cjs +0 -1563
  103. package/geometries/TeapotGeometry.js +0 -1563
  104. package/geometries/TextGeometry.cjs +0 -27
  105. package/geometries/TextGeometry.js +0 -27
  106. package/helpers/LightProbeHelper.cjs +0 -73
  107. package/helpers/LightProbeHelper.js +0 -73
  108. package/helpers/PositionalAudioHelper.cjs +0 -68
  109. package/helpers/PositionalAudioHelper.js +0 -68
  110. package/helpers/RectAreaLightHelper.cjs +0 -44
  111. package/helpers/RectAreaLightHelper.js +0 -44
  112. package/helpers/VertexNormalsHelper.cjs +0 -47
  113. package/helpers/VertexNormalsHelper.js +0 -47
  114. package/helpers/VertexTangentsHelper.cjs +0 -43
  115. package/helpers/VertexTangentsHelper.js +0 -43
  116. package/interactive/HTMLMesh.cjs +0 -325
  117. package/interactive/HTMLMesh.js +0 -325
  118. package/interactive/InteractiveGroup.cjs +0 -68
  119. package/interactive/InteractiveGroup.js +0 -68
  120. package/interactive/SelectionBox.cjs +0 -134
  121. package/interactive/SelectionBox.js +0 -134
  122. package/interactive/SelectionHelper.cjs +0 -51
  123. package/interactive/SelectionHelper.js +0 -51
  124. package/libs/MeshoptDecoder.cjs +0 -221
  125. package/libs/MeshoptDecoder.js +0 -221
  126. package/libs/MotionControllers.cjs +0 -325
  127. package/libs/MotionControllers.js +0 -325
  128. package/lights/LightProbeGenerator.cjs +0 -145
  129. package/lights/LightProbeGenerator.js +0 -145
  130. package/lights/RectAreaLightUniformsLib.cjs +0 -32846
  131. package/lights/RectAreaLightUniformsLib.js +0 -32846
  132. package/lines/Line2.cjs +0 -13
  133. package/lines/Line2.js +0 -13
  134. package/lines/LineGeometry.cjs +0 -44
  135. package/lines/LineGeometry.js +0 -44
  136. package/lines/LineMaterial.cjs +0 -547
  137. package/lines/LineMaterial.js +0 -547
  138. package/lines/LineSegments2.cjs +0 -203
  139. package/lines/LineSegments2.js +0 -203
  140. package/lines/LineSegmentsGeometry.cjs +0 -124
  141. package/lines/LineSegmentsGeometry.js +0 -124
  142. package/lines/Wireframe.cjs +0 -32
  143. package/lines/Wireframe.js +0 -32
  144. package/lines/WireframeGeometry2.cjs +0 -13
  145. package/lines/WireframeGeometry2.js +0 -13
  146. package/loaders/3DMLoader.cjs +0 -803
  147. package/loaders/3DMLoader.js +0 -803
  148. package/loaders/3MFLoader.cjs +0 -854
  149. package/loaders/3MFLoader.js +0 -854
  150. package/loaders/AMFLoader.cjs +0 -284
  151. package/loaders/AMFLoader.js +0 -284
  152. package/loaders/AssimpLoader.cjs +0 -1434
  153. package/loaders/AssimpLoader.js +0 -1434
  154. package/loaders/BVHLoader.cjs +0 -207
  155. package/loaders/BVHLoader.js +0 -207
  156. package/loaders/BasisTextureLoader.cjs +0 -489
  157. package/loaders/BasisTextureLoader.js +0 -489
  158. package/loaders/ColladaLoader.cjs +0 -2405
  159. package/loaders/ColladaLoader.js +0 -2405
  160. package/loaders/DDSLoader.cjs +0 -148
  161. package/loaders/DDSLoader.js +0 -148
  162. package/loaders/DRACOLoader.cjs +0 -341
  163. package/loaders/DRACOLoader.js +0 -341
  164. package/loaders/EXRLoader.cjs +0 -1356
  165. package/loaders/EXRLoader.js +0 -1356
  166. package/loaders/FBXLoader.cjs +0 -2457
  167. package/loaders/FBXLoader.js +0 -2457
  168. package/loaders/FontLoader.cjs +0 -123
  169. package/loaders/FontLoader.js +0 -123
  170. package/loaders/GCodeLoader.cjs +0 -141
  171. package/loaders/GCodeLoader.js +0 -141
  172. package/loaders/GLTFLoader.cjs +0 -2504
  173. package/loaders/GLTFLoader.js +0 -2504
  174. package/loaders/HDRCubeTextureLoader.cjs +0 -75
  175. package/loaders/HDRCubeTextureLoader.js +0 -75
  176. package/loaders/KMZLoader.cjs +0 -75
  177. package/loaders/KMZLoader.js +0 -75
  178. package/loaders/KTX2Loader.cjs +0 -480
  179. package/loaders/KTX2Loader.js +0 -480
  180. package/loaders/KTXLoader.cjs +0 -93
  181. package/loaders/KTXLoader.js +0 -93
  182. package/loaders/LDrawLoader.cjs +0 -1424
  183. package/loaders/LDrawLoader.js +0 -1424
  184. package/loaders/LUT3dlLoader.cjs +0 -103
  185. package/loaders/LUT3dlLoader.js +0 -103
  186. package/loaders/LUTCubeLoader.cjs +0 -107
  187. package/loaders/LUTCubeLoader.js +0 -107
  188. package/loaders/LWOLoader.cjs +0 -645
  189. package/loaders/LWOLoader.js +0 -645
  190. package/loaders/LottieLoader.cjs +0 -47
  191. package/loaders/LottieLoader.js +0 -47
  192. package/loaders/MD2Loader.cjs +0 -359
  193. package/loaders/MD2Loader.js +0 -359
  194. package/loaders/MDDLoader.cjs +0 -58
  195. package/loaders/MDDLoader.js +0 -58
  196. package/loaders/MMDLoader.cjs +0 -1121
  197. package/loaders/MMDLoader.js +0 -1121
  198. package/loaders/MTLLoader.cjs +0 -304
  199. package/loaders/MTLLoader.js +0 -304
  200. package/loaders/NRRDLoader.cjs +0 -401
  201. package/loaders/NRRDLoader.js +0 -401
  202. package/loaders/OBJLoader.cjs +0 -487
  203. package/loaders/OBJLoader.js +0 -487
  204. package/loaders/PCDLoader.cjs +0 -248
  205. package/loaders/PCDLoader.js +0 -248
  206. package/loaders/PDBLoader.cjs +0 -247
  207. package/loaders/PDBLoader.js +0 -247
  208. package/loaders/PLYLoader.cjs +0 -317
  209. package/loaders/PLYLoader.js +0 -317
  210. package/loaders/PRWMLoader.cjs +0 -160
  211. package/loaders/PRWMLoader.js +0 -160
  212. package/loaders/PVRLoader.cjs +0 -131
  213. package/loaders/PVRLoader.js +0 -131
  214. package/loaders/RGBELoader.cjs +0 -252
  215. package/loaders/RGBELoader.js +0 -252
  216. package/loaders/RGBMLoader.cjs +0 -1004
  217. package/loaders/RGBMLoader.js +0 -1004
  218. package/loaders/STLLoader.cjs +0 -190
  219. package/loaders/STLLoader.js +0 -190
  220. package/loaders/SVGLoader.cjs +0 -1712
  221. package/loaders/SVGLoader.js +0 -1712
  222. package/loaders/TDSLoader.cjs +0 -650
  223. package/loaders/TDSLoader.js +0 -650
  224. package/loaders/TGALoader.cjs +0 -285
  225. package/loaders/TGALoader.js +0 -285
  226. package/loaders/TTFLoader.cjs +0 -131
  227. package/loaders/TTFLoader.js +0 -131
  228. package/loaders/TiltLoader.cjs +0 -375
  229. package/loaders/TiltLoader.js +0 -375
  230. package/loaders/VOXLoader.cjs +0 -432
  231. package/loaders/VOXLoader.js +0 -432
  232. package/loaders/VRMLLoader.cjs +0 -2105
  233. package/loaders/VRMLLoader.js +0 -2105
  234. package/loaders/VRMLoader.cjs +0 -38
  235. package/loaders/VRMLoader.js +0 -38
  236. package/loaders/VTKLoader.cjs +0 -648
  237. package/loaders/VTKLoader.js +0 -648
  238. package/loaders/XLoader.cjs +0 -1258
  239. package/loaders/XLoader.js +0 -1258
  240. package/loaders/XYZLoader.cjs +0 -60
  241. package/loaders/XYZLoader.js +0 -60
  242. package/loaders/lwo/IFFParser.cjs +0 -743
  243. package/loaders/lwo/IFFParser.js +0 -743
  244. package/loaders/lwo/LWO2Parser.cjs +0 -312
  245. package/loaders/lwo/LWO2Parser.js +0 -312
  246. package/loaders/lwo/LWO3Parser.cjs +0 -282
  247. package/loaders/lwo/LWO3Parser.js +0 -282
  248. package/math/Capsule.cjs +0 -98
  249. package/math/Capsule.js +0 -98
  250. package/math/ColorConverter.cjs +0 -42
  251. package/math/ColorConverter.js +0 -42
  252. package/math/ConvexHull.cjs +0 -596
  253. package/math/ConvexHull.js +0 -596
  254. package/math/ImprovedNoise.cjs +0 -304
  255. package/math/ImprovedNoise.js +0 -304
  256. package/math/Lut.cjs +0 -137
  257. package/math/Lut.js +0 -137
  258. package/math/MeshSurfaceSampler.cjs +0 -103
  259. package/math/MeshSurfaceSampler.js +0 -103
  260. package/math/OBB.cjs +0 -242
  261. package/math/OBB.js +0 -242
  262. package/math/Octree.cjs +0 -273
  263. package/math/Octree.js +0 -273
  264. package/math/SimplexNoise.cjs +0 -440
  265. package/math/SimplexNoise.js +0 -440
  266. package/misc/ConvexObjectBreaker.cjs +0 -292
  267. package/misc/ConvexObjectBreaker.js +0 -292
  268. package/misc/GPUComputationRenderer.cjs +0 -205
  269. package/misc/GPUComputationRenderer.js +0 -205
  270. package/misc/Gyroscope.cjs +0 -33
  271. package/misc/Gyroscope.js +0 -33
  272. package/misc/MD2Character.cjs +0 -167
  273. package/misc/MD2Character.js +0 -167
  274. package/misc/MD2CharacterComplex.cjs +0 -332
  275. package/misc/MD2CharacterComplex.js +0 -332
  276. package/misc/MorphAnimMesh.cjs +0 -40
  277. package/misc/MorphAnimMesh.js +0 -40
  278. package/misc/MorphBlendMesh.cjs +0 -179
  279. package/misc/MorphBlendMesh.js +0 -179
  280. package/misc/ProgressiveLightmap.cjs +0 -186
  281. package/misc/ProgressiveLightmap.js +0 -186
  282. package/misc/RollerCoaster.cjs +0 -353
  283. package/misc/RollerCoaster.js +0 -353
  284. package/misc/Timer.cjs +0 -101
  285. package/misc/Timer.js +0 -101
  286. package/misc/TubePainter.cjs +0 -123
  287. package/misc/TubePainter.js +0 -123
  288. package/misc/Volume.cjs +0 -305
  289. package/misc/Volume.js +0 -305
  290. package/misc/VolumeSlice.cjs +0 -114
  291. package/misc/VolumeSlice.js +0 -114
  292. package/misc/WebGL.cjs +0 -74
  293. package/misc/WebGL.js +0 -74
  294. package/modifiers/CurveModifier.cjs +0 -232
  295. package/modifiers/CurveModifier.js +0 -232
  296. package/modifiers/EdgeSplitModifier.cjs +0 -167
  297. package/modifiers/EdgeSplitModifier.js +0 -168
  298. package/modifiers/SimplifyModifier.cjs +0 -301
  299. package/modifiers/SimplifyModifier.js +0 -301
  300. package/modifiers/TessellateModifier.cjs +0 -214
  301. package/modifiers/TessellateModifier.js +0 -214
  302. package/objects/GroundProjectedEnv.cjs +0 -134
  303. package/objects/GroundProjectedEnv.js +0 -134
  304. package/objects/Lensflare.cjs +0 -291
  305. package/objects/Lensflare.js +0 -291
  306. package/objects/LightningStorm.cjs +0 -110
  307. package/objects/LightningStorm.js +0 -110
  308. package/objects/MarchingCubes.cjs +0 -4809
  309. package/objects/MarchingCubes.js +0 -4809
  310. package/objects/Reflector.cjs +0 -202
  311. package/objects/Reflector.js +0 -202
  312. package/objects/ReflectorForSSRPass.cjs +0 -260
  313. package/objects/ReflectorForSSRPass.js +0 -260
  314. package/objects/ReflectorRTT.cjs +0 -10
  315. package/objects/ReflectorRTT.js +0 -10
  316. package/objects/Refractor.cjs +0 -215
  317. package/objects/Refractor.js +0 -215
  318. package/objects/ShadowMesh.cjs +0 -45
  319. package/objects/ShadowMesh.js +0 -45
  320. package/objects/Sky.cjs +0 -200
  321. package/objects/Sky.js +0 -200
  322. package/objects/Water.cjs +0 -242
  323. package/objects/Water.js +0 -242
  324. package/objects/Water2.cjs +0 -256
  325. package/objects/Water2.js +0 -256
  326. package/physics/AmmoPhysics.cjs +0 -166
  327. package/physics/AmmoPhysics.js +0 -166
  328. package/postprocessing/AdaptiveToneMappingPass.cjs +0 -218
  329. package/postprocessing/AdaptiveToneMappingPass.js +0 -218
  330. package/postprocessing/AfterimagePass.cjs +0 -68
  331. package/postprocessing/AfterimagePass.js +0 -68
  332. package/postprocessing/BloomPass.cjs +0 -109
  333. package/postprocessing/BloomPass.js +0 -109
  334. package/postprocessing/BokehPass.cjs +0 -90
  335. package/postprocessing/BokehPass.js +0 -90
  336. package/postprocessing/ClearPass.cjs +0 -36
  337. package/postprocessing/ClearPass.js +0 -36
  338. package/postprocessing/CubeTexturePass.cjs +0 -53
  339. package/postprocessing/CubeTexturePass.js +0 -53
  340. package/postprocessing/DotScreenPass.cjs +0 -49
  341. package/postprocessing/DotScreenPass.js +0 -49
  342. package/postprocessing/EffectComposer.cjs +0 -157
  343. package/postprocessing/EffectComposer.js +0 -157
  344. package/postprocessing/FilmPass.cjs +0 -51
  345. package/postprocessing/FilmPass.js +0 -51
  346. package/postprocessing/GlitchPass.cjs +0 -84
  347. package/postprocessing/GlitchPass.js +0 -84
  348. package/postprocessing/HalftonePass.cjs +0 -53
  349. package/postprocessing/HalftonePass.js +0 -53
  350. package/postprocessing/LUTPass.cjs +0 -142
  351. package/postprocessing/LUTPass.js +0 -142
  352. package/postprocessing/MaskPass.cjs +0 -69
  353. package/postprocessing/MaskPass.js +0 -69
  354. package/postprocessing/OutlinePass.cjs +0 -479
  355. package/postprocessing/OutlinePass.js +0 -479
  356. package/postprocessing/Pass.cjs +0 -48
  357. package/postprocessing/Pass.js +0 -48
  358. package/postprocessing/RenderPass.cjs +0 -59
  359. package/postprocessing/RenderPass.js +0 -59
  360. package/postprocessing/RenderPixelatedPass.cjs +0 -199
  361. package/postprocessing/RenderPixelatedPass.js +0 -199
  362. package/postprocessing/SAOPass.cjs +0 -288
  363. package/postprocessing/SAOPass.js +0 -288
  364. package/postprocessing/SMAAPass.cjs +0 -112
  365. package/postprocessing/SMAAPass.js +0 -112
  366. package/postprocessing/SSAARenderPass.cjs +0 -189
  367. package/postprocessing/SSAARenderPass.js +0 -189
  368. package/postprocessing/SSAOPass.cjs +0 -272
  369. package/postprocessing/SSAOPass.js +0 -272
  370. package/postprocessing/SSRPass.cjs +0 -411
  371. package/postprocessing/SSRPass.js +0 -411
  372. package/postprocessing/SavePass.cjs +0 -38
  373. package/postprocessing/SavePass.js +0 -38
  374. package/postprocessing/ShaderPass.cjs +0 -49
  375. package/postprocessing/ShaderPass.js +0 -49
  376. package/postprocessing/TAARenderPass.cjs +0 -174
  377. package/postprocessing/TAARenderPass.js +0 -174
  378. package/postprocessing/TexturePass.cjs +0 -42
  379. package/postprocessing/TexturePass.js +0 -42
  380. package/postprocessing/UnrealBloomPass.cjs +0 -277
  381. package/postprocessing/UnrealBloomPass.js +0 -277
  382. package/postprocessing/WaterPass.cjs +0 -72
  383. package/postprocessing/WaterPass.js +0 -72
  384. package/renderers/CSS2DRenderer.cjs +0 -122
  385. package/renderers/CSS2DRenderer.js +0 -122
  386. package/renderers/CSS3DRenderer.cjs +0 -167
  387. package/renderers/CSS3DRenderer.js +0 -167
  388. package/renderers/Projector.cjs +0 -499
  389. package/renderers/Projector.js +0 -499
  390. package/renderers/SVGRenderer.cjs +0 -311
  391. package/renderers/SVGRenderer.js +0 -311
  392. package/shaders/ACESFilmicToneMappingShader.cjs +0 -55
  393. package/shaders/ACESFilmicToneMappingShader.js +0 -55
  394. package/shaders/AfterimageShader.cjs +0 -32
  395. package/shaders/AfterimageShader.js +0 -32
  396. package/shaders/BasicShader.cjs +0 -12
  397. package/shaders/BasicShader.js +0 -12
  398. package/shaders/BleachBypassShader.cjs +0 -35
  399. package/shaders/BleachBypassShader.js +0 -35
  400. package/shaders/BlendShader.cjs +0 -30
  401. package/shaders/BlendShader.js +0 -30
  402. package/shaders/BokehShader.cjs +0 -109
  403. package/shaders/BokehShader.js +0 -109
  404. package/shaders/BokehShader2.cjs +0 -269
  405. package/shaders/BokehShader2.js +0 -269
  406. package/shaders/BrightnessContrastShader.cjs +0 -32
  407. package/shaders/BrightnessContrastShader.js +0 -32
  408. package/shaders/ColorCorrectionShader.cjs +0 -30
  409. package/shaders/ColorCorrectionShader.js +0 -30
  410. package/shaders/ColorifyShader.cjs +0 -28
  411. package/shaders/ColorifyShader.js +0 -28
  412. package/shaders/ConvolutionShader.cjs +0 -55
  413. package/shaders/ConvolutionShader.js +0 -55
  414. package/shaders/CopyShader.cjs +0 -25
  415. package/shaders/CopyShader.js +0 -25
  416. package/shaders/DOFMipMapShader.cjs +0 -32
  417. package/shaders/DOFMipMapShader.js +0 -32
  418. package/shaders/DepthLimitedBlurShader.cjs +0 -114
  419. package/shaders/DepthLimitedBlurShader.js +0 -114
  420. package/shaders/DigitalGlitch.cjs +0 -85
  421. package/shaders/DigitalGlitch.js +0 -85
  422. package/shaders/DotScreenShader.cjs +0 -39
  423. package/shaders/DotScreenShader.js +0 -39
  424. package/shaders/FXAAShader.cjs +0 -1098
  425. package/shaders/FXAAShader.js +0 -1098
  426. package/shaders/FilmShader.cjs +0 -53
  427. package/shaders/FilmShader.js +0 -53
  428. package/shaders/FocusShader.cjs +0 -55
  429. package/shaders/FocusShader.js +0 -55
  430. package/shaders/FreiChenShader.cjs +0 -64
  431. package/shaders/FreiChenShader.js +0 -64
  432. package/shaders/FresnelShader.cjs +0 -47
  433. package/shaders/FresnelShader.js +0 -47
  434. package/shaders/GammaCorrectionShader.cjs +0 -23
  435. package/shaders/GammaCorrectionShader.js +0 -23
  436. package/shaders/GodRaysShader.cjs +0 -183
  437. package/shaders/GodRaysShader.js +0 -183
  438. package/shaders/HalftoneShader.cjs +0 -228
  439. package/shaders/HalftoneShader.js +0 -228
  440. package/shaders/HorizontalBlurShader.cjs +0 -49
  441. package/shaders/HorizontalBlurShader.js +0 -49
  442. package/shaders/HorizontalTiltShiftShader.cjs +0 -37
  443. package/shaders/HorizontalTiltShiftShader.js +0 -37
  444. package/shaders/HueSaturationShader.cjs +0 -43
  445. package/shaders/HueSaturationShader.js +0 -43
  446. package/shaders/KaleidoShader.cjs +0 -34
  447. package/shaders/KaleidoShader.js +0 -34
  448. package/shaders/LuminosityHighPassShader.cjs +0 -37
  449. package/shaders/LuminosityHighPassShader.js +0 -37
  450. package/shaders/LuminosityShader.cjs +0 -25
  451. package/shaders/LuminosityShader.js +0 -25
  452. package/shaders/MirrorShader.cjs +0 -35
  453. package/shaders/MirrorShader.js +0 -35
  454. package/shaders/NormalMapShader.cjs +0 -31
  455. package/shaders/NormalMapShader.js +0 -31
  456. package/shaders/ParallaxShader.cjs +0 -133
  457. package/shaders/ParallaxShader.js +0 -133
  458. package/shaders/PixelShader.cjs +0 -28
  459. package/shaders/PixelShader.js +0 -28
  460. package/shaders/RGBShiftShader.cjs +0 -30
  461. package/shaders/RGBShiftShader.js +0 -30
  462. package/shaders/SAOShader.cjs +0 -144
  463. package/shaders/SAOShader.js +0 -144
  464. package/shaders/SMAAShader.cjs +0 -358
  465. package/shaders/SMAAShader.js +0 -358
  466. package/shaders/SSAOShader.cjs +0 -182
  467. package/shaders/SSAOShader.js +0 -182
  468. package/shaders/SSRShader.cjs +0 -342
  469. package/shaders/SSRShader.js +0 -342
  470. package/shaders/SepiaShader.cjs +0 -29
  471. package/shaders/SepiaShader.js +0 -29
  472. package/shaders/SobelOperatorShader.cjs +0 -54
  473. package/shaders/SobelOperatorShader.js +0 -54
  474. package/shaders/SubsurfaceScatteringShader.cjs +0 -98
  475. package/shaders/SubsurfaceScatteringShader.js +0 -98
  476. package/shaders/TechnicolorShader.cjs +0 -24
  477. package/shaders/TechnicolorShader.js +0 -24
  478. package/shaders/ToneMapShader.cjs +0 -51
  479. package/shaders/ToneMapShader.js +0 -51
  480. package/shaders/ToonShader.cjs +0 -188
  481. package/shaders/ToonShader.js +0 -188
  482. package/shaders/TriangleBlurShader.cjs +0 -37
  483. package/shaders/TriangleBlurShader.js +0 -37
  484. package/shaders/UnpackDepthRGBAShader.cjs +0 -26
  485. package/shaders/UnpackDepthRGBAShader.js +0 -26
  486. package/shaders/VerticalBlurShader.cjs +0 -50
  487. package/shaders/VerticalBlurShader.js +0 -50
  488. package/shaders/VerticalTiltShiftShader.cjs +0 -37
  489. package/shaders/VerticalTiltShiftShader.js +0 -37
  490. package/shaders/VignetteShader.cjs +0 -38
  491. package/shaders/VignetteShader.js +0 -38
  492. package/shaders/VolumeShader.cjs +0 -225
  493. package/shaders/VolumeShader.js +0 -225
  494. package/shaders/WaterRefractionShader.cjs +0 -59
  495. package/shaders/WaterRefractionShader.js +0 -59
  496. package/shaders/types.cjs +0 -1
  497. package/shaders/types.js +0 -1
  498. package/textures/FlakesTexture.cjs +0 -30
  499. package/textures/FlakesTexture.js +0 -30
  500. package/types/helpers.cjs +0 -4
  501. package/types/helpers.js +0 -4
  502. package/utils/BufferGeometryUtils.cjs +0 -636
  503. package/utils/BufferGeometryUtils.js +0 -636
  504. package/utils/GeometryCompressionUtils.cjs +0 -573
  505. package/utils/GeometryCompressionUtils.js +0 -573
  506. package/utils/GeometryUtils.cjs +0 -109
  507. package/utils/GeometryUtils.js +0 -109
  508. package/utils/RoughnessMipmapper.cjs +0 -223
  509. package/utils/RoughnessMipmapper.js +0 -223
  510. package/utils/SceneUtils.cjs +0 -36
  511. package/utils/SceneUtils.js +0 -36
  512. package/utils/ShadowMapViewer.cjs +0 -111
  513. package/utils/ShadowMapViewer.js +0 -111
  514. package/utils/SkeletonUtils.cjs +0 -211
  515. package/utils/SkeletonUtils.js +0 -211
  516. package/utils/UVsDebug.cjs +0 -80
  517. package/utils/UVsDebug.js +0 -80
  518. package/utils/WorkerPool.cjs +0 -62
  519. package/utils/WorkerPool.js +0 -62
  520. package/webxr/ARButton.cjs +0 -119
  521. package/webxr/ARButton.js +0 -119
  522. package/webxr/OculusHandModel.cjs +0 -82
  523. package/webxr/OculusHandModel.js +0 -82
  524. package/webxr/OculusHandPointerModel.cjs +0 -241
  525. package/webxr/OculusHandPointerModel.js +0 -224
  526. package/webxr/Text2D.cjs +0 -48
  527. package/webxr/Text2D.js +0 -31
  528. package/webxr/VRButton.cjs +0 -111
  529. package/webxr/VRButton.js +0 -111
  530. package/webxr/XRControllerModelFactory.cjs +0 -174
  531. package/webxr/XRControllerModelFactory.js +0 -174
  532. package/webxr/XREstimatedLight.cjs +0 -126
  533. package/webxr/XREstimatedLight.js +0 -126
  534. package/webxr/XRHandMeshModel.cjs +0 -82
  535. package/webxr/XRHandMeshModel.js +0 -82
  536. package/webxr/XRHandModelFactory.cjs +0 -61
  537. package/webxr/XRHandModelFactory.js +0 -61
  538. package/webxr/XRHandPrimitiveModel.cjs +0 -68
  539. package/webxr/XRHandPrimitiveModel.js +0 -68
@@ -1,325 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const THREE = require("three");
4
- class HTMLMesh extends THREE.Mesh {
5
- constructor(dom) {
6
- const texture = new HTMLTexture(dom);
7
- const geometry = new THREE.PlaneGeometry(texture.image.width * 1e-3, texture.image.height * 1e-3);
8
- const material = new THREE.MeshBasicMaterial({ map: texture, toneMapped: false, transparent: true });
9
- super(geometry, material);
10
- function onEvent(event) {
11
- material.map.dispatchDOMEvent(event);
12
- }
13
- this.addEventListener("mousedown", onEvent);
14
- this.addEventListener("mousemove", onEvent);
15
- this.addEventListener("mouseup", onEvent);
16
- this.addEventListener("click", onEvent);
17
- this.dispose = function() {
18
- geometry.dispose();
19
- material.dispose();
20
- material.map.dispose();
21
- canvases.delete(dom);
22
- this.removeEventListener("mousedown", onEvent);
23
- this.removeEventListener("mousemove", onEvent);
24
- this.removeEventListener("mouseup", onEvent);
25
- this.removeEventListener("click", onEvent);
26
- };
27
- }
28
- }
29
- class HTMLTexture extends THREE.CanvasTexture {
30
- constructor(dom) {
31
- super(html2canvas(dom));
32
- this.dom = dom;
33
- this.anisotropy = 16;
34
- if ("colorSpace" in this)
35
- this.colorSpace = "srgb";
36
- else
37
- this.encoding = 3001;
38
- this.minFilter = THREE.LinearFilter;
39
- this.magFilter = THREE.LinearFilter;
40
- const observer = new MutationObserver(() => {
41
- if (!this.scheduleUpdate) {
42
- this.scheduleUpdate = setTimeout(() => this.update(), 16);
43
- }
44
- });
45
- const config = { attributes: true, childList: true, subtree: true, characterData: true };
46
- observer.observe(dom, config);
47
- this.observer = observer;
48
- }
49
- dispatchDOMEvent(event) {
50
- if (event.data) {
51
- htmlevent(this.dom, event.type, event.data.x, event.data.y);
52
- }
53
- }
54
- update() {
55
- this.image = html2canvas(this.dom);
56
- this.needsUpdate = true;
57
- this.scheduleUpdate = null;
58
- }
59
- dispose() {
60
- if (this.observer) {
61
- this.observer.disconnect();
62
- }
63
- this.scheduleUpdate = clearTimeout(this.scheduleUpdate);
64
- super.dispose();
65
- }
66
- }
67
- const canvases = /* @__PURE__ */ new WeakMap();
68
- function html2canvas(element) {
69
- const range = document.createRange();
70
- const color = new THREE.Color();
71
- function Clipper(context2) {
72
- const clips = [];
73
- let isClipping = false;
74
- function doClip() {
75
- if (isClipping) {
76
- isClipping = false;
77
- context2.restore();
78
- }
79
- if (clips.length === 0)
80
- return;
81
- let minX = -Infinity, minY = -Infinity;
82
- let maxX = Infinity, maxY = Infinity;
83
- for (let i = 0; i < clips.length; i++) {
84
- const clip = clips[i];
85
- minX = Math.max(minX, clip.x);
86
- minY = Math.max(minY, clip.y);
87
- maxX = Math.min(maxX, clip.x + clip.width);
88
- maxY = Math.min(maxY, clip.y + clip.height);
89
- }
90
- context2.save();
91
- context2.beginPath();
92
- context2.rect(minX, minY, maxX - minX, maxY - minY);
93
- context2.clip();
94
- isClipping = true;
95
- }
96
- return {
97
- add: function(clip) {
98
- clips.push(clip);
99
- doClip();
100
- },
101
- remove: function() {
102
- clips.pop();
103
- doClip();
104
- }
105
- };
106
- }
107
- function drawText(style, x, y, string) {
108
- if (string !== "") {
109
- if (style.textTransform === "uppercase") {
110
- string = string.toUpperCase();
111
- }
112
- context.font = style.fontWeight + " " + style.fontSize + " " + style.fontFamily;
113
- context.textBaseline = "top";
114
- context.fillStyle = style.color;
115
- context.fillText(string, x, y + parseFloat(style.fontSize) * 0.1);
116
- }
117
- }
118
- function buildRectPath(x, y, w, h, r) {
119
- if (w < 2 * r)
120
- r = w / 2;
121
- if (h < 2 * r)
122
- r = h / 2;
123
- context.beginPath();
124
- context.moveTo(x + r, y);
125
- context.arcTo(x + w, y, x + w, y + h, r);
126
- context.arcTo(x + w, y + h, x, y + h, r);
127
- context.arcTo(x, y + h, x, y, r);
128
- context.arcTo(x, y, x + w, y, r);
129
- context.closePath();
130
- }
131
- function drawBorder(style, which, x, y, width, height) {
132
- const borderWidth = style[which + "Width"];
133
- const borderStyle = style[which + "Style"];
134
- const borderColor = style[which + "Color"];
135
- if (borderWidth !== "0px" && borderStyle !== "none" && borderColor !== "transparent" && borderColor !== "rgba(0, 0, 0, 0)") {
136
- context.strokeStyle = borderColor;
137
- context.lineWidth = parseFloat(borderWidth);
138
- context.beginPath();
139
- context.moveTo(x, y);
140
- context.lineTo(x + width, y + height);
141
- context.stroke();
142
- }
143
- }
144
- function drawElement(element2, style) {
145
- let x = 0, y = 0, width = 0, height = 0;
146
- if (element2.nodeType === Node.TEXT_NODE) {
147
- range.selectNode(element2);
148
- const rect = range.getBoundingClientRect();
149
- x = rect.left - offset.left - 0.5;
150
- y = rect.top - offset.top - 0.5;
151
- width = rect.width;
152
- height = rect.height;
153
- drawText(style, x, y, element2.nodeValue.trim());
154
- } else if (element2.nodeType === Node.COMMENT_NODE) {
155
- return;
156
- } else if (element2 instanceof HTMLCanvasElement) {
157
- if (element2.style.display === "none")
158
- return;
159
- context.save();
160
- const dpr = window.devicePixelRatio;
161
- context.scale(1 / dpr, 1 / dpr);
162
- context.drawImage(element2, 0, 0);
163
- context.restore();
164
- } else {
165
- if (element2.style.display === "none")
166
- return;
167
- const rect = element2.getBoundingClientRect();
168
- x = rect.left - offset.left - 0.5;
169
- y = rect.top - offset.top - 0.5;
170
- width = rect.width;
171
- height = rect.height;
172
- style = window.getComputedStyle(element2);
173
- buildRectPath(x, y, width, height, parseFloat(style.borderRadius));
174
- const backgroundColor = style.backgroundColor;
175
- if (backgroundColor !== "transparent" && backgroundColor !== "rgba(0, 0, 0, 0)") {
176
- context.fillStyle = backgroundColor;
177
- context.fill();
178
- }
179
- const borders = ["borderTop", "borderLeft", "borderBottom", "borderRight"];
180
- let match = true;
181
- let prevBorder = null;
182
- for (const border of borders) {
183
- if (prevBorder !== null) {
184
- match = style[border + "Width"] === style[prevBorder + "Width"] && style[border + "Color"] === style[prevBorder + "Color"] && style[border + "Style"] === style[prevBorder + "Style"];
185
- }
186
- if (match === false)
187
- break;
188
- prevBorder = border;
189
- }
190
- if (match === true) {
191
- const width2 = parseFloat(style.borderTopWidth);
192
- if (style.borderTopWidth !== "0px" && style.borderTopStyle !== "none" && style.borderTopColor !== "transparent" && style.borderTopColor !== "rgba(0, 0, 0, 0)") {
193
- context.strokeStyle = style.borderTopColor;
194
- context.lineWidth = width2;
195
- context.stroke();
196
- }
197
- } else {
198
- drawBorder(style, "borderTop", x, y, width, 0);
199
- drawBorder(style, "borderLeft", x, y, 0, height);
200
- drawBorder(style, "borderBottom", x, y + height, width, 0);
201
- drawBorder(style, "borderRight", x + width, y, 0, height);
202
- }
203
- if (element2 instanceof HTMLInputElement) {
204
- let accentColor = style.accentColor;
205
- if (accentColor === void 0 || accentColor === "auto")
206
- accentColor = style.color;
207
- color.set(accentColor);
208
- const luminance = Math.sqrt(0.299 * color.r ** 2 + 0.587 * color.g ** 2 + 0.114 * color.b ** 2);
209
- const accentTextColor = luminance < 0.5 ? "white" : "#111111";
210
- if (element2.type === "radio") {
211
- buildRectPath(x, y, width, height, height);
212
- context.fillStyle = "white";
213
- context.strokeStyle = accentColor;
214
- context.lineWidth = 1;
215
- context.fill();
216
- context.stroke();
217
- if (element2.checked) {
218
- buildRectPath(x + 2, y + 2, width - 4, height - 4, height);
219
- context.fillStyle = accentColor;
220
- context.strokeStyle = accentTextColor;
221
- context.lineWidth = 2;
222
- context.fill();
223
- context.stroke();
224
- }
225
- }
226
- if (element2.type === "checkbox") {
227
- buildRectPath(x, y, width, height, 2);
228
- context.fillStyle = element2.checked ? accentColor : "white";
229
- context.strokeStyle = element2.checked ? accentTextColor : accentColor;
230
- context.lineWidth = 1;
231
- context.stroke();
232
- context.fill();
233
- if (element2.checked) {
234
- const currentTextAlign = context.textAlign;
235
- context.textAlign = "center";
236
- const properties = {
237
- color: accentTextColor,
238
- fontFamily: style.fontFamily,
239
- fontSize: height + "px",
240
- fontWeight: "bold"
241
- };
242
- drawText(properties, x + width / 2, y, "✔");
243
- context.textAlign = currentTextAlign;
244
- }
245
- }
246
- if (element2.type === "range") {
247
- const [min, max, value] = ["min", "max", "value"].map((property) => parseFloat(element2[property]));
248
- const position = (value - min) / (max - min) * (width - height);
249
- buildRectPath(x, y + height / 4, width, height / 2, height / 4);
250
- context.fillStyle = accentTextColor;
251
- context.strokeStyle = accentColor;
252
- context.lineWidth = 1;
253
- context.fill();
254
- context.stroke();
255
- buildRectPath(x, y + height / 4, position + height / 2, height / 2, height / 4);
256
- context.fillStyle = accentColor;
257
- context.fill();
258
- buildRectPath(x + position, y, height, height, height / 2);
259
- context.fillStyle = accentColor;
260
- context.fill();
261
- }
262
- if (element2.type === "color" || element2.type === "text" || element2.type === "number") {
263
- clipper.add({ x, y, width, height });
264
- drawText(style, x + parseInt(style.paddingLeft), y + parseInt(style.paddingTop), element2.value);
265
- clipper.remove();
266
- }
267
- }
268
- }
269
- const isClipping = style.overflow === "auto" || style.overflow === "hidden";
270
- if (isClipping)
271
- clipper.add({ x, y, width, height });
272
- for (let i = 0; i < element2.childNodes.length; i++) {
273
- drawElement(element2.childNodes[i], style);
274
- }
275
- if (isClipping)
276
- clipper.remove();
277
- }
278
- const offset = element.getBoundingClientRect();
279
- let canvas = canvases.get(element);
280
- if (canvas === void 0) {
281
- canvas = document.createElement("canvas");
282
- canvas.width = offset.width;
283
- canvas.height = offset.height;
284
- canvases.set(element, canvas);
285
- }
286
- const context = canvas.getContext(
287
- "2d"
288
- /*, { alpha: false }*/
289
- );
290
- const clipper = new Clipper(context);
291
- drawElement(element);
292
- return canvas;
293
- }
294
- function htmlevent(element, event, x, y) {
295
- const mouseEventInit = {
296
- clientX: x * element.offsetWidth + element.offsetLeft,
297
- clientY: y * element.offsetHeight + element.offsetTop,
298
- view: element.ownerDocument.defaultView
299
- };
300
- window.dispatchEvent(new MouseEvent(event, mouseEventInit));
301
- const rect = element.getBoundingClientRect();
302
- x = x * rect.width + rect.left;
303
- y = y * rect.height + rect.top;
304
- function traverse(element2) {
305
- if (element2.nodeType !== Node.TEXT_NODE && element2.nodeType !== Node.COMMENT_NODE) {
306
- const rect2 = element2.getBoundingClientRect();
307
- if (x > rect2.left && x < rect2.right && y > rect2.top && y < rect2.bottom) {
308
- element2.dispatchEvent(new MouseEvent(event, mouseEventInit));
309
- if (element2 instanceof HTMLInputElement && element2.type === "range" && (event === "mousedown" || event === "click")) {
310
- const [min, max] = ["min", "max"].map((property) => parseFloat(element2[property]));
311
- const width = rect2.width;
312
- const offsetX = x - rect2.x;
313
- const proportion = offsetX / width;
314
- element2.value = min + (max - min) * proportion;
315
- element2.dispatchEvent(new InputEvent("input", { bubbles: true }));
316
- }
317
- }
318
- for (let i = 0; i < element2.childNodes.length; i++) {
319
- traverse(element2.childNodes[i]);
320
- }
321
- }
322
- }
323
- traverse(element);
324
- }
325
- exports.HTMLMesh = HTMLMesh;
@@ -1,325 +0,0 @@
1
- import { Mesh, PlaneGeometry, MeshBasicMaterial, CanvasTexture, LinearFilter, Color } from "three";
2
- class HTMLMesh extends Mesh {
3
- constructor(dom) {
4
- const texture = new HTMLTexture(dom);
5
- const geometry = new PlaneGeometry(texture.image.width * 1e-3, texture.image.height * 1e-3);
6
- const material = new MeshBasicMaterial({ map: texture, toneMapped: false, transparent: true });
7
- super(geometry, material);
8
- function onEvent(event) {
9
- material.map.dispatchDOMEvent(event);
10
- }
11
- this.addEventListener("mousedown", onEvent);
12
- this.addEventListener("mousemove", onEvent);
13
- this.addEventListener("mouseup", onEvent);
14
- this.addEventListener("click", onEvent);
15
- this.dispose = function() {
16
- geometry.dispose();
17
- material.dispose();
18
- material.map.dispose();
19
- canvases.delete(dom);
20
- this.removeEventListener("mousedown", onEvent);
21
- this.removeEventListener("mousemove", onEvent);
22
- this.removeEventListener("mouseup", onEvent);
23
- this.removeEventListener("click", onEvent);
24
- };
25
- }
26
- }
27
- class HTMLTexture extends CanvasTexture {
28
- constructor(dom) {
29
- super(html2canvas(dom));
30
- this.dom = dom;
31
- this.anisotropy = 16;
32
- if ("colorSpace" in this)
33
- this.colorSpace = "srgb";
34
- else
35
- this.encoding = 3001;
36
- this.minFilter = LinearFilter;
37
- this.magFilter = LinearFilter;
38
- const observer = new MutationObserver(() => {
39
- if (!this.scheduleUpdate) {
40
- this.scheduleUpdate = setTimeout(() => this.update(), 16);
41
- }
42
- });
43
- const config = { attributes: true, childList: true, subtree: true, characterData: true };
44
- observer.observe(dom, config);
45
- this.observer = observer;
46
- }
47
- dispatchDOMEvent(event) {
48
- if (event.data) {
49
- htmlevent(this.dom, event.type, event.data.x, event.data.y);
50
- }
51
- }
52
- update() {
53
- this.image = html2canvas(this.dom);
54
- this.needsUpdate = true;
55
- this.scheduleUpdate = null;
56
- }
57
- dispose() {
58
- if (this.observer) {
59
- this.observer.disconnect();
60
- }
61
- this.scheduleUpdate = clearTimeout(this.scheduleUpdate);
62
- super.dispose();
63
- }
64
- }
65
- const canvases = /* @__PURE__ */ new WeakMap();
66
- function html2canvas(element) {
67
- const range = document.createRange();
68
- const color = new Color();
69
- function Clipper(context2) {
70
- const clips = [];
71
- let isClipping = false;
72
- function doClip() {
73
- if (isClipping) {
74
- isClipping = false;
75
- context2.restore();
76
- }
77
- if (clips.length === 0)
78
- return;
79
- let minX = -Infinity, minY = -Infinity;
80
- let maxX = Infinity, maxY = Infinity;
81
- for (let i = 0; i < clips.length; i++) {
82
- const clip = clips[i];
83
- minX = Math.max(minX, clip.x);
84
- minY = Math.max(minY, clip.y);
85
- maxX = Math.min(maxX, clip.x + clip.width);
86
- maxY = Math.min(maxY, clip.y + clip.height);
87
- }
88
- context2.save();
89
- context2.beginPath();
90
- context2.rect(minX, minY, maxX - minX, maxY - minY);
91
- context2.clip();
92
- isClipping = true;
93
- }
94
- return {
95
- add: function(clip) {
96
- clips.push(clip);
97
- doClip();
98
- },
99
- remove: function() {
100
- clips.pop();
101
- doClip();
102
- }
103
- };
104
- }
105
- function drawText(style, x, y, string) {
106
- if (string !== "") {
107
- if (style.textTransform === "uppercase") {
108
- string = string.toUpperCase();
109
- }
110
- context.font = style.fontWeight + " " + style.fontSize + " " + style.fontFamily;
111
- context.textBaseline = "top";
112
- context.fillStyle = style.color;
113
- context.fillText(string, x, y + parseFloat(style.fontSize) * 0.1);
114
- }
115
- }
116
- function buildRectPath(x, y, w, h, r) {
117
- if (w < 2 * r)
118
- r = w / 2;
119
- if (h < 2 * r)
120
- r = h / 2;
121
- context.beginPath();
122
- context.moveTo(x + r, y);
123
- context.arcTo(x + w, y, x + w, y + h, r);
124
- context.arcTo(x + w, y + h, x, y + h, r);
125
- context.arcTo(x, y + h, x, y, r);
126
- context.arcTo(x, y, x + w, y, r);
127
- context.closePath();
128
- }
129
- function drawBorder(style, which, x, y, width, height) {
130
- const borderWidth = style[which + "Width"];
131
- const borderStyle = style[which + "Style"];
132
- const borderColor = style[which + "Color"];
133
- if (borderWidth !== "0px" && borderStyle !== "none" && borderColor !== "transparent" && borderColor !== "rgba(0, 0, 0, 0)") {
134
- context.strokeStyle = borderColor;
135
- context.lineWidth = parseFloat(borderWidth);
136
- context.beginPath();
137
- context.moveTo(x, y);
138
- context.lineTo(x + width, y + height);
139
- context.stroke();
140
- }
141
- }
142
- function drawElement(element2, style) {
143
- let x = 0, y = 0, width = 0, height = 0;
144
- if (element2.nodeType === Node.TEXT_NODE) {
145
- range.selectNode(element2);
146
- const rect = range.getBoundingClientRect();
147
- x = rect.left - offset.left - 0.5;
148
- y = rect.top - offset.top - 0.5;
149
- width = rect.width;
150
- height = rect.height;
151
- drawText(style, x, y, element2.nodeValue.trim());
152
- } else if (element2.nodeType === Node.COMMENT_NODE) {
153
- return;
154
- } else if (element2 instanceof HTMLCanvasElement) {
155
- if (element2.style.display === "none")
156
- return;
157
- context.save();
158
- const dpr = window.devicePixelRatio;
159
- context.scale(1 / dpr, 1 / dpr);
160
- context.drawImage(element2, 0, 0);
161
- context.restore();
162
- } else {
163
- if (element2.style.display === "none")
164
- return;
165
- const rect = element2.getBoundingClientRect();
166
- x = rect.left - offset.left - 0.5;
167
- y = rect.top - offset.top - 0.5;
168
- width = rect.width;
169
- height = rect.height;
170
- style = window.getComputedStyle(element2);
171
- buildRectPath(x, y, width, height, parseFloat(style.borderRadius));
172
- const backgroundColor = style.backgroundColor;
173
- if (backgroundColor !== "transparent" && backgroundColor !== "rgba(0, 0, 0, 0)") {
174
- context.fillStyle = backgroundColor;
175
- context.fill();
176
- }
177
- const borders = ["borderTop", "borderLeft", "borderBottom", "borderRight"];
178
- let match = true;
179
- let prevBorder = null;
180
- for (const border of borders) {
181
- if (prevBorder !== null) {
182
- match = style[border + "Width"] === style[prevBorder + "Width"] && style[border + "Color"] === style[prevBorder + "Color"] && style[border + "Style"] === style[prevBorder + "Style"];
183
- }
184
- if (match === false)
185
- break;
186
- prevBorder = border;
187
- }
188
- if (match === true) {
189
- const width2 = parseFloat(style.borderTopWidth);
190
- if (style.borderTopWidth !== "0px" && style.borderTopStyle !== "none" && style.borderTopColor !== "transparent" && style.borderTopColor !== "rgba(0, 0, 0, 0)") {
191
- context.strokeStyle = style.borderTopColor;
192
- context.lineWidth = width2;
193
- context.stroke();
194
- }
195
- } else {
196
- drawBorder(style, "borderTop", x, y, width, 0);
197
- drawBorder(style, "borderLeft", x, y, 0, height);
198
- drawBorder(style, "borderBottom", x, y + height, width, 0);
199
- drawBorder(style, "borderRight", x + width, y, 0, height);
200
- }
201
- if (element2 instanceof HTMLInputElement) {
202
- let accentColor = style.accentColor;
203
- if (accentColor === void 0 || accentColor === "auto")
204
- accentColor = style.color;
205
- color.set(accentColor);
206
- const luminance = Math.sqrt(0.299 * color.r ** 2 + 0.587 * color.g ** 2 + 0.114 * color.b ** 2);
207
- const accentTextColor = luminance < 0.5 ? "white" : "#111111";
208
- if (element2.type === "radio") {
209
- buildRectPath(x, y, width, height, height);
210
- context.fillStyle = "white";
211
- context.strokeStyle = accentColor;
212
- context.lineWidth = 1;
213
- context.fill();
214
- context.stroke();
215
- if (element2.checked) {
216
- buildRectPath(x + 2, y + 2, width - 4, height - 4, height);
217
- context.fillStyle = accentColor;
218
- context.strokeStyle = accentTextColor;
219
- context.lineWidth = 2;
220
- context.fill();
221
- context.stroke();
222
- }
223
- }
224
- if (element2.type === "checkbox") {
225
- buildRectPath(x, y, width, height, 2);
226
- context.fillStyle = element2.checked ? accentColor : "white";
227
- context.strokeStyle = element2.checked ? accentTextColor : accentColor;
228
- context.lineWidth = 1;
229
- context.stroke();
230
- context.fill();
231
- if (element2.checked) {
232
- const currentTextAlign = context.textAlign;
233
- context.textAlign = "center";
234
- const properties = {
235
- color: accentTextColor,
236
- fontFamily: style.fontFamily,
237
- fontSize: height + "px",
238
- fontWeight: "bold"
239
- };
240
- drawText(properties, x + width / 2, y, "✔");
241
- context.textAlign = currentTextAlign;
242
- }
243
- }
244
- if (element2.type === "range") {
245
- const [min, max, value] = ["min", "max", "value"].map((property) => parseFloat(element2[property]));
246
- const position = (value - min) / (max - min) * (width - height);
247
- buildRectPath(x, y + height / 4, width, height / 2, height / 4);
248
- context.fillStyle = accentTextColor;
249
- context.strokeStyle = accentColor;
250
- context.lineWidth = 1;
251
- context.fill();
252
- context.stroke();
253
- buildRectPath(x, y + height / 4, position + height / 2, height / 2, height / 4);
254
- context.fillStyle = accentColor;
255
- context.fill();
256
- buildRectPath(x + position, y, height, height, height / 2);
257
- context.fillStyle = accentColor;
258
- context.fill();
259
- }
260
- if (element2.type === "color" || element2.type === "text" || element2.type === "number") {
261
- clipper.add({ x, y, width, height });
262
- drawText(style, x + parseInt(style.paddingLeft), y + parseInt(style.paddingTop), element2.value);
263
- clipper.remove();
264
- }
265
- }
266
- }
267
- const isClipping = style.overflow === "auto" || style.overflow === "hidden";
268
- if (isClipping)
269
- clipper.add({ x, y, width, height });
270
- for (let i = 0; i < element2.childNodes.length; i++) {
271
- drawElement(element2.childNodes[i], style);
272
- }
273
- if (isClipping)
274
- clipper.remove();
275
- }
276
- const offset = element.getBoundingClientRect();
277
- let canvas = canvases.get(element);
278
- if (canvas === void 0) {
279
- canvas = document.createElement("canvas");
280
- canvas.width = offset.width;
281
- canvas.height = offset.height;
282
- canvases.set(element, canvas);
283
- }
284
- const context = canvas.getContext(
285
- "2d"
286
- /*, { alpha: false }*/
287
- );
288
- const clipper = new Clipper(context);
289
- drawElement(element);
290
- return canvas;
291
- }
292
- function htmlevent(element, event, x, y) {
293
- const mouseEventInit = {
294
- clientX: x * element.offsetWidth + element.offsetLeft,
295
- clientY: y * element.offsetHeight + element.offsetTop,
296
- view: element.ownerDocument.defaultView
297
- };
298
- window.dispatchEvent(new MouseEvent(event, mouseEventInit));
299
- const rect = element.getBoundingClientRect();
300
- x = x * rect.width + rect.left;
301
- y = y * rect.height + rect.top;
302
- function traverse(element2) {
303
- if (element2.nodeType !== Node.TEXT_NODE && element2.nodeType !== Node.COMMENT_NODE) {
304
- const rect2 = element2.getBoundingClientRect();
305
- if (x > rect2.left && x < rect2.right && y > rect2.top && y < rect2.bottom) {
306
- element2.dispatchEvent(new MouseEvent(event, mouseEventInit));
307
- if (element2 instanceof HTMLInputElement && element2.type === "range" && (event === "mousedown" || event === "click")) {
308
- const [min, max] = ["min", "max"].map((property) => parseFloat(element2[property]));
309
- const width = rect2.width;
310
- const offsetX = x - rect2.x;
311
- const proportion = offsetX / width;
312
- element2.value = min + (max - min) * proportion;
313
- element2.dispatchEvent(new InputEvent("input", { bubbles: true }));
314
- }
315
- }
316
- for (let i = 0; i < element2.childNodes.length; i++) {
317
- traverse(element2.childNodes[i]);
318
- }
319
- }
320
- }
321
- traverse(element);
322
- }
323
- export {
324
- HTMLMesh
325
- };