@kitware/vtk.js 28.10.2 → 28.11.0

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 (565) hide show
  1. package/Common/Core/Base64.js +53 -82
  2. package/Common/Core/CellArray.js +52 -60
  3. package/Common/Core/ClassHierarchy.js +8 -36
  4. package/Common/Core/DataArray/Constants.js +6 -6
  5. package/Common/Core/DataArray.js +185 -270
  6. package/Common/Core/Endian.js +14 -17
  7. package/Common/Core/HalfFloat.js +17 -34
  8. package/Common/Core/ImageHelper.js +17 -25
  9. package/Common/Core/LookupTable.js +131 -144
  10. package/Common/Core/Math/Constants.js +8 -8
  11. package/Common/Core/Math/index.js +754 -942
  12. package/Common/Core/Math.js +2 -4
  13. package/Common/Core/MatrixBuilder.js +99 -151
  14. package/Common/Core/Points.js +43 -43
  15. package/Common/Core/PriorityQueue.js +30 -28
  16. package/Common/Core/ProgressHandler.js +31 -32
  17. package/Common/Core/ScalarsToColors/Constants.js +4 -4
  18. package/Common/Core/ScalarsToColors.js +196 -253
  19. package/Common/Core/StringArray.js +48 -73
  20. package/Common/Core/URLExtract.js +10 -29
  21. package/Common/Core/VariantArray.js +48 -73
  22. package/Common/Core.js +11 -11
  23. package/Common/DataModel/AbstractPointLocator.js +19 -17
  24. package/Common/DataModel/BoundingBox.js +322 -490
  25. package/Common/DataModel/Box.js +46 -63
  26. package/Common/DataModel/CardinalSpline1D.js +92 -102
  27. package/Common/DataModel/Cell.js +41 -61
  28. package/Common/DataModel/CellLinks.js +91 -127
  29. package/Common/DataModel/CellTypes/Constants.js +7 -6
  30. package/Common/DataModel/CellTypes.js +55 -74
  31. package/Common/DataModel/Collection.js +45 -61
  32. package/Common/DataModel/Cone.js +28 -20
  33. package/Common/DataModel/Cylinder.js +41 -35
  34. package/Common/DataModel/DataSet/Constants.js +11 -5
  35. package/Common/DataModel/DataSet.js +37 -25
  36. package/Common/DataModel/DataSetAttributes/Constants.js +18 -18
  37. package/Common/DataModel/DataSetAttributes/FieldData.js +103 -194
  38. package/Common/DataModel/DataSetAttributes.js +96 -138
  39. package/Common/DataModel/EdgeLocator.js +45 -70
  40. package/Common/DataModel/ITKHelper.js +67 -137
  41. package/Common/DataModel/ImageData.js +115 -172
  42. package/Common/DataModel/ImplicitBoolean/Constants.js +2 -2
  43. package/Common/DataModel/ImplicitBoolean.js +66 -96
  44. package/Common/DataModel/IncrementalOctreeNode.js +201 -231
  45. package/Common/DataModel/IncrementalOctreePointLocator.js +160 -198
  46. package/Common/DataModel/KochanekSpline1D.js +78 -81
  47. package/Common/DataModel/Line/Constants.js +2 -2
  48. package/Common/DataModel/Line.js +82 -105
  49. package/Common/DataModel/Locator.js +17 -10
  50. package/Common/DataModel/Molecule.js +26 -17
  51. package/Common/DataModel/PiecewiseFunction.js +218 -239
  52. package/Common/DataModel/Plane.js +90 -113
  53. package/Common/DataModel/PointSet.js +30 -26
  54. package/Common/DataModel/PolyData/Constants.js +2 -2
  55. package/Common/DataModel/PolyData.js +95 -120
  56. package/Common/DataModel/PolyLine.js +44 -61
  57. package/Common/DataModel/Polygon/Constants.js +4 -4
  58. package/Common/DataModel/Polygon.js +128 -169
  59. package/Common/DataModel/Quad/Constants.js +2 -2
  60. package/Common/DataModel/Quad.js +61 -100
  61. package/Common/DataModel/SelectionNode/Constants.js +5 -4
  62. package/Common/DataModel/SelectionNode.js +25 -21
  63. package/Common/DataModel/Sphere.js +40 -35
  64. package/Common/DataModel/Spline1D/Constants.js +3 -2
  65. package/Common/DataModel/Spline1D.js +34 -18
  66. package/Common/DataModel/Spline3D/Constants.js +2 -2
  67. package/Common/DataModel/Spline3D.js +46 -41
  68. package/Common/DataModel/StructuredData/Constants.js +2 -2
  69. package/Common/DataModel/StructuredData.js +9 -20
  70. package/Common/DataModel/Triangle.js +207 -250
  71. package/Common/DataModel.js +19 -19
  72. package/Common/System/MobileVR.js +56 -61
  73. package/Common/System/TimerLog.js +1 -1
  74. package/Common/System.js +2 -2
  75. package/Common/Transform/LandmarkTransform/Constants.js +2 -2
  76. package/Common/Transform/LandmarkTransform.js +133 -117
  77. package/Common/Transform/Transform.js +42 -57
  78. package/Common/Transform.js +2 -2
  79. package/Common/index.js +4 -4
  80. package/Filters/Core/Cutter.js +134 -146
  81. package/Filters/Core/PolyDataNormals.js +44 -50
  82. package/Filters/Core.js +2 -2
  83. package/Filters/Cornerstone/ImageDataToCornerstoneImage.js +45 -33
  84. package/Filters/Cornerstone.js +1 -1
  85. package/Filters/General/AppendPolyData.js +84 -100
  86. package/Filters/General/Calculator.js +95 -163
  87. package/Filters/General/ClipClosedSurface/Constants.js +2 -2
  88. package/Filters/General/ClipClosedSurface.js +341 -416
  89. package/Filters/General/ClosedPolyLineToSurfaceFilter.js +141 -156
  90. package/Filters/General/ContourTriangulator/Constants.js +2 -2
  91. package/Filters/General/ContourTriangulator/helper.js +684 -812
  92. package/Filters/General/ContourTriangulator.js +92 -89
  93. package/Filters/General/ImageCropFilter.js +77 -78
  94. package/Filters/General/ImageDataOutlineFilter.js +42 -36
  95. package/Filters/General/ImageMarchingCubes/caseTable.js +9 -521
  96. package/Filters/General/ImageMarchingCubes.js +99 -112
  97. package/Filters/General/ImageMarchingSquares/caseTable.js +9 -41
  98. package/Filters/General/ImageMarchingSquares.js +93 -118
  99. package/Filters/General/ImageOutlineFilter.js +53 -54
  100. package/Filters/General/ImageSliceFilter.js +39 -30
  101. package/Filters/General/ImageStreamline.js +107 -124
  102. package/Filters/General/LineFilter.js +26 -15
  103. package/Filters/General/MoleculeToRepresentation.js +136 -149
  104. package/Filters/General/OBBTree/OBBNode.js +36 -34
  105. package/Filters/General/OBBTree/helper.js +19 -24
  106. package/Filters/General/OBBTree.js +396 -488
  107. package/Filters/General/OutlineFilter.js +52 -34
  108. package/Filters/General/PaintFilter/PaintFilter.worker.js +93 -130
  109. package/Filters/General/PaintFilter.js +150 -162
  110. package/Filters/General/ScalarToRGBA.js +38 -33
  111. package/Filters/General/TriangleFilter.js +65 -62
  112. package/Filters/General/TubeFilter/Constants.js +4 -4
  113. package/Filters/General/TubeFilter.js +376 -496
  114. package/Filters/General/WarpScalar.js +58 -60
  115. package/Filters/General/WindowedSincPolyDataFilter.js +258 -330
  116. package/Filters/General.js +21 -21
  117. package/Filters/Sources/Arrow2DSource/Constants.js +2 -2
  118. package/Filters/Sources/Arrow2DSource.js +56 -56
  119. package/Filters/Sources/ArrowSource.js +39 -29
  120. package/Filters/Sources/CircleSource.js +43 -43
  121. package/Filters/Sources/ConcentricCylinderSource.js +151 -174
  122. package/Filters/Sources/ConeSource.js +51 -42
  123. package/Filters/Sources/CubeSource.js +75 -96
  124. package/Filters/Sources/Cursor3D.js +94 -109
  125. package/Filters/Sources/CylinderSource.js +90 -90
  126. package/Filters/Sources/ImageGridSource.js +43 -43
  127. package/Filters/Sources/LineSource.js +49 -39
  128. package/Filters/Sources/PlaneSource.js +97 -104
  129. package/Filters/Sources/PointSource.js +46 -37
  130. package/Filters/Sources/RTAnalyticSource.js +50 -48
  131. package/Filters/Sources/SLICSource.js +63 -73
  132. package/Filters/Sources/SphereSource.js +88 -78
  133. package/Filters/Sources/ViewFinderSource.js +26 -23
  134. package/Filters/Sources.js +14 -14
  135. package/Filters/Texture/TextureMapToPlane.js +95 -97
  136. package/Filters/Texture/TextureMapToSphere.js +46 -54
  137. package/Filters/Texture.js +2 -2
  138. package/Filters/index.js +5 -5
  139. package/IO/Core/BinaryHelper.js +12 -18
  140. package/IO/Core/DataAccessHelper/HtmlDataAccessHelper.js +43 -59
  141. package/IO/Core/DataAccessHelper/HttpDataAccessHelper.js +76 -113
  142. package/IO/Core/DataAccessHelper/JSZipDataAccessHelper.js +62 -112
  143. package/IO/Core/DataAccessHelper/LiteHttpDataAccessHelper.js +76 -113
  144. package/IO/Core/DataAccessHelper.js +6 -6
  145. package/IO/Core/HttpDataSetReader.js +136 -139
  146. package/IO/Core/HttpDataSetSeriesReader.js +64 -75
  147. package/IO/Core/HttpSceneLoader.js +130 -179
  148. package/IO/Core/ImageStream/DefaultProtocol.js +29 -43
  149. package/IO/Core/ImageStream/ViewStream.js +100 -103
  150. package/IO/Core/ImageStream.js +62 -54
  151. package/IO/Core/ResourceLoader.js +10 -9
  152. package/IO/Core/Serializer/ArraySerializer.js +40 -40
  153. package/IO/Core/Serializer/FieldDataSerializer.js +18 -28
  154. package/IO/Core/Serializer/ImageDataSerializer.js +22 -23
  155. package/IO/Core/Serializer/PolyDataSerializer.js +17 -21
  156. package/IO/Core/Serializer.js +6 -13
  157. package/IO/Core/WSLinkClient.js +90 -76
  158. package/IO/Core/ZipMultiDataSetReader.js +46 -44
  159. package/IO/Core/ZipMultiDataSetWriter.js +43 -34
  160. package/IO/Core.js +7 -7
  161. package/IO/Geometry/DracoReader.js +118 -121
  162. package/IO/Geometry/PLYReader.js +163 -223
  163. package/IO/Geometry/PLYWriter/Constants.js +5 -5
  164. package/IO/Geometry/PLYWriter.js +139 -154
  165. package/IO/Geometry/STLReader.js +123 -146
  166. package/IO/Geometry/STLWriter/Constants.js +2 -2
  167. package/IO/Geometry/STLWriter.js +83 -82
  168. package/IO/Geometry.js +5 -5
  169. package/IO/Legacy/LegacyAsciiParser.js +78 -139
  170. package/IO/Legacy/PolyDataReader.js +48 -36
  171. package/IO/Legacy.js +2 -2
  172. package/IO/Misc/ElevationReader.js +67 -60
  173. package/IO/Misc/HttpDataSetLODsLoader.js +41 -38
  174. package/IO/Misc/ITKImageReader.js +58 -45
  175. package/IO/Misc/ITKPolyDataReader.js +50 -38
  176. package/IO/Misc/JSONNucleoReader.js +49 -42
  177. package/IO/Misc/JSONReader.js +38 -33
  178. package/IO/Misc/MTLReader.js +74 -119
  179. package/IO/Misc/OBJReader.js +153 -206
  180. package/IO/Misc/PDBReader.js +70 -68
  181. package/IO/Misc/SkyboxReader.js +77 -82
  182. package/IO/Misc.js +9 -9
  183. package/IO/XML/XMLImageDataReader.js +36 -38
  184. package/IO/XML/XMLImageDataWriter.js +28 -21
  185. package/IO/XML/XMLPolyDataReader.js +49 -46
  186. package/IO/XML/XMLPolyDataWriter.js +43 -42
  187. package/IO/XML/XMLReader.js +262 -304
  188. package/IO/XML/XMLWriter/Constants.js +3 -3
  189. package/IO/XML/XMLWriter.js +70 -84
  190. package/IO/XML.js +6 -6
  191. package/IO/index.js +5 -5
  192. package/Imaging/Core/AbstractImageInterpolator/Constants.js +4 -4
  193. package/Imaging/Core/AbstractImageInterpolator/InterpolationInfo.js +30 -27
  194. package/Imaging/Core/AbstractImageInterpolator.js +74 -87
  195. package/Imaging/Core/ImageInterpolator.js +201 -252
  196. package/Imaging/Core/ImagePointDataIterator.js +96 -122
  197. package/Imaging/Core/ImageReslice/Constants.js +2 -2
  198. package/Imaging/Core/ImageReslice.js +327 -464
  199. package/Imaging/Core.js +4 -4
  200. package/Imaging/Hybrid/SampleFunction.js +58 -51
  201. package/Imaging/Hybrid.js +1 -1
  202. package/Imaging/index.js +2 -2
  203. package/Interaction/Animations/TimeStepBasedAnimationHandler.js +39 -54
  204. package/Interaction/Manipulators/CompositeCameraManipulator.js +22 -13
  205. package/Interaction/Manipulators/CompositeGestureManipulator.js +31 -43
  206. package/Interaction/Manipulators/CompositeKeyboardManipulator.js +15 -11
  207. package/Interaction/Manipulators/CompositeMouseManipulator.js +27 -33
  208. package/Interaction/Manipulators/CompositeVRManipulator.js +22 -15
  209. package/Interaction/Manipulators/GestureCameraManipulator.js +54 -36
  210. package/Interaction/Manipulators/KeyboardCameraManipulator.js +95 -97
  211. package/Interaction/Manipulators/MouseBoxSelectorManipulator.js +70 -89
  212. package/Interaction/Manipulators/MouseCameraAxisRotateManipulator.js +67 -54
  213. package/Interaction/Manipulators/MouseCameraSliceManipulator.js +40 -38
  214. package/Interaction/Manipulators/MouseCameraTrackballFirstPersonManipulator.js +83 -68
  215. package/Interaction/Manipulators/MouseCameraTrackballMultiRotateManipulator.js +32 -28
  216. package/Interaction/Manipulators/MouseCameraTrackballPanManipulator.js +47 -40
  217. package/Interaction/Manipulators/MouseCameraTrackballRollManipulator.js +55 -43
  218. package/Interaction/Manipulators/MouseCameraTrackballRotateManipulator.js +56 -46
  219. package/Interaction/Manipulators/MouseCameraTrackballZoomManipulator.js +41 -46
  220. package/Interaction/Manipulators/MouseCameraTrackballZoomToMouseManipulator.js +29 -27
  221. package/Interaction/Manipulators/MouseCameraUnicamManipulator.js +123 -146
  222. package/Interaction/Manipulators/MouseCameraUnicamRotateManipulator.js +144 -166
  223. package/Interaction/Manipulators/MouseRangeManipulator.js +127 -132
  224. package/Interaction/Manipulators/VRButtonPanManipulator.js +33 -23
  225. package/Interaction/Manipulators.js +21 -21
  226. package/Interaction/Misc/DeviceOrientationToCamera.js +25 -47
  227. package/Interaction/Misc.js +1 -1
  228. package/Interaction/Style/InteractorStyleImage.js +101 -121
  229. package/Interaction/Style/InteractorStyleMPRSlice.js +111 -128
  230. package/Interaction/Style/InteractorStyleManipulator/Presets.js +9 -17
  231. package/Interaction/Style/InteractorStyleManipulator.js +254 -329
  232. package/Interaction/Style/InteractorStyleRemoteMouse.js +195 -180
  233. package/Interaction/Style/InteractorStyleTrackballCamera.js +154 -157
  234. package/Interaction/Style/InteractorStyleUnicam.js +30 -38
  235. package/Interaction/Style.js +5 -5
  236. package/Interaction/UI/CornerAnnotation/CornerAnnotation.module.css.js +1 -1
  237. package/Interaction/UI/CornerAnnotation.js +65 -48
  238. package/Interaction/UI/FPSMonitor.js +104 -105
  239. package/Interaction/UI/Icons.js +1 -1
  240. package/Interaction/UI/Slider/Constants.js +2 -2
  241. package/Interaction/UI/Slider.js +78 -95
  242. package/Interaction/UI/VolumeController.js +104 -97
  243. package/Interaction/UI.js +5 -5
  244. package/Interaction/Widgets/OrientationMarkerWidget/Constants.js +2 -2
  245. package/Interaction/Widgets/OrientationMarkerWidget.js +90 -135
  246. package/Interaction/Widgets/PiecewiseGaussianWidget/ComputeHistogram.worker.js +0 -3
  247. package/Interaction/Widgets/PiecewiseGaussianWidget.js +381 -498
  248. package/Interaction/Widgets.js +2 -2
  249. package/Interaction/index.js +5 -5
  250. package/Proxy/Animation/AbstractAnimationProxy.js +22 -15
  251. package/Proxy/Animation/AnimationProxyManager.js +43 -51
  252. package/Proxy/Animation/TimeStepBasedAnimationHandlerProxy.js +26 -19
  253. package/Proxy/Core/AbstractRepresentationProxy.js +97 -151
  254. package/Proxy/Core/LookupTableProxy/Constants.js +4 -4
  255. package/Proxy/Core/LookupTableProxy.js +49 -52
  256. package/Proxy/Core/PiecewiseFunctionProxy/Constants.js +4 -4
  257. package/Proxy/Core/PiecewiseFunctionProxy.js +63 -72
  258. package/Proxy/Core/ProxyManager/core.js +83 -106
  259. package/Proxy/Core/ProxyManager/properties.js +53 -76
  260. package/Proxy/Core/ProxyManager/state.js +100 -110
  261. package/Proxy/Core/ProxyManager/view.js +45 -55
  262. package/Proxy/Core/ProxyManager.js +16 -8
  263. package/Proxy/Core/SourceProxy.js +41 -38
  264. package/Proxy/Core/View2DProxy.js +143 -199
  265. package/Proxy/Core/ViewProxy.js +223 -269
  266. package/Proxy/Core.js +7 -7
  267. package/Proxy/Representations/GeometryRepresentationProxy.js +34 -20
  268. package/Proxy/Representations/GlyphRepresentationProxy.js +42 -41
  269. package/Proxy/Representations/MoleculeRepresentationProxy.js +32 -22
  270. package/Proxy/Representations/ResliceRepresentationProxy.js +48 -32
  271. package/Proxy/Representations/SkyboxRepresentationProxy.js +30 -29
  272. package/Proxy/Representations/SliceRepresentationProxy.js +93 -112
  273. package/Proxy/Representations/SlicedGeometryRepresentationProxy.js +46 -42
  274. package/Proxy/Representations/VolumeRepresentationProxy.js +108 -133
  275. package/Proxy/Representations.js +7 -7
  276. package/Proxy/index.js +2 -2
  277. package/Rendering/Core/AbstractImageMapper/helper.js +44 -49
  278. package/Rendering/Core/AbstractImageMapper.js +18 -19
  279. package/Rendering/Core/AbstractMapper.js +39 -55
  280. package/Rendering/Core/AbstractMapper3D.js +26 -31
  281. package/Rendering/Core/AbstractPicker.js +25 -21
  282. package/Rendering/Core/Actor.js +71 -93
  283. package/Rendering/Core/Actor2D.js +64 -78
  284. package/Rendering/Core/AnnotatedCubeActor/Presets.js +5 -11
  285. package/Rendering/Core/AnnotatedCubeActor.js +94 -79
  286. package/Rendering/Core/AxesActor.js +65 -87
  287. package/Rendering/Core/Camera.js +246 -271
  288. package/Rendering/Core/CellPicker.js +125 -148
  289. package/Rendering/Core/ColorTransferFunction/ColorMaps.js +20 -21
  290. package/Rendering/Core/ColorTransferFunction/ColorMapsLite.js +20 -21
  291. package/Rendering/Core/ColorTransferFunction/Constants.js +4 -4
  292. package/Rendering/Core/ColorTransferFunction.js +460 -546
  293. package/Rendering/Core/Coordinate/Constants.js +2 -2
  294. package/Rendering/Core/Coordinate.js +119 -198
  295. package/Rendering/Core/CubeAxesActor.js +294 -320
  296. package/Rendering/Core/Follower.js +46 -45
  297. package/Rendering/Core/Glyph3DMapper/Constants.js +4 -4
  298. package/Rendering/Core/Glyph3DMapper.js +96 -148
  299. package/Rendering/Core/HardwareSelector.js +36 -69
  300. package/Rendering/Core/ImageArrayMapper.js +87 -126
  301. package/Rendering/Core/ImageCPRMapper.js +134 -209
  302. package/Rendering/Core/ImageMapper/Constants.js +2 -2
  303. package/Rendering/Core/ImageMapper.js +85 -144
  304. package/Rendering/Core/ImageProperty/Constants.js +2 -2
  305. package/Rendering/Core/ImageProperty.js +66 -81
  306. package/Rendering/Core/ImageResliceMapper/Constants.js +2 -2
  307. package/Rendering/Core/ImageResliceMapper.js +36 -29
  308. package/Rendering/Core/ImageSlice.js +85 -127
  309. package/Rendering/Core/InteractorObserver.js +82 -73
  310. package/Rendering/Core/InteractorStyle/Constants.js +2 -2
  311. package/Rendering/Core/InteractorStyle.js +56 -58
  312. package/Rendering/Core/Light.js +43 -49
  313. package/Rendering/Core/Mapper/CoincidentTopologyHelper.js +37 -48
  314. package/Rendering/Core/Mapper/Constants.js +6 -6
  315. package/Rendering/Core/Mapper/Static.js +15 -12
  316. package/Rendering/Core/Mapper.js +194 -259
  317. package/Rendering/Core/Mapper2D.js +61 -100
  318. package/Rendering/Core/Picker.js +124 -143
  319. package/Rendering/Core/PixelSpaceCallbackMapper.js +40 -37
  320. package/Rendering/Core/PointPicker.js +68 -79
  321. package/Rendering/Core/Prop/Constants.js +2 -2
  322. package/Rendering/Core/Prop.js +58 -106
  323. package/Rendering/Core/Prop3D.js +54 -83
  324. package/Rendering/Core/Property/Constants.js +6 -6
  325. package/Rendering/Core/Property.js +45 -74
  326. package/Rendering/Core/Property2D/Constants.js +2 -2
  327. package/Rendering/Core/Property2D.js +33 -42
  328. package/Rendering/Core/RenderWindow.js +70 -82
  329. package/Rendering/Core/RenderWindowInteractor/Constants.js +7 -7
  330. package/Rendering/Core/RenderWindowInteractor.js +324 -439
  331. package/Rendering/Core/Renderer.js +192 -256
  332. package/Rendering/Core/ScalarBarActor.js +267 -272
  333. package/Rendering/Core/Skybox.js +26 -24
  334. package/Rendering/Core/SphereMapper.js +22 -12
  335. package/Rendering/Core/StickMapper.js +22 -12
  336. package/Rendering/Core/SurfaceLICInterface/Constants.js +6 -6
  337. package/Rendering/Core/SurfaceLICInterface.js +13 -9
  338. package/Rendering/Core/SurfaceLICMapper.js +23 -15
  339. package/Rendering/Core/Texture.js +99 -141
  340. package/Rendering/Core/Viewport.js +60 -88
  341. package/Rendering/Core/Volume.js +55 -77
  342. package/Rendering/Core/VolumeMapper/Constants.js +4 -4
  343. package/Rendering/Core/VolumeMapper.js +59 -91
  344. package/Rendering/Core/VolumeProperty/Constants.js +4 -4
  345. package/Rendering/Core/VolumeProperty.js +78 -115
  346. package/Rendering/Core.js +47 -49
  347. package/Rendering/Misc/CanvasView.js +62 -61
  348. package/Rendering/Misc/FullScreenRenderWindow.js +60 -62
  349. package/Rendering/Misc/GenericRenderWindow.js +48 -37
  350. package/Rendering/Misc/RemoteView.js +86 -80
  351. package/Rendering/Misc/RenderWindowWithControlBar.js +54 -48
  352. package/Rendering/Misc/SynchronizableRenderWindow/BehaviorManager/CameraSynchronizer.js +43 -51
  353. package/Rendering/Misc/SynchronizableRenderWindow/BehaviorManager.js +52 -82
  354. package/Rendering/Misc/SynchronizableRenderWindow/ObjectManager.js +258 -308
  355. package/Rendering/Misc/SynchronizableRenderWindow.js +133 -163
  356. package/Rendering/Misc/TextureLODsDownloader.js +72 -74
  357. package/Rendering/Misc.js +7 -7
  358. package/Rendering/OpenGL/Actor.js +57 -68
  359. package/Rendering/OpenGL/Actor2D.js +56 -56
  360. package/Rendering/OpenGL/BufferObject/Constants.js +2 -2
  361. package/Rendering/OpenGL/BufferObject.js +50 -65
  362. package/Rendering/OpenGL/Camera.js +35 -29
  363. package/Rendering/OpenGL/CellArrayBufferObject.js +119 -149
  364. package/Rendering/OpenGL/Convolution2DPass.js +87 -81
  365. package/Rendering/OpenGL/CubeAxesActor.js +28 -21
  366. package/Rendering/OpenGL/ForwardPass.js +53 -64
  367. package/Rendering/OpenGL/Framebuffer.js +61 -101
  368. package/Rendering/OpenGL/Glyph3DMapper.js +165 -196
  369. package/Rendering/OpenGL/HardwareSelector/Constants.js +2 -2
  370. package/Rendering/OpenGL/HardwareSelector.js +272 -397
  371. package/Rendering/OpenGL/Helper.js +58 -73
  372. package/Rendering/OpenGL/ImageCPRMapper.js +339 -421
  373. package/Rendering/OpenGL/ImageMapper.js +268 -361
  374. package/Rendering/OpenGL/ImageResliceMapper.js +306 -438
  375. package/Rendering/OpenGL/ImageSlice.js +48 -54
  376. package/Rendering/OpenGL/OrderIndependentTranslucentPass.js +102 -84
  377. package/Rendering/OpenGL/PixelSpaceCallbackMapper.js +43 -42
  378. package/Rendering/OpenGL/PolyDataMapper.js +358 -492
  379. package/Rendering/OpenGL/PolyDataMapper2D.js +153 -205
  380. package/Rendering/OpenGL/RadialDistortionPass.js +86 -89
  381. package/Rendering/OpenGL/RenderWindow/Constants.js +2 -2
  382. package/Rendering/OpenGL/RenderWindow/ContextProxy.js +20 -29
  383. package/Rendering/OpenGL/RenderWindow.js +356 -510
  384. package/Rendering/OpenGL/Renderer.js +77 -89
  385. package/Rendering/OpenGL/ReplacementShaderMapper.js +28 -46
  386. package/Rendering/OpenGL/ScalarBarActor.js +28 -21
  387. package/Rendering/OpenGL/Shader.js +37 -31
  388. package/Rendering/OpenGL/ShaderCache.js +67 -74
  389. package/Rendering/OpenGL/ShaderProgram.js +136 -248
  390. package/Rendering/OpenGL/Skybox.js +99 -60
  391. package/Rendering/OpenGL/SphereMapper.js +94 -108
  392. package/Rendering/OpenGL/StickMapper.js +110 -114
  393. package/Rendering/OpenGL/SurfaceLIC/LineIntegralConvolution2D/pingpong.js +91 -157
  394. package/Rendering/OpenGL/SurfaceLIC/LineIntegralConvolution2D.js +142 -151
  395. package/Rendering/OpenGL/SurfaceLIC/SurfaceLICInterface.js +142 -216
  396. package/Rendering/OpenGL/SurfaceLIC/SurfaceLICMapper.js +79 -100
  397. package/Rendering/OpenGL/SurfaceLIC.js +2 -2
  398. package/Rendering/OpenGL/Texture/Constants.js +4 -4
  399. package/Rendering/OpenGL/Texture.js +443 -608
  400. package/Rendering/OpenGL/TextureUnitManager.js +47 -43
  401. package/Rendering/OpenGL/VertexArrayObject.js +92 -131
  402. package/Rendering/OpenGL/ViewNodeFactory.js +25 -13
  403. package/Rendering/OpenGL/Volume.js +38 -34
  404. package/Rendering/OpenGL/VolumeMapper.js +437 -547
  405. package/Rendering/OpenGL.js +28 -28
  406. package/Rendering/SceneGraph/RenderPass.js +34 -31
  407. package/Rendering/SceneGraph/RenderWindowViewNode.js +68 -94
  408. package/Rendering/SceneGraph/ViewNode.js +82 -111
  409. package/Rendering/SceneGraph/ViewNodeFactory.js +31 -26
  410. package/Rendering/SceneGraph.js +4 -4
  411. package/Rendering/WebGPU/Actor.js +49 -49
  412. package/Rendering/WebGPU/Actor2D.js +45 -44
  413. package/Rendering/WebGPU/BindGroup.js +43 -50
  414. package/Rendering/WebGPU/Buffer.js +41 -50
  415. package/Rendering/WebGPU/BufferManager/Constants.js +4 -4
  416. package/Rendering/WebGPU/BufferManager.js +111 -141
  417. package/Rendering/WebGPU/Camera.js +65 -67
  418. package/Rendering/WebGPU/CellArrayMapper.js +621 -388
  419. package/Rendering/WebGPU/CubeAxesActor.js +28 -19
  420. package/Rendering/WebGPU/Device.js +78 -133
  421. package/Rendering/WebGPU/ForwardPass.js +75 -72
  422. package/Rendering/WebGPU/FullScreenQuad.js +25 -18
  423. package/Rendering/WebGPU/Glyph3DMapper.js +62 -74
  424. package/Rendering/WebGPU/HardwareSelectionPass.js +45 -38
  425. package/Rendering/WebGPU/HardwareSelector.js +200 -276
  426. package/Rendering/WebGPU/ImageMapper.js +180 -171
  427. package/Rendering/WebGPU/ImageSlice.js +45 -44
  428. package/Rendering/WebGPU/IndexBuffer.js +166 -200
  429. package/Rendering/WebGPU/OpaquePass.js +37 -36
  430. package/Rendering/WebGPU/OrderIndependentTranslucentPass.js +72 -45
  431. package/Rendering/WebGPU/Pipeline.js +37 -51
  432. package/Rendering/WebGPU/PixelSpaceCallbackMapper.js +27 -19
  433. package/Rendering/WebGPU/PolyDataMapper.js +50 -53
  434. package/Rendering/WebGPU/PolyDataMapper2D.js +39 -39
  435. package/Rendering/WebGPU/RenderEncoder.js +68 -88
  436. package/Rendering/WebGPU/RenderWindow.js +262 -376
  437. package/Rendering/WebGPU/Renderer.js +224 -208
  438. package/Rendering/WebGPU/Sampler.js +27 -21
  439. package/Rendering/WebGPU/ScalarBarActor.js +28 -19
  440. package/Rendering/WebGPU/ShaderCache.js +43 -41
  441. package/Rendering/WebGPU/ShaderDescription.js +52 -59
  442. package/Rendering/WebGPU/ShaderModule.js +26 -17
  443. package/Rendering/WebGPU/SimpleMapper.js +185 -121
  444. package/Rendering/WebGPU/SphereMapper.js +200 -130
  445. package/Rendering/WebGPU/StickMapper.js +289 -152
  446. package/Rendering/WebGPU/StorageBuffer.js +100 -115
  447. package/Rendering/WebGPU/Texture.js +79 -99
  448. package/Rendering/WebGPU/TextureManager.js +52 -54
  449. package/Rendering/WebGPU/TextureView.js +40 -43
  450. package/Rendering/WebGPU/Types.js +53 -70
  451. package/Rendering/WebGPU/UniformBuffer.js +158 -184
  452. package/Rendering/WebGPU/VertexInput.js +64 -90
  453. package/Rendering/WebGPU/ViewNodeFactory.js +25 -13
  454. package/Rendering/WebGPU/Volume.js +52 -51
  455. package/Rendering/WebGPU/VolumePass.js +218 -239
  456. package/Rendering/WebGPU/VolumePassFSQ.js +625 -306
  457. package/Rendering/WebGPU.js +1 -1
  458. package/Rendering/index.js +5 -5
  459. package/Widgets/Core/AbstractWidget/Constants.js +2 -2
  460. package/Widgets/Core/AbstractWidget.js +49 -58
  461. package/Widgets/Core/AbstractWidgetFactory.js +101 -122
  462. package/Widgets/Core/StateBuilder/boundsMixin.js +23 -28
  463. package/Widgets/Core/StateBuilder/color3Mixin.js +10 -7
  464. package/Widgets/Core/StateBuilder/colorMixin.js +10 -6
  465. package/Widgets/Core/StateBuilder/cornerMixin.js +16 -15
  466. package/Widgets/Core/StateBuilder/directionMixin.js +20 -18
  467. package/Widgets/Core/StateBuilder/manipulatorMixin.js +26 -18
  468. package/Widgets/Core/StateBuilder/nameMixin.js +10 -6
  469. package/Widgets/Core/StateBuilder/orientationMixin.js +19 -16
  470. package/Widgets/Core/StateBuilder/originMixin.js +25 -32
  471. package/Widgets/Core/StateBuilder/scale1Mixin.js +10 -6
  472. package/Widgets/Core/StateBuilder/scale3Mixin.js +10 -6
  473. package/Widgets/Core/StateBuilder/shapeMixin.js +12 -6
  474. package/Widgets/Core/StateBuilder/textMixin.js +10 -6
  475. package/Widgets/Core/StateBuilder/visibleMixin.js +10 -6
  476. package/Widgets/Core/StateBuilder.js +120 -149
  477. package/Widgets/Core/WidgetManager/Constants.js +7 -7
  478. package/Widgets/Core/WidgetManager.js +249 -421
  479. package/Widgets/Core/WidgetState.js +48 -57
  480. package/Widgets/Core.js +5 -5
  481. package/Widgets/Manipulators/AbstractManipulator.js +20 -14
  482. package/Widgets/Manipulators/CPRManipulator.js +55 -71
  483. package/Widgets/Manipulators/LineManipulator.js +31 -28
  484. package/Widgets/Manipulators/PickerManipulator.d.ts +48 -0
  485. package/Widgets/Manipulators/PickerManipulator.js +65 -0
  486. package/Widgets/Manipulators/PlaneManipulator.js +26 -23
  487. package/Widgets/Manipulators/TrackballManipulator.js +39 -35
  488. package/Widgets/Manipulators.js +4 -2
  489. package/Widgets/Representations/ArrowHandleRepresentation.js +148 -162
  490. package/Widgets/Representations/CircleContextRepresentation.js +44 -38
  491. package/Widgets/Representations/ContextRepresentation.js +17 -14
  492. package/Widgets/Representations/ConvexFaceContextRepresentation.js +50 -47
  493. package/Widgets/Representations/CroppingOutlineRepresentation.js +38 -27
  494. package/Widgets/Representations/CubeHandleRepresentation.js +21 -18
  495. package/Widgets/Representations/GlyphRepresentation.js +107 -152
  496. package/Widgets/Representations/HandleRepresentation.js +17 -14
  497. package/Widgets/Representations/ImplicitPlaneRepresentation.js +97 -91
  498. package/Widgets/Representations/LineHandleRepresentation.js +44 -41
  499. package/Widgets/Representations/OutlineContextRepresentation.js +42 -36
  500. package/Widgets/Representations/PolyLineRepresentation.js +60 -75
  501. package/Widgets/Representations/RectangleContextRepresentation.js +42 -37
  502. package/Widgets/Representations/SphereContextRepresentation.js +19 -27
  503. package/Widgets/Representations/SphereHandleRepresentation.js +31 -27
  504. package/Widgets/Representations/SplineContextRepresentation.js +46 -70
  505. package/Widgets/Representations/WidgetRepresentation/Constants.js +2 -2
  506. package/Widgets/Representations/WidgetRepresentation.js +99 -134
  507. package/Widgets/Representations.js +13 -13
  508. package/Widgets/Widgets3D/AngleWidget/behavior.js +41 -63
  509. package/Widgets/Widgets3D/AngleWidget.js +40 -38
  510. package/Widgets/Widgets3D/DistanceWidget/behavior.js +40 -61
  511. package/Widgets/Widgets3D/DistanceWidget.js +38 -36
  512. package/Widgets/Widgets3D/EllipseWidget/behavior.js +14 -19
  513. package/Widgets/Widgets3D/EllipseWidget/state.js +4 -2
  514. package/Widgets/Widgets3D/EllipseWidget.js +37 -26
  515. package/Widgets/Widgets3D/ImageCroppingWidget/behavior.js +26 -56
  516. package/Widgets/Widgets3D/ImageCroppingWidget/helpers.js +14 -17
  517. package/Widgets/Widgets3D/ImageCroppingWidget/state.js +20 -16
  518. package/Widgets/Widgets3D/ImageCroppingWidget.js +80 -98
  519. package/Widgets/Widgets3D/ImplicitPlaneWidget.js +55 -77
  520. package/Widgets/Widgets3D/InteractiveOrientationWidget/behavior.js +17 -18
  521. package/Widgets/Widgets3D/InteractiveOrientationWidget/state.js +15 -7
  522. package/Widgets/Widgets3D/InteractiveOrientationWidget.js +30 -29
  523. package/Widgets/Widgets3D/LabelWidget/behavior.js +37 -62
  524. package/Widgets/Widgets3D/LabelWidget.js +31 -25
  525. package/Widgets/Widgets3D/LineWidget/Constants.js +8 -8
  526. package/Widgets/Widgets3D/LineWidget/behavior.js +77 -114
  527. package/Widgets/Widgets3D/LineWidget/helpers.js +13 -20
  528. package/Widgets/Widgets3D/LineWidget/state.js +2 -1
  529. package/Widgets/Widgets3D/LineWidget.js +39 -35
  530. package/Widgets/Widgets3D/PaintWidget/behavior.js +24 -59
  531. package/Widgets/Widgets3D/PaintWidget.js +39 -37
  532. package/Widgets/Widgets3D/PolyLineWidget/behavior.js +44 -68
  533. package/Widgets/Widgets3D/PolyLineWidget.js +36 -31
  534. package/Widgets/Widgets3D/RectangleWidget/behavior.js +6 -11
  535. package/Widgets/Widgets3D/RectangleWidget/state.js +4 -2
  536. package/Widgets/Widgets3D/RectangleWidget.js +37 -25
  537. package/Widgets/Widgets3D/ResliceCursorWidget/Constants.js +35 -21
  538. package/Widgets/Widgets3D/ResliceCursorWidget/behavior.js +133 -209
  539. package/Widgets/Widgets3D/ResliceCursorWidget/cprBehavior.js +26 -41
  540. package/Widgets/Widgets3D/ResliceCursorWidget/helpers.js +89 -116
  541. package/Widgets/Widgets3D/ResliceCursorWidget/state.js +33 -40
  542. package/Widgets/Widgets3D/ResliceCursorWidget.js +186 -227
  543. package/Widgets/Widgets3D/SeedWidget/behavior.js +82 -0
  544. package/Widgets/Widgets3D/SeedWidget/state.js +18 -0
  545. package/Widgets/Widgets3D/SeedWidget.d.ts +44 -0
  546. package/Widgets/Widgets3D/SeedWidget.js +43 -0
  547. package/Widgets/Widgets3D/ShapeWidget/Constants.js +19 -19
  548. package/Widgets/Widgets3D/ShapeWidget/behavior.js +150 -252
  549. package/Widgets/Widgets3D/ShapeWidget.js +24 -27
  550. package/Widgets/Widgets3D/SphereWidget/behavior.js +35 -69
  551. package/Widgets/Widgets3D/SphereWidget/state.js +9 -5
  552. package/Widgets/Widgets3D/SphereWidget.js +34 -44
  553. package/Widgets/Widgets3D/SplineWidget/behavior.js +85 -120
  554. package/Widgets/Widgets3D/SplineWidget.js +43 -39
  555. package/Widgets/Widgets3D.js +15 -15
  556. package/Widgets/index.js +4 -4
  557. package/_virtual/rollup-plugin-worker-loader__module_Sources/Filters/General/PaintFilter/PaintFilter.worker.js +95 -207
  558. package/_virtual/rollup-plugin-worker-loader__module_Sources/Interaction/Widgets/PiecewiseGaussianWidget/ComputeHistogram.worker.js +0 -3
  559. package/favicon.js +5 -6
  560. package/index.d.ts +4 -2
  561. package/index.js +4 -3
  562. package/macros.js +4 -1931
  563. package/macros2.js +1684 -0
  564. package/package.json +6 -6
  565. package/vtk.js +18 -31
