@anov/3d 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (570) hide show
  1. package/README.md +142 -1
  2. package/dist/core/camera.d.ts +31 -4
  3. package/dist/core/camera.js +62 -52
  4. package/dist/core/control/transformControls.d.ts +12 -0
  5. package/dist/core/control/transformControls.js +72 -0
  6. package/dist/core/cssRenderer.d.ts +17 -0
  7. package/dist/core/cssRenderer.js +36 -0
  8. package/dist/core/global/global.d.ts +27 -0
  9. package/dist/core/global/global.js +72 -0
  10. package/dist/core/global/globalControl.d.ts +17 -0
  11. package/dist/core/global/globalControl.js +62 -0
  12. package/dist/core/group.d.ts +51 -6
  13. package/dist/core/group.js +124 -16
  14. package/dist/core/line.d.ts +13 -0
  15. package/dist/core/line.js +83 -0
  16. package/dist/core/mesh.d.ts +12 -7
  17. package/dist/core/mesh.js +57 -56
  18. package/dist/core/model.d.ts +11 -3
  19. package/dist/core/model.js +34 -7
  20. package/dist/core/scene.d.ts +84 -25
  21. package/dist/core/scene.js +207 -53
  22. package/dist/core/use/useScene.d.ts +10 -0
  23. package/dist/core/use/useScene.js +14 -0
  24. package/dist/core/use/useframe.d.ts +6 -0
  25. package/dist/core/use/useframe.js +11 -0
  26. package/dist/export.d.ts +41 -0
  27. package/dist/export.js +37 -0
  28. package/dist/index.d.ts +3 -6
  29. package/dist/index.js +5 -6
  30. package/dist/threeCell.d.ts +8 -0
  31. package/dist/threeCell.js +16 -0
  32. package/dist/type.d.ts +4 -3
  33. package/dist/utils/createElement.d.ts +103 -0
  34. package/dist/utils/createElement.js +145 -0
  35. package/dist/utils/createLabel.d.ts +2 -0
  36. package/dist/utils/createLabel.js +4 -0
  37. package/dist/utils/index.d.ts +36 -0
  38. package/dist/utils/index.js +76 -0
  39. package/dist/utils/line.d.ts +0 -0
  40. package/dist/utils/line.js +0 -0
  41. package/dist/utils/move.d.ts +48 -0
  42. package/dist/utils/move.js +149 -0
  43. package/examples/fonts/LICENSE +13 -0
  44. package/examples/fonts/README.md +11 -0
  45. package/examples/fonts/droid/NOTICE +190 -0
  46. package/examples/fonts/droid/README.txt +18 -0
  47. package/examples/fonts/droid/droid_sans_bold.typeface.json +1 -0
  48. package/examples/fonts/droid/droid_sans_mono_regular.typeface.json +1 -0
  49. package/examples/fonts/droid/droid_sans_regular.typeface.json +1 -0
  50. package/examples/fonts/droid/droid_serif_bold.typeface.json +1 -0
  51. package/examples/fonts/droid/droid_serif_regular.typeface.json +1 -0
  52. package/examples/fonts/gentilis_bold.typeface.json +1 -0
  53. package/examples/fonts/gentilis_regular.typeface.json +1 -0
  54. package/examples/fonts/helvetiker_bold.typeface.json +1 -0
  55. package/examples/fonts/helvetiker_regular.typeface.json +1 -0
  56. package/examples/fonts/optimer_bold.typeface.json +1 -0
  57. package/examples/fonts/optimer_regular.typeface.json +1 -0
  58. package/examples/fonts/ttf/README.md +9 -0
  59. package/examples/fonts/ttf/kenpixel.ttf +0 -0
  60. package/examples/jsm/animation/AnimationClipCreator.js +116 -0
  61. package/examples/jsm/animation/CCDIKSolver.js +482 -0
  62. package/examples/jsm/animation/MMDAnimationHelper.js +1207 -0
  63. package/examples/jsm/animation/MMDPhysics.js +1406 -0
  64. package/examples/jsm/cameras/CinematicCamera.js +208 -0
  65. package/examples/jsm/capabilities/WebGL.js +91 -0
  66. package/examples/jsm/capabilities/WebGPU.js +53 -0
  67. package/examples/jsm/controls/ArcballControls.js +3224 -0
  68. package/examples/jsm/controls/DragControls.js +220 -0
  69. package/examples/jsm/controls/FirstPersonControls.js +325 -0
  70. package/examples/jsm/controls/FlyControls.js +300 -0
  71. package/examples/jsm/controls/MapControls.js +28 -0
  72. package/examples/jsm/controls/OrbitControls.js +1388 -0
  73. package/examples/jsm/controls/PointerLockControls.js +162 -0
  74. package/examples/jsm/controls/TrackballControls.js +828 -0
  75. package/examples/jsm/controls/TransformControls.js +1557 -0
  76. package/examples/jsm/csm/CSM.js +384 -0
  77. package/examples/jsm/csm/CSMFrustum.js +152 -0
  78. package/examples/jsm/csm/CSMHelper.js +193 -0
  79. package/examples/jsm/csm/CSMShader.js +252 -0
  80. package/examples/jsm/curves/CurveExtras.js +422 -0
  81. package/examples/jsm/curves/NURBSCurve.js +80 -0
  82. package/examples/jsm/curves/NURBSSurface.js +52 -0
  83. package/examples/jsm/curves/NURBSUtils.js +487 -0
  84. package/examples/jsm/effects/AnaglyphEffect.js +154 -0
  85. package/examples/jsm/effects/AsciiEffect.js +263 -0
  86. package/examples/jsm/effects/OutlineEffect.js +539 -0
  87. package/examples/jsm/effects/ParallaxBarrierEffect.js +119 -0
  88. package/examples/jsm/effects/PeppersGhostEffect.js +153 -0
  89. package/examples/jsm/effects/StereoEffect.js +55 -0
  90. package/examples/jsm/environments/DebugEnvironment.js +52 -0
  91. package/examples/jsm/environments/RoomEnvironment.js +148 -0
  92. package/examples/jsm/exporters/DRACOExporter.js +267 -0
  93. package/examples/jsm/exporters/EXRExporter.js +501 -0
  94. package/examples/jsm/exporters/GLTFExporter.js +3161 -0
  95. package/examples/jsm/exporters/KTX2Exporter.js +292 -0
  96. package/examples/jsm/exporters/MMDExporter.js +217 -0
  97. package/examples/jsm/exporters/OBJExporter.js +284 -0
  98. package/examples/jsm/exporters/PLYExporter.js +528 -0
  99. package/examples/jsm/exporters/STLExporter.js +199 -0
  100. package/examples/jsm/exporters/USDZExporter.js +711 -0
  101. package/examples/jsm/geometries/BoxLineGeometry.js +69 -0
  102. package/examples/jsm/geometries/ConvexGeometry.js +53 -0
  103. package/examples/jsm/geometries/DecalGeometry.js +356 -0
  104. package/examples/jsm/geometries/ParametricGeometries.js +254 -0
  105. package/examples/jsm/geometries/ParametricGeometry.js +139 -0
  106. package/examples/jsm/geometries/RoundedBoxGeometry.js +155 -0
  107. package/examples/jsm/geometries/TeapotGeometry.js +704 -0
  108. package/examples/jsm/geometries/TextGeometry.js +57 -0
  109. package/examples/jsm/helpers/LightProbeHelper.js +130 -0
  110. package/examples/jsm/helpers/OctreeHelper.js +73 -0
  111. package/examples/jsm/helpers/PositionalAudioHelper.js +109 -0
  112. package/examples/jsm/helpers/RectAreaLightHelper.js +85 -0
  113. package/examples/jsm/helpers/VertexNormalsHelper.js +96 -0
  114. package/examples/jsm/helpers/VertexTangentsHelper.js +88 -0
  115. package/examples/jsm/helpers/ViewHelper.js +333 -0
  116. package/examples/jsm/interactive/HTMLMesh.js +565 -0
  117. package/examples/jsm/interactive/InteractiveGroup.js +116 -0
  118. package/examples/jsm/interactive/SelectionBox.js +227 -0
  119. package/examples/jsm/interactive/SelectionHelper.js +104 -0
  120. package/examples/jsm/libs/ammo.wasm.js +822 -0
  121. package/examples/jsm/libs/ammo.wasm.wasm +0 -0
  122. package/examples/jsm/libs/basis/README.md +46 -0
  123. package/examples/jsm/libs/basis/basis_transcoder.js +21 -0
  124. package/examples/jsm/libs/basis/basis_transcoder.wasm +0 -0
  125. package/examples/jsm/libs/chevrotain.module.min.js +141 -0
  126. package/examples/jsm/libs/draco/README.md +32 -0
  127. package/examples/jsm/libs/draco/draco_decoder.js +34 -0
  128. package/examples/jsm/libs/draco/draco_decoder.wasm +0 -0
  129. package/examples/jsm/libs/draco/draco_encoder.js +33 -0
  130. package/examples/jsm/libs/draco/draco_wasm_wrapper.js +117 -0
  131. package/examples/jsm/libs/draco/gltf/draco_decoder.js +33 -0
  132. package/examples/jsm/libs/draco/gltf/draco_decoder.wasm +0 -0
  133. package/examples/jsm/libs/draco/gltf/draco_encoder.js +33 -0
  134. package/examples/jsm/libs/draco/gltf/draco_wasm_wrapper.js +116 -0
  135. package/examples/jsm/libs/ecsy.module.js +1792 -0
  136. package/examples/jsm/libs/fflate.module.js +2474 -0
  137. package/examples/jsm/libs/ktx-parse.module.js +1 -0
  138. package/examples/jsm/libs/lil-gui.module.min.js +8 -0
  139. package/examples/jsm/libs/lottie_canvas.module.js +14844 -0
  140. package/examples/jsm/libs/meshopt_decoder.module.js +178 -0
  141. package/examples/jsm/libs/mikktspace.module.js +128 -0
  142. package/examples/jsm/libs/mmdparser.module.js +11530 -0
  143. package/examples/jsm/libs/motion-controllers.module.js +397 -0
  144. package/examples/jsm/libs/opentype.module.js +14568 -0
  145. package/examples/jsm/libs/potpack.module.js +125 -0
  146. package/examples/jsm/libs/rhino3dm/rhino3dm.js +21 -0
  147. package/examples/jsm/libs/rhino3dm/rhino3dm.module.js +16 -0
  148. package/examples/jsm/libs/rhino3dm/rhino3dm.wasm +0 -0
  149. package/examples/jsm/libs/stats.module.js +167 -0
  150. package/examples/jsm/libs/tween.module.js +803 -0
  151. package/examples/jsm/libs/utif.module.js +1579 -0
  152. package/examples/jsm/libs/zstddec.module.js +1 -0
  153. package/examples/jsm/lights/IESSpotLight.js +25 -0
  154. package/examples/jsm/lights/LightProbeGenerator.js +252 -0
  155. package/examples/jsm/lights/RectAreaLightUniformsLib.js +79 -0
  156. package/examples/jsm/lines/Line2.js +19 -0
  157. package/examples/jsm/lines/LineGeometry.js +79 -0
  158. package/examples/jsm/lines/LineMaterial.js +702 -0
  159. package/examples/jsm/lines/LineSegments2.js +361 -0
  160. package/examples/jsm/lines/LineSegmentsGeometry.js +241 -0
  161. package/examples/jsm/lines/Wireframe.js +56 -0
  162. package/examples/jsm/lines/WireframeGeometry2.js +24 -0
  163. package/examples/jsm/loaders/3DMLoader.js +1497 -0
  164. package/examples/jsm/loaders/3MFLoader.js +1478 -0
  165. package/examples/jsm/loaders/AMFLoader.js +521 -0
  166. package/examples/jsm/loaders/BVHLoader.js +437 -0
  167. package/examples/jsm/loaders/ColladaLoader.js +4122 -0
  168. package/examples/jsm/loaders/DDSLoader.js +274 -0
  169. package/examples/jsm/loaders/DRACOLoader.js +612 -0
  170. package/examples/jsm/loaders/EXRLoader.js +2309 -0
  171. package/examples/jsm/loaders/FBXLoader.js +4142 -0
  172. package/examples/jsm/loaders/FontLoader.js +183 -0
  173. package/examples/jsm/loaders/GCodeLoader.js +261 -0
  174. package/examples/jsm/loaders/GLTFLoader.js +4576 -0
  175. package/examples/jsm/loaders/HDRCubeTextureLoader.js +115 -0
  176. package/examples/jsm/loaders/IESLoader.js +337 -0
  177. package/examples/jsm/loaders/KMZLoader.js +130 -0
  178. package/examples/jsm/loaders/KTX2Loader.js +868 -0
  179. package/examples/jsm/loaders/KTXLoader.js +176 -0
  180. package/examples/jsm/loaders/LDrawLoader.js +2464 -0
  181. package/examples/jsm/loaders/LUT3dlLoader.js +151 -0
  182. package/examples/jsm/loaders/LUTCubeLoader.js +153 -0
  183. package/examples/jsm/loaders/LWOLoader.js +1052 -0
  184. package/examples/jsm/loaders/LogLuvLoader.js +606 -0
  185. package/examples/jsm/loaders/LottieLoader.js +77 -0
  186. package/examples/jsm/loaders/MD2Loader.js +399 -0
  187. package/examples/jsm/loaders/MDDLoader.js +102 -0
  188. package/examples/jsm/loaders/MMDLoader.js +2273 -0
  189. package/examples/jsm/loaders/MTLLoader.js +567 -0
  190. package/examples/jsm/loaders/MaterialXLoader.js +734 -0
  191. package/examples/jsm/loaders/NRRDLoader.js +699 -0
  192. package/examples/jsm/loaders/OBJLoader.js +905 -0
  193. package/examples/jsm/loaders/PCDLoader.js +467 -0
  194. package/examples/jsm/loaders/PDBLoader.js +232 -0
  195. package/examples/jsm/loaders/PLYLoader.js +771 -0
  196. package/examples/jsm/loaders/PVRLoader.js +251 -0
  197. package/examples/jsm/loaders/RGBELoader.js +468 -0
  198. package/examples/jsm/loaders/RGBMLoader.js +1065 -0
  199. package/examples/jsm/loaders/STLLoader.js +403 -0
  200. package/examples/jsm/loaders/SVGLoader.js +3172 -0
  201. package/examples/jsm/loaders/TDSLoader.js +1124 -0
  202. package/examples/jsm/loaders/TGALoader.js +517 -0
  203. package/examples/jsm/loaders/TIFFLoader.js +36 -0
  204. package/examples/jsm/loaders/TTFLoader.js +214 -0
  205. package/examples/jsm/loaders/TiltLoader.js +520 -0
  206. package/examples/jsm/loaders/USDZLoader.js +633 -0
  207. package/examples/jsm/loaders/VOXLoader.js +311 -0
  208. package/examples/jsm/loaders/VRMLLoader.js +3533 -0
  209. package/examples/jsm/loaders/VTKLoader.js +1163 -0
  210. package/examples/jsm/loaders/XYZLoader.js +106 -0
  211. package/examples/jsm/loaders/lwo/IFFParser.js +1218 -0
  212. package/examples/jsm/loaders/lwo/LWO2Parser.js +414 -0
  213. package/examples/jsm/loaders/lwo/LWO3Parser.js +373 -0
  214. package/examples/jsm/materials/MeshGouraudMaterial.js +420 -0
  215. package/examples/jsm/math/Capsule.js +137 -0
  216. package/examples/jsm/math/ColorConverter.js +36 -0
  217. package/examples/jsm/math/ConvexHull.js +1271 -0
  218. package/examples/jsm/math/ImprovedNoise.js +71 -0
  219. package/examples/jsm/math/Lut.js +204 -0
  220. package/examples/jsm/math/MeshSurfaceSampler.js +250 -0
  221. package/examples/jsm/math/OBB.js +423 -0
  222. package/examples/jsm/math/Octree.js +462 -0
  223. package/examples/jsm/math/SimplexNoise.js +444 -0
  224. package/examples/jsm/misc/ConvexObjectBreaker.js +519 -0
  225. package/examples/jsm/misc/GPUComputationRenderer.js +446 -0
  226. package/examples/jsm/misc/Gyroscope.js +66 -0
  227. package/examples/jsm/misc/MD2Character.js +276 -0
  228. package/examples/jsm/misc/MD2CharacterComplex.js +576 -0
  229. package/examples/jsm/misc/MorphAnimMesh.js +75 -0
  230. package/examples/jsm/misc/MorphBlendMesh.js +322 -0
  231. package/examples/jsm/misc/ProgressiveLightMap.js +323 -0
  232. package/examples/jsm/misc/RollerCoaster.js +566 -0
  233. package/examples/jsm/misc/TubePainter.js +205 -0
  234. package/examples/jsm/misc/Volume.js +473 -0
  235. package/examples/jsm/misc/VolumeSlice.js +229 -0
  236. package/examples/jsm/modifiers/CurveModifier.js +326 -0
  237. package/examples/jsm/modifiers/EdgeSplitModifier.js +279 -0
  238. package/examples/jsm/modifiers/SimplifyModifier.js +525 -0
  239. package/examples/jsm/modifiers/TessellateModifier.js +307 -0
  240. package/examples/jsm/nodes/Nodes.js +171 -0
  241. package/examples/jsm/nodes/accessors/BitangentNode.js +89 -0
  242. package/examples/jsm/nodes/accessors/BufferAttributeNode.js +99 -0
  243. package/examples/jsm/nodes/accessors/BufferNode.js +30 -0
  244. package/examples/jsm/nodes/accessors/CameraNode.js +98 -0
  245. package/examples/jsm/nodes/accessors/CubeTextureNode.js +103 -0
  246. package/examples/jsm/nodes/accessors/ExtendedMaterialNode.js +77 -0
  247. package/examples/jsm/nodes/accessors/InstanceNode.js +71 -0
  248. package/examples/jsm/nodes/accessors/MaterialNode.js +267 -0
  249. package/examples/jsm/nodes/accessors/MaterialReferenceNode.js +39 -0
  250. package/examples/jsm/nodes/accessors/ModelNode.js +34 -0
  251. package/examples/jsm/nodes/accessors/ModelViewProjectionNode.js +29 -0
  252. package/examples/jsm/nodes/accessors/MorphNode.js +70 -0
  253. package/examples/jsm/nodes/accessors/NormalNode.js +96 -0
  254. package/examples/jsm/nodes/accessors/Object3DNode.js +150 -0
  255. package/examples/jsm/nodes/accessors/PointUVNode.js +26 -0
  256. package/examples/jsm/nodes/accessors/PositionNode.js +104 -0
  257. package/examples/jsm/nodes/accessors/ReferenceNode.js +72 -0
  258. package/examples/jsm/nodes/accessors/ReflectVectorNode.js +35 -0
  259. package/examples/jsm/nodes/accessors/SceneNode.js +52 -0
  260. package/examples/jsm/nodes/accessors/SkinningNode.js +93 -0
  261. package/examples/jsm/nodes/accessors/StorageBufferNode.js +27 -0
  262. package/examples/jsm/nodes/accessors/TangentNode.js +103 -0
  263. package/examples/jsm/nodes/accessors/TextureBicubicNode.js +94 -0
  264. package/examples/jsm/nodes/accessors/TextureNode.js +271 -0
  265. package/examples/jsm/nodes/accessors/TextureSizeNode.js +35 -0
  266. package/examples/jsm/nodes/accessors/UVNode.js +47 -0
  267. package/examples/jsm/nodes/accessors/UserDataNode.js +29 -0
  268. package/examples/jsm/nodes/code/CodeNode.js +78 -0
  269. package/examples/jsm/nodes/code/ExpressionNode.js +37 -0
  270. package/examples/jsm/nodes/code/FunctionCallNode.js +96 -0
  271. package/examples/jsm/nodes/code/FunctionNode.js +127 -0
  272. package/examples/jsm/nodes/code/ScriptableNode.js +488 -0
  273. package/examples/jsm/nodes/code/ScriptableValueNode.js +167 -0
  274. package/examples/jsm/nodes/core/ArrayUniformNode.js +26 -0
  275. package/examples/jsm/nodes/core/AttributeNode.js +102 -0
  276. package/examples/jsm/nodes/core/BypassNode.js +45 -0
  277. package/examples/jsm/nodes/core/CacheNode.js +46 -0
  278. package/examples/jsm/nodes/core/ConstNode.js +32 -0
  279. package/examples/jsm/nodes/core/ContextNode.js +61 -0
  280. package/examples/jsm/nodes/core/IndexNode.js +66 -0
  281. package/examples/jsm/nodes/core/InputNode.js +83 -0
  282. package/examples/jsm/nodes/core/LightingModel.js +15 -0
  283. package/examples/jsm/nodes/core/Node.js +454 -0
  284. package/examples/jsm/nodes/core/NodeAttribute.js +15 -0
  285. package/examples/jsm/nodes/core/NodeBuilder.js +1016 -0
  286. package/examples/jsm/nodes/core/NodeCache.js +26 -0
  287. package/examples/jsm/nodes/core/NodeCode.js +15 -0
  288. package/examples/jsm/nodes/core/NodeFrame.js +110 -0
  289. package/examples/jsm/nodes/core/NodeFunction.js +22 -0
  290. package/examples/jsm/nodes/core/NodeFunctionInput.js +17 -0
  291. package/examples/jsm/nodes/core/NodeKeywords.js +80 -0
  292. package/examples/jsm/nodes/core/NodeParser.js +11 -0
  293. package/examples/jsm/nodes/core/NodeUniform.js +28 -0
  294. package/examples/jsm/nodes/core/NodeUtils.js +212 -0
  295. package/examples/jsm/nodes/core/NodeVar.js +14 -0
  296. package/examples/jsm/nodes/core/NodeVarying.js +17 -0
  297. package/examples/jsm/nodes/core/PropertyNode.js +61 -0
  298. package/examples/jsm/nodes/core/StackNode.js +99 -0
  299. package/examples/jsm/nodes/core/TempNode.js +58 -0
  300. package/examples/jsm/nodes/core/UniformNode.js +61 -0
  301. package/examples/jsm/nodes/core/VarNode.js +87 -0
  302. package/examples/jsm/nodes/core/VaryingNode.js +69 -0
  303. package/examples/jsm/nodes/core/constants.js +27 -0
  304. package/examples/jsm/nodes/display/BlendModeNode.js +99 -0
  305. package/examples/jsm/nodes/display/BumpMapNode.js +77 -0
  306. package/examples/jsm/nodes/display/ColorAdjustmentNode.js +100 -0
  307. package/examples/jsm/nodes/display/ColorSpaceNode.js +108 -0
  308. package/examples/jsm/nodes/display/FrontFacingNode.js +27 -0
  309. package/examples/jsm/nodes/display/NormalMapNode.js +106 -0
  310. package/examples/jsm/nodes/display/PosterizeNode.js +32 -0
  311. package/examples/jsm/nodes/display/ToneMappingNode.js +141 -0
  312. package/examples/jsm/nodes/display/ViewportDepthNode.js +69 -0
  313. package/examples/jsm/nodes/display/ViewportDepthTextureNode.js +34 -0
  314. package/examples/jsm/nodes/display/ViewportNode.js +115 -0
  315. package/examples/jsm/nodes/display/ViewportSharedTextureNode.js +31 -0
  316. package/examples/jsm/nodes/display/ViewportTextureNode.js +75 -0
  317. package/examples/jsm/nodes/fog/FogExp2Node.js +35 -0
  318. package/examples/jsm/nodes/fog/FogNode.js +37 -0
  319. package/examples/jsm/nodes/fog/FogRangeNode.js +34 -0
  320. package/examples/jsm/nodes/functions/BSDF/BRDF_GGX.js +40 -0
  321. package/examples/jsm/nodes/functions/BSDF/BRDF_Lambert.js +9 -0
  322. package/examples/jsm/nodes/functions/BSDF/BRDF_Sheen.js +43 -0
  323. package/examples/jsm/nodes/functions/BSDF/DFGApprox.js +29 -0
  324. package/examples/jsm/nodes/functions/BSDF/D_GGX.js +18 -0
  325. package/examples/jsm/nodes/functions/BSDF/EnvironmentBRDF.js +13 -0
  326. package/examples/jsm/nodes/functions/BSDF/F_Schlick.js +16 -0
  327. package/examples/jsm/nodes/functions/BSDF/Schlick_to_F0.js +13 -0
  328. package/examples/jsm/nodes/functions/BSDF/V_GGX_SmithCorrelated.js +20 -0
  329. package/examples/jsm/nodes/functions/PhongLightingModel.js +67 -0
  330. package/examples/jsm/nodes/functions/PhysicalLightingModel.js +343 -0
  331. package/examples/jsm/nodes/functions/material/getGeometryRoughness.js +13 -0
  332. package/examples/jsm/nodes/functions/material/getRoughness.js +18 -0
  333. package/examples/jsm/nodes/geometry/RangeNode.js +104 -0
  334. package/examples/jsm/nodes/gpgpu/ComputeNode.js +85 -0
  335. package/examples/jsm/nodes/lighting/AONode.js +27 -0
  336. package/examples/jsm/nodes/lighting/AmbientLightNode.js +27 -0
  337. package/examples/jsm/nodes/lighting/AnalyticLightNode.js +184 -0
  338. package/examples/jsm/nodes/lighting/DirectionalLightNode.js +40 -0
  339. package/examples/jsm/nodes/lighting/EnvironmentNode.js +191 -0
  340. package/examples/jsm/nodes/lighting/HemisphereLightNode.js +55 -0
  341. package/examples/jsm/nodes/lighting/IESSpotLightNode.js +39 -0
  342. package/examples/jsm/nodes/lighting/LightNode.js +57 -0
  343. package/examples/jsm/nodes/lighting/LightUtils.js +17 -0
  344. package/examples/jsm/nodes/lighting/LightingContextNode.js +102 -0
  345. package/examples/jsm/nodes/lighting/LightingNode.js +21 -0
  346. package/examples/jsm/nodes/lighting/LightsNode.js +128 -0
  347. package/examples/jsm/nodes/lighting/PointLightNode.js +68 -0
  348. package/examples/jsm/nodes/lighting/SpotLightNode.js +89 -0
  349. package/examples/jsm/nodes/loaders/NodeLoader.js +108 -0
  350. package/examples/jsm/nodes/loaders/NodeMaterialLoader.js +59 -0
  351. package/examples/jsm/nodes/loaders/NodeObjectLoader.js +70 -0
  352. package/examples/jsm/nodes/materials/LineBasicNodeMaterial.js +28 -0
  353. package/examples/jsm/nodes/materials/Materials.js +12 -0
  354. package/examples/jsm/nodes/materials/MeshBasicNodeMaterial.js +27 -0
  355. package/examples/jsm/nodes/materials/MeshLambertNodeMaterial.js +34 -0
  356. package/examples/jsm/nodes/materials/MeshNormalNodeMaterial.js +40 -0
  357. package/examples/jsm/nodes/materials/MeshPhongNodeMaterial.js +65 -0
  358. package/examples/jsm/nodes/materials/MeshPhysicalNodeMaterial.js +128 -0
  359. package/examples/jsm/nodes/materials/MeshStandardNodeMaterial.js +80 -0
  360. package/examples/jsm/nodes/materials/NodeMaterial.js +536 -0
  361. package/examples/jsm/nodes/materials/PointsNodeMaterial.js +49 -0
  362. package/examples/jsm/nodes/materials/SpriteNodeMaterial.js +103 -0
  363. package/examples/jsm/nodes/materialx/DISCLAIMER.md +199 -0
  364. package/examples/jsm/nodes/materialx/MaterialXNodes.js +68 -0
  365. package/examples/jsm/nodes/materialx/lib/mx_hsv.js +56 -0
  366. package/examples/jsm/nodes/materialx/lib/mx_noise.js +618 -0
  367. package/examples/jsm/nodes/materialx/lib/mx_transform_color.js +19 -0
  368. package/examples/jsm/nodes/math/CondNode.js +86 -0
  369. package/examples/jsm/nodes/math/MathNode.js +359 -0
  370. package/examples/jsm/nodes/math/OperatorNode.js +269 -0
  371. package/examples/jsm/nodes/parsers/GLSLNodeFunction.js +152 -0
  372. package/examples/jsm/nodes/parsers/GLSLNodeParser.js +14 -0
  373. package/examples/jsm/nodes/procedural/CheckerNode.js +42 -0
  374. package/examples/jsm/nodes/shadernode/ShaderNode.js +420 -0
  375. package/examples/jsm/nodes/utils/ArrayElementNode.js +33 -0
  376. package/examples/jsm/nodes/utils/ConvertNode.js +65 -0
  377. package/examples/jsm/nodes/utils/DiscardNode.js +26 -0
  378. package/examples/jsm/nodes/utils/EquirectUVNode.js +33 -0
  379. package/examples/jsm/nodes/utils/JoinNode.js +51 -0
  380. package/examples/jsm/nodes/utils/LoopNode.js +186 -0
  381. package/examples/jsm/nodes/utils/MatcapUVNode.js +30 -0
  382. package/examples/jsm/nodes/utils/MaxMipLevelNode.js +46 -0
  383. package/examples/jsm/nodes/utils/OscNode.js +81 -0
  384. package/examples/jsm/nodes/utils/PackingNode.js +55 -0
  385. package/examples/jsm/nodes/utils/RemapNode.js +42 -0
  386. package/examples/jsm/nodes/utils/RotateUVNode.js +43 -0
  387. package/examples/jsm/nodes/utils/SpecularMIPLevelNode.js +37 -0
  388. package/examples/jsm/nodes/utils/SplitNode.js +104 -0
  389. package/examples/jsm/nodes/utils/SpriteSheetUVNode.js +41 -0
  390. package/examples/jsm/nodes/utils/TimerNode.js +94 -0
  391. package/examples/jsm/nodes/utils/TriplanarTexturesNode.js +62 -0
  392. package/examples/jsm/objects/GroundProjectedSkybox.js +172 -0
  393. package/examples/jsm/objects/Lensflare.js +377 -0
  394. package/examples/jsm/objects/MarchingCubes.js +1176 -0
  395. package/examples/jsm/objects/Reflector.js +264 -0
  396. package/examples/jsm/objects/ReflectorForSSRPass.js +349 -0
  397. package/examples/jsm/objects/Refractor.js +324 -0
  398. package/examples/jsm/objects/ShadowMesh.js +80 -0
  399. package/examples/jsm/objects/Sky.js +219 -0
  400. package/examples/jsm/objects/Water.js +330 -0
  401. package/examples/jsm/objects/Water2.js +358 -0
  402. package/examples/jsm/offscreen/jank.js +45 -0
  403. package/examples/jsm/offscreen/offscreen.js +8 -0
  404. package/examples/jsm/offscreen/scene.js +86 -0
  405. package/examples/jsm/physics/AmmoPhysics.js +285 -0
  406. package/examples/jsm/physics/RapierPhysics.js +199 -0
  407. package/examples/jsm/postprocessing/AfterimagePass.js +104 -0
  408. package/examples/jsm/postprocessing/BloomPass.js +172 -0
  409. package/examples/jsm/postprocessing/BokehPass.js +140 -0
  410. package/examples/jsm/postprocessing/ClearPass.js +46 -0
  411. package/examples/jsm/postprocessing/CubeTexturePass.js +85 -0
  412. package/examples/jsm/postprocessing/DotScreenPass.js +65 -0
  413. package/examples/jsm/postprocessing/EffectComposer.js +231 -0
  414. package/examples/jsm/postprocessing/FilmPass.js +66 -0
  415. package/examples/jsm/postprocessing/GlitchPass.js +128 -0
  416. package/examples/jsm/postprocessing/HalftonePass.js +79 -0
  417. package/examples/jsm/postprocessing/LUTPass.js +173 -0
  418. package/examples/jsm/postprocessing/MaskPass.js +104 -0
  419. package/examples/jsm/postprocessing/OutlinePass.js +654 -0
  420. package/examples/jsm/postprocessing/OutputPass.js +91 -0
  421. package/examples/jsm/postprocessing/Pass.js +84 -0
  422. package/examples/jsm/postprocessing/RenderPass.js +81 -0
  423. package/examples/jsm/postprocessing/RenderPixelatedPass.js +235 -0
  424. package/examples/jsm/postprocessing/SAOPass.js +411 -0
  425. package/examples/jsm/postprocessing/SMAAPass.js +201 -0
  426. package/examples/jsm/postprocessing/SSAARenderPass.js +228 -0
  427. package/examples/jsm/postprocessing/SSAOPass.js +440 -0
  428. package/examples/jsm/postprocessing/SSRPass.js +641 -0
  429. package/examples/jsm/postprocessing/SavePass.js +79 -0
  430. package/examples/jsm/postprocessing/ShaderPass.js +77 -0
  431. package/examples/jsm/postprocessing/TAARenderPass.js +189 -0
  432. package/examples/jsm/postprocessing/TexturePass.js +67 -0
  433. package/examples/jsm/postprocessing/UnrealBloomPass.js +415 -0
  434. package/examples/jsm/renderers/CSS2DRenderer.js +215 -0
  435. package/examples/jsm/renderers/CSS3DRenderer.js +335 -0
  436. package/examples/jsm/renderers/Projector.js +918 -0
  437. package/examples/jsm/renderers/SVGRenderer.js +553 -0
  438. package/examples/jsm/renderers/common/Animation.js +58 -0
  439. package/examples/jsm/renderers/common/Attributes.js +75 -0
  440. package/examples/jsm/renderers/common/Backend.js +162 -0
  441. package/examples/jsm/renderers/common/Background.js +136 -0
  442. package/examples/jsm/renderers/common/Binding.js +19 -0
  443. package/examples/jsm/renderers/common/Bindings.js +165 -0
  444. package/examples/jsm/renderers/common/Buffer.js +38 -0
  445. package/examples/jsm/renderers/common/BufferUtils.js +33 -0
  446. package/examples/jsm/renderers/common/ChainMap.js +89 -0
  447. package/examples/jsm/renderers/common/ComputePipeline.js +17 -0
  448. package/examples/jsm/renderers/common/Constants.js +14 -0
  449. package/examples/jsm/renderers/common/CubeRenderTarget.js +65 -0
  450. package/examples/jsm/renderers/common/DataMap.js +54 -0
  451. package/examples/jsm/renderers/common/Geometries.js +215 -0
  452. package/examples/jsm/renderers/common/Info.js +73 -0
  453. package/examples/jsm/renderers/common/Pipeline.js +13 -0
  454. package/examples/jsm/renderers/common/Pipelines.js +370 -0
  455. package/examples/jsm/renderers/common/ProgrammableStage.js +18 -0
  456. package/examples/jsm/renderers/common/RenderContext.js +38 -0
  457. package/examples/jsm/renderers/common/RenderContexts.js +49 -0
  458. package/examples/jsm/renderers/common/RenderList.js +178 -0
  459. package/examples/jsm/renderers/common/RenderLists.js +38 -0
  460. package/examples/jsm/renderers/common/RenderObject.js +129 -0
  461. package/examples/jsm/renderers/common/RenderObjects.js +95 -0
  462. package/examples/jsm/renderers/common/RenderPipeline.js +16 -0
  463. package/examples/jsm/renderers/common/Renderer.js +895 -0
  464. package/examples/jsm/renderers/common/SampledTexture.js +80 -0
  465. package/examples/jsm/renderers/common/Sampler.js +18 -0
  466. package/examples/jsm/renderers/common/StorageBuffer.js +17 -0
  467. package/examples/jsm/renderers/common/Textures.js +218 -0
  468. package/examples/jsm/renderers/common/Uniform.js +140 -0
  469. package/examples/jsm/renderers/common/UniformBuffer.js +15 -0
  470. package/examples/jsm/renderers/common/UniformsGroup.js +299 -0
  471. package/examples/jsm/renderers/common/nodes/NodeSampledTexture.js +39 -0
  472. package/examples/jsm/renderers/common/nodes/NodeSampler.js +21 -0
  473. package/examples/jsm/renderers/common/nodes/NodeUniform.js +135 -0
  474. package/examples/jsm/renderers/common/nodes/Nodes.js +330 -0
  475. package/examples/jsm/renderers/webgl/nodes/GLSLNodeBuilder.js +340 -0
  476. package/examples/jsm/renderers/webgl/nodes/SlotNode.js +26 -0
  477. package/examples/jsm/renderers/webgl/nodes/WebGLNodeBuilder.js +764 -0
  478. package/examples/jsm/renderers/webgl/nodes/WebGLNodes.js +49 -0
  479. package/examples/jsm/renderers/webgpu/WebGPUBackend.js +844 -0
  480. package/examples/jsm/renderers/webgpu/WebGPURenderer.js +32 -0
  481. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeBuilder.js +902 -0
  482. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeFunction.js +104 -0
  483. package/examples/jsm/renderers/webgpu/nodes/WGSLNodeParser.js +14 -0
  484. package/examples/jsm/renderers/webgpu/utils/WebGPUAttributeUtils.js +274 -0
  485. package/examples/jsm/renderers/webgpu/utils/WebGPUBindingUtils.js +223 -0
  486. package/examples/jsm/renderers/webgpu/utils/WebGPUConstants.js +324 -0
  487. package/examples/jsm/renderers/webgpu/utils/WebGPUPipelineUtils.js +533 -0
  488. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureMipmapUtils.js +163 -0
  489. package/examples/jsm/renderers/webgpu/utils/WebGPUTextureUtils.js +964 -0
  490. package/examples/jsm/renderers/webgpu/utils/WebGPUUtils.js +92 -0
  491. package/examples/jsm/shaders/ACESFilmicToneMappingShader.js +87 -0
  492. package/examples/jsm/shaders/AfterimageShader.js +56 -0
  493. package/examples/jsm/shaders/BasicShader.js +27 -0
  494. package/examples/jsm/shaders/BleachBypassShader.js +62 -0
  495. package/examples/jsm/shaders/BlendShader.js +47 -0
  496. package/examples/jsm/shaders/BokehShader.js +143 -0
  497. package/examples/jsm/shaders/BokehShader2.js +393 -0
  498. package/examples/jsm/shaders/BrightnessContrastShader.js +54 -0
  499. package/examples/jsm/shaders/ColorCorrectionShader.js +50 -0
  500. package/examples/jsm/shaders/ColorifyShader.js +51 -0
  501. package/examples/jsm/shaders/ConvolutionShader.js +103 -0
  502. package/examples/jsm/shaders/CopyShader.js +45 -0
  503. package/examples/jsm/shaders/DOFMipMapShader.js +54 -0
  504. package/examples/jsm/shaders/DepthLimitedBlurShader.js +166 -0
  505. package/examples/jsm/shaders/DigitalGlitch.js +101 -0
  506. package/examples/jsm/shaders/DotScreenShader.js +70 -0
  507. package/examples/jsm/shaders/ExposureShader.js +44 -0
  508. package/examples/jsm/shaders/FXAAShader.js +286 -0
  509. package/examples/jsm/shaders/FilmShader.js +102 -0
  510. package/examples/jsm/shaders/FocusShader.js +87 -0
  511. package/examples/jsm/shaders/FreiChenShader.js +94 -0
  512. package/examples/jsm/shaders/GammaCorrectionShader.js +43 -0
  513. package/examples/jsm/shaders/GodRaysShader.js +313 -0
  514. package/examples/jsm/shaders/HalftoneShader.js +310 -0
  515. package/examples/jsm/shaders/HorizontalBlurShader.js +59 -0
  516. package/examples/jsm/shaders/HorizontalTiltShiftShader.js +61 -0
  517. package/examples/jsm/shaders/HueSaturationShader.js +65 -0
  518. package/examples/jsm/shaders/KaleidoShader.js +56 -0
  519. package/examples/jsm/shaders/LuminosityHighPassShader.js +64 -0
  520. package/examples/jsm/shaders/LuminosityShader.js +46 -0
  521. package/examples/jsm/shaders/MMDToonShader.js +132 -0
  522. package/examples/jsm/shaders/MirrorShader.js +54 -0
  523. package/examples/jsm/shaders/NormalMapShader.js +53 -0
  524. package/examples/jsm/shaders/OutputShader.js +78 -0
  525. package/examples/jsm/shaders/RGBShiftShader.js +54 -0
  526. package/examples/jsm/shaders/SAOShader.js +188 -0
  527. package/examples/jsm/shaders/SMAAShader.js +460 -0
  528. package/examples/jsm/shaders/SSAOShader.js +288 -0
  529. package/examples/jsm/shaders/SSRShader.js +364 -0
  530. package/examples/jsm/shaders/SepiaShader.js +52 -0
  531. package/examples/jsm/shaders/SobelOperatorShader.js +90 -0
  532. package/examples/jsm/shaders/SubsurfaceScatteringShader.js +88 -0
  533. package/examples/jsm/shaders/TechnicolorShader.js +43 -0
  534. package/examples/jsm/shaders/ToonShader.js +326 -0
  535. package/examples/jsm/shaders/TriangleBlurShader.js +72 -0
  536. package/examples/jsm/shaders/UnpackDepthRGBAShader.js +45 -0
  537. package/examples/jsm/shaders/VelocityShader.js +128 -0
  538. package/examples/jsm/shaders/VerticalBlurShader.js +59 -0
  539. package/examples/jsm/shaders/VerticalTiltShiftShader.js +61 -0
  540. package/examples/jsm/shaders/VignetteShader.js +51 -0
  541. package/examples/jsm/shaders/VolumeShader.js +289 -0
  542. package/examples/jsm/shaders/WaterRefractionShader.js +93 -0
  543. package/examples/jsm/textures/FlakesTexture.js +40 -0
  544. package/examples/jsm/utils/BufferGeometryUtils.js +1373 -0
  545. package/examples/jsm/utils/CameraUtils.js +73 -0
  546. package/examples/jsm/utils/GPUStatsPanel.js +128 -0
  547. package/examples/jsm/utils/GeometryCompressionUtils.js +639 -0
  548. package/examples/jsm/utils/GeometryUtils.js +221 -0
  549. package/examples/jsm/utils/LDrawUtils.js +202 -0
  550. package/examples/jsm/utils/PackedPhongMaterial.js +178 -0
  551. package/examples/jsm/utils/SceneUtils.js +254 -0
  552. package/examples/jsm/utils/ShadowMapViewer.js +210 -0
  553. package/examples/jsm/utils/SkeletonUtils.js +413 -0
  554. package/examples/jsm/utils/TextureUtils.js +86 -0
  555. package/examples/jsm/utils/UVsDebug.js +165 -0
  556. package/examples/jsm/utils/WorkerPool.js +102 -0
  557. package/examples/jsm/webxr/ARButton.js +208 -0
  558. package/examples/jsm/webxr/OculusHandModel.js +109 -0
  559. package/examples/jsm/webxr/OculusHandPointerModel.js +413 -0
  560. package/examples/jsm/webxr/Text2D.js +38 -0
  561. package/examples/jsm/webxr/VRButton.js +200 -0
  562. package/examples/jsm/webxr/XRButton.js +198 -0
  563. package/examples/jsm/webxr/XRControllerModelFactory.js +299 -0
  564. package/examples/jsm/webxr/XREstimatedLight.js +223 -0
  565. package/examples/jsm/webxr/XRHandMeshModel.js +112 -0
  566. package/examples/jsm/webxr/XRHandModelFactory.js +105 -0
  567. package/examples/jsm/webxr/XRHandPrimitiveModel.js +103 -0
  568. package/examples/jsm/webxr/XRPlanes.js +100 -0
  569. package/lib/3d.min.js +1 -0
  570. package/package.json +25 -12