@@ -1,11 +1,17 @@
1
- import { newInstance as newInstance$1, vtkErrorMacro as vtkErrorMacro$1 } from '../../macros.js';
1
+ import { n as newInstance$1, c as macro } from '../../macros2.js';
2
2
  import vtkWebGPUCellArrayMapper from './CellArrayMapper.js';
3
3
  import vtkWebGPUBufferManager from './BufferManager.js';
4
4
  import vtkWebGPUShaderCache from './ShaderCache.js';
5
5
  import { registerOverride } from './ViewNodeFactory.js';
6
6
 
7
- var BufferUsage = vtkWebGPUBufferManager.BufferUsage;
8
- var vtkErrorMacro = vtkErrorMacro$1; // Vertices
7
+ const {
8
+ BufferUsage
9
+ } = vtkWebGPUBufferManager;
10
+ const {
11
+ vtkErrorMacro
12
+ } = macro;
13
+
14
+ // Vertices
9
15
  // 013 - 032 - 324 - 453
10
16
  //
11
17
  // _.4---_.5
@@ -26,265 +32,396 @@ var vtkErrorMacro = vtkErrorMacro$1; // Vertices
26
32
  // 4: 011
27
33
  // 5: 111
28
34
 
29
- var vtkWebGPUStickMapperVS = "\n//VTK::Renderer::Dec\n\n//VTK::Mapper::Dec\n\n//VTK::Color::Dec\n\n//VTK::IOStructs::Dec\n\n@vertex\nfn main(\n//VTK::IOStructs::Input\n)\n//VTK::IOStructs::Output\n{\n var offsetsArray: array<vec3<f32>, 12> = array<vec3<f32>, 12>(\n vec3<f32>(-1.0, -1.0, -1.0),\n vec3<f32>(1.0, -1.0, -1.0),\n vec3<f32>(1.0, -1.0, 1.0),\n\n vec3<f32>(-1.0, -1.0, -1.0),\n vec3<f32>(1.0, -1.0, 1.0),\n vec3<f32>(-1.0, -1.0, 1.0),\n\n vec3<f32>(-1.0, -1.0, 1.0),\n vec3<f32>(1.0, -1.0, 1.0),\n vec3<f32>(1.0, 1.0, 1.0),\n\n vec3<f32>(-1.0, -1.0, 1.0),\n vec3<f32>(1.0, 1.0, 1.0),\n vec3<f32>(-1.0, 1.0, 1.0)\n );\n\n var output : vertexOutput;\n\n var vertexVC: vec4<f32> = rendererUBO.SCVCMatrix * mapperUBO.BCSCMatrix * vec4<f32>(vertexBC.xyz, 1.0);\n\n //VTK::Color::Impl\n\n // compute the projected vertex position\n output.centerVC = vertexVC.xyz;\n output.radiusVC = radiusMC;\n output.lengthVC = length(orientMC);\n output.orientVC = (rendererUBO.WCVCNormals * vec4<f32>(normalize(orientMC), 0.0)).xyz;\n\n // make sure it is pointing out of the screen\n if (output.orientVC.z < 0.0)\n {\n output.orientVC = -output.orientVC;\n }\n\n // make the basis\n var xbase: vec3<f32>;\n var ybase: vec3<f32>;\n var dir: vec3<f32> = vec3<f32>(0.0,0.0,1.0);\n if (rendererUBO.cameraParallel == 0u)\n {\n dir = normalize(-vertexVC.xyz);\n }\n if (abs(dot(dir,output.orientVC)) == 1.0)\n {\n xbase = normalize(cross(vec3<f32>(0.0,1.0,0.0),output.orientVC));\n ybase = cross(xbase,output.orientVC);\n }\n else\n {\n xbase = normalize(cross(output.orientVC,dir));\n ybase = cross(output.orientVC,xbase);\n }\n\n\n var vertIdx: u32 = input.vertexIndex % 12u;\n var offsets: vec3<f32> = offsetsArray[vertIdx];\n\n vertexVC = vec4<f32>(vertexVC.xyz +\n output.radiusVC * offsets.x * xbase +\n output.radiusVC * offsets.y * ybase +\n 0.5 * output.lengthVC * offsets.z * output.orientVC, 1.0);\n\n output.vertexVC = vertexVC;\n\n //VTK::Position::Impl\n\n return output;\n}\n"; // ----------------------------------------------------------------------------
35
+ const vtkWebGPUStickMapperVS = `
36
+ //VTK::Renderer::Dec
37
+
38
+ //VTK::Mapper::Dec
39
+
40
+ //VTK::Color::Dec
41
+
42
+ //VTK::IOStructs::Dec
43
+
44
+ @vertex
45
+ fn main(
46
+ //VTK::IOStructs::Input
47
+ )
48
+ //VTK::IOStructs::Output
49
+ {
50
+ var offsetsArray: array<vec3<f32>, 12> = array<vec3<f32>, 12>(
51
+ vec3<f32>(-1.0, -1.0, -1.0),
52
+ vec3<f32>(1.0, -1.0, -1.0),
53
+ vec3<f32>(1.0, -1.0, 1.0),
54
+
55
+ vec3<f32>(-1.0, -1.0, -1.0),
56
+ vec3<f32>(1.0, -1.0, 1.0),
57
+ vec3<f32>(-1.0, -1.0, 1.0),
58
+
59
+ vec3<f32>(-1.0, -1.0, 1.0),
60
+ vec3<f32>(1.0, -1.0, 1.0),
61
+ vec3<f32>(1.0, 1.0, 1.0),
62
+
63
+ vec3<f32>(-1.0, -1.0, 1.0),
64
+ vec3<f32>(1.0, 1.0, 1.0),
65
+ vec3<f32>(-1.0, 1.0, 1.0)
66
+ );
67
+
68
+ var output : vertexOutput;
69
+
70
+ var vertexVC: vec4<f32> = rendererUBO.SCVCMatrix * mapperUBO.BCSCMatrix * vec4<f32>(vertexBC.xyz, 1.0);
71
+
72
+ //VTK::Color::Impl
73
+
74
+ // compute the projected vertex position
75
+ output.centerVC = vertexVC.xyz;
76
+ output.radiusVC = radiusMC;
77
+ output.lengthVC = length(orientMC);
78
+ output.orientVC = (rendererUBO.WCVCNormals * vec4<f32>(normalize(orientMC), 0.0)).xyz;
79
+
80
+ // make sure it is pointing out of the screen
81
+ if (output.orientVC.z < 0.0)
82
+ {
83
+ output.orientVC = -output.orientVC;
84
+ }
85
+
86
+ // make the basis
87
+ var xbase: vec3<f32>;
88
+ var ybase: vec3<f32>;
89
+ var dir: vec3<f32> = vec3<f32>(0.0,0.0,1.0);
90
+ if (rendererUBO.cameraParallel == 0u)
91
+ {
92
+ dir = normalize(-vertexVC.xyz);
93
+ }
94
+ if (abs(dot(dir,output.orientVC)) == 1.0)
95
+ {
96
+ xbase = normalize(cross(vec3<f32>(0.0,1.0,0.0),output.orientVC));
97
+ ybase = cross(xbase,output.orientVC);
98
+ }
99
+ else
100
+ {
101
+ xbase = normalize(cross(output.orientVC,dir));
102
+ ybase = cross(output.orientVC,xbase);
103
+ }
104
+
105
+
106
+ var vertIdx: u32 = input.vertexIndex % 12u;
107
+ var offsets: vec3<f32> = offsetsArray[vertIdx];
108
+
109
+ vertexVC = vec4<f32>(vertexVC.xyz +
110
+ output.radiusVC * offsets.x * xbase +
111
+ output.radiusVC * offsets.y * ybase +
112
+ 0.5 * output.lengthVC * offsets.z * output.orientVC, 1.0);
113
+
114
+ output.vertexVC = vertexVC;
115
+
116
+ //VTK::Position::Impl
117
+
118
+ return output;
119
+ }
120
+ `;
121
+
122
+ // ----------------------------------------------------------------------------
30
123
  // vtkWebGPUStickMapper methods