@@ -0,0 +1,205 @@
1
+ import {
2
+ BufferAttribute,
3
+ BufferGeometry,
4
+ Color,
5
+ DynamicDrawUsage,
6
+ Matrix4,
7
+ Mesh,
8
+ MeshStandardMaterial,
9
+ Vector3
10
+ } from 'three';
11
+
12
+ function TubePainter() {
13
+
14
+ const BUFFER_SIZE = 1000000 * 3;
15
+
16
+ const positions = new BufferAttribute( new Float32Array( BUFFER_SIZE ), 3 );
17
+ positions.usage = DynamicDrawUsage;
18
+
19
+ const normals = new BufferAttribute( new Float32Array( BUFFER_SIZE ), 3 );
20
+ normals.usage = DynamicDrawUsage;
21
+
22
+ const colors = new BufferAttribute( new Float32Array( BUFFER_SIZE ), 3 );
23
+ colors.usage = DynamicDrawUsage;
24
+
25
+ const geometry = new BufferGeometry();
26
+ geometry.setAttribute( 'position', positions );
27
+ geometry.setAttribute( 'normal', normals );
28
+ geometry.setAttribute( 'color', colors );
29
+ geometry.drawRange.count = 0;
30
+
31
+ const material = new MeshStandardMaterial( {
32
+ vertexColors: true
33
+ } );
34
+
35
+ const mesh = new Mesh( geometry, material );
36
+ mesh.frustumCulled = false;
37
+
38
+ //
39
+
40
+ function getPoints( size ) {
41
+
42
+ const PI2 = Math.PI * 2;
43
+
44
+ const sides = 10;
45
+ const array = [];
46
+ const radius = 0.01 * size;
47
+
48
+ for ( let i = 0; i < sides; i ++ ) {
49
+
50
+ const angle = ( i / sides ) * PI2;
51
+ array.push( new Vector3( Math.sin( angle ) * radius, Math.cos( angle ) * radius, 0 ) );
52
+
53
+ }
54
+
55
+ return array;
56
+
57
+ }
58
+
59
+ //
60
+
61
+ const vector1 = new Vector3();
62
+ const vector2 = new Vector3();
63
+ const vector3 = new Vector3();
64
+ const vector4 = new Vector3();
65
+
66
+ const color = new Color( 0xffffff );
67
+ let size = 1;
68
+
69
+ function stroke( position1, position2, matrix1, matrix2 ) {
70
+
71
+ if ( position1.distanceToSquared( position2 ) === 0 ) return;
72
+
73
+ let count = geometry.drawRange.count;
74
+
75
+ const points = getPoints( size );
76
+
77
+ for ( let i = 0, il = points.length; i < il; i ++ ) {
78
+
79
+ const vertex1 = points[ i ];
80
+ const vertex2 = points[ ( i + 1 ) % il ];
81
+
82
+ // positions
83
+
84
+ vector1.copy( vertex1 ).applyMatrix4( matrix2 ).add( position2 );
85
+ vector2.copy( vertex2 ).applyMatrix4( matrix2 ).add( position2 );
86
+ vector3.copy( vertex2 ).applyMatrix4( matrix1 ).add( position1 );
87
+ vector4.copy( vertex1 ).applyMatrix4( matrix1 ).add( position1 );
88
+
89
+ vector1.toArray( positions.array, ( count + 0 ) * 3 );
90
+ vector2.toArray( positions.array, ( count + 1 ) * 3 );
91
+ vector4.toArray( positions.array, ( count + 2 ) * 3 );
92
+
93
+ vector2.toArray( positions.array, ( count + 3 ) * 3 );
94
+ vector3.toArray( positions.array, ( count + 4 ) * 3 );
95
+ vector4.toArray( positions.array, ( count + 5 ) * 3 );
96
+
97
+ // normals
98
+
99
+ vector1.copy( vertex1 ).applyMatrix4( matrix2 ).normalize();
100
+ vector2.copy( vertex2 ).applyMatrix4( matrix2 ).normalize();
101
+ vector3.copy( vertex2 ).applyMatrix4( matrix1 ).normalize();
102
+ vector4.copy( vertex1 ).applyMatrix4( matrix1 ).normalize();
103
+
104
+ vector1.toArray( normals.array, ( count + 0 ) * 3 );
105
+ vector2.toArray( normals.array, ( count + 1 ) * 3 );
106
+ vector4.toArray( normals.array, ( count + 2 ) * 3 );
107
+
108
+ vector2.toArray( normals.array, ( count + 3 ) * 3 );
109
+ vector3.toArray( normals.array, ( count + 4 ) * 3 );
110
+ vector4.toArray( normals.array, ( count + 5 ) * 3 );
111
+
112
+ // colors
113
+
114
+ color.toArray( colors.array, ( count + 0 ) * 3 );
115
+ color.toArray( colors.array, ( count + 1 ) * 3 );
116
+ color.toArray( colors.array, ( count + 2 ) * 3 );
117
+
118
+ color.toArray( colors.array, ( count + 3 ) * 3 );
119
+ color.toArray( colors.array, ( count + 4 ) * 3 );
120
+ color.toArray( colors.array, ( count + 5 ) * 3 );
121
+
122
+ count += 6;
123
+
124
+ }
125
+
126
+ geometry.drawRange.count = count;
127
+
128
+ }
129
+
130
+ //
131
+
132
+ const up = new Vector3( 0, 1, 0 );
133
+
134
+ const point1 = new Vector3();
135
+ const point2 = new Vector3();
136
+
137
+ const matrix1 = new Matrix4();
138
+ const matrix2 = new Matrix4();
139
+
140
+ function moveTo( position ) {
141
+
142
+ point1.copy( position );
143
+ matrix1.lookAt( point2, point1, up );
144
+
145
+ point2.copy( position );
146
+ matrix2.copy( matrix1 );
147
+
148
+ }
149
+
150
+ function lineTo( position ) {
151
+
152
+ point1.copy( position );
153
+ matrix1.lookAt( point2, point1, up );
154
+
155
+ stroke( point1, point2, matrix1, matrix2 );
156
+
157
+ point2.copy( point1 );
158
+ matrix2.copy( matrix1 );
159
+
160
+ }
161
+
162
+ function setSize( value ) {
163
+
164
+ size = value;
165
+
166
+ }
167
+
168
+ //
169
+
170
+ let count = 0;
171
+
172
+ function update() {
173
+
174
+ const start = count;
175
+ const end = geometry.drawRange.count;
176
+
177
+ if ( start === end ) return;
178
+
179
+ positions.updateRange.offset = start * 3;
180
+ positions.updateRange.count = ( end - start ) * 3;
181
+ positions.needsUpdate = true;
182
+
183
+ normals.updateRange.offset = start * 3;
184
+ normals.updateRange.count = ( end - start ) * 3;
185
+ normals.needsUpdate = true;
186
+
187
+ colors.updateRange.offset = start * 3;
188
+ colors.updateRange.count = ( end - start ) * 3;
189
+ colors.needsUpdate = true;
190
+
191
+ count = geometry.drawRange.count;
192
+
193
+ }
194
+
195
+ return {
196
+ mesh: mesh,
197
+ moveTo: moveTo,
198
+ lineTo: lineTo,
199
+ setSize: setSize,
200
+ update: update
201
+ };
202
+
203
+ }
204
+
205
+ export { TubePainter };
@@ -0,0 +1,473 @@
1
+ import {
2
+ Matrix3,
3
+ Matrix4,
4
+ Vector3
5
+ } from 'three';
6
+ import { VolumeSlice } from '../misc/VolumeSlice.js';
7
+
8
+ /**
9
+ * This class had been written to handle the output of the NRRD loader.
10
+ * It contains a volume of data and informations about it.
11
+ * For now it only handles 3 dimensional data.
12
+ * See the webgl_loader_nrrd.html example and the loaderNRRD.js file to see how to use this class.
13
+ * @class
14
+ * @param {number} xLength Width of the volume
15
+ * @param {number} yLength Length of the volume
16
+ * @param {number} zLength Depth of the volume
17
+ * @param {string} type The type of data (uint8, uint16, ...)
18
+ * @param {ArrayBuffer} arrayBuffer The buffer with volume data
19
+ */
20
+ class Volume {
21
+
22
+ constructor( xLength, yLength, zLength, type, arrayBuffer ) {
23
+
24
+ if ( xLength !== undefined ) {
25
+
26
+ /**
27
+ * @member {number} xLength Width of the volume in the IJK coordinate system
28
+ */
29
+ this.xLength = Number( xLength ) || 1;
30
+ /**
31
+ * @member {number} yLength Height of the volume in the IJK coordinate system
32
+ */
33
+ this.yLength = Number( yLength ) || 1;
34
+ /**
35
+ * @member {number} zLength Depth of the volume in the IJK coordinate system
36
+ */
37
+ this.zLength = Number( zLength ) || 1;
38
+ /**
39
+ * @member {Array<string>} The order of the Axis dictated by the NRRD header
40
+ */
41
+ this.axisOrder = [ 'x', 'y', 'z' ];
42
+ /**
43
+ * @member {TypedArray} data Data of the volume
44
+ */
45
+
46
+ switch ( type ) {
47
+
48
+ case 'Uint8' :
49
+ case 'uint8' :
50
+ case 'uchar' :
51
+ case 'unsigned char' :
52
+ case 'uint8_t' :
53
+ this.data = new Uint8Array( arrayBuffer );
54
+ break;
55
+ case 'Int8' :
56
+ case 'int8' :
57
+ case 'signed char' :
58
+ case 'int8_t' :
59
+ this.data = new Int8Array( arrayBuffer );
60
+ break;
61
+ case 'Int16' :
62
+ case 'int16' :
63
+ case 'short' :
64
+ case 'short int' :
65
+ case 'signed short' :
66
+ case 'signed short int' :
67
+ case 'int16_t' :
68
+ this.data = new Int16Array( arrayBuffer );
69
+ break;
70
+ case 'Uint16' :
71
+ case 'uint16' :
72
+ case 'ushort' :
73
+ case 'unsigned short' :
74
+ case 'unsigned short int' :
75
+ case 'uint16_t' :
76
+ this.data = new Uint16Array( arrayBuffer );
77
+ break;
78
+ case 'Int32' :
79
+ case 'int32' :
80
+ case 'int' :
81
+ case 'signed int' :
82
+ case 'int32_t' :
83
+ this.data = new Int32Array( arrayBuffer );
84
+ break;
85
+ case 'Uint32' :
86
+ case 'uint32' :
87
+ case 'uint' :
88
+ case 'unsigned int' :
89
+ case 'uint32_t' :
90
+ this.data = new Uint32Array( arrayBuffer );
91
+ break;
92
+ case 'longlong' :
93
+ case 'long long' :
94
+ case 'long long int' :
95
+ case 'signed long long' :
96
+ case 'signed long long int' :
97
+ case 'int64' :
98
+ case 'int64_t' :
99
+ case 'ulonglong' :
100
+ case 'unsigned long long' :
101
+ case 'unsigned long long int' :
102
+ case 'uint64' :
103
+ case 'uint64_t' :
104
+ throw new Error( 'Error in Volume constructor : this type is not supported in JavaScript' );
105
+ break;
106
+ case 'Float32' :
107
+ case 'float32' :
108
+ case 'float' :
109
+ this.data = new Float32Array( arrayBuffer );
110
+ break;
111
+ case 'Float64' :
112
+ case 'float64' :
113
+ case 'double' :
114
+ this.data = new Float64Array( arrayBuffer );
115
+ break;
116
+ default :
117
+ this.data = new Uint8Array( arrayBuffer );
118
+
119
+ }
120
+
121
+ if ( this.data.length !== this.xLength * this.yLength * this.zLength ) {
122
+
123
+ throw new Error( 'Error in Volume constructor, lengths are not matching arrayBuffer size' );
124
+
125
+ }
126
+
127
+ }
128
+
129
+ /**
130
+ * @member {Array} spacing Spacing to apply to the volume from IJK to RAS coordinate system
131
+ */
132
+ this.spacing = [ 1, 1, 1 ];
133
+ /**
134
+ * @member {Array} offset Offset of the volume in the RAS coordinate system
135
+ */
136
+ this.offset = [ 0, 0, 0 ];
137
+ /**
138
+ * @member {Martrix3} matrix The IJK to RAS matrix
139
+ */
140
+ this.matrix = new Matrix3();
141
+ this.matrix.identity();
142
+ /**
143
+ * @member {Martrix3} inverseMatrix The RAS to IJK matrix
144
+ */
145
+ /**
146
+ * @member {number} lowerThreshold The voxels with values under this threshold won't appear in the slices.
147
+ * If changed, geometryNeedsUpdate is automatically set to true on all the slices associated to this volume
148
+ */
149
+ let lowerThreshold = - Infinity;
150
+ Object.defineProperty( this, 'lowerThreshold', {
151
+ get: function () {
152
+
153
+ return lowerThreshold;
154
+
155
+ },
156
+ set: function ( value ) {
157
+
158
+ lowerThreshold = value;
159
+ this.sliceList.forEach( function ( slice ) {
160
+
161
+ slice.geometryNeedsUpdate = true;
162
+
163
+ } );
164
+
165
+ }
166
+ } );
167
+ /**
168
+ * @member {number} upperThreshold The voxels with values over this threshold won't appear in the slices.
169
+ * If changed, geometryNeedsUpdate is automatically set to true on all the slices associated to this volume
170
+ */
171
+ let upperThreshold = Infinity;
172
+ Object.defineProperty( this, 'upperThreshold', {
173
+ get: function () {
174
+
175
+ return upperThreshold;
176
+
177
+ },
178
+ set: function ( value ) {
179
+
180
+ upperThreshold = value;
181
+ this.sliceList.forEach( function ( slice ) {
182
+
183
+ slice.geometryNeedsUpdate = true;
184
+
185
+ } );
186
+
187
+ }
188
+ } );
189
+
190
+
191
+ /**
192
+ * @member {Array} sliceList The list of all the slices associated to this volume
193
+ */
194
+ this.sliceList = [];
195
+
196
+
197
+ /**
198
+ * @member {boolean} segmentation in segmentation mode, it can load 16-bits nrrds correctly
199
+ */
200
+ this.segmentation = false;
201
+
202
+
203
+ /**
204
+ * @member {Array} RASDimensions This array holds the dimensions of the volume in the RAS space
205
+ */
206
+
207
+
208
+
209
+ }
210
+
211
+ /**
212
+ * @member {Function} getData Shortcut for data[access(i,j,k)]
213
+ * @memberof Volume
214
+ * @param {number} i First coordinate
215
+ * @param {number} j Second coordinate
216
+ * @param {number} k Third coordinate
217
+ * @returns {number} value in the data array
218
+ */
219
+ getData( i, j, k ) {
220
+
221
+ return this.data[ k * this.xLength * this.yLength + j * this.xLength + i ];
222
+
223
+ }
224
+
225
+ /**
226
+ * @member {Function} access compute the index in the data array corresponding to the given coordinates in IJK system
227
+ * @memberof Volume
228
+ * @param {number} i First coordinate
229
+ * @param {number} j Second coordinate
230
+ * @param {number} k Third coordinate
231
+ * @returns {number} index
232
+ */
233
+ access( i, j, k ) {
234
+
235
+ return k * this.xLength * this.yLength + j * this.xLength + i;
236
+
237
+ }
238
+
239
+ /**
240
+ * @member {Function} reverseAccess Retrieve the IJK coordinates of the voxel corresponding of the given index in the data
241
+ * @memberof Volume
242
+ * @param {number} index index of the voxel
243
+ * @returns {Array} [x,y,z]
244
+ */
245
+ reverseAccess( index ) {
246
+
247
+ const z = Math.floor( index / ( this.yLength * this.xLength ) );
248
+ const y = Math.floor( ( index - z * this.yLength * this.xLength ) / this.xLength );
249
+ const x = index - z * this.yLength * this.xLength - y * this.xLength;
250
+ return [ x, y, z ];
251
+
252
+ }
253
+
254
+ /**
255
+ * @member {Function} map Apply a function to all the voxels, be careful, the value will be replaced
256
+ * @memberof Volume
257
+ * @param {Function} functionToMap A function to apply to every voxel, will be called with the following parameters :
258
+ * value of the voxel
259
+ * index of the voxel
260
+ * the data (TypedArray)
261
+ * @param {Object} context You can specify a context in which call the function, default if this Volume
262
+ * @returns {Volume} this
263
+ */
264
+ map( functionToMap, context ) {
265
+
266
+ const length = this.data.length;
267
+ context = context || this;
268
+
269
+ for ( let i = 0; i < length; i ++ ) {
270
+
271
+ this.data[ i ] = functionToMap.call( context, this.data[ i ], i, this.data );
272
+
273
+ }
274
+
275
+ return this;
276
+
277
+ }
278
+
279
+ /**
280
+ * @member {Function} extractPerpendicularPlane Compute the orientation of the slice and returns all the information relative to the geometry such as sliceAccess, the plane matrix (orientation and position in RAS coordinate) and the dimensions of the plane in both coordinate system.
281
+ * @memberof Volume
282
+ * @param {string} axis the normal axis to the slice 'x' 'y' or 'z'
283
+ * @param {number} index the index of the slice
284
+ * @returns {Object} an object containing all the usefull information on the geometry of the slice
285
+ */
286
+ extractPerpendicularPlane( axis, RASIndex ) {
287
+
288
+ let firstSpacing,
289
+ secondSpacing,
290
+ positionOffset,
291
+ IJKIndex;
292
+
293
+ const axisInIJK = new Vector3(),
294
+ firstDirection = new Vector3(),
295
+ secondDirection = new Vector3(),
296
+ planeMatrix = ( new Matrix4() ).identity(),
297
+ volume = this;
298
+
299
+ const dimensions = new Vector3( this.xLength, this.yLength, this.zLength );
300
+
301
+
302
+ switch ( axis ) {
303
+
304
+ case 'x' :
305
+ axisInIJK.set( 1, 0, 0 );
306
+ firstDirection.set( 0, 0, - 1 );
307
+ secondDirection.set( 0, - 1, 0 );
308
+ firstSpacing = this.spacing[ this.axisOrder.indexOf( 'z' ) ];
309
+ secondSpacing = this.spacing[ this.axisOrder.indexOf( 'y' ) ];
310
+ IJKIndex = new Vector3( RASIndex, 0, 0 );
311
+
312
+ planeMatrix.multiply( ( new Matrix4() ).makeRotationY( Math.PI / 2 ) );
313
+ positionOffset = ( volume.RASDimensions[ 0 ] - 1 ) / 2;
314
+ planeMatrix.setPosition( new Vector3( RASIndex - positionOffset, 0, 0 ) );
315
+ break;
316
+ case 'y' :
317
+ axisInIJK.set( 0, 1, 0 );
318
+ firstDirection.set( 1, 0, 0 );
319
+ secondDirection.set( 0, 0, 1 );
320
+ firstSpacing = this.spacing[ this.axisOrder.indexOf( 'x' ) ];
321
+ secondSpacing = this.spacing[ this.axisOrder.indexOf( 'z' ) ];
322
+ IJKIndex = new Vector3( 0, RASIndex, 0 );
323
+
324
+ planeMatrix.multiply( ( new Matrix4() ).makeRotationX( - Math.PI / 2 ) );
325
+ positionOffset = ( volume.RASDimensions[ 1 ] - 1 ) / 2;
326
+ planeMatrix.setPosition( new Vector3( 0, RASIndex - positionOffset, 0 ) );
327
+ break;
328
+ case 'z' :
329
+ default :
330
+ axisInIJK.set( 0, 0, 1 );
331
+ firstDirection.set( 1, 0, 0 );
332
+ secondDirection.set( 0, - 1, 0 );
333
+ firstSpacing = this.spacing[ this.axisOrder.indexOf( 'x' ) ];
334
+ secondSpacing = this.spacing[ this.axisOrder.indexOf( 'y' ) ];
335
+ IJKIndex = new Vector3( 0, 0, RASIndex );
336
+
337
+ positionOffset = ( volume.RASDimensions[ 2 ] - 1 ) / 2;
338
+ planeMatrix.setPosition( new Vector3( 0, 0, RASIndex - positionOffset ) );
339
+ break;
340
+
341
+ }
342
+
343
+ if ( ! this.segmentation ) {
344
+
345
+ firstDirection.applyMatrix4( volume.inverseMatrix ).normalize();
346
+ secondDirection.applyMatrix4( volume.inverseMatrix ).normalize();
347
+ axisInIJK.applyMatrix4( volume.inverseMatrix ).normalize();
348
+
349
+ }
350
+
351
+ firstDirection.arglet = 'i';
352
+ secondDirection.arglet = 'j';
353
+ const iLength = Math.floor( Math.abs( firstDirection.dot( dimensions ) ) );
354
+ const jLength = Math.floor( Math.abs( secondDirection.dot( dimensions ) ) );
355
+ const planeWidth = Math.abs( iLength * firstSpacing );
356
+ const planeHeight = Math.abs( jLength * secondSpacing );
357
+
358
+ IJKIndex = Math.abs( Math.round( IJKIndex.applyMatrix4( volume.inverseMatrix ).dot( axisInIJK ) ) );
359
+ const base = [ new Vector3( 1, 0, 0 ), new Vector3( 0, 1, 0 ), new Vector3( 0, 0, 1 ) ];
360
+ const iDirection = [ firstDirection, secondDirection, axisInIJK ].find( function ( x ) {
361
+
362
+ return Math.abs( x.dot( base[ 0 ] ) ) > 0.9;
363
+
364
+ } );
365
+ const jDirection = [ firstDirection, secondDirection, axisInIJK ].find( function ( x ) {
366
+
367
+ return Math.abs( x.dot( base[ 1 ] ) ) > 0.9;
368
+
369
+ } );
370
+ const kDirection = [ firstDirection, secondDirection, axisInIJK ].find( function ( x ) {
371
+
372
+ return Math.abs( x.dot( base[ 2 ] ) ) > 0.9;
373
+
374
+ } );
375
+
376
+ function sliceAccess( i, j ) {
377
+
378
+ const si = ( iDirection === axisInIJK ) ? IJKIndex : ( iDirection.arglet === 'i' ? i : j );
379
+ const sj = ( jDirection === axisInIJK ) ? IJKIndex : ( jDirection.arglet === 'i' ? i : j );
380
+ const sk = ( kDirection === axisInIJK ) ? IJKIndex : ( kDirection.arglet === 'i' ? i : j );
381
+
382
+ // invert indices if necessary
383
+
384
+ const accessI = ( iDirection.dot( base[ 0 ] ) > 0 ) ? si : ( volume.xLength - 1 ) - si;
385
+ const accessJ = ( jDirection.dot( base[ 1 ] ) > 0 ) ? sj : ( volume.yLength - 1 ) - sj;
386
+ const accessK = ( kDirection.dot( base[ 2 ] ) > 0 ) ? sk : ( volume.zLength - 1 ) - sk;
387
+
388
+ return volume.access( accessI, accessJ, accessK );
389
+
390
+ }
391
+
392
+ return {
393
+ iLength: iLength,
394
+ jLength: jLength,
395
+ sliceAccess: sliceAccess,
396
+ matrix: planeMatrix,
397
+ planeWidth: planeWidth,
398
+ planeHeight: planeHeight
399
+ };
400
+
401
+ }
402
+
403
+ /**
404
+ * @member {Function} extractSlice Returns a slice corresponding to the given axis and index
405
+ * The coordinate are given in the Right Anterior Superior coordinate format
406
+ * @memberof Volume
407
+ * @param {string} axis the normal axis to the slice 'x' 'y' or 'z'
408
+ * @param {number} index the index of the slice
409
+ * @returns {VolumeSlice} the extracted slice
410
+ */
411
+ extractSlice( axis, index ) {
412
+
413
+ const slice = new VolumeSlice( this, index, axis );
414
+ this.sliceList.push( slice );
415
+ return slice;
416
+
417
+ }
418
+
419
+ /**
420
+ * @member {Function} repaintAllSlices Call repaint on all the slices extracted from this volume
421
+ * @see VolumeSlice.repaint
422
+ * @memberof Volume
423
+ * @returns {Volume} this
424
+ */
425
+ repaintAllSlices() {
426
+
427
+ this.sliceList.forEach( function ( slice ) {
428
+
429
+ slice.repaint();
430
+
431
+ } );
432
+
433
+ return this;
434
+
435
+ }
436
+
437
+ /**
438
+ * @member {Function} computeMinMax Compute the minimum and the maximum of the data in the volume
439
+ * @memberof Volume
440
+ * @returns {Array} [min,max]
441
+ */
442
+ computeMinMax() {
443
+
444
+ let min = Infinity;
445
+ let max = - Infinity;
446
+
447
+ // buffer the length
448
+ const datasize = this.data.length;
449
+
450
+ let i = 0;
451
+
452
+ for ( i = 0; i < datasize; i ++ ) {
453
+
454
+ if ( ! isNaN( this.data[ i ] ) ) {
455
+
456
+ const value = this.data[ i ];
457
+ min = Math.min( min, value );
458
+ max = Math.max( max, value );
459
+
460
+ }
461
+
462
+ }
463
+
464
+ this.min = min;
465
+ this.max = max;
466
+
467
+ return [ min, max ];
468
+
469
+ }
470
+
471
+ }
472
+
473
+ export { Volume };