31
124
  // ----------------------------------------------------------------------------
32
125
 
33
126
  function vtkWebGPUStickMapper(publicAPI, model) {
34
127
  // Set our className
35
128
  model.classHierarchy.push('vtkWebGPUStickMapper');
36
- var cellMapperBuildPass = publicAPI.buildPass;
37
-
38
- publicAPI.buildPass = function (prepass) {
129
+ const cellMapperBuildPass = publicAPI.buildPass;
130
+ publicAPI.buildPass = prepass => {
39
131
  if (prepass) {
40
132
  if (!model.renderable.getStatic()) {
41
133
  model.renderable.update();
42
134
  }
43
-
44
- var poly = model.renderable.getInputData();
135
+ const poly = model.renderable.getInputData();
45
136
  publicAPI.setCellArray(poly.getVerts());
46
137
  publicAPI.setCurrentInput(poly);
47
138
  }
48
-
49
139
  cellMapperBuildPass(prepass);
50
140
  };
51
-
52
- publicAPI.replaceShaderNormal = function (hash, pipeline, vertexInput) {
53
- var vDesc = pipeline.getShaderDescription('vertex');
141
+ publicAPI.replaceShaderNormal = (hash, pipeline, vertexInput) => {
142
+ const vDesc = pipeline.getShaderDescription('vertex');
54
143
  if (!vDesc.hasOutput('vertexVC')) vDesc.addOutput('vec4<f32>', 'vertexVC');
55
144
  vDesc.addOutput('vec3<f32>', 'centerVC');
56
145
  vDesc.addOutput('vec3<f32>', 'orientVC');
57
146
  vDesc.addOutput('f32', 'radiusVC');
58
147
  vDesc.addOutput('f32', 'lengthVC');
59
148
  vDesc.addBuiltinInput('u32', '@builtin(vertex_index) vertexIndex');
60
- var fDesc = pipeline.getShaderDescription('fragment');
149
+ const fDesc = pipeline.getShaderDescription('fragment');
61
150
  fDesc.addBuiltinOutput('f32', '@builtin(frag_depth) fragDepth');
62
- var stickFrag = "\n // compute the eye position and unit direction\n var vertexVC: vec4<f32>;\n var EyePos: vec3<f32>;\n var EyeDir: vec3<f32>;\n\n if (rendererUBO.cameraParallel != 0u)\n {\n EyePos = vec3<f32>(input.vertexVC.x, input.vertexVC.y, input.vertexVC.z + 3.0*input.radiusVC);\n EyeDir = vec3<f32>(0.0, 0.0, -1.0);\n }\n else\n {\n EyeDir = input.vertexVC.xyz;\n EyePos = vec3<f32>(0.0,0.0,0.0);\n var lengthED: f32 = length(EyeDir);\n EyeDir = normalize(EyeDir);\n // we adjust the EyePos to be closer if it is too far away\n // to prevent floating point precision noise\n if (lengthED > input.radiusVC*3.0)\n {\n EyePos = input.vertexVC.xyz - EyeDir*3.0*input.radiusVC;\n }\n }\n // translate to Sphere center\n EyePos = EyePos - input.centerVC;\n\n // rotate to new basis\n // base1, base2, orientVC\n var base1: vec3<f32>;\n if (abs(input.orientVC.z) < 0.99)\n {\n base1 = normalize(cross(input.orientVC,vec3<f32>(0.0,0.0,1.0)));\n }\n else\n {\n base1 = normalize(cross(input.orientVC,vec3<f32>(0.0,1.0,0.0)));\n }\n var base2: vec3<f32> = cross(input.orientVC,base1);\n EyePos = vec3<f32>(dot(EyePos,base1),dot(EyePos,base2),dot(EyePos,input.orientVC));\n EyeDir = vec3<f32>(dot(EyeDir,base1),dot(EyeDir,base2),dot(EyeDir,input.orientVC));\n\n // scale to radius 1.0\n EyePos = EyePos * (1.0 / input.radiusVC);\n\n // find the intersection\n var a: f32 = EyeDir.x*EyeDir.x + EyeDir.y*EyeDir.y;\n var b: f32 = 2.0*(EyePos.x*EyeDir.x + EyePos.y*EyeDir.y);\n var c: f32 = EyePos.x*EyePos.x + EyePos.y*EyePos.y - 1.0;\n var d: f32 = b*b - 4.0*a*c;\n var normal: vec3<f32> = vec3<f32>(0.0,0.0,1.0);\n if (d < 0.0) { discard; }\n else\n {\n var t: f32 = (-b - sqrt(d))*(0.5 / a);\n var tz: f32 = EyePos.z + t*EyeDir.z;\n var iPoint: vec3<f32> = EyePos + t*EyeDir;\n if (abs(iPoint.z)*input.radiusVC > input.lengthVC*0.5)\n {\n // test for end cap\n var t2: f32 = (-b + sqrt(d))*(0.5 / a);\n var tz2: f32 = EyePos.z + t2*EyeDir.z;\n if (tz2*input.radiusVC > input.lengthVC*0.5 || tz*input.radiusVC < -0.5*input.lengthVC) { discard; }\n else\n {\n normal = input.orientVC;\n var t3: f32 = (input.lengthVC*0.5/input.radiusVC - EyePos.z)/EyeDir.z;\n iPoint = EyePos + t3*EyeDir;\n vertexVC = vec4<f32>(input.radiusVC*(iPoint.x*base1 + iPoint.y*base2 + iPoint.z*input.orientVC) + input.centerVC, 1.0);\n }\n }\n else\n {\n // The normal is the iPoint.xy rotated back into VC\n normal = iPoint.x*base1 + iPoint.y*base2;\n // rescale rerotate and translate\n vertexVC = vec4<f32>(input.radiusVC*(normal + iPoint.z*input.orientVC) + input.centerVC, 1.0);\n }\n }\n // compute the pixel's depth\n var pos: vec4<f32> = rendererUBO.VCPCMatrix * vertexVC;\n output.fragDepth = pos.z / pos.w;\n ";
63
- var code = fDesc.getCode();
151
+ const stickFrag = `
152
+ // compute the eye position and unit direction
153
+ var vertexVC: vec4<f32>;
154
+ var EyePos: vec3<f32>;
155
+ var EyeDir: vec3<f32>;
156
+
157
+ if (rendererUBO.cameraParallel != 0u)
158
+ {
159
+ EyePos = vec3<f32>(input.vertexVC.x, input.vertexVC.y, input.vertexVC.z + 3.0*input.radiusVC);
160
+ EyeDir = vec3<f32>(0.0, 0.0, -1.0);
161
+ }
162
+ else
163
+ {
164
+ EyeDir = input.vertexVC.xyz;
165
+ EyePos = vec3<f32>(0.0,0.0,0.0);
166
+ var lengthED: f32 = length(EyeDir);
167
+ EyeDir = normalize(EyeDir);
168
+ // we adjust the EyePos to be closer if it is too far away
169
+ // to prevent floating point precision noise
170
+ if (lengthED > input.radiusVC*3.0)
171
+ {
172
+ EyePos = input.vertexVC.xyz - EyeDir*3.0*input.radiusVC;
173
+ }
174
+ }
175
+ // translate to Sphere center
176
+ EyePos = EyePos - input.centerVC;
177
+
178
+ // rotate to new basis
179
+ // base1, base2, orientVC
180
+ var base1: vec3<f32>;
181
+ if (abs(input.orientVC.z) < 0.99)
182
+ {
183
+ base1 = normalize(cross(input.orientVC,vec3<f32>(0.0,0.0,1.0)));
184
+ }
185
+ else
186
+ {
187
+ base1 = normalize(cross(input.orientVC,vec3<f32>(0.0,1.0,0.0)));
188
+ }
189
+ var base2: vec3<f32> = cross(input.orientVC,base1);
190
+ EyePos = vec3<f32>(dot(EyePos,base1),dot(EyePos,base2),dot(EyePos,input.orientVC));
191
+ EyeDir = vec3<f32>(dot(EyeDir,base1),dot(EyeDir,base2),dot(EyeDir,input.orientVC));
192
+
193
+ // scale to radius 1.0
194
+ EyePos = EyePos * (1.0 / input.radiusVC);
195
+
196
+ // find the intersection
197
+ var a: f32 = EyeDir.x*EyeDir.x + EyeDir.y*EyeDir.y;
198
+ var b: f32 = 2.0*(EyePos.x*EyeDir.x + EyePos.y*EyeDir.y);
199
+ var c: f32 = EyePos.x*EyePos.x + EyePos.y*EyePos.y - 1.0;
200
+ var d: f32 = b*b - 4.0*a*c;
201
+ var normal: vec3<f32> = vec3<f32>(0.0,0.0,1.0);
202
+ if (d < 0.0) { discard; }
203
+ else
204
+ {
205
+ var t: f32 = (-b - sqrt(d))*(0.5 / a);
206
+ var tz: f32 = EyePos.z + t*EyeDir.z;
207
+ var iPoint: vec3<f32> = EyePos + t*EyeDir;
208
+ if (abs(iPoint.z)*input.radiusVC > input.lengthVC*0.5)
209
+ {
210
+ // test for end cap
211
+ var t2: f32 = (-b + sqrt(d))*(0.5 / a);
212
+ var tz2: f32 = EyePos.z + t2*EyeDir.z;
213
+ if (tz2*input.radiusVC > input.lengthVC*0.5 || tz*input.radiusVC < -0.5*input.lengthVC) { discard; }
214
+ else
215
+ {
216
+ normal = input.orientVC;
217
+ var t3: f32 = (input.lengthVC*0.5/input.radiusVC - EyePos.z)/EyeDir.z;
218
+ iPoint = EyePos + t3*EyeDir;
219
+ vertexVC = vec4<f32>(input.radiusVC*(iPoint.x*base1 + iPoint.y*base2 + iPoint.z*input.orientVC) + input.centerVC, 1.0);
220
+ }
221
+ }
222
+ else
223
+ {
224
+ // The normal is the iPoint.xy rotated back into VC
225
+ normal = iPoint.x*base1 + iPoint.y*base2;
226
+ // rescale rerotate and translate
227
+ vertexVC = vec4<f32>(input.radiusVC*(normal + iPoint.z*input.orientVC) + input.centerVC, 1.0);
228
+ }
229
+ }
230
+ // compute the pixel's depth
231
+ var pos: vec4<f32> = rendererUBO.VCPCMatrix * vertexVC;
232
+ output.fragDepth = pos.z / pos.w;
233
+ `;
234
+ let code = fDesc.getCode();
64
235
  code = vtkWebGPUShaderCache.substitute(code, '//VTK::Normal::Impl', [stickFrag]).result;
65
236
  fDesc.setCode(code);
66
237
  };
67
-
68
- publicAPI.replaceShaderPosition = function (hash, pipeline, vertexInput) {
69
- var vDesc = pipeline.getShaderDescription('vertex');
238
+ publicAPI.replaceShaderPosition = (hash, pipeline, vertexInput) => {
239
+ const vDesc = pipeline.getShaderDescription('vertex');
70
240
  vDesc.addBuiltinOutput('vec4<f32>', '@builtin(position) Position');
71
- var code = vDesc.getCode();
241
+ let code = vDesc.getCode();
72
242
  code = vtkWebGPUShaderCache.substitute(code, '//VTK::Position::Impl', [' output.Position = rendererUBO.VCPCMatrix*vertexVC;']).result;
73
243
  vDesc.setCode(code);
74
- }; // compute a unique hash for a pipeline, this needs to be unique enough to
244
+ };
245
+
246
+ // compute a unique hash for a pipeline, this needs to be unique enough to
75
247
  // capture any pipeline code changes (which includes shader changes)
76
248
  // or vertex input changes/ bind groups/ etc
77
-
78
-
79
- publicAPI.computePipelineHash = function () {
249
+ publicAPI.computePipelineHash = () => {
80
250
  model.pipelineHash = 'stm';
81
-
82
- if (model.vertexInput.hasAttribute("colorVI")) {
83
- model.pipelineHash += "c";
251
+ if (model.vertexInput.hasAttribute(`colorVI`)) {
252
+ model.pipelineHash += `c`;
84
253
  }
85
-
86
254
  model.pipelineHash += model.renderEncoder.getPipelineHash();
87
255
  };
88
-
89
- publicAPI.updateBuffers = function () {
90
- var poly = model.currentInput;
256
+ publicAPI.updateBuffers = () => {
257
+ const poly = model.currentInput;
91
258
  model.renderable.mapScalars(poly, 1.0);
92
- var device = model.device;
93
- var points = poly.getPoints();
94
- var pointData = poly.getPointData();
95
- var numPoints = points.getNumberOfPoints();
96
- var pointArray = points.getData();
259
+ const device = model.device;
260
+ const points = poly.getPoints();
261
+ const pointData = poly.getPointData();
262
+ const numPoints = points.getNumberOfPoints();
263
+ const pointArray = points.getData();
97
264
  publicAPI.setNumberOfInstances(numPoints);
98
265
  publicAPI.setNumberOfVertices(12);
99
- var vertexInput = model.vertexInput;
100
- var hash = "stm".concat(points.getMTime(), "float32x3");
101
-
266
+ const vertexInput = model.vertexInput;
267
+ let hash = `stm${points.getMTime()}float32x3`;
102
268
  if (!device.getBufferManager().hasBuffer(hash)) {
103
- var buffRequest = {
104
- hash: hash,
269
+ const buffRequest = {
270
+ hash,
105
271
  usage: BufferUsage.RawVertex,
106
272
  format: 'float32x3'
107
- }; // xyz v1 v2 v3
108
-
109
- var tmpVBO = new Float32Array(numPoints * 3);
110
- var pointIdx = 0;
111
- var vboIdx = 0;
112
-
113
- for (var id = 0; id < numPoints; ++id) {
273
+ };
274
+ // xyz v1 v2 v3
275
+ const tmpVBO = new Float32Array(numPoints * 3);
276
+ let pointIdx = 0;
277
+ let vboIdx = 0;
278
+ for (let id = 0; id < numPoints; ++id) {
114
279
  pointIdx = id * 3;
115
280
  tmpVBO[vboIdx++] = pointArray[pointIdx];
116
281
  tmpVBO[vboIdx++] = pointArray[pointIdx + 1];
117
282
  tmpVBO[vboIdx++] = pointArray[pointIdx + 2];
118
283
  }
119
-
120
284
  buffRequest.nativeArray = tmpVBO;
121
- var buff = device.getBufferManager().getBuffer(buffRequest);
285
+ const buff = device.getBufferManager().getBuffer(buffRequest);
122
286
  vertexInput.addBuffer(buff, ['vertexBC'], 'instance');
123
- } // compute offset VBO
124
-
125
-
126
- var scales = null;
287
+ }
127
288
 
289
+ // compute offset VBO
290
+ let scales = null;
128
291
  if (model.renderable.getScaleArray() != null && pointData.hasArray(model.renderable.getScaleArray())) {
129
292
  scales = pointData.getArray(model.renderable.getScaleArray()).getData();
130
293
  }
131
-
132
- var defaultRadius = model.renderable.getRadius();
133
-
294
+ const defaultRadius = model.renderable.getRadius();
134
295
  if (scales || defaultRadius !== model._lastRadius) {
135
- hash = "stm".concat(scales ? pointData.getArray(model.renderable.getScaleArray()).getMTime() : defaultRadius, "float32");
136
-
296
+ hash = `stm${scales ? pointData.getArray(model.renderable.getScaleArray()).getMTime() : defaultRadius}float32`;
137
297
  if (!device.getBufferManager().hasBuffer(hash)) {
138
- var _buffRequest = {
139
- hash: hash,
298
+ const buffRequest = {
299
+ hash,
140
300
  usage: BufferUsage.RawVertex,
141
301
  format: 'float32'
142
302
  };
143
-
144
- var _tmpVBO = new Float32Array(numPoints);
145
-
146
- var _vboIdx = 0;
147
-
148
- for (var _id = 0; _id < numPoints; ++_id) {
149
- var radius = model.renderable.getRadius();
150
-
303
+ const tmpVBO = new Float32Array(numPoints);
304
+ let vboIdx = 0;
305
+ for (let id = 0; id < numPoints; ++id) {
306
+ let radius = model.renderable.getRadius();
151
307
  if (scales) {
152
- radius = scales[_id * 2 + 1];
308
+ radius = scales[id * 2 + 1];
153
309
  }
154
-
155
- _tmpVBO[_vboIdx++] = radius;
310
+ tmpVBO[vboIdx++] = radius;
156
311
  }
157
-
158
- _buffRequest.nativeArray = _tmpVBO;
159
-
160
- var _buff = device.getBufferManager().getBuffer(_buffRequest);
161
-
162
- vertexInput.addBuffer(_buff, ['radiusMC'], 'instance');
312
+ buffRequest.nativeArray = tmpVBO;
313
+ const buff = device.getBufferManager().getBuffer(buffRequest);
314
+ vertexInput.addBuffer(buff, ['radiusMC'], 'instance');
163
315
  }
164
-
165
316
  model._lastRadius = defaultRadius;
166
317
  }
167
-
168
- var orientationArray = null;
169
-
318
+ let orientationArray = null;
170
319
  if (model.renderable.getOrientationArray() != null && pointData.hasArray(model.renderable.getOrientationArray())) {
171
320
  orientationArray = pointData.getArray(model.renderable.getOrientationArray()).getData();
172
321
  } else {
173
322
  vtkErrorMacro(['Error setting orientationArray.\n', 'You have to specify the stick orientation']);
174
323
  }
175
-
176
- hash = "stm".concat(pointData.getArray(model.renderable.getOrientationArray()).getMTime(), "float32x3");
177
-
324
+ hash = `stm${pointData.getArray(model.renderable.getOrientationArray()).getMTime()}float32x3`;
178
325
  if (!device.getBufferManager().hasBuffer(hash)) {
179
- var _buffRequest2 = {
180
- hash: hash,
326
+ const buffRequest = {
327
+ hash,
181
328
  usage: BufferUsage.RawVertex,
182
329
  format: 'float32x3'
183
- }; // xyz v1 v2 v3
184
-
185
- var _tmpVBO2 = new Float32Array(numPoints * 3);
186
-
187
- var _pointIdx = 0;
188
- var _vboIdx2 = 0;
189
-
190
- for (var _id2 = 0; _id2 < numPoints; ++_id2) {
191
- _pointIdx = _id2 * 3;
192
- var length = model.renderable.getLength();
193
-
330
+ };
331
+ // xyz v1 v2 v3
332
+ const tmpVBO = new Float32Array(numPoints * 3);
333
+ let pointIdx = 0;
334
+ let vboIdx = 0;
335
+ for (let id = 0; id < numPoints; ++id) {
336
+ pointIdx = id * 3;
337
+ let length = model.renderable.getLength();
194
338
  if (scales) {
195
- length = scales[_id2 * 2];
339
+ length = scales[id * 2];
196
340
  }
197
-
198
- _tmpVBO2[_vboIdx2++] = orientationArray[_pointIdx] * length;
199
- _tmpVBO2[_vboIdx2++] = orientationArray[_pointIdx + 1] * length;
200
- _tmpVBO2[_vboIdx2++] = orientationArray[_pointIdx + 2] * length;
341
+ tmpVBO[vboIdx++] = orientationArray[pointIdx] * length;
342
+ tmpVBO[vboIdx++] = orientationArray[pointIdx + 1] * length;
343
+ tmpVBO[vboIdx++] = orientationArray[pointIdx + 2] * length;
201
344
  }
345
+ buffRequest.nativeArray = tmpVBO;
346
+ const buff = device.getBufferManager().getBuffer(buffRequest);
347
+ vertexInput.addBuffer(buff, ['orientMC'], 'instance');
348
+ }
202
349
 
203
- _buffRequest2.nativeArray = _tmpVBO2;
204
-
205
- var _buff2 = device.getBufferManager().getBuffer(_buffRequest2);
206
-
207
- vertexInput.addBuffer(_buff2, ['orientMC'], 'instance');
208
- } // deal with colors but only if modified
209
-
210
-
211
- var haveColors = false;
212
-
350
+ // deal with colors but only if modified
351
+ let haveColors = false;
213
352
  if (model.renderable.getScalarVisibility()) {
214
- var c = model.renderable.getColorMapColors();
215
-
353
+ const c = model.renderable.getColorMapColors();
216
354
  if (c) {
217
- hash = "stm".concat(c.getMTime(), "unorm8x4");
218
-
355
+ hash = `stm${c.getMTime()}unorm8x4`;
219
356
  if (!device.getBufferManager().hasBuffer(hash)) {
220
- var _buffRequest3 = {
357
+ const buffRequest = {
221
358
  usage: BufferUsage.RawVertex,
222
359
  format: 'unorm8x4'
223
360
  };
224
- var colorComponents = c.getNumberOfComponents();
225
-
361
+ const colorComponents = c.getNumberOfComponents();
226
362
  if (colorComponents !== 4) {
227
363
  vtkErrorMacro('this should be 4');
228
364
  }
229
-
230
- var _tmpVBO3 = new Uint8Array(numPoints * 4);
231
-
232
- var _vboIdx3 = 0;
233
- var colorData = c.getData();
234
-
235
- for (var _id3 = 0; _id3 < numPoints; ++_id3) {
236
- var colorIdx = _id3 * colorComponents;
237
- _tmpVBO3[_vboIdx3++] = colorData[colorIdx];
238
- _tmpVBO3[_vboIdx3++] = colorData[colorIdx + 1];
239
- _tmpVBO3[_vboIdx3++] = colorData[colorIdx + 2];
240
- _tmpVBO3[_vboIdx3++] = colorData[colorIdx + 3];
365
+ const tmpVBO = new Uint8Array(numPoints * 4);
366
+ let vboIdx = 0;
367
+ const colorData = c.getData();
368
+ for (let id = 0; id < numPoints; ++id) {
369
+ const colorIdx = id * colorComponents;
370
+ tmpVBO[vboIdx++] = colorData[colorIdx];
371
+ tmpVBO[vboIdx++] = colorData[colorIdx + 1];
372
+ tmpVBO[vboIdx++] = colorData[colorIdx + 2];
373
+ tmpVBO[vboIdx++] = colorData[colorIdx + 3];
241
374
  }
242
-
243
- _buffRequest3.nativeArray = _tmpVBO3;
244
-
245
- var _buff3 = device.getBufferManager().getBuffer(_buffRequest3);
246
-
247
- vertexInput.addBuffer(_buff3, ['colorVI'], 'instance');
375
+ buffRequest.nativeArray = tmpVBO;
376
+ const buff = device.getBufferManager().getBuffer(buffRequest);
377
+ vertexInput.addBuffer(buff, ['colorVI'], 'instance');
248
378
  }
249
-
250
379
  haveColors = true;
251
380
  }
252
381
  }
253
-
254
382
  if (!haveColors) {
255
383
  vertexInput.removeBufferIfPresent('colorVI');
256
384
  }
257
-
258
385
  publicAPI.setTopology('triangle-list');
259
386
  publicAPI.updateUBO();
260
387
  };
261
- } // ----------------------------------------------------------------------------
388
+ }
389
+
390
+ // ----------------------------------------------------------------------------
262
391
  // Object factory
263
392
  // ----------------------------------------------------------------------------
264
393
 
394
+ const DEFAULT_VALUES = {};
265
395
 
266
- var DEFAULT_VALUES = {}; // ----------------------------------------------------------------------------
396
+ // ----------------------------------------------------------------------------
267
397
 
268
398
  function extend(publicAPI, model) {
269
- var initialValues = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
270
- Object.assign(model, DEFAULT_VALUES, initialValues); // Inheritance
399
+ let initialValues = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
400
+ Object.assign(model, DEFAULT_VALUES, initialValues);
271
401
 
402
+ // Inheritance
272
403
  vtkWebGPUCellArrayMapper.extend(publicAPI, model, initialValues);
273
- publicAPI.setVertexShaderTemplate(vtkWebGPUStickMapperVS); // Object methods
404
+ publicAPI.setVertexShaderTemplate(vtkWebGPUStickMapperVS);
274
405
 
406
+ // Object methods
275
407
  vtkWebGPUStickMapper(publicAPI, model);
276
- var sr = model.shaderReplacements;
408
+ const sr = model.shaderReplacements;
277
409
  sr.set('replaceShaderPosition', publicAPI.replaceShaderPosition);
278
410
  sr.set('replaceShaderNormal', publicAPI.replaceShaderNormal);
279
- } // ----------------------------------------------------------------------------
411
+ }
412
+
413
+ // ----------------------------------------------------------------------------
414
+
415
+ const newInstance = newInstance$1(extend, 'vtkWebGPUStickMapper');
280
416
 
281
- var newInstance = newInstance$1(extend, 'vtkWebGPUStickMapper'); // ----------------------------------------------------------------------------
417
+ // ----------------------------------------------------------------------------
282
418
 
283
419
  var index = {
284
- newInstance: newInstance,
285
- extend: extend
286
- }; // Register ourself to WebGPU backend if imported
420
+ newInstance,
421
+ extend
422
+ };
287
423
 
424
+ // Register ourself to WebGPU backend if imported
288
425
  registerOverride('vtkStickMapper', newInstance);
289
426
 
290
427
  export { index as default, extend, newInstance };