x_ite 4.7.12 → 5.0.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.
- package/.vscode/settings.json +9 -2
- package/Makefile +27 -24
- package/build/bin/version-number.pl +1 -1
- package/build/bin/version.pl +3 -3
- package/build/parts/default.start.frag.js +2 -2
- package/build/parts/x_ite.end.frag.js +1 -2
- package/build/parts/x_ite.start.frag.js +4 -7
- package/dist/assets/components/annotation.js +312 -312
- package/dist/assets/components/annotation.min.js +1 -1
- package/dist/assets/components/cad-geometry.js +536 -538
- package/dist/assets/components/cad-geometry.min.js +1 -1
- package/dist/assets/components/cube-map-texturing.js +797 -796
- package/dist/assets/components/cube-map-texturing.min.js +1 -1
- package/dist/assets/components/dis.js +487 -472
- package/dist/assets/components/dis.min.js +1 -1
- package/dist/assets/components/event-utilities.js +486 -505
- package/dist/assets/components/event-utilities.min.js +1 -1
- package/dist/assets/components/geometry2d.js +1221 -1271
- package/dist/assets/components/geometry2d.min.js +1 -1
- package/dist/assets/components/geospatial.js +2657 -2653
- package/dist/assets/components/geospatial.min.js +1 -2
- package/dist/assets/components/h-anim.js +640 -640
- package/dist/assets/components/h-anim.min.js +1 -1
- package/dist/assets/components/key-device-sensor.js +547 -549
- package/dist/assets/components/key-device-sensor.min.js +1 -1
- package/dist/assets/components/layout.js +1435 -1433
- package/dist/assets/components/layout.min.js +1 -1
- package/dist/assets/components/nurbs.js +3942 -3964
- package/dist/assets/components/nurbs.min.js +1 -2
- package/dist/assets/components/particle-systems.js +3227 -3238
- package/dist/assets/components/particle-systems.min.js +1 -2
- package/dist/assets/components/picking.js +1704 -1712
- package/dist/assets/components/picking.min.js +1 -1
- package/dist/assets/components/projective-texture-mapping.js +553 -553
- package/dist/assets/components/projective-texture-mapping.min.js +1 -1
- package/dist/assets/components/rigid-body-physics.js +3255 -3265
- package/dist/assets/components/rigid-body-physics.min.js +1 -59
- package/dist/assets/components/scripting.js +544 -549
- package/dist/assets/components/scripting.min.js +1 -1
- package/dist/assets/components/texturing-3d.js +2716 -2651
- package/dist/assets/components/texturing-3d.min.js +131 -48
- package/dist/assets/components/volume-rendering.js +2815 -2804
- package/dist/assets/components/volume-rendering.min.js +1 -3
- package/dist/assets/components/x_ite.js +142 -144
- package/dist/assets/components/x_ite.min.js +1 -1
- package/dist/assets/shaders/webgl1/Gouraud.fs +52 -15
- package/dist/assets/shaders/webgl1/Gouraud.vs +8 -9
- package/dist/assets/shaders/webgl1/{Wireframe.fs → Line.fs} +0 -0
- package/dist/assets/shaders/webgl1/{Wireframe.vs → Line.vs} +1 -1
- package/dist/assets/shaders/webgl1/PBR.fs +785 -0
- package/dist/assets/shaders/webgl1/PBR.vs +37 -0
- package/dist/assets/shaders/webgl1/Phong.fs +204 -32
- package/dist/assets/shaders/webgl1/Phong.vs +2 -3
- package/dist/assets/shaders/webgl1/{PointSet.fs → Point.fs} +59 -33
- package/dist/assets/shaders/webgl1/{PointSet.vs → Point.vs} +2 -2
- package/dist/assets/shaders/webgl1/Unlit.fs +73 -18
- package/dist/assets/shaders/webgl1/Unlit.vs +2 -3
- package/dist/assets/shaders/webgl2/Gouraud.fs +31 -19
- package/dist/assets/shaders/webgl2/Gouraud.vs +8 -9
- package/dist/assets/shaders/webgl2/{Wireframe.fs → Line.fs} +0 -0
- package/dist/assets/shaders/webgl2/{Wireframe.vs → Line.vs} +1 -1
- package/dist/assets/shaders/webgl2/PBR.fs +913 -0
- package/dist/assets/shaders/webgl2/PBR.vs +37 -0
- package/dist/assets/shaders/webgl2/Phong.fs +196 -35
- package/dist/assets/shaders/webgl2/Phong.vs +2 -3
- package/dist/assets/shaders/webgl2/{PointSet.fs → Point.fs} +87 -86
- package/dist/assets/shaders/webgl2/{PointSet.vs → Point.vs} +2 -2
- package/dist/assets/shaders/webgl2/Unlit.fs +55 -22
- package/dist/assets/shaders/webgl2/Unlit.vs +2 -3
- package/dist/example.html +2 -2
- package/dist/x_ite.css +316 -328
- package/dist/x_ite.js +55663 -52034
- package/dist/x_ite.min.js +79 -41
- package/dist/x_ite.zip +0 -0
- package/docs/Custom-Shaders.md +4 -3
- package/docs/_config.yml +1 -1
- package/docs/index.md +60 -7
- package/package.json +20 -20
- package/src/assets/components/annotation.js +24 -24
- package/src/assets/components/cad-geometry.js +24 -25
- package/src/assets/components/cube-map-texturing.js +18 -19
- package/src/assets/components/dis.js +22 -23
- package/src/assets/components/event-utilities.js +28 -29
- package/src/assets/components/geometry2d.js +28 -29
- package/src/assets/components/geospatial.js +34 -35
- package/src/assets/components/h-anim.js +22 -22
- package/src/assets/components/key-device-sensor.js +18 -19
- package/src/assets/components/layout.js +24 -25
- package/src/assets/components/nurbs.js +44 -45
- package/src/assets/components/particle-systems.js +36 -37
- package/src/assets/components/picking.js +25 -25
- package/src/assets/components/projective-texture-mapping.js +16 -16
- package/src/assets/components/rigid-body-physics.js +48 -48
- package/src/assets/components/scripting.js +14 -15
- package/src/assets/components/texturing-3d.js +26 -27
- package/src/assets/components/volume-rendering.js +46 -46
- package/src/assets/components/x_ite.js +12 -12
- package/src/assets/shaders/Types.glsl +230 -51
- package/src/assets/shaders/webgl1/Background.fs +2 -2
- package/src/assets/shaders/webgl1/Background.vs +4 -4
- package/src/assets/shaders/webgl1/Depth.fs +2 -2
- package/src/assets/shaders/webgl1/Depth.vs +3 -3
- package/src/assets/shaders/webgl1/Fallback.fs +15 -15
- package/src/assets/shaders/webgl1/Fallback.vs +5 -5
- package/src/assets/shaders/webgl1/FallbackUnlit.fs +4 -4
- package/src/assets/shaders/webgl1/FallbackUnlit.vs +3 -3
- package/src/assets/shaders/webgl1/Gouraud.fs +14 -14
- package/src/assets/shaders/webgl1/Gouraud.vs +54 -69
- package/src/assets/shaders/webgl1/Line.fs +74 -0
- package/src/assets/shaders/webgl1/Line.vs +63 -0
- package/src/assets/shaders/webgl1/PBR.fs +364 -0
- package/src/assets/shaders/webgl1/PBR.vs +46 -0
- package/src/assets/shaders/webgl1/Phong.fs +207 -84
- package/src/assets/shaders/webgl1/Phong.vs +17 -18
- package/src/assets/shaders/webgl1/Point.fs +88 -0
- package/src/assets/shaders/webgl1/Point.vs +70 -0
- package/src/assets/shaders/webgl1/Unlit.fs +53 -28
- package/src/assets/shaders/webgl1/Unlit.vs +17 -18
- package/src/assets/shaders/webgl1/include/ClipPlanes.glsl +7 -7
- package/src/assets/shaders/webgl1/include/Colors.glsl +27 -0
- package/src/assets/shaders/webgl1/include/Fog.glsl +17 -17
- package/src/assets/shaders/webgl1/include/Hatch.glsl +8 -8
- package/src/assets/shaders/webgl1/include/Normal.glsl +44 -0
- package/src/assets/shaders/webgl1/include/Pack.glsl +11 -11
- package/src/assets/shaders/webgl1/include/Perlin.glsl +19 -19
- package/src/assets/shaders/webgl1/include/Shadow.glsl +212 -212
- package/src/assets/shaders/webgl1/include/SpotFactor.glsl +12 -0
- package/src/assets/shaders/webgl1/include/Texture.glsl +444 -393
- package/src/assets/shaders/webgl2/Background.fs +2 -2
- package/src/assets/shaders/webgl2/Background.vs +4 -4
- package/src/assets/shaders/webgl2/Depth.fs +2 -2
- package/src/assets/shaders/webgl2/Depth.vs +3 -3
- package/src/assets/shaders/webgl2/Gouraud.fs +14 -14
- package/src/assets/shaders/webgl2/Gouraud.vs +54 -69
- package/src/assets/shaders/webgl2/Line.fs +73 -0
- package/src/assets/shaders/webgl2/Line.vs +64 -0
- package/src/assets/shaders/webgl2/PBR.fs +370 -0
- package/src/assets/shaders/webgl2/PBR.vs +48 -0
- package/src/assets/shaders/webgl2/Phong.fs +219 -84
- package/src/assets/shaders/webgl2/Phong.vs +17 -18
- package/src/assets/shaders/webgl2/Point.fs +87 -0
- package/src/assets/shaders/webgl2/Point.vs +71 -0
- package/src/assets/shaders/webgl2/Unlit.fs +56 -28
- package/src/assets/shaders/webgl2/Unlit.vs +17 -18
- package/src/assets/shaders/webgl2/include/ClipPlanes.glsl +7 -7
- package/src/assets/shaders/webgl2/include/Colors.glsl +27 -0
- package/src/assets/shaders/webgl2/include/Fog.glsl +34 -34
- package/src/assets/shaders/webgl2/include/Hatch.glsl +8 -8
- package/src/assets/shaders/webgl2/include/Normal.glsl +46 -0
- package/src/assets/shaders/webgl2/include/Pack.glsl +11 -11
- package/src/assets/shaders/webgl2/include/Perlin.glsl +19 -20
- package/src/assets/shaders/webgl2/include/Shadow.glsl +226 -226
- package/src/assets/shaders/webgl2/include/SpotFactor.glsl +12 -0
- package/src/assets/shaders/webgl2/include/Texture.glsl +557 -537
- package/src/bookmarks.js +92 -92
- package/src/examples.js +147 -147
- package/src/lib/ammojs/AmmoJS.js +2 -2
- package/src/lib/ammojs/Makefile +14 -15
- package/src/lib/jquery.fullscreen-min.js +2 -2
- package/src/lib/nurbs/extras/sample.js +215 -215
- package/src/lib/nurbs/nurbs.js +326 -326
- package/src/lib/nurbs/src/evaluate.js +405 -405
- package/src/lib/nurbs/src/numerical-derivative.js +48 -48
- package/src/lib/nurbs/src/support.js +143 -143
- package/src/lib/nurbs/src/transform.js +70 -70
- package/src/lib/nurbs/src/utils/accessor-preamble.js +23 -23
- package/src/lib/nurbs/src/utils/bisection-search.js +18 -18
- package/src/lib/nurbs/src/utils/cache-key.js +49 -50
- package/src/lib/nurbs/src/utils/create-accessors.js +101 -101
- package/src/lib/nurbs/src/utils/infer-type.js +43 -43
- package/src/lib/nurbs/src/utils/is-array-like.js +5 -5
- package/src/lib/nurbs/src/utils/is-ndarray-like.js +11 -11
- package/src/lib/nurbs/src/utils/is-ndarray.js +13 -13
- package/src/lib/nurbs/src/utils/ndloop.js +18 -18
- package/src/lib/nurbs/src/utils/size-getter.js +15 -15
- package/src/lib/nurbs/src/utils/variable.js +25 -25
- package/src/lib/opentype.js/bin/ot +27 -27
- package/src/lib/opentype.js/dist/opentype.js +5 -5
- package/src/lib/opentype.js/font-inspector.html +1 -1
- package/src/lib/opentype.js/site.css +1 -3
- package/src/locale/gettext.js +73 -73
- package/src/spinner.css +40 -43
- package/src/standard/Geospatial/Geodetic.js +195 -195
- package/src/standard/Geospatial/ReferenceEllipsoids.js +43 -43
- package/src/standard/Geospatial/UniversalTransverseMercator.js +159 -159
- package/src/standard/Math/Algorithm.js +199 -187
- package/src/standard/Math/Algorithms/Bezier.js +80 -80
- package/src/standard/Math/Algorithms/MergeSort.js +49 -49
- package/src/standard/Math/Algorithms/PartialSort.js +36 -36
- package/src/standard/Math/Algorithms/QuickSort.js +51 -51
- package/src/standard/Math/Algorithms/SAT.js +62 -62
- package/src/standard/Math/Algorithms/eigendecomposition.js +141 -141
- package/src/standard/Math/Geometry/Box2.js +205 -205
- package/src/standard/Math/Geometry/Box3.js +624 -624
- package/src/standard/Math/Geometry/Camera.js +68 -68
- package/src/standard/Math/Geometry/Cylinder3.js +112 -112
- package/src/standard/Math/Geometry/Line3.js +188 -153
- package/src/standard/Math/Geometry/Plane3.js +120 -120
- package/src/standard/Math/Geometry/Sphere3.js +148 -148
- package/src/standard/Math/Geometry/Spheroid3.js +38 -38
- package/src/standard/Math/Geometry/Triangle2.js +19 -19
- package/src/standard/Math/Geometry/Triangle3.js +148 -148
- package/src/standard/Math/Geometry/ViewVolume.js +359 -359
- package/src/standard/Math/Numbers/Color3.js +219 -214
- package/src/standard/Math/Numbers/Color4.js +148 -142
- package/src/standard/Math/Numbers/Complex.js +139 -139
- package/src/standard/Math/Numbers/Matrix2.js +193 -193
- package/src/standard/Math/Numbers/Matrix3.js +679 -679
- package/src/standard/Math/Numbers/Matrix4.js +883 -883
- package/src/standard/Math/Numbers/Quaternion.js +496 -496
- package/src/standard/Math/Numbers/Rotation4.js +421 -415
- package/src/standard/Math/Numbers/Vector2.js +220 -220
- package/src/standard/Math/Numbers/Vector3.js +280 -280
- package/src/standard/Math/Numbers/Vector4.js +296 -296
- package/src/standard/Math/Utility/BVH.js +303 -303
- package/src/standard/Math/Utility/MatrixStack.js +64 -64
- package/src/standard/Networking/BinaryTransport.js +67 -67
- package/src/standard/Time/MicroTime.js +22 -22
- package/src/standard/Utility/DataStorage.js +85 -81
- package/src/standard/Utility/MapUtilities.js +14 -1
- package/src/standard/Utility/ObjectCache.js +24 -24
- package/src/standard/Utility/Shuffle.js +13 -13
- package/src/tests.js +355 -384
- package/src/x_ite/Base/Events.js +64 -55
- package/src/x_ite/{Basic/X3DArrayField.js → Base/FieldArray.js} +19 -12
- package/src/x_ite/Base/FieldDefinitionArray.js +75 -0
- package/src/x_ite/{Basic/FieldDefinitionArray.js → Base/X3DArrayField.js} +35 -59
- package/src/x_ite/Base/X3DBaseNode.js +588 -0
- package/src/x_ite/{Bits → Base}/X3DCast.js +23 -22
- package/src/x_ite/Base/X3DChildObject.js +68 -62
- package/src/x_ite/{Bits → Base}/X3DConstants.js +85 -85
- package/src/x_ite/Base/X3DEventObject.js +73 -68
- package/src/x_ite/Base/X3DField.js +450 -0
- package/src/x_ite/Base/X3DFieldDefinition.js +78 -0
- package/src/x_ite/Base/X3DInfoArray.js +291 -0
- package/src/x_ite/Base/X3DObject.js +152 -109
- package/src/x_ite/Base/X3DObjectArrayField.js +573 -0
- package/src/x_ite/Base/X3DTypedArrayField.js +866 -0
- package/src/x_ite/Browser/Core/BrowserOptions.js +376 -394
- package/src/x_ite/Browser/Core/BrowserProperties.js +38 -38
- package/src/x_ite/Browser/Core/BrowserTimings.js +173 -172
- package/src/x_ite/Browser/Core/ContextMenu.js +547 -551
- package/src/x_ite/Browser/Core/Notification.js +57 -56
- package/src/x_ite/Browser/Core/PrimitiveQuality.js +8 -8
- package/src/x_ite/Browser/Core/RenderingProperties.js +55 -55
- package/src/x_ite/Browser/Core/Shading.js +10 -10
- package/src/x_ite/Browser/Core/TextureQuality.js +8 -8
- package/src/x_ite/Browser/Core/X3DCoreContext.js +746 -724
- package/src/x_ite/Browser/EnvironmentalEffects/X3DEnvironmentalEffectsContext.js +33 -25
- package/src/x_ite/Browser/Followers/X3DArrayChaserTemplate.js +23 -23
- package/src/x_ite/Browser/Followers/X3DArrayFollowerTemplate.js +127 -127
- package/src/x_ite/Browser/Geometry2D/Arc2DOptions.js +25 -25
- package/src/x_ite/Browser/Geometry2D/ArcClose2DOptions.js +25 -25
- package/src/x_ite/Browser/Geometry2D/Circle2DOptions.js +56 -55
- package/src/x_ite/Browser/Geometry2D/Disk2DOptions.js +116 -116
- package/src/x_ite/Browser/Geometry2D/Rectangle2DOptions.js +59 -59
- package/src/x_ite/Browser/Geometry2D/X3DGeometry2DContext.js +80 -77
- package/src/x_ite/Browser/Geometry3D/BoxOptions.js +70 -70
- package/src/x_ite/Browser/Geometry3D/ConeOptions.js +26 -26
- package/src/x_ite/Browser/Geometry3D/CylinderOptions.js +27 -27
- package/src/x_ite/Browser/Geometry3D/IcoSphere.js +357 -357
- package/src/x_ite/Browser/Geometry3D/IcoSphereOptions.js +61 -61
- package/src/x_ite/Browser/Geometry3D/QuadSphereOptions.js +243 -241
- package/src/x_ite/Browser/Geometry3D/X3DGeometry3DContext.js +37 -34
- package/src/x_ite/Browser/Geospatial/Geocentric.js +27 -27
- package/src/x_ite/Browser/Geospatial/Geospatial.js +157 -156
- package/src/x_ite/Browser/Grouping/X3DGroupingContext.js +38 -33
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator.js +128 -130
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator1.js +39 -41
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator2.js +3 -3
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolator3.js +3 -3
- package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolatorTemplate.js +54 -56
- package/src/x_ite/Browser/Interpolation/SquatInterpolator.js +54 -56
- package/src/x_ite/Browser/KeyDeviceSensor/X3DKeyDeviceSensorContext.js +44 -41
- package/src/x_ite/Browser/Layering/X3DLayeringContext.js +20 -18
- package/src/x_ite/Browser/Layout/ScreenText.js +406 -405
- package/src/x_ite/Browser/Layout/X3DLayoutContext.js +36 -30
- package/src/x_ite/Browser/Lighting/X3DLightingContext.js +54 -50
- package/src/x_ite/Browser/NURBS/NURBS.js +417 -417
- package/src/x_ite/Browser/Navigation/ExamineViewer.js +753 -753
- package/src/x_ite/Browser/Navigation/FlyViewer.js +39 -39
- package/src/x_ite/Browser/Navigation/LookAtViewer.js +461 -461
- package/src/x_ite/Browser/Navigation/NoneViewer.js +18 -18
- package/src/x_ite/Browser/Navigation/PlaneViewer.js +193 -193
- package/src/x_ite/Browser/Navigation/WalkViewer.js +61 -61
- package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +709 -710
- package/src/x_ite/Browser/Navigation/X3DNavigationContext.js +188 -182
- package/src/x_ite/Browser/Navigation/X3DViewer.js +160 -160
- package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +152 -143
- package/src/x_ite/Browser/Networking/urls.js +31 -31
- package/src/x_ite/Browser/ParticleSystems/X3DParticleSystemsContext.js +17 -13
- package/src/x_ite/Browser/Picking/IntersectionType.js +7 -7
- package/src/x_ite/Browser/Picking/MatchCriterion.js +8 -8
- package/src/x_ite/Browser/Picking/SortOrder.js +9 -9
- package/src/x_ite/Browser/Picking/VolumePicker.js +138 -138
- package/src/x_ite/Browser/Picking/X3DPickingContext.js +80 -69
- package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +208 -209
- package/src/x_ite/Browser/PointingDeviceSensor/PointingDeviceSensorContainer.js +34 -34
- package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +269 -263
- package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +132 -119
- package/src/x_ite/Browser/RigidBodyPhysics/AppliedParametersType.js +14 -14
- package/src/x_ite/Browser/Scripting/X3DScriptingContext.js +20 -19
- package/src/x_ite/Browser/Scripting/evaluate.js +7 -7
- package/src/x_ite/Browser/Shaders/Shader.js +152 -159
- package/src/x_ite/Browser/Shaders/ShaderSource.js +81 -63
- package/src/x_ite/Browser/Shaders/ShaderTest.js +97 -98
- package/src/x_ite/Browser/Shaders/X3DShadersContext.js +256 -249
- package/src/x_ite/Browser/Shape/AlphaMode.js +9 -9
- package/src/x_ite/Browser/Shape/X3DShapeContext.js +111 -89
- package/src/x_ite/Browser/Sound/X3DSoundContext.js +11 -11
- package/src/x_ite/Browser/Text/PolygonText.js +319 -319
- package/src/x_ite/Browser/Text/TextAlignment.js +9 -9
- package/src/x_ite/Browser/Text/X3DTextContext.js +72 -65
- package/src/x_ite/Browser/Text/X3DTextGeometry.js +506 -506
- package/src/x_ite/Browser/Texturing/MultiTextureFunctionType.js +8 -8
- package/src/x_ite/Browser/Texturing/MultiTextureModeType.js +25 -25
- package/src/x_ite/Browser/Texturing/MultiTextureSourceType.js +9 -9
- package/src/x_ite/Browser/Texturing/TextureCoordinateGeneratorModeType.js +17 -17
- package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +259 -224
- package/src/x_ite/Browser/Texturing3D/DICOMParser.js +1066 -1066
- package/src/x_ite/Browser/Texturing3D/NRRDParser.js +641 -630
- package/src/x_ite/Browser/Time/X3DTimeContext.js +54 -37
- package/src/x_ite/Browser/VERSION.js +1 -1
- package/src/x_ite/Browser/VolumeRendering/VolumeStyle.fs +55 -55
- package/src/x_ite/Browser/VolumeRendering/VolumeStyle.vs +5 -5
- package/src/x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext.js +52 -41
- package/src/x_ite/Browser/X3DBrowser.js +819 -755
- package/src/x_ite/Browser/X3DBrowserContext.js +253 -220
- package/src/x_ite/Components/Annotation/AnnotationLayer.js +43 -43
- package/src/x_ite/Components/Annotation/AnnotationTarget.js +38 -38
- package/src/x_ite/Components/Annotation/GroupAnnotation.js +48 -48
- package/src/x_ite/Components/Annotation/IconAnnotation.js +46 -46
- package/src/x_ite/Components/Annotation/TextAnnotation.js +39 -39
- package/src/x_ite/Components/Annotation/URLAnnotation.js +38 -38
- package/src/x_ite/Components/Annotation/X3DAnnotationNode.js +16 -16
- package/src/x_ite/Components/CADGeometry/CADAssembly.js +41 -41
- package/src/x_ite/Components/CADGeometry/CADFace.js +189 -189
- package/src/x_ite/Components/CADGeometry/CADLayer.js +38 -38
- package/src/x_ite/Components/CADGeometry/CADPart.js +46 -46
- package/src/x_ite/Components/CADGeometry/IndexedQuadSet.js +67 -67
- package/src/x_ite/Components/CADGeometry/QuadSet.js +64 -63
- package/src/x_ite/Components/CADGeometry/X3DProductStructureChildNode.js +13 -15
- package/src/x_ite/Components/Core/MetadataBoolean.js +38 -40
- package/src/x_ite/Components/Core/MetadataDouble.js +38 -40
- package/src/x_ite/Components/Core/MetadataFloat.js +38 -40
- package/src/x_ite/Components/Core/MetadataInteger.js +38 -40
- package/src/x_ite/Components/Core/MetadataSet.js +38 -40
- package/src/x_ite/Components/Core/MetadataString.js +38 -40
- package/src/x_ite/Components/Core/WorldInfo.js +42 -42
- package/src/x_ite/Components/Core/X3DBindableNode.js +20 -20
- package/src/x_ite/Components/Core/X3DChildNode.js +38 -40
- package/src/x_ite/Components/Core/X3DInfoNode.js +13 -15
- package/src/x_ite/Components/Core/X3DMetadataObject.js +11 -13
- package/src/x_ite/Components/Core/X3DNode.js +795 -14
- package/src/x_ite/Components/Core/X3DPrototypeInstance.js +585 -479
- package/src/x_ite/Components/Core/X3DSensorNode.js +13 -15
- package/src/x_ite/Components/Core.js +39 -39
- package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +193 -200
- package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +209 -206
- package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +213 -219
- package/src/x_ite/Components/CubeMapTexturing/X3DEnvironmentTextureNode.js +69 -60
- package/src/x_ite/Components/DIS/DISEntityManager.js +38 -40
- package/src/x_ite/Components/DIS/DISEntityTypeMapping.js +59 -41
- package/src/x_ite/Components/DIS/EspduTransform.js +128 -128
- package/src/x_ite/Components/DIS/ReceiverPdu.js +68 -68
- package/src/x_ite/Components/DIS/SignalPdu.js +68 -68
- package/src/x_ite/Components/DIS/TransmitterPdu.js +84 -84
- package/src/x_ite/Components/EnvironmentalEffects/Background.js +87 -89
- package/src/x_ite/Components/EnvironmentalEffects/Fog.js +59 -59
- package/src/x_ite/Components/EnvironmentalEffects/FogCoordinate.js +78 -78
- package/src/x_ite/Components/EnvironmentalEffects/LocalFog.js +56 -56
- package/src/x_ite/Components/EnvironmentalEffects/TextureBackground.js +86 -88
- package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +582 -589
- package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +105 -105
- package/src/x_ite/Components/EnvironmentalEffects.js +25 -25
- package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +229 -229
- package/src/x_ite/Components/EnvironmentalSensor/TransformSensor.js +256 -256
- package/src/x_ite/Components/EnvironmentalSensor/VisibilitySensor.js +114 -114
- package/src/x_ite/Components/EnvironmentalSensor/X3DEnvironmentalSensorNode.js +71 -71
- package/src/x_ite/Components/EnvironmentalSensor.js +19 -19
- package/src/x_ite/Components/EventUtilities/BooleanFilter.js +50 -52
- package/src/x_ite/Components/EventUtilities/BooleanSequencer.js +50 -52
- package/src/x_ite/Components/EventUtilities/BooleanToggle.js +43 -45
- package/src/x_ite/Components/EventUtilities/BooleanTrigger.js +42 -44
- package/src/x_ite/Components/EventUtilities/IntegerSequencer.js +50 -52
- package/src/x_ite/Components/EventUtilities/IntegerTrigger.js +43 -45
- package/src/x_ite/Components/EventUtilities/TimeTrigger.js +43 -45
- package/src/x_ite/Components/EventUtilities/X3DSequencerNode.js +92 -94
- package/src/x_ite/Components/EventUtilities/X3DTriggerNode.js +13 -15
- package/src/x_ite/Components/Followers/ColorChaser.js +78 -78
- package/src/x_ite/Components/Followers/ColorDamper.js +78 -78
- package/src/x_ite/Components/Followers/CoordinateChaser.js +46 -46
- package/src/x_ite/Components/Followers/CoordinateDamper.js +48 -48
- package/src/x_ite/Components/Followers/OrientationChaser.js +64 -64
- package/src/x_ite/Components/Followers/OrientationDamper.js +61 -61
- package/src/x_ite/Components/Followers/PositionChaser.js +42 -42
- package/src/x_ite/Components/Followers/PositionChaser2D.js +42 -42
- package/src/x_ite/Components/Followers/PositionDamper.js +44 -44
- package/src/x_ite/Components/Followers/PositionDamper2D.js +44 -44
- package/src/x_ite/Components/Followers/ScalarChaser.js +70 -70
- package/src/x_ite/Components/Followers/ScalarDamper.js +60 -60
- package/src/x_ite/Components/Followers/TexCoordChaser2D.js +46 -46
- package/src/x_ite/Components/Followers/TexCoordDamper2D.js +48 -48
- package/src/x_ite/Components/Followers/X3DChaserNode.js +194 -194
- package/src/x_ite/Components/Followers/X3DDamperNode.js +120 -120
- package/src/x_ite/Components/Followers/X3DFollowerNode.js +83 -83
- package/src/x_ite/Components/Followers.js +45 -45
- package/src/x_ite/Components/Geometry2D/Arc2D.js +99 -113
- package/src/x_ite/Components/Geometry2D/ArcClose2D.js +164 -166
- package/src/x_ite/Components/Geometry2D/Circle2D.js +59 -67
- package/src/x_ite/Components/Geometry2D/Disk2D.js +207 -211
- package/src/x_ite/Components/Geometry2D/Polyline2D.js +43 -52
- package/src/x_ite/Components/Geometry2D/Polypoint2D.js +43 -60
- package/src/x_ite/Components/Geometry2D/Rectangle2D.js +76 -73
- package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +69 -71
- package/src/x_ite/Components/Geometry3D/Box.js +90 -86
- package/src/x_ite/Components/Geometry3D/Cone.js +185 -187
- package/src/x_ite/Components/Geometry3D/Cylinder.js +246 -246
- package/src/x_ite/Components/Geometry3D/ElevationGrid.js +383 -384
- package/src/x_ite/Components/Geometry3D/Extrusion.js +653 -647
- package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +437 -445
- package/src/x_ite/Components/Geometry3D/Sphere.js +72 -74
- package/src/x_ite/Components/Geometry3D.js +25 -25
- package/src/x_ite/Components/Geospatial/GeoCoordinate.js +189 -191
- package/src/x_ite/Components/Geospatial/GeoElevationGrid.js +381 -383
- package/src/x_ite/Components/Geospatial/GeoLOD.js +397 -397
- package/src/x_ite/Components/Geospatial/GeoLocation.js +56 -56
- package/src/x_ite/Components/Geospatial/GeoMetadata.js +54 -36
- package/src/x_ite/Components/Geospatial/GeoOrigin.js +50 -52
- package/src/x_ite/Components/Geospatial/GeoPositionInterpolator.js +81 -83
- package/src/x_ite/Components/Geospatial/GeoProximitySensor.js +95 -97
- package/src/x_ite/Components/Geospatial/GeoTouchSensor.js +77 -79
- package/src/x_ite/Components/Geospatial/GeoTransform.js +79 -79
- package/src/x_ite/Components/Geospatial/GeoViewpoint.js +278 -278
- package/src/x_ite/Components/Geospatial/X3DGeospatialObject.js +216 -218
- package/src/x_ite/Components/Grouping/Group.js +37 -37
- package/src/x_ite/Components/Grouping/StaticGroup.js +245 -245
- package/src/x_ite/Components/Grouping/Switch.js +234 -234
- package/src/x_ite/Components/Grouping/Transform.js +42 -42
- package/src/x_ite/Components/Grouping/X3DBoundedObject.js +93 -93
- package/src/x_ite/Components/Grouping/X3DGroupingNode.js +654 -649
- package/src/x_ite/Components/Grouping/X3DTransformMatrix3DNode.js +99 -99
- package/src/x_ite/Components/Grouping/X3DTransformNode.js +31 -31
- package/src/x_ite/Components/Grouping.js +27 -27
- package/src/x_ite/Components/HAnim/HAnimDisplacer.js +35 -35
- package/src/x_ite/Components/HAnim/HAnimHumanoid.js +293 -293
- package/src/x_ite/Components/HAnim/HAnimJoint.js +137 -137
- package/src/x_ite/Components/HAnim/HAnimMotion.js +50 -50
- package/src/x_ite/Components/HAnim/HAnimSegment.js +44 -44
- package/src/x_ite/Components/HAnim/HAnimSite.js +43 -43
- package/src/x_ite/Components/Interpolation/ColorInterpolator.js +61 -63
- package/src/x_ite/Components/Interpolation/CoordinateInterpolator.js +60 -62
- package/src/x_ite/Components/Interpolation/CoordinateInterpolator2D.js +57 -59
- package/src/x_ite/Components/Interpolation/EaseInEaseOut.js +79 -80
- package/src/x_ite/Components/Interpolation/NormalInterpolator.js +96 -93
- package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +70 -70
- package/src/x_ite/Components/Interpolation/PositionInterpolator.js +57 -59
- package/src/x_ite/Components/Interpolation/PositionInterpolator2D.js +57 -59
- package/src/x_ite/Components/Interpolation/ScalarInterpolator.js +53 -55
- package/src/x_ite/Components/Interpolation/SplinePositionInterpolator.js +78 -80
- package/src/x_ite/Components/Interpolation/SplinePositionInterpolator2D.js +77 -79
- package/src/x_ite/Components/Interpolation/SplineScalarInterpolator.js +78 -80
- package/src/x_ite/Components/Interpolation/SquadOrientationInterpolator.js +66 -66
- package/src/x_ite/Components/Interpolation/X3DInterpolatorNode.js +67 -69
- package/src/x_ite/Components/Interpolation.js +39 -39
- package/src/x_ite/Components/KeyDeviceSensor/KeySensor.js +304 -306
- package/src/x_ite/Components/KeyDeviceSensor/StringSensor.js +102 -104
- package/src/x_ite/Components/KeyDeviceSensor/X3DKeyDeviceSensorNode.js +51 -51
- package/src/x_ite/Components/Layering/Layer.js +50 -50
- package/src/x_ite/Components/Layering/LayerSet.js +160 -161
- package/src/x_ite/Components/Layering/Viewport.js +118 -118
- package/src/x_ite/Components/Layering/X3DLayerNode.js +322 -322
- package/src/x_ite/Components/Layering/X3DViewportNode.js +13 -13
- package/src/x_ite/Components/Layering.js +21 -21
- package/src/x_ite/Components/Layout/Layout.js +576 -578
- package/src/x_ite/Components/Layout/LayoutGroup.js +126 -126
- package/src/x_ite/Components/Layout/LayoutLayer.js +53 -53
- package/src/x_ite/Components/Layout/ScreenFontStyle.js +48 -48
- package/src/x_ite/Components/Layout/ScreenGroup.js +136 -136
- package/src/x_ite/Components/Layout/X3DLayoutNode.js +12 -14
- package/src/x_ite/Components/Lighting/DirectionalLight.js +239 -246
- package/src/x_ite/Components/Lighting/PointLight.js +296 -303
- package/src/x_ite/Components/Lighting/SpotLight.js +321 -316
- package/src/x_ite/Components/Lighting/X3DLightNode.js +153 -153
- package/src/x_ite/Components/Lighting.js +19 -19
- package/src/x_ite/Components/NURBS/Contour2D.js +81 -83
- package/src/x_ite/Components/NURBS/ContourPolyline2D.js +100 -102
- package/src/x_ite/Components/NURBS/CoordinateDouble.js +32 -34
- package/src/x_ite/Components/NURBS/NurbsCurve.js +167 -169
- package/src/x_ite/Components/NURBS/NurbsCurve2D.js +149 -149
- package/src/x_ite/Components/NURBS/NurbsOrientationInterpolator.js +166 -166
- package/src/x_ite/Components/NURBS/NurbsPatchSurface.js +45 -47
- package/src/x_ite/Components/NURBS/NurbsPositionInterpolator.js +154 -154
- package/src/x_ite/Components/NURBS/NurbsSet.js +125 -125
- package/src/x_ite/Components/NURBS/NurbsSurfaceInterpolator.js +128 -130
- package/src/x_ite/Components/NURBS/NurbsSweptSurface.js +120 -122
- package/src/x_ite/Components/NURBS/NurbsSwungSurface.js +120 -122
- package/src/x_ite/Components/NURBS/NurbsTextureCoordinate.js +93 -93
- package/src/x_ite/Components/NURBS/NurbsTrimmedSurface.js +88 -90
- package/src/x_ite/Components/NURBS/X3DNurbsControlCurveNode.js +13 -15
- package/src/x_ite/Components/NURBS/X3DNurbsSurfaceGeometryNode.js +339 -339
- package/src/x_ite/Components/NURBS/X3DParametricGeometryNode.js +18 -20
- package/src/x_ite/Components/Navigation/Billboard.js +132 -132
- package/src/x_ite/Components/Navigation/Collision.js +116 -116
- package/src/x_ite/Components/Navigation/LOD.js +308 -308
- package/src/x_ite/Components/Navigation/NavigationInfo.js +279 -285
- package/src/x_ite/Components/Navigation/OrthoViewpoint.js +258 -258
- package/src/x_ite/Components/Navigation/Viewpoint.js +137 -137
- package/src/x_ite/Components/Navigation/ViewpointGroup.js +169 -171
- package/src/x_ite/Components/Navigation/X3DViewpointNode.js +450 -453
- package/src/x_ite/Components/Navigation.js +27 -27
- package/src/x_ite/Components/Networking/Anchor.js +140 -128
- package/src/x_ite/Components/Networking/Inline.js +156 -197
- package/src/x_ite/Components/Networking/LoadSensor.js +193 -195
- package/src/x_ite/Components/Networking/X3DNetworkSensorNode.js +13 -15
- package/src/x_ite/Components/Networking/X3DUrlObject.js +170 -116
- package/src/x_ite/Components/Networking.js +21 -21
- package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +62 -64
- package/src/x_ite/Components/ParticleSystems/ConeEmitter.js +81 -83
- package/src/x_ite/Components/ParticleSystems/ExplosionEmitter.js +59 -61
- package/src/x_ite/Components/ParticleSystems/ForcePhysicsModel.js +42 -44
- package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +1433 -1433
- package/src/x_ite/Components/ParticleSystems/PointEmitter.js +77 -79
- package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +196 -196
- package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +195 -195
- package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +250 -250
- package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +69 -71
- package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +346 -346
- package/src/x_ite/Components/ParticleSystems/X3DParticlePhysicsModelNode.js +15 -17
- package/src/x_ite/Components/Picking/LinePickSensor.js +284 -286
- package/src/x_ite/Components/Picking/PickableGroup.js +155 -155
- package/src/x_ite/Components/Picking/PointPickSensor.js +272 -272
- package/src/x_ite/Components/Picking/PrimitivePickSensor.js +207 -209
- package/src/x_ite/Components/Picking/VolumePickSensor.js +182 -184
- package/src/x_ite/Components/Picking/X3DPickSensorNode.js +382 -382
- package/src/x_ite/Components/Picking/X3DPickableObject.js +28 -30
- package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +257 -259
- package/src/x_ite/Components/PointingDeviceSensor/PlaneSensor.js +245 -247
- package/src/x_ite/Components/PointingDeviceSensor/SphereSensor.js +173 -175
- package/src/x_ite/Components/PointingDeviceSensor/TouchSensor.js +61 -63
- package/src/x_ite/Components/PointingDeviceSensor/X3DDragSensorNode.js +14 -16
- package/src/x_ite/Components/PointingDeviceSensor/X3DPointingDeviceSensorNode.js +57 -59
- package/src/x_ite/Components/PointingDeviceSensor/X3DTouchSensorNode.js +19 -21
- package/src/x_ite/Components/PointingDeviceSensor.js +25 -25
- package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +191 -191
- package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +162 -162
- package/src/x_ite/Components/ProjectiveTextureMapping/X3DTextureProjectorNode.js +156 -156
- package/src/x_ite/Components/Rendering/ClipPlane.js +120 -120
- package/src/x_ite/Components/Rendering/Color.js +112 -112
- package/src/x_ite/Components/Rendering/ColorRGBA.js +114 -114
- package/src/x_ite/Components/Rendering/Coordinate.js +33 -35
- package/src/x_ite/Components/Rendering/IndexedLineSet.js +236 -243
- package/src/x_ite/Components/Rendering/IndexedTriangleFanSet.js +102 -102
- package/src/x_ite/Components/Rendering/IndexedTriangleSet.js +55 -55
- package/src/x_ite/Components/Rendering/IndexedTriangleStripSet.js +110 -110
- package/src/x_ite/Components/Rendering/LineSet.js +172 -179
- package/src/x_ite/Components/Rendering/Normal.js +100 -100
- package/src/x_ite/Components/Rendering/PointSet.js +142 -154
- package/src/x_ite/Components/Rendering/TriangleFanSet.js +73 -73
- package/src/x_ite/Components/Rendering/TriangleSet.js +51 -53
- package/src/x_ite/Components/Rendering/TriangleStripSet.js +76 -76
- package/src/x_ite/Components/Rendering/X3DColorNode.js +25 -27
- package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +318 -321
- package/src/x_ite/Components/Rendering/X3DCoordinateNode.js +132 -132
- package/src/x_ite/Components/Rendering/X3DGeometricPropertyNode.js +13 -15
- package/src/x_ite/Components/Rendering/X3DGeometryNode.js +1190 -1171
- package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +231 -189
- package/src/x_ite/Components/Rendering/X3DNormalNode.js +13 -15
- package/src/x_ite/Components/Rendering/X3DPointGeometryNode.js +267 -0
- package/src/x_ite/Components/Rendering.js +53 -53
- package/src/x_ite/Components/RigidBodyPhysics/BallJoint.js +149 -149
- package/src/x_ite/Components/RigidBodyPhysics/CollidableOffset.js +229 -229
- package/src/x_ite/Components/RigidBodyPhysics/CollidableShape.js +465 -465
- package/src/x_ite/Components/RigidBodyPhysics/CollisionCollection.js +152 -154
- package/src/x_ite/Components/RigidBodyPhysics/CollisionSensor.js +223 -223
- package/src/x_ite/Components/RigidBodyPhysics/CollisionSpace.js +117 -117
- package/src/x_ite/Components/RigidBodyPhysics/Contact.js +54 -56
- package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +245 -245
- package/src/x_ite/Components/RigidBodyPhysics/MotorJoint.js +68 -70
- package/src/x_ite/Components/RigidBodyPhysics/RigidBody.js +453 -453
- package/src/x_ite/Components/RigidBodyPhysics/RigidBodyCollection.js +326 -326
- package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +171 -171
- package/src/x_ite/Components/RigidBodyPhysics/SliderJoint.js +169 -169
- package/src/x_ite/Components/RigidBodyPhysics/UniversalJoint.js +50 -52
- package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollidableNode.js +101 -101
- package/src/x_ite/Components/RigidBodyPhysics/X3DNBodyCollisionSpaceNode.js +15 -15
- package/src/x_ite/Components/RigidBodyPhysics/X3DRigidJointNode.js +161 -163
- package/src/x_ite/Components/Scripting/Script.js +506 -510
- package/src/x_ite/Components/Scripting/X3DScriptNode.js +15 -15
- package/src/x_ite/Components/Shaders/ComposedShader.js +215 -178
- package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +84 -83
- package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +74 -74
- package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +73 -73
- package/src/x_ite/Components/Shaders/PackagedShader.js +52 -49
- package/src/x_ite/Components/Shaders/ProgramShader.js +36 -38
- package/src/x_ite/Components/Shaders/ShaderPart.js +135 -147
- package/src/x_ite/Components/Shaders/ShaderProgram.js +49 -46
- package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +1259 -1255
- package/src/x_ite/Components/Shaders/X3DShaderNode.js +83 -93
- package/src/x_ite/Components/Shaders/X3DVertexAttributeNode.js +13 -15
- package/src/x_ite/Components/Shaders.js +33 -33
- package/src/x_ite/{Execution/ExportedNode.js → Components/Shape/AcousticProperties.js} +41 -71
- package/src/x_ite/Components/Shape/Appearance.js +331 -318
- package/src/x_ite/Components/Shape/FillProperties.js +101 -98
- package/src/x_ite/Components/Shape/LineProperties.js +71 -69
- package/src/x_ite/Components/Shape/Material.js +344 -116
- package/src/x_ite/Components/Shape/PhysicalMaterial.js +310 -0
- package/src/x_ite/Components/Shape/PointProperties.js +79 -95
- package/src/x_ite/Components/Shape/Shape.js +178 -181
- package/src/x_ite/Components/Shape/TwoSidedMaterial.js +200 -200
- package/src/x_ite/Components/Shape/UnlitMaterial.js +93 -46
- package/src/x_ite/Components/Shape/X3DAppearanceChildNode.js +13 -15
- package/src/x_ite/Components/Shape/X3DAppearanceNode.js +24 -24
- package/src/x_ite/Components/Shape/X3DMaterialNode.js +24 -24
- package/src/x_ite/Components/Shape/X3DOneSidedMaterialNode.js +158 -54
- package/src/x_ite/Components/Shape/X3DShapeNode.js +147 -147
- package/src/x_ite/Components/Shape.js +43 -37
- package/src/x_ite/Components/Sound/AudioClip.js +135 -140
- package/src/x_ite/Components/Sound/Sound.js +246 -246
- package/src/x_ite/Components/Sound/X3DSoundNode.js +13 -15
- package/src/x_ite/Components/Sound/X3DSoundSourceNode.js +165 -179
- package/src/x_ite/Components/Sound.js +19 -19
- package/src/x_ite/Components/Text/FontStyle.js +49 -49
- package/src/x_ite/Components/Text/Text.js +135 -135
- package/src/x_ite/Components/Text/X3DFontStyleNode.js +207 -205
- package/src/x_ite/Components/Text.js +17 -17
- package/src/x_ite/Components/Texturing/ImageTexture.js +181 -194
- package/src/x_ite/Components/Texturing/MovieTexture.js +180 -190
- package/src/x_ite/Components/Texturing/MultiTexture.js +255 -262
- package/src/x_ite/Components/Texturing/MultiTextureCoordinate.js +124 -118
- package/src/x_ite/Components/Texturing/MultiTextureTransform.js +82 -76
- package/src/x_ite/Components/Texturing/PixelTexture.js +222 -221
- package/src/x_ite/Components/Texturing/TextureCoordinate.js +116 -116
- package/src/x_ite/Components/Texturing/TextureCoordinateGenerator.js +90 -90
- package/src/x_ite/Components/Texturing/TextureProperties.js +158 -160
- package/src/x_ite/Components/Texturing/TextureTransform.js +99 -99
- package/src/x_ite/Components/Texturing/X3DSingleTextureCoordinateNode.js +33 -28
- package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +54 -54
- package/src/x_ite/Components/Texturing/X3DSingleTextureTransformNode.js +22 -17
- package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +135 -124
- package/src/x_ite/Components/Texturing/X3DTextureCoordinateNode.js +16 -16
- package/src/x_ite/Components/Texturing/X3DTextureNode.js +24 -24
- package/src/x_ite/Components/Texturing/X3DTextureTransformNode.js +22 -22
- package/src/x_ite/Components/Texturing.js +45 -45
- package/src/x_ite/Components/Texturing3D/ComposedTexture3D.js +125 -123
- package/src/x_ite/Components/Texturing3D/ImageTexture3D.js +115 -131
- package/src/x_ite/Components/Texturing3D/PixelTexture3D.js +158 -160
- package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +116 -116
- package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +116 -116
- package/src/x_ite/Components/Texturing3D/TextureTransform3D.js +88 -88
- package/src/x_ite/Components/Texturing3D/TextureTransformMatrix3D.js +46 -46
- package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +135 -121
- package/src/x_ite/Components/Time/TimeSensor.js +155 -152
- package/src/x_ite/Components/Time/X3DTimeDependentNode.js +299 -302
- package/src/x_ite/Components/Time.js +15 -15
- package/src/x_ite/Components/VolumeRendering/BlendedVolumeStyle.js +338 -338
- package/src/x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle.js +80 -80
- package/src/x_ite/Components/VolumeRendering/CartoonVolumeStyle.js +228 -228
- package/src/x_ite/Components/VolumeRendering/ComposedVolumeStyle.js +163 -163
- package/src/x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle.js +117 -117
- package/src/x_ite/Components/VolumeRendering/IsoSurfaceVolumeData.js +334 -334
- package/src/x_ite/Components/VolumeRendering/OpacityMapVolumeStyle.js +116 -116
- package/src/x_ite/Components/VolumeRendering/ProjectionVolumeStyle.js +167 -167
- package/src/x_ite/Components/VolumeRendering/SegmentedVolumeData.js +247 -247
- package/src/x_ite/Components/VolumeRendering/ShadedVolumeStyle.js +198 -198
- package/src/x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle.js +116 -116
- package/src/x_ite/Components/VolumeRendering/ToneMappedVolumeStyle.js +126 -126
- package/src/x_ite/Components/VolumeRendering/VolumeData.js +173 -173
- package/src/x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode.js +12 -12
- package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +167 -167
- package/src/x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode.js +70 -70
- package/src/x_ite/Components/X_ITE/BlendMode.js +143 -145
- package/src/x_ite/Components.js +47 -47
- package/src/x_ite/Configuration/ComponentInfo.js +47 -42
- package/src/x_ite/Configuration/ComponentInfoArray.js +21 -19
- package/src/x_ite/Configuration/ProfileInfo.js +33 -23
- package/src/x_ite/Configuration/ProfileInfoArray.js +26 -16
- package/src/x_ite/Configuration/SupportedComponents.js +311 -311
- package/src/x_ite/Configuration/SupportedNodes.js +53 -38
- package/src/x_ite/Configuration/SupportedProfiles.js +190 -190
- package/src/x_ite/Configuration/UnitInfo.js +60 -51
- package/src/x_ite/Configuration/UnitInfoArray.js +17 -10
- package/src/x_ite/DEBUG.js +2 -2
- package/src/x_ite/Execution/BindableList.js +146 -149
- package/src/x_ite/Execution/BindableStack.js +130 -123
- package/src/x_ite/Execution/ExportedNodesArray.js +75 -0
- package/src/x_ite/Execution/ImportedNodesArray.js +75 -0
- package/src/x_ite/{Basic/X3DFieldDefinition.js → Execution/NamedNodesArray.js} +20 -10
- package/src/x_ite/Execution/Scene.js +93 -90
- package/src/x_ite/Execution/X3DExecutionContext.js +957 -781
- package/src/x_ite/Execution/X3DExportedNode.js +152 -0
- package/src/x_ite/Execution/X3DImportedNode.js +393 -0
- package/src/x_ite/Execution/X3DScene.js +546 -493
- package/src/x_ite/Execution/X3DWorld.js +171 -0
- package/src/x_ite/Fallback.js +31 -31
- package/src/x_ite/Fields/ArrayFields.js +463 -443
- package/src/x_ite/Fields/SFBool.js +50 -47
- package/src/x_ite/Fields/SFColor.js +163 -160
- package/src/x_ite/Fields/SFColorRGBA.js +155 -152
- package/src/x_ite/Fields/SFDouble.js +51 -48
- package/src/x_ite/Fields/SFFloat.js +51 -48
- package/src/x_ite/Fields/SFImage.js +216 -213
- package/src/x_ite/Fields/SFInt32.js +47 -44
- package/src/x_ite/Fields/SFMatrix3.js +74 -71
- package/src/x_ite/Fields/SFMatrix4.js +68 -65
- package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +98 -98
- package/src/x_ite/Fields/SFNode.js +392 -299
- package/src/x_ite/Fields/SFNodeCache.js +22 -33
- package/src/x_ite/Fields/SFRotation.js +178 -175
- package/src/x_ite/Fields/SFString.js +71 -68
- package/src/x_ite/Fields/SFTime.js +47 -44
- package/src/x_ite/Fields/SFVec2.js +73 -70
- package/src/x_ite/Fields/SFVec3.js +105 -102
- package/src/x_ite/Fields/SFVec4.js +118 -115
- package/src/x_ite/Fields/SFVecPrototypeTemplate.js +94 -94
- package/src/x_ite/Fields.js +44 -44
- package/src/x_ite/InputOutput/FileLoader.js +426 -531
- package/src/x_ite/InputOutput/Generator.js +379 -376
- package/src/x_ite/{Configuration/X3DInfoArray.js → Parser/GoldenGate.js} +54 -86
- package/src/x_ite/Parser/HTMLSupport.js +28 -6
- package/src/x_ite/Parser/JSONParser.js +414 -388
- package/src/x_ite/Parser/VRMLParser.js +2964 -0
- package/src/x_ite/Parser/X3DParser.js +128 -128
- package/src/x_ite/Parser/XMLParser.js +1231 -1178
- package/src/x_ite/Prototype/ExternProtoDeclarationArray.js +17 -27
- package/src/x_ite/Prototype/ProtoDeclarationArray.js +17 -27
- package/src/x_ite/Prototype/X3DExternProtoDeclaration.js +279 -297
- package/src/x_ite/Prototype/X3DProtoDeclaration.js +264 -263
- package/src/x_ite/Prototype/X3DProtoDeclarationNode.js +58 -35
- package/src/x_ite/Rendering/DependentRenderer.js +83 -80
- package/src/x_ite/Rendering/TextureBuffer.js +171 -168
- package/src/x_ite/{Bits → Rendering}/TraverseType.js +11 -11
- package/src/x_ite/Rendering/X3DRenderObject.js +895 -906
- package/src/x_ite/Routing/RouteArray.js +19 -71
- package/src/x_ite/Routing/X3DRoute.js +185 -179
- package/src/x_ite/Routing/X3DRoutingContext.js +60 -54
- package/src/x_ite/X3D.js +191 -175
- package/src/x_ite.config.js +83 -83
- package/src/x_ite.css +279 -288
- package/src/x_ite.html +226 -193
- package/src/x_ite.js +100 -127
- package/x_ite.min.html +220 -187
- package/src/assets/shaders/webgl1/PointSet.fs +0 -100
- package/src/assets/shaders/webgl1/PointSet.vs +0 -70
- package/src/assets/shaders/webgl1/Wireframe.fs +0 -74
- package/src/assets/shaders/webgl1/Wireframe.vs +0 -63
- package/src/assets/shaders/webgl2/PointSet.fs +0 -99
- package/src/assets/shaders/webgl2/PointSet.vs +0 -71
- package/src/assets/shaders/webgl2/Wireframe.fs +0 -73
- package/src/assets/shaders/webgl2/Wireframe.vs +0 -64
- package/src/x_ite/Basic/X3DBaseNode.js +0 -1253
- package/src/x_ite/Basic/X3DField.js +0 -370
- package/src/x_ite/Basic/X3DObjectArrayField.js +0 -545
- package/src/x_ite/Basic/X3DTypedArrayField.js +0 -839
- package/src/x_ite/Browser/Core/X3DCoreContext.js.~1~ +0 -714
- package/src/x_ite/Components/Texturing/X3DTexture2DNode.js.~1~ +0 -209
- package/src/x_ite/Execution/ImportedNode.js +0 -375
- package/src/x_ite/Execution/World.js +0 -162
- package/src/x_ite/Parser/Parser.js +0 -2944
|
@@ -1,3 +1 @@
|
|
|
1
|
-
!function(){const e=X3D.define,t=X3D.require;e("x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode",["x_ite/Components/Core/X3DNode","x_ite/Bits/X3DConstants"],function(e,t){"use strict";function n(n){e.call(this,n),this.addType(t.X3DVolumeRenderStyleNode),this.volumeDataNodes=new Set}return n.prototype=Object.assign(Object.create(e.prototype),{constructor:n,addShaderFields:function(e){},getUniformsText:function(){return""},getFunctionsText:function(){return""},getVolumeData:function(){return this.volumeDataNodes},addVolumeData:function(e){this.volumeDataNodes.add(e)},removeVolumeData:function(e){this.volumeDataNodes.delete(e)},getNormalText:function(e){var t="";return e?(t+="uniform sampler3D surfaceNormals_"+this.getId()+";\n",t+="\n",t+="vec4\n",t+="getNormal_"+this.getId()+" (in vec3 texCoord)\n",t+="{\n",t+="\tvec3 n = texture (surfaceNormals_"+this.getId()+", texCoord) .xyz * 2.0 - 1.0;\n",t+="\n",t+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",t+="}\n"):(t+="\n",t+="vec4\n",t+="getNormal_"+this.getId()+" (in vec3 texCoord)\n",t+="{\n",t+="\tvec4 offset = vec4 (1.0 / x3d_TextureSize, 0.0);\n",t+="\tfloat i0 = texture (x3d_Texture3D [0], texCoord + offset .xww) .r;\n",t+="\tfloat i1 = texture (x3d_Texture3D [0], texCoord - offset .xww) .r;\n",t+="\tfloat i2 = texture (x3d_Texture3D [0], texCoord + offset .wyw) .r;\n",t+="\tfloat i3 = texture (x3d_Texture3D [0], texCoord - offset .wyw) .r;\n",t+="\tfloat i4 = texture (x3d_Texture3D [0], texCoord + offset .wwz) .r;\n",t+="\tfloat i5 = texture (x3d_Texture3D [0], texCoord - offset .wwz) .r;\n",t+="\tvec3 n = vec3 (i1 - i0, i3 - i2, i5 - i4);\n",t+="\n",t+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",t+="}\n"),t}}),n}),e("x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode",["x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode","x_ite/Bits/X3DConstants"],function(e,t){"use strict";function n(n){e.call(this,n),this.addType(t.X3DComposableVolumeRenderStyleNode)}return n.prototype=Object.assign(Object.create(e.prototype),{constructor:n}),n}),e("x_ite/Components/VolumeRendering/OpacityMapVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.OpacityMapVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"transferFunction",new e.SFNode)]),getTypeName:function(){return"OpacityMapVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.transferFunction_.addInterest("set_transferFunction__",this),this.set_transferFunction__())},set_transferFunction__:function(){this.transferFunctionNode=r(i.X3DTexture2DNode,this.transferFunction_),this.transferFunctionNode||(this.transferFunctionNode=r(i.X3DTexture3DNode,this.transferFunction_)),this.transferFunctionNode||(this.transferFunctionNode=this.getBrowser().getDefaultTransferFunction())},addShaderFields:function(t){this.enabled_.getValue()&&t.addUserDefinedField(i.inputOutput,"transferFunction_"+this.getId(),new e.SFNode(this.transferFunctionNode))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// OpacityMapVolumeStyle\n",e+="\n",this.transferFunctionNode.getType().indexOf(i.X3DTexture2DNode)!==-1?(e+="uniform sampler2D transferFunction_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getOpacityMapStyle_"+this.getId()+" (in vec4 originalColor)\n",e+="{\n",e+="\treturn texture (transferFunction_"+this.getId()+", originalColor .rg);\n",e+="}\n"):(e+="uniform sampler3D transferFunction_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getOpacityMapStyle_"+this.getId()+" (in vec4 originalColor)\n",e+="{\n",e+="\treturn texture (transferFunction_"+this.getId()+", originalColor .rgb);\n",e+="}\n"),e},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// OpacityMapVolumeStyle\n",e+="\n",e+="\ttextureColor = getOpacityMapStyle_"+this.getId()+" (textureColor);\n"}}),s}),e("x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext",["x_ite/Components/Texturing/PixelTexture","x_ite/Components/Texturing/TextureProperties","x_ite/Components/VolumeRendering/OpacityMapVolumeStyle"],function(e,t,n){"use strict";function o(){}return o.prototype={getDefaultVolumeStyle:function(){return this.defaultVolumeStyle=new n(this.getPrivateScene()),this.defaultVolumeStyle.setup(),this.getDefaultVolumeStyle=function(){return this.defaultVolumeStyle},this.defaultVolumeStyle},getDefaultBlendedVolumeStyle:function(){return this.defaultBlendedVolumeStyle=new n(this.getPrivateScene()),this.defaultBlendedVolumeStyle.setup(),this.getDefaultBlendedVolumeStyle=function(){return this.defaultBlendedVolumeStyle},this.defaultBlendedVolumeStyle},getDefaultTransferFunction:function(){this.defaultTransferFunction=new e(this.getPrivateScene());var n=new t(this.getPrivateScene());n.generateMipMaps_=!0,n.boundaryModeS_="CLAMP_TO_EDGE",n.boundaryModeT_="REPEAT",this.defaultTransferFunction.textureProperties_=n,this.defaultTransferFunction.image_.width=256,this.defaultTransferFunction.image_.height=1,this.defaultTransferFunction.image_.comp=2;for(var o=this.defaultTransferFunction.image_.array,i=0;i<256;++i)o[i]=i<<8|i;return n.setup(),this.defaultTransferFunction.setup(),this.getDefaultTransferFunction=function(){return this.defaultTransferFunction},this.defaultTransferFunction}},o}),e("x_ite/Components/VolumeRendering/BlendedVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast","x_ite/DEBUG"],function(e,t,n,o,i,r,s){"use strict";function a(e){o.call(this,e),this.addType(i.BlendedVolumeStyle)}return a.prototype=Object.assign(Object.create(o.prototype),{constructor:a,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"weightConstant1",new e.SFFloat(.5)),new t(i.inputOutput,"weightConstant2",new e.SFFloat(.5)),new t(i.inputOutput,"weightFunction1",new e.SFString("CONSTANT")),new t(i.inputOutput,"weightFunction2",new e.SFString("CONSTANT")),new t(i.inputOutput,"weightTransferFunction1",new e.SFNode),new t(i.inputOutput,"weightTransferFunction2",new e.SFNode),new t(i.inputOutput,"renderStyle",new e.SFNode),new t(i.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"BlendedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.weightTransferFunction1_.addInterest("set_weightTransferFunction1__",this),this.weightTransferFunction2_.addInterest("set_weightTransferFunction2__",this),this.renderStyle_.addInterest("set_renderStyle__",this),this.voxels_.addInterest("set_voxels__",this),this.set_weightTransferFunction1__(),this.set_weightTransferFunction2__(),this.set_renderStyle__(),this.set_voxels__())},addVolumeData:function(e){o.prototype.addVolumeData.call(this,e),this.renderStyleNode&&this.renderStyleNode.addVolumeData(e)},removeVolumeData:function(e){o.prototype.removeVolumeData.call(this,e),this.renderStyleNode&&this.renderStyleNode.removeVolumeData(e)},set_weightTransferFunction1__:function(){this.weightTransferFunction1Node=r(i.X3DTexture2DNode,this.weightTransferFunction1_)},set_weightTransferFunction2__:function(){this.weightTransferFunction2Node=r(i.X3DTexture2DNode,this.weightTransferFunction2_)},set_renderStyle__:function(){this.renderStyleNode&&(this.renderStyleNode.removeInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){this.renderStyleNode.removeVolumeData(e)}.bind(this))),this.renderStyleNode=r(i.X3DComposableVolumeRenderStyleNode,this.renderStyle_),this.renderStyleNode&&(this.renderStyleNode.addInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){this.renderStyleNode.addVolumeData(e)}.bind(this)))},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=r(i.X3DTexture3DNode,this.voxels_),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){this.getVolumeData().forEach(function(e){try{var t=e.getShader().getField("textureSize_"+this.getId());t.x=this.voxelsNode.getWidth(),t.y=this.voxelsNode.getHeight(),t.z=this.voxelsNode.getDepth()}catch(e){s&&console.log(e)}}.bind(this))},addShaderFields:function(t){if(this.enabled_.getValue()){if(t.addUserDefinedField(i.inputOutput,"weightConstant1_"+this.getId(),this.weightConstant1_.copy()),t.addUserDefinedField(i.inputOutput,"weightConstant2_"+this.getId(),this.weightConstant2_.copy()),this.weightTransferFunction1Node&&t.addUserDefinedField(i.inputOutput,"weightTransferFunction1_"+this.getId(),new e.SFNode(this.weightTransferFunction1Node)),this.weightTransferFunction2Node&&t.addUserDefinedField(i.inputOutput,"weightTransferFunction2_"+this.getId(),new e.SFNode(this.weightTransferFunction2Node)),this.voxelsNode){var n=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());t.addUserDefinedField(i.inputOutput,"voxels_"+this.getId(),new e.SFNode(this.voxelsNode)),t.addUserDefinedField(i.inputOutput,"textureSize_"+this.getId(),n)}else t.addUserDefinedField(i.inputOutput,"textureSize_"+this.getId(),new e.SFVec3f);this.getBrowser().getDefaultBlendedVolumeStyle().addShaderFields(t),this.renderStyleNode&&this.renderStyleNode.addShaderFields(t)}},getUniformsText:function(){if(!this.enabled_.getValue())return"";if(!this.voxelsNode)return"";var e="";e+="\n",e+="// BlendedVolumeStyle\n",e+="\n",e+="uniform float weightConstant1_"+this.getId()+";\n",e+="uniform float weightConstant2_"+this.getId()+";\n",this.weightTransferFunction1Node&&(e+="uniform sampler2D weightTransferFunction1_"+this.getId()+";\n"),this.weightTransferFunction2Node&&(e+="uniform sampler2D weightTransferFunction2_"+this.getId()+";\n"),e+="uniform sampler3D voxels_"+this.getId()+";\n",e+="uniform vec3 textureSize_"+this.getId()+";\n";var t=this.getBrowser().getDefaultBlendedVolumeStyle().getUniformsText();this.renderStyleNode&&(t+=this.renderStyleNode.getUniformsText()),t=t.replace(/x3d_Texture3D \[0\]/g,"voxels_"+this.getId()),t=t.replace(/x3d_TextureSize/g,"textureSize_"+this.getId()),e+="\n",e+=t,e+="\n",e+="vec4\n",e+="getBlendedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 blendColor_"+this.getId()+" = texture (voxels_"+this.getId()+", texCoord);";var n=this.getBrowser().getDefaultBlendedVolumeStyle().getFunctionsText();switch(this.renderStyleNode&&(n+=this.renderStyleNode.getFunctionsText()),n=n.replace(/textureColor/g,"blendColor_"+this.getId()),e+="\n",e+=n,this.weightFunction1_.getValue()){default:e+="\tfloat w1_"+this.getId()+" = weightConstant1_"+this.getId()+";\n";break;case"ALPHA0":e+="\tfloat w1_"+this.getId()+" = originalColor .a;\n";break;case"ALPHA1":e+="\tfloat w1_"+this.getId()+" = blendColor_ "+this.getId()+" .a;\n";break;case"ONE_MINUS_ALPHA0":e+="\tfloat w1_"+this.getId()+" = 1.0 - originalColor .a;\n";break;case"ONE_MINUS_ALPHA1":e+="\tfloat w1_"+this.getId()+" = 1.0 - blendColor_ "+this.getId()+" .a;\n";break;case"TABLE":e+=this.weightTransferFunction1Node?"\tfloat w1_"+this.getId()+" = texture (weightTransferFunction1_"+this.getId()+", vec2 (originalColor .a, blendColor_"+this.getId()+" .a)) .r;\n":"\tfloat w1_"+this.getId()+" = weightConstant1_"+this.getId()+";\n"}switch(this.weightFunction2_.getValue()){default:e+="\tfloat w2_"+this.getId()+" = weightConstant2_"+this.getId()+";\n";break;case"ALPHA0":e+="\tfloat w2_"+this.getId()+" = originalColor .a;\n";break;case"ALPHA1":e+="\tfloat w2_"+this.getId()+" = blendColor_ "+this.getId()+" .a;\n";break;case"ONE_MINUS_ALPHA0":e+="\tfloat w2_"+this.getId()+" = 1.0 - originalColor .a;\n";break;case"ONE_MINUS_ALPHA1":e+="\tfloat w2_"+this.getId()+" = 1.0 - blendColor_ "+this.getId()+" .a;\n";break;case"TABLE":e+=this.weightTransferFunction2Node?"\tfloat w2_"+this.getId()+" = texture (weightTransferFunction2_"+this.getId()+", vec2 (originalColor .a, blendColor_"+this.getId()+" .a)) .r;\n":"\tfloat w2_"+this.getId()+" = weightConstant2_"+this.getId()+";\n"}return e+="\n",e+="\treturn clamp (originalColor * w1_"+this.getId()+" + blendColor_"+this.getId()+" * w2_"+this.getId()+", 0.0, 1.0);\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";if(!this.voxelsNode)return"";var e="";return e+="\n",e+="\t// BlendedVolumeStyle\n",e+="\n",e+="\ttextureColor = getBlendedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),a}),e("x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants"],function(e,t,n,o,i){"use strict";function r(e){o.call(this,e),this.addType(i.BoundaryEnhancementVolumeStyle)}return r.prototype=Object.assign(Object.create(o.prototype),{constructor:r,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"retainedOpacity",new e.SFFloat(.2)),new t(i.inputOutput,"boundaryOpacity",new e.SFFloat(.9)),new t(i.inputOutput,"opacityFactor",new e.SFFloat(2))]),getTypeName:function(){return"BoundaryEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},addShaderFields:function(e){this.enabled_.getValue()&&(e.addUserDefinedField(i.inputOutput,"retainedOpacity_"+this.getId(),this.retainedOpacity_.copy()),e.addUserDefinedField(i.inputOutput,"boundaryOpacity_"+this.getId(),this.boundaryOpacity_.copy()),e.addUserDefinedField(i.inputOutput,"opacityFactor_"+this.getId(),this.opacityFactor_.copy()))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// BoundaryEnhancementVolumeStyle\n",e+="\n",e+="uniform float retainedOpacity_"+this.getId()+";\n",e+="uniform float boundaryOpacity_"+this.getId()+";\n",e+="uniform float opacityFactor_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getBoundaryEnhancementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tfloat f0 = texture (x3d_Texture3D [0], texCoord) .r;\n",e+="\tfloat f1 = texture (x3d_Texture3D [0], texCoord + vec3 (0.0, 0.0, 1.0 / x3d_TextureSize .z)) .r;\n",e+="\tfloat f = abs (f0 - f1);\n",e+="\n",e+="\tfloat retainedOpacity = retainedOpacity_"+this.getId()+";\n",e+="\tfloat boundaryOpacity = boundaryOpacity_"+this.getId()+";\n",e+="\tfloat opacityFactor = opacityFactor_"+this.getId()+";\n",e+="\n",e+="\treturn vec4 (originalColor .rgb, originalColor .a * (retainedOpacity + boundaryOpacity * pow (f, opacityFactor)));\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// BoundaryEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getBoundaryEnhancementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),r}),e("x_ite/Components/VolumeRendering/CartoonVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.CartoonVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"colorSteps",new e.SFInt32(4)),new t(i.inputOutput,"orthogonalColor",new e.SFColorRGBA(1,1,1,1)),new t(i.inputOutput,"parallelColor",new e.SFColorRGBA(0,0,0,1)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"CartoonVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.surfaceNormals_.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this.surfaceNormals_)},addShaderFields:function(t){this.enabled_.getValue()&&(t.addUserDefinedField(i.inputOutput,"colorSteps_"+this.getId(),this.colorSteps_.copy()),t.addUserDefinedField(i.inputOutput,"orthogonalColor_"+this.getId(),this.orthogonalColor_.copy()),t.addUserDefinedField(i.inputOutput,"parallelColor_"+this.getId(),this.parallelColor_.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// CartoonVolumeStyle\n",e+="\n",e+="uniform int colorSteps_"+this.getId()+";\n",e+="uniform vec4 orthogonalColor_"+this.getId()+";\n",e+="uniform vec4 parallelColor_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec3\n",e+="rgb2hsv_"+this.getId()+" (in vec3 color)\n",e+="{\n",e+="\tfloat h = 0.0;\n",e+="\tfloat s = 0.0;\n",e+="\tfloat v = 0.0;\n",e+="\n",e+="\tfloat min = min (min (color .r, color .g), color .b);\n",e+="\tfloat max = max (max (color .r, color .g), color .b);\n",e+="\tv = max; // value\n",e+="\n",e+="\tfloat delta = max - min;\n",e+="\n",e+="\tif (max != 0.0 && delta != 0.0)\n",e+="\t{\n",e+="\t\ts = delta / max; // s\n",e+="\n",e+="\t\tif (color .r == max)\n",e+="\t\t\th = (color .g - color .b) / delta; // between yellow & magenta\n",e+="\t\telse if (color .g == max)\n",e+="\t\t\th = 2.0 + (color .b - color .r) / delta; // between cyan & yellow\n",e+="\t\telse\n",e+="\t\t\th = 4.0 + (color .r - color .g) / delta; // between magenta & cyan\n",e+="\n",e+="\t\th *= M_PI / 3.0; // radiants\n",e+="\t\tif (h < 0.0)\n",e+="\t\t\th += M_PI * 2.0;\n",e+="\t}\n",e+="\telse\n",e+="\t\ts = h = 0.0; // s = 0, h is undefined\n",e+="\n",e+="\treturn vec3 (h, s, v);\n",e+="}\n",e+="\n",e+="vec3\n",e+="hsv2rgb_"+this.getId()+" (in vec3 hsv)\n",e+="{\n",e+="\tfloat h = hsv [0];\n",e+="\tfloat s = clamp (hsv [1], 0.0, 1.0);\n",e+="\tfloat v = clamp (hsv [2], 0.0, 1.0);\n",e+="\n",e+="\t// H is given on [0, 2 * Pi]. S and V are given on [0, 1].\n",e+="\t// RGB are each returned on [0, 1].\n",e+="\n",e+="\tif (s == 0.0)\n",e+="\t{\n",e+="\t\t// achromatic (grey)\n",e+="\t\treturn vec3 (v, v, v);\n",e+="\t}\n",e+="\telse\n",e+="\t{\n",e+="\t\tfloat w = (h * (180.0 / M_PI)) / 60.0; // sector 0 to 5\n",e+="\n",e+="\t\tfloat i = floor (w);\n",e+="\t\tfloat f = w - i; // factorial part of h\n",e+="\t\tfloat p = v * ( 1.0 - s );\n",e+="\t\tfloat q = v * ( 1.0 - s * f );\n",e+="\t\tfloat t = v * ( 1.0 - s * ( 1.0 - f ) );\n",e+="\n",e+="\t\tswitch (int (i) % 6)\n",e+="\t\t{\n",e+="\t\t\tcase 0: return vec3 (v, t, p);\n",e+="\t\t\tcase 1: return vec3 (q, v, p);\n",e+="\t\t\tcase 2: return vec3 (p, v, t);\n",e+="\t\t\tcase 3: return vec3 (p, q, v);\n",e+="\t\t\tcase 4: return vec3 (t, p, v);\n",e+="\t\t\tdefault: return vec3 (v, p, q);\n",e+="\t\t}\n",e+="\t}\n",e+="\n",e+="\treturn vec3 (0.0);\n",e+="}\n",e+="\n",e+="vec3\n",e+="mix_hsv_"+this.getId()+" (in vec3 a, in vec3 b, in float t)\n",e+="{\n",e+="\t// Linearely interpolate in HSV space between source color @a a and destination color @a b by an amount of @a t.\n",e+="\t// Source and destination color must be in HSV space.\n",e+="\n",e+="\tfloat ha = a [0];\n",e+="\tfloat sa = a [1];\n",e+="\tfloat va = a [2];\n",e+="\n",e+="\tfloat hb = b [0];\n",e+="\tfloat sb = b [1];\n",e+="\tfloat vb = b [2];\n",e+="\n",e+="\tif (sa == 0.0)\n",e+="\t\tha = hb;\n",e+="\n",e+="\tif (sb == 0.0)\n",e+="\t\thb = ha;\n",e+="\n",e+="\tfloat range = abs (hb - ha);\n",e+="\n",e+="\tif (range <= M_PI)\n",e+="\t{\n",e+="\t\tfloat h = ha + t * (hb - ha);\n",e+="\t\tfloat s = sa + t * (sb - sa);\n",e+="\t\tfloat v = va + t * (vb - va);\n",e+="\t\treturn vec3 (h, s, v);\n",e+="\t}\n",e+="\n",e+="\tfloat PI2 = M_PI * 2.0;\n",e+="\tfloat step = (PI2 - range) * t;\n",e+="\tfloat h = ha < hb ? ha - step : ha + step;\n",e+="\n",e+="\tif (h < 0.0)\n",e+="\t\th += PI2;\n",e+="\n",e+="\telse if (h > PI2)\n",e+="\t\th -= PI2;\n",e+="\n",e+="\tfloat s = sa + t * (sb - sa);\n",e+="\tfloat v = va + t * (vb - va);\n",e+="\treturn vec3 (h, s, v);\n",e+="}\n",e+="\n",e+="vec4\n",e+="getCartoonStyle_"+this.getId()+" (in vec4 originalColor, vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 orthogonalColor = orthogonalColor_"+this.getId()+";\n",e+="\tvec4 parallelColor = parallelColor_"+this.getId()+";\n",e+="\tint colorSteps = colorSteps_"+this.getId()+";\n",e+="\n",e+="\tfloat steps = clamp (float (colorSteps), 1.0, 64.0);\n",e+="\tfloat step = M_PI / 2.0 / steps;\n",e+="\tfloat cosTheta = min (dot (surfaceNormal .xyz, normalize (vertex)), 1.0);\n",e+="\n",e+="\tif (cosTheta < 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tfloat t = cos (min (floor (acos (cosTheta) / step) * (steps > 1.0 ? steps / (steps - 1.0) : 1.0), steps) * step);\n",e+="\tvec3 orthogonalHSV = rgb2hsv_"+this.getId()+" (orthogonalColor .rgb);\n",e+="\tvec3 parallelHSV = rgb2hsv_"+this.getId()+" (parallelColor .rgb);\n",e+="\n",e+="\treturn vec4 (hsv2rgb_"+this.getId()+" (mix_hsv_"+this.getId()+" (orthogonalHSV, parallelHSV, t)), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// CartoonVolumeStyle\n",e+="\n",e+="\ttextureColor = getCartoonStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/ComposedVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ComposedVolumeStyle),this.renderStyleNodes=[]}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"renderStyle",new e.MFNode)]),getTypeName:function(){return"ComposedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.renderStyle_.addInterest("set_renderStyle__",this),this.set_renderStyle__())},addVolumeData:function(e){o.prototype.addVolumeData.call(this,e);for(var t=this.renderStyleNodes,n=0,i=t.length;n<i;++n){t[n].addVolumeData(e)}},removeVolumeData:function(e){o.prototype.removeVolumeData.call(this,e);for(var t=0,n=renderStyleNodes.length;t<n;++t){renderStyleNodes[t].removeVolumeData(e)}},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){var o=e[t];o.removeInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){o.removeVolumeData(e)})}e.length=0;for(var t=0,n=this.renderStyle_.length;t<n;++t){var o=r(i.X3DComposableVolumeRenderStyleNode,this.renderStyle_[t]);o&&e.push(o)}for(var t=0,n=e.length;t<n;++t){var o=e[t];o.addInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){o.addVolumeData(e)})}},addShaderFields:function(e){if(this.enabled_.getValue())for(var t=this.renderStyleNodes,n=0,o=t.length;n<o;++n)t[n].addShaderFields(e)},getUniformsText:function(){if(!this.enabled_.getValue())return"";for(var e=this.renderStyleNodes,t="",n=0,o=e.length;n<o;++n)t+=e[n].getUniformsText();t+="\n",t+="vec4\n",t+="getComposedStyle_"+this.getId()+" (in vec4 textureColor, in vec3 texCoord)\n",t+="{\n";for(var n=0,o=e.length;n<o;++n)t+=e[n].getFunctionsText();return t+="\n",t+="\treturn textureColor;\n",t+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// ComposedVolumeStyle\n",e+="\n",e+="\ttextureColor = getComposedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.EdgeEnhancementVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"edgeColor",new e.SFColorRGBA(0,0,0,1)),new t(i.inputOutput,"gradientThreshold",new e.SFFloat(.4)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"EdgeEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.surfaceNormals_.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this.surfaceNormals_)},addShaderFields:function(t){this.enabled_.getValue()&&(t.addUserDefinedField(i.inputOutput,"edgeColor_"+this.getId(),this.edgeColor_.copy()),t.addUserDefinedField(i.inputOutput,"gradientThreshold_"+this.getId(),this.gradientThreshold_.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// EdgeEnhancementVolumeStyle\n",e+="\n",e+="uniform vec4 edgeColor_"+this.getId()+";\n",e+="uniform float gradientThreshold_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getEdgeEnhacementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 edgeColor = edgeColor_"+this.getId()+";\n",e+="\tfloat gradientThreshold = gradientThreshold_"+this.getId()+";\n",e+="\n",e+="\tfloat angle = abs (dot (surfaceNormal .xyz, normalize (vertex)));\n",e+="\n",e+="\tif (angle >= cos (gradientThreshold))\n",e+="\t\treturn originalColor;\n",e+="\telse\n",e+="\t\treturn vec4 (mix (edgeColor .rgb, originalColor.rgb, angle), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// EdgeEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getEdgeEnhacementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/X3DVolumeDataNode",["x_ite/Fields","x_ite/Components/Core/X3DChildNode","x_ite/Components/Grouping/X3DBoundedObject","x_ite/Bits/X3DConstants","x_ite/Browser/Core/TextureQuality","standard/Math/Numbers/Vector3"],function(e,t,n,o,i,r){"use strict";function s(e){t.call(this,e),n.call(this,e),this.addType(o.X3DVolumeDataNode),this.proximitySensorNode=e.createNode("ProximitySensor",!1),this.transformNode=e.createNode("Transform",!1),this.shapeNode=e.createNode("Shape",!1),this.appearanceNode=e.createNode("Appearance",!1),this.textureTransformNode=e.createNode("TextureTransform3D",!1),this.geometryNode=e.createNode("QuadSet",!1),this.textureCoordinateNode=e.createNode("TextureCoordinate3D",!1),this.coordinateNode=e.createNode("Coordinate",!1),this.setCameraObject(!0)}return s.prototype=Object.assign(Object.create(t.prototype),n.prototype,{constructor:s,initialize:function(){t.prototype.initialize.call(this),n.prototype.initialize.call(this);var o=this.getBrowser(),i=o.getContext();o.getBrowserOptions().TextureQuality_.addInterest("set_dimensions__",this),i.getVersion()>=2&&(this.dimensions_.addInterest("set_dimensions__",this),this.set_dimensions__()),this.appearanceNode.setPrivate(!0),this.proximitySensorNode.size_=new e.SFVec3f(-1,-1,-1),this.transformNode.children_=new e.MFNode(this.shapeNode),this.shapeNode.appearance_=this.appearanceNode,this.shapeNode.geometry_=this.geometryNode,this.appearanceNode.alphaMode_="BLEND",this.appearanceNode.textureTransform_=this.textureTransformNode,this.textureTransformNode.translation_=new e.SFVec3f(.5,.5,.5),this.textureTransformNode.center_=new e.SFVec3f(-.5,-.5,-.5),this.geometryNode.texCoord_=this.textureCoordinateNode,this.geometryNode.coord_=this.coordinateNode,this.coordinateNode.setup(),this.textureCoordinateNode.setup(),this.geometryNode.setup(),this.textureTransformNode.setup(),this.appearanceNode.setup(),this.shapeNode.setup(),this.transformNode.setup(),this.proximitySensorNode.setup(),this.proximitySensorNode.orientation_changed_.addFieldInterest(this.transformNode.rotation_),this.proximitySensorNode.orientation_changed_.addFieldInterest(this.textureTransformNode.rotation_),this.textureTransformNode.addInterest("set_textureTransform__",this)},getBBox:function(e,t){return this.bboxSize_.getValue().equals(this.getDefaultBBoxSize())?e.set(this.dimensions_.getValue(),r.Zero):e.set(this.bboxSize_.getValue(),this.bboxCenter_.getValue())},getAppearance:function(){return this.appearanceNode},setShader:function(t){this.getAppearance().shaders_[0]=t,t.addUserDefinedField(o.inputOutput,"x3d_TextureNormalMatrix",new e.SFMatrix3f),t.setup(),this.set_textureTransform__()},getShader:function(){var e=this.appearanceNode.shaders_[0];return e?e.getValue():null},getNumPlanes:function(){switch(this.getBrowser().getBrowserOptions().getTextureQuality()){case i.LOW:return 200;case i.MEDIUM:return 400;case i.HIGH:return 600}return 200},set_dimensions__:function(){var t=this.getNumPlanes(),n=this.dimensions_.getValue().abs(),o=n/2,i=[];this.coordinateNode.point_.length=0;for(var r=0;r<t;++r){var s=r/(t-1)-.5;i.push(o,o,n*s,-o,o,n*s,-o,-o,n*s,o,-o,n*s)}this.coordinateNode.point_=i,this.textureCoordinateNode.point_=i,this.textureTransformNode.scale_=new e.SFVec3f(1/this.dimensions_.x,1/this.dimensions_.y,1/this.dimensions_.z)},set_textureTransform__:function(){var e=this.getShader();if(e){e.getField("x3d_TextureNormalMatrix").setValue(this.textureTransformNode.getMatrix().submatrix.inverse().transpose())}},traverse:function(e,t){this.proximitySensorNode.traverse(e,t),this.transformNode.traverse(e,t)}}),s}),e("text!x_ite/Browser/VolumeRendering/VolumeStyle.vs",[],function(){
|
|
2
|
-
return"#version 300 es\n\nprecision highp float;\nprecision highp int;\n\nuniform mat4 x3d_ProjectionMatrix;\nuniform mat4 x3d_ModelViewMatrix;\nuniform mat4 x3d_TextureMatrix [1];\n\nin float x3d_FogDepth;\nin vec4 x3d_TexCoord0;\nin vec4 x3d_Vertex;\n\nout float fogDepth;\nout vec3 vertex;\nout vec4 texCoord;\n\nvoid\nmain ()\n{\n\tvec4 position = x3d_ModelViewMatrix * x3d_Vertex;\n\n\tfogDepth = x3d_FogDepth;\n\tvertex = position .xyz;\n\ttexCoord = x3d_TextureMatrix [0] * x3d_TexCoord0;\n\n\tgl_Position = x3d_ProjectionMatrix * position;\n}\n"}),e("text!x_ite/Browser/VolumeRendering/VolumeStyle.fs",[],function(){return"#version 300 es\n\nprecision highp float;\nprecision highp int;\nprecision highp sampler3D;\n\nuniform int x3d_NumLights;\nuniform x3d_LightSourceParameters x3d_LightSource [x3d_MaxLights];\n\nuniform int x3d_NumTextures;\nuniform sampler3D x3d_Texture3D [1];\nuniform vec3 x3d_TextureSize;\n\nuniform mat3 x3d_TextureNormalMatrix;\n\nconst float M_PI = 3.14159265359;\n\nin float fogDepth;\nin vec3 vertex;\nin vec4 texCoord;\n\n\nuniform x3d_FogParameters x3d_Fog;\n\nfloat\ngetFogInterpolant ()\n{\n\t// Returns 0.0 for fog color and 1.0 for material color.\n\n\tif (x3d_Fog .type == x3d_None)\n\t\treturn 1.0;\n\n\tif (x3d_Fog .fogCoord)\n\t\treturn clamp (1.0 - fogDepth, 0.0, 1.0);\n\n\tfloat visibilityRange = x3d_Fog .visibilityRange;\n\n\tif (visibilityRange <= 0.0)\n\t\treturn 1.0;\n\n\tfloat dV = length (x3d_Fog .matrix * vertex);\n\n\tif (dV >= visibilityRange)\n\t\treturn 0.0;\n\n\tswitch (x3d_Fog .type)\n\t{\n\t\tcase x3d_LinearFog:\n\t\t{\n\t\t\treturn (visibilityRange - dV) / visibilityRange;\n\t\t}\n\t\tcase x3d_ExponentialFog:\n\t\t{\n\t\t\treturn exp (-dV / (visibilityRange - dV));\n\t\t}\n\t\tdefault:\n\t\t{\n\t\t\treturn 1.0;\n\t\t}\n\t}\n}\n\nvec3\ngetFogColor (const in vec3 color)\n{\n\treturn mix (x3d_Fog .color, color, getFogInterpolant ());\n}\n\n// VOLUME_STYLES_UNIFORMS\n\nout vec4 x3d_FragColor;\n\n\nuniform int x3d_NumClipPlanes;\nuniform vec4 x3d_ClipPlane [x3d_MaxClipPlanes];\n\nvoid\nclip ()\n{\n\tfor (int i = 0; i < x3d_MaxClipPlanes; ++ i)\n\t{\n\t\tif (i == x3d_NumClipPlanes)\n\t\t\tbreak;\n\n\t\tif (dot (vertex, x3d_ClipPlane [i] .xyz) - x3d_ClipPlane [i] .w < 0.0)\n\t\t\tdiscard;\n\t}\n}\n\nvec4\ngetTextureColor (in vec3 texCoord)\n{\n\tif (x3d_NumTextures == 0)\n\t\tdiscard;\n\n\tif (texCoord .s < 0.0 || texCoord .s > 1.0)\n\t\tdiscard;\n\n\tif (texCoord .t < 0.0 || texCoord .t > 1.0)\n\t\tdiscard;\n\n\tif (texCoord .p < 0.0 || texCoord .p > 1.0)\n\t\tdiscard;\n\n\tvec4 textureColor = texture (x3d_Texture3D [0], texCoord);\n\n\t// Apply volume styles.\n\n// VOLUME_STYLES_FUNCTIONS\n\n\treturn textureColor;\n}\n\nvoid\nmain ()\n{\n\tclip ();\n\n\tx3d_FragColor = getTextureColor (texCoord .stp / texCoord .q);\n}\n"}),e("x_ite/Components/VolumeRendering/IsoSurfaceVolumeData",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],function(e,t,n,o,i,r,s,a,l,d,u){"use strict";function h(e){o.call(this,e),this.addType(s.IsoSurfaceVolumeData),this.renderStyleNodes=[]}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,fieldDefinitions:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"contourStepSize",new e.SFFloat(0)),new t(s.inputOutput,"surfaceValues",new e.MFFloat),new t(s.inputOutput,"surfaceTolerance",new e.SFFloat(0)),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"renderStyle",new e.MFNode),new t(s.inputOutput,"gradients",new e.SFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"IsoSurfaceVolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.gradients_.addInterest("set_gradients__",this),this.renderStyle_.addInterest("set_renderStyle__",this),this.voxels_.addFieldInterest(this.getAppearance().texture_),this.contourStepSize_.addInterest("update",this),this.surfaceValues_.addInterest("update",this),this.surfaceTolerance_.addInterest("update",this),this.renderStyle_.addInterest("update",this),this.getAppearance().texture_=this.voxels_,this.set_gradients__(),this.set_renderStyle__(),this.set_voxels__(),this.update())},set_gradients__:function(){this.gradientsNode=a(s.X3DTexture3DNode,this.gradients_)},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){var o=e[t];o.removeInterest("update",this),o.removeVolumeData(this)}e.length=0;for(var t=0,n=this.renderStyle_.length;t<n;++t){var o=a(s.X3DComposableVolumeRenderStyleNode,this.renderStyle_[t]);o&&e.push(o)}for(var t=0,n=e.length;t<n;++t){var o=e[t];o.addInterest("update",this),o.addVolumeData(this)}},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this.voxels_),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(l,d))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),l=o.getFunctionsText();a+="\n",a+="uniform float surfaceValues ["+this.surfaceValues_.length+"];\n",a+="uniform float surfaceTolerance;\n";for(var d=0,u=this.renderStyleNodes.length;d<u;++d)a+=this.renderStyleNodes[d].getUniformsText();if(l+="\n",l+="\t// IsoSurfaceVolumeData\n",l+="\n",this.gradientsNode?(a+="\n",a+="uniform sampler3D gradients;\n",l+="\tif (length (texture (gradients, texCoord) .xyz * 2.0 - 1.0) < surfaceTolerance)\n",l+="\t\tdiscard;\n"):(a+="\n",a+="vec4\n",a+="getNormal (in vec3 texCoord)\n",a+="{\n",a+="\tvec4 offset = vec4 (1.0 / x3d_TextureSize, 0.0);\n",a+="\tfloat i0 = texture (x3d_Texture3D [0], texCoord + offset .xww) .r;\n",a+="\tfloat i1 = texture (x3d_Texture3D [0], texCoord - offset .xww) .r;\n",a+="\tfloat i2 = texture (x3d_Texture3D [0], texCoord + offset .wyw) .r;\n",a+="\tfloat i3 = texture (x3d_Texture3D [0], texCoord - offset .wyw) .r;\n",a+="\tfloat i4 = texture (x3d_Texture3D [0], texCoord + offset .wwz) .r;\n",a+="\tfloat i5 = texture (x3d_Texture3D [0], texCoord - offset .wwz) .r;\n",a+="\tvec3 n = vec3 (i1 - i0, i3 - i2, i5 - i4);\n",a+="\n",a+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",a+="}\n",l+="\tif (getNormal (texCoord) .w < surfaceTolerance)\n",l+="\t\tdiscard;\n"),l+="\n",l+="\tfloat intensity = textureColor .r;\n",l+="\n",1===this.surfaceValues_.length){var h=Math.abs(this.contourStepSize_.getValue());if(0===h)l+="\tif (intensity > surfaceValues [0])\n",l+="\t{\n",l+="\t\ttextureColor = vec4 (vec3 (surfaceValues [0]), 1.0);\n",this.renderStyleNodes.length&&(l+=this.renderStyleNodes[0].getFunctionsText()),l+="\t}\n",l+="\telse\n",l+="\t{\n",l+="\t\tdiscard;\n",l+="\t}\n",l+="\n";else{for(var c=[],g=this.surfaceValues_[0]-h;g>0;g-=h)c.unshift(g);c.push(this.surfaceValues_[0]);for(var g=this.surfaceValues_[0]+h;g<1;g+=h)c.push(g);l+="\tif (false)\n",l+="\t{ }\n";for(var d=surfaceValues_.length-1;d>=0;--d)l+="\telse if (intensity > "+c[d]+")\n",l+="\t{\n",l+="\t\ttextureColor = vec4 (vec3 ("+c[d]+"), 1.0);\n",this.renderStyleNodes.length&&(l+=this.renderStyleNodes[0].getFunctionsText()),l+="\t}\n";l+="\telse\n",l+="\t{\n",l+="\t\tdiscard;\n",l+="\t}\n",l+="\n"}}else{l+="\tif (false)\n",l+="\t{ }\n";for(var d=this.surfaceValues_.length-1;d>=0;--d){if(l+="\telse if (intensity > surfaceValues ["+d+"])\n",l+="\t{\n",l+="\t\ttextureColor = vec4 (vec3 (surfaceValues ["+d+"]), 1.0);\n",this.renderStyleNodes.length){var f=Math.min(d,this.renderStyleNodes.length-1);l+=this.renderStyleNodes[f].getFunctionsText()}l+="\t}\n"}l+="\telse\n",l+="\t{\n",l+="\t\tdiscard;\n",l+="\t}\n",l+="\n"}n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a),n=n.replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,l);var p=new r(this.getExecutionContext());p.setName("VolumeDataVertexShader"),p.url_.push("data:x-shader/x-vertex,"+t),p.setup();var m=new r(this.getExecutionContext());m.setName("VolumeDataFragmentShader"),m.type_="FRAGMENT",m.url_.push("data:x-shader/x-fragment,"+n),m.setup();var _=new i(this.getExecutionContext());if(_.setName("VolumeDataShader"),_.language_="GLSL",_.parts_.push(p),_.parts_.push(m),_.addUserDefinedField(s.inputOutput,"surfaceValues",this.surfaceValues_.copy()),_.addUserDefinedField(s.inputOutput,"surfaceTolerance",this.surfaceTolerance_.copy()),this.gradientsNode&&_.addUserDefinedField(s.inputOutput,"grandients",new e.SFNode(this.gradientsNode)),this.voxelsNode){var x=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());_.addUserDefinedField(s.inputOutput,"x3d_TextureSize",x)}else _.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);o.addShaderFields(_);for(var d=0,u=this.renderStyleNodes.length;d<u;++d)this.renderStyleNodes[d].addShaderFields(_);return _}}),h}),e("x_ite/Components/VolumeRendering/ProjectionVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode","x_ite/Bits/X3DConstants"],function(e,t,n,o,i){"use strict";function r(e){o.call(this,e),this.addType(i.ProjectionVolumeStyle)}return r.prototype=Object.assign(Object.create(o.prototype),{constructor:r,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"type",new e.SFString("MAX")),new t(i.inputOutput,"intensityThreshold",new e.SFFloat(0))]),getTypeName:function(){return"ProjectionVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},addShaderFields:function(e){this.enabled_.getValue()&&e.addUserDefinedField(i.inputOutput,"intensityThreshold_"+this.getId(),this.intensityThreshold_.copy())},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";switch(e+="\n",e+="// ProjectionVolumeStyle\n",e+="\n",e+="uniform float intensityThreshold_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getProjectionStyle_"+this.getId()+"(in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",this.type_.getValue()){default:case"MAX":e+="\tfloat projectionColor = 0.0;\n";break;case"MIN":e+="\tfloat projectionColor = 1.0;\n";break;case"AVERAGE":e+="\tfloat projectionColor = 0.0;\n"}switch(e+="\tconst int samples = 32;\n",e+="\tvec3 step = normalize (x3d_TextureNormalMatrix * vec3 (0.0, 0.0, 1.0)) / float (samples);\n",e+="\tvec3 ray = texCoord - step * float (samples) * 0.5;\n",e+="\tbool first = false;\n",e+="\n",e+="\tfor (int i = 0; i < samples; ++ i, ray += step)\n",e+="\t{\n",e+="\t\tif (ray .s < 0.0 || ray .s > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (ray .t < 0.0 || ray .t > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (ray .p < 0.0 || ray .p > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tfloat intensity = texture (x3d_Texture3D [0], ray) .r;\n",e+="\n",this.type_.getValue()){default:case"MAX":e+="\t\tif (intensity < intensityThreshold_"+this.getId()+")\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (intensityThreshold_"+this.getId()+" > 0.0 && first)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tif (intensity <= projectionColor)\n",e+="\t\t{\n",e+="\t\t\tfirst = true;\n",e+="\t\t\tcontinue;\n",e+="\t\t}\n",e+="\n",e+="\t\tprojectionColor = intensity;\n";break;case"MIN":e+="\t\tif (intensity < intensityThreshold_"+this.getId()+")\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (intensityThreshold_"+this.getId()+" > 0.0 && first)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tif (intensity >= projectionColor)\n",e+="\t\t{\n",e+="\t\t\tfirst = true;\n",e+="\t\t\tcontinue;\n",e+="\t\t}\n",e+="\n",e+="\t\tprojectionColor = intensity;\n";break;case"AVERAGE":e+="\t\tprojectionColor += intensity;\n"}return e+="\t}\n",e+="\n","AVERAGE"===this.type_.getValue()&&(e+="\tprojectionColor /= float (samples);\n"),e+="\treturn vec4 (vec3 (projectionColor), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// ProjectionVolumeStyle\n",e+="\n",e+="\ttextureColor = getProjectionStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),r}),e("x_ite/Components/VolumeRendering/SegmentedVolumeData",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],function(e,t,n,o,i,r,s,a,l,d,u){"use strict";function h(e){o.call(this,e),this.addType(s.SegmentedVolumeData),this.segmentIdentifiersNode=null,this.renderStyleNodes=[]}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,fieldDefinitions:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"segmentEnabled",new e.MFBool),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"segmentIdentifiers",new e.SFNode),new t(s.inputOutput,"renderStyle",new e.MFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"SegmentedVolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.segmentIdentifiers_.addInterest("set_segmentIdentifiers__",this),this.renderStyle_.addInterest("set_renderStyle__",this),this.voxels_.addFieldInterest(this.getAppearance().texture_),this.segmentEnabled_.addInterest("update",this),this.segmentIdentifiers_.addInterest("update",this),this.renderStyle_.addInterest("update",this),this.getAppearance().texture_=this.voxels_,this.set_segmentIdentifiers__(),this.set_renderStyle__(),this.set_voxels__(),this.update())},getSegmentEnabled:function(e){return!(e<this.segmentEnabled_.length)||this.segmentEnabled_[e]},set_segmentIdentifiers__:function(){this.segmentIdentifiersNode=a(s.X3DTexture3DNode,this.segmentIdentifiers_)},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){var o=e[t];o.removeInterest("update",this),o.removeVolumeData(this)}e.length=0;for(var t=0,n=this.renderStyle_.length;t<n;++t){var o=a(s.X3DComposableVolumeRenderStyleNode,this.renderStyle_[t]);o&&e.push(o)}for(var t=0,n=e.length;t<n;++t){var o=e[t];o.addInterest("update",this),o.addVolumeData(this)}},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this.voxels_),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(l,d))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),l=o.getFunctionsText();if(this.segmentIdentifiersNode?(a+="\n",a+="uniform sampler3D segmentIdentifiers;\n",l+="\n",l+="\n",l+="\tint segment = int (texture (segmentIdentifiers, texCoord) .r * 255.0);\n"):l+="\tint segment = 0;\n",this.renderStyleNodes.length){l+="\n",l+="\tswitch (segment)\n",l+="\t{\n";for(var d=0,u=this.renderStyleNodes.length;d<u;++d)l+="\t\tcase "+d+":\n",l+="\t\t{\n",this.getSegmentEnabled(d)?(a+=this.renderStyleNodes[d].getUniformsText(),l+=this.renderStyleNodes[d].getFunctionsText(),l+="\t\t\tbreak;\n"):l+="\t\t\tdiscard;\n",l+="\t\t}\n";l+="\t}\n"}n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a),n=n.replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,l);var h=new r(this.getExecutionContext());h.setName("SegmentedVolumeDataVertexShader"),h.url_.push("data:x-shader/x-vertex,"+t),h.setup();var c=new r(this.getExecutionContext());c.setName("SegmentedVolumeDataFragmentShader"),c.type_="FRAGMENT",c.url_.push("data:x-shader/x-fragment,"+n),c.setup();var g=new i(this.getExecutionContext());if(g.setName("SegmentedVolumeDataShader"),g.language_="GLSL",g.parts_.push(h),g.parts_.push(c),this.voxelsNode){var f=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());g.addUserDefinedField(s.inputOutput,"x3d_TextureSize",f)}else g.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);this.segmentIdentifiersNode&&g.addUserDefinedField(s.inputOutput,"segmentIdentifiers",new e.SFNode(this.segmentIdentifiersNode)),o.addShaderFields(g);for(var d=0,u=this.renderStyleNodes.length;d<u;++d)this.getSegmentEnabled(d)&&this.renderStyleNodes[d].addShaderFields(g);return g}}),h}),e("x_ite/Components/VolumeRendering/ShadedVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ShadedVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"lighting",new e.SFBool),new t(i.inputOutput,"shadows",new e.SFBool),new t(i.initializeOnly,"phaseFunction",new e.SFString("Henyey-Greenstein")),new t(i.inputOutput,"material",new e.SFNode),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"ShadedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.material_.addInterest("set_material__",this),this.surfaceNormals_.addInterest("set_surfaceNormals__",this),this.set_material__(),this.set_surfaceNormals__())},set_material__:function(){this.materialNode&&this.materialNode.removeInterest("addNodeEvent",this),this.materialNode=r(i.X3DMaterialNode,this.material_),this.materialNode&&this.materialNode.addInterest("addNodeEvent",this)},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this.surfaceNormals_)},addShaderFields:function(t){this.enabled_.getValue()&&(this.materialNode&&(t.addUserDefinedField(i.inputOutput,"ambientIntensity_"+this.getId(),this.materialNode.ambientIntensity_.copy()),t.addUserDefinedField(i.inputOutput,"diffuseColor_"+this.getId(),this.materialNode.diffuseColor_.copy()),t.addUserDefinedField(i.inputOutput,"specularColor_"+this.getId(),this.materialNode.specularColor_.copy()),t.addUserDefinedField(i.inputOutput,"emissiveColor_"+this.getId(),this.materialNode.emissiveColor_.copy()),t.addUserDefinedField(i.inputOutput,"shininess_"+this.getId(),this.materialNode.shininess_.copy()),t.addUserDefinedField(i.inputOutput,"transparency_"+this.getId(),this.materialNode.transparency_.copy())),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// ShadedVolumeStyle\n",e+="\n",e+="uniform float ambientIntensity_"+this.getId()+";\n",e+="uniform vec3 diffuseColor_"+this.getId()+";\n",e+="uniform vec3 specularColor_"+this.getId()+";\n",e+="uniform vec3 emissiveColor_"+this.getId()+";\n",e+="uniform float shininess_"+this.getId()+";\n",e+="uniform float transparency_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="float\n",e+="getSpotFactor_"+this.getId()+" (const in float cutOffAngle, const in float beamWidth, const in vec3 L, const in vec3 d)\n",e+="{\n",e+="\tfloat spotAngle = acos (clamp (dot (-L, d), -1.0, 1.0));\n",e+="\n",e+="\tif (spotAngle >= cutOffAngle)\n",e+="\t\treturn 0.0;\n",e+="\telse if (spotAngle <= beamWidth)\n",e+="\t\treturn 1.0;\n",e+="\n",e+="\treturn (spotAngle - cutOffAngle) / (beamWidth - cutOffAngle);\n",e+="}\n",e+="\n",e+="vec4\n",e+="getShadedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 shadedColor = vec4 (0.0);\n",this.lighting_.getValue()?(this.materialNode?(e+="\tvec3 diffuseFactor = diffuseColor_"+this.getId()+";\n",e+="\tvec3 ambientTerm = diffuseFactor * ambientIntensity_"+this.getId()+";\n",e+="\n",e+="\tshadedColor .a = originalColor .a * (1.0 - transparency_"+this.getId()+");\n"):(e+="\tvec3 diffuseFactor = originalColor .rgb;\n",e+="\tvec3 ambientTerm = vec3 (0.0);\n",e+="\n",e+="\tshadedColor .a = originalColor .a;\n"),e+="\n",e+="\tvec3 N = surfaceNormal .xyz;\n",e+="\tvec3 V = normalize (-vertex); // normalized vector from point on geometry to viewer's position\n",e+="\n",e+="\tfor (int i = 0; i < x3d_MaxLights; ++ i)\n",e+="\t{\n",e+="\t\tif (i == x3d_NumLights)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tx3d_LightSourceParameters light = x3d_LightSource [i];\n",e+="\n",e+="\t\tvec3 vL = light .location - vertex; // Light to fragment\n",e+="\t\tfloat dL = length (light .matrix * vL);\n",e+="\t\tbool di = light .type == x3d_DirectionalLight;\n",e+="\n",e+="\t\tif (di || dL <= light .radius)\n",e+="\t\t{\n",e+="\t\t\tvec3 d = light .direction;\n",e+="\t\t\tvec3 c = light .attenuation;\n",e+="\t\t\tvec3 L = di ? -d : normalize (vL); // Normalized vector from point on geometry to light source i position.\n",e+="\t\t\tvec3 H = normalize (L + V); // Specular term\n",e+="\n",e+="\t\t\tfloat lightAngle = max (dot (N, L), 0.0); // Angle between normal and light ray.\n",e+="\t\t\tvec3 diffuseTerm = diffuseFactor * lightAngle;\n",e+="\t\t\tfloat specularFactor = shininess_"+this.getId()+" > 0.0 ? pow (max (dot (N, H), 0.0), shininess_"+this.getId()+" * 128.0) : 1.0;\n",e+="\t\t\tvec3 specularTerm = light .intensity * specularColor_"+this.getId()+" * specularFactor;\n",e+="\n",e+="\t\t\tfloat attenuationFactor = di ? 1.0 : 1.0 / max (c [0] + c [1] * dL + c [2] * (dL * dL), 1.0);\n",e+="\t\t\tfloat spotFactor = light .type == x3d_SpotLight ? getSpotFactor_"+this.getId()+" (light .cutOffAngle, light .beamWidth, L, d) : 1.0;\n",e+="\t\t\tfloat attenuationSpotFactor = attenuationFactor * spotFactor;\n",e+="\t\t\tvec3 ambientColor = light .ambientIntensity * ambientTerm;\n",e+="\t\t\tvec3 diffuseSpecularColor = light .intensity * (diffuseTerm + specularTerm);\n",e+="\n",e+="\t\t\tshadedColor .rgb += attenuationSpotFactor * light .color * (ambientColor + diffuseSpecularColor);\n",e+="\t\t}\n",e+="\n",e+="\t\tshadedColor .rgb += emissiveColor_"+this.getId()+";\n",e+="\t\tshadedColor .rgb = getFogColor (shadedColor .rgb);\n",e+="\t}\n"):this.materialNode?(e+="\tshadedColor .rgb = diffuseColor_"+this.getId()+";\n",e+="\tshadedColor .a = originalColor .a * (1.0 - transparency_"+this.getId()+");\n"):e+="\tshadedColor = originalColor;\n",e+="\n",e+="\treturn shadedColor;\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// ShadedVolumeStyle\n",e+="\n",e+="\ttextureColor = getShadedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.SilhouetteEnhancementVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"silhouetteRetainedOpacity",new e.SFFloat(1)),new t(i.inputOutput,"silhouetteBoundaryOpacity",new e.SFFloat(0)),new t(i.inputOutput,"silhouetteSharpness",new e.SFFloat(.5)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"SilhouetteEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.surfaceNormals_.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this.surfaceNormals_)},addShaderFields:function(t){this.enabled_.getValue()&&(t.addUserDefinedField(i.inputOutput,"silhouetteRetainedOpacity_"+this.getId(),this.silhouetteRetainedOpacity_.copy()),t.addUserDefinedField(i.inputOutput,"silhouetteBoundaryOpacity_"+this.getId(),this.silhouetteBoundaryOpacity_.copy()),t.addUserDefinedField(i.inputOutput,"silhouetteSharpness_"+this.getId(),this.silhouetteSharpness_.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// SilhouetteEnhancementVolumeStyle\n",e+="\n",e+="uniform float silhouetteRetainedOpacity_"+this.getId()+";\n",e+="uniform float silhouetteBoundaryOpacity_"+this.getId()+";\n",e+="uniform float silhouetteSharpness_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getSilhouetteEnhancementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\t\n",e+="\tfloat silhouetteRetainedOpacity = silhouetteRetainedOpacity_"+this.getId()+";\n",e+="\tfloat silhouetteBoundaryOpacity = silhouetteBoundaryOpacity_"+this.getId()+";\n",e+="\tfloat silhouetteSharpness = silhouetteSharpness_"+this.getId()+";\n",e+="\n",e+="\treturn vec4 (originalColor .rgb, originalColor .a * (silhouetteRetainedOpacity + silhouetteBoundaryOpacity * pow (1.0 - abs (dot (surfaceNormal .xyz, normalize (vertex))), silhouetteSharpness)));\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// SilhouetteEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getSilhouetteEnhancementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/ToneMappedVolumeStyle",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast"],function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ToneMappedVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,fieldDefinitions:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"coolColor",new e.SFColorRGBA(0,0,1,0)),new t(i.inputOutput,"warmColor",new e.SFColorRGBA(1,1,0,0)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"ToneMappedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this.surfaceNormals_.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this.surfaceNormals_)},addShaderFields:function(t){this.enabled_.getValue()&&(t.addUserDefinedField(i.inputOutput,"coolColor_"+this.getId(),this.coolColor_.copy()),t.addUserDefinedField(i.inputOutput,"warmColor_"+this.getId(),this.warmColor_.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="// ToneMappedVolumeStyle\n",e+="\n",e+="uniform vec4 coolColor_"+this.getId()+";\n",e+="uniform vec4 warmColor_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getToneMappedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec3 toneColor = vec3 (0.0);\n",e+="\tvec3 coolColor = coolColor_"+this.getId()+" .rgb;\n",e+="\tvec3 warmColor = warmColor_"+this.getId()+" .rgb;\n",e+="\n",e+="\tfor (int i = 0; i < x3d_MaxLights; ++ i)\n",e+="\t{\n",e+="\t\tif (i == x3d_NumLights)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tx3d_LightSourceParameters light = x3d_LightSource [i];\n",e+="\n",e+="\t\tvec3 L = light .type == x3d_DirectionalLight ? -light .direction : normalize (light .location - vertex);\n",e+="\t\tfloat colorFactor = (1.0 + dot (L, surfaceNormal .xyz)) * 0.5;\n",e+="\n",e+="\t\ttoneColor += mix (warmColor .rgb, coolColor .rgb, colorFactor);\n",e+="\t}\n",e+="\n",e+="\treturn vec4 (toneColor, originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this.enabled_.getValue())return"";var e="";return e+="\n",e+="\t// ToneMappedVolumeStyle\n",e+="\n",e+="\ttextureColor = getToneMappedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s}),e("x_ite/Components/VolumeRendering/VolumeData",["x_ite/Fields","x_ite/Basic/X3DFieldDefinition","x_ite/Basic/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Bits/X3DConstants","x_ite/Bits/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],function(e,t,n,o,i,r,s,a,l,d,u){"use strict";function h(e){o.call(this,e),this.addType(s.VolumeData),this.renderStyleNode=null}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,fieldDefinitions:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"renderStyle",new e.SFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"VolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),
|
|
3
|
-
this.getBrowser().getContext().getVersion()<2||(this.renderStyle_.addInterest("set_renderStyle__",this),this.voxels_.addInterest("set_voxels__",this),this.voxels_.addFieldInterest(this.getAppearance().texture_),this.renderStyle_.addInterest("update",this),this.getAppearance().texture_=this.voxels_,this.set_renderStyle__(),this.set_voxels__(),this.update())},set_renderStyle__:function(){this.renderStyleNode&&(this.renderStyleNode.removeInterest("update",this),this.renderStyleNode.removeVolumeData(this)),this.renderStyleNode=a(s.X3DVolumeRenderStyleNode,this.renderStyle_),this.renderStyleNode&&(this.renderStyleNode.addInterest("update",this),this.renderStyleNode.addVolumeData(this))},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this.voxels_),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(l,d))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),l=o.getFunctionsText();this.renderStyleNode&&(a+=this.renderStyleNode.getUniformsText(),l+=this.renderStyleNode.getFunctionsText()),n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a),n=n.replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,l);var d=new r(this.getExecutionContext());d.setName("VolumeDataVertexShader"),d.url_.push("data:x-shader/x-vertex,"+t),d.setup();var u=new r(this.getExecutionContext());u.setName("VolumeDataFragmentShader"),u.type_="FRAGMENT",u.url_.push("data:x-shader/x-fragment,"+n),u.setup();var h=new i(this.getExecutionContext());if(h.setName("VolumeDataShader"),h.language_="GLSL",h.parts_.push(d),h.parts_.push(u),this.voxelsNode){var c=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());h.addUserDefinedField(s.inputOutput,"x3d_TextureSize",c)}else h.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);return o.addShaderFields(h),this.renderStyleNode&&this.renderStyleNode.addShaderFields(h),h}}),h}),e(t.getComponentUrl("volume-rendering"),["x_ite/Components","x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext","x_ite/Components/VolumeRendering/BlendedVolumeStyle","x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle","x_ite/Components/VolumeRendering/CartoonVolumeStyle","x_ite/Components/VolumeRendering/ComposedVolumeStyle","x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle","x_ite/Components/VolumeRendering/IsoSurfaceVolumeData","x_ite/Components/VolumeRendering/OpacityMapVolumeStyle","x_ite/Components/VolumeRendering/ProjectionVolumeStyle","x_ite/Components/VolumeRendering/SegmentedVolumeData","x_ite/Components/VolumeRendering/ShadedVolumeStyle","x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle","x_ite/Components/VolumeRendering/ToneMappedVolumeStyle","x_ite/Components/VolumeRendering/VolumeData","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode",t.getComponentUrl("cad-geometry"),t.getComponentUrl("texturing-3d")],function(e,t,n,o,i,r,s,a,l,d,u,h,c,g,f,p,m,_){"use strict";e.addComponent({name:"VolumeRendering",types:{BlendedVolumeStyle:n,BoundaryEnhancementVolumeStyle:o,CartoonVolumeStyle:i,ComposedVolumeStyle:r,EdgeEnhancementVolumeStyle:s,IsoSurfaceVolumeData:a,OpacityMapVolumeStyle:l,ProjectionVolumeStyle:d,SegmentedVolumeData:u,ShadedVolumeStyle:h,SilhouetteEnhancementVolumeStyle:c,ToneMappedVolumeStyle:g,VolumeData:f},abstractTypes:{X3DComposableVolumeRenderStyleNode:p,X3DVolumeDataNode:m,X3DVolumeRenderStyleNode:_},browser:t})})}();
|
|
1
|
+
!function(){const e=window[Symbol.for("X_ITE.X3D-5.0.0")].define,t=window[Symbol.for("X_ITE.X3D-5.0.0")].require;e("x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode",["x_ite/Components/Core/X3DNode","x_ite/Base/X3DConstants"],(function(e,t){"use strict";function n(n){e.call(this,n),this.addType(t.X3DVolumeRenderStyleNode),this.volumeDataNodes=new Set}return n.prototype=Object.assign(Object.create(e.prototype),{constructor:n,addShaderFields:function(e){},getUniformsText:function(){return""},getFunctionsText:function(){return""},getVolumeData:function(){return this.volumeDataNodes},addVolumeData:function(e){this.volumeDataNodes.add(e)},removeVolumeData:function(e){this.volumeDataNodes.delete(e)},getNormalText:function(e){var t="";return e?(t+="uniform sampler3D surfaceNormals_"+this.getId()+";\n",t+="\n",t+="vec4\n",t+="getNormal_"+this.getId()+" (in vec3 texCoord)\n",t+="{\n",t+="\tvec3 n = texture (surfaceNormals_"+this.getId()+", texCoord) .xyz * 2.0 - 1.0;\n",t+="\n",t+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",t+="}\n"):(t+="\n",t+="vec4\n",t+="getNormal_"+this.getId()+" (in vec3 texCoord)\n",t+="{\n",t+="\tvec4 offset = vec4 (1.0 / x3d_TextureSize, 0.0);\n",t+="\tfloat i0 = texture (x3d_Texture3D [0], texCoord + offset .xww) .r;\n",t+="\tfloat i1 = texture (x3d_Texture3D [0], texCoord - offset .xww) .r;\n",t+="\tfloat i2 = texture (x3d_Texture3D [0], texCoord + offset .wyw) .r;\n",t+="\tfloat i3 = texture (x3d_Texture3D [0], texCoord - offset .wyw) .r;\n",t+="\tfloat i4 = texture (x3d_Texture3D [0], texCoord + offset .wwz) .r;\n",t+="\tfloat i5 = texture (x3d_Texture3D [0], texCoord - offset .wwz) .r;\n",t+="\tvec3 n = vec3 (i1 - i0, i3 - i2, i5 - i4);\n",t+="\n",t+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",t+="}\n"),t}}),n})),e("x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode",["x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode","x_ite/Base/X3DConstants"],(function(e,t){"use strict";function n(n){e.call(this,n),this.addType(t.X3DComposableVolumeRenderStyleNode)}return n.prototype=Object.assign(Object.create(e.prototype),{constructor:n}),n})),e("x_ite/Components/VolumeRendering/OpacityMapVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.OpacityMapVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"transferFunction",new e.SFNode)]),getTypeName:function(){return"OpacityMapVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._transferFunction.addInterest("set_transferFunction__",this),this.set_transferFunction__())},set_transferFunction__:function(){this.transferFunctionNode=r(i.X3DTexture2DNode,this._transferFunction),this.transferFunctionNode||(this.transferFunctionNode=r(i.X3DTexture3DNode,this._transferFunction)),this.transferFunctionNode||(this.transferFunctionNode=this.getBrowser().getDefaultTransferFunction())},addShaderFields:function(t){this._enabled.getValue()&&t.addUserDefinedField(i.inputOutput,"transferFunction_"+this.getId(),new e.SFNode(this.transferFunctionNode))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// OpacityMapVolumeStyle\n",e+="\n",-1!==this.transferFunctionNode.getType().indexOf(i.X3DTexture2DNode)?(e+="uniform sampler2D transferFunction_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getOpacityMapStyle_"+this.getId()+" (in vec4 originalColor)\n",e+="{\n",e+="\treturn texture (transferFunction_"+this.getId()+", originalColor .rg);\n",e+="}\n"):(e+="uniform sampler3D transferFunction_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getOpacityMapStyle_"+this.getId()+" (in vec4 originalColor)\n",e+="{\n",e+="\treturn texture (transferFunction_"+this.getId()+", originalColor .rgb);\n",e+="}\n"),e},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// OpacityMapVolumeStyle\n",e+="\n",e+="\ttextureColor = getOpacityMapStyle_"+this.getId()+" (textureColor);\n"}}),s})),e("x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext",["x_ite/Components/Texturing/PixelTexture","x_ite/Components/Texturing/TextureProperties","x_ite/Components/VolumeRendering/OpacityMapVolumeStyle"],(function(e,t,n){"use strict";const o=Symbol(),i=Symbol(),r=Symbol();function s(){}return s.prototype={getDefaultVolumeStyle:function(){return this[o]=new n(this.getPrivateScene()),this[o].setup(),this.getDefaultVolumeStyle=function(){return this[o]},Object.defineProperty(this,"getDefaultVolumeStyle",{enumerable:!1}),this[o]},getDefaultBlendedVolumeStyle:function(){return this[i]=new n(this.getPrivateScene()),this[i].setup(),this.getDefaultBlendedVolumeStyle=function(){return this[i]},Object.defineProperty(this,"getDefaultBlendedVolumeStyle",{enumerable:!1}),this[i]},getDefaultTransferFunction:function(){this[r]=new e(this.getPrivateScene());const n=new t(this.getPrivateScene());n._generateMipMaps=!0,n._boundaryModeS="CLAMP_TO_EDGE",n._boundaryModeT="REPEAT",this[r]._textureProperties=n,this[r]._image.width=256,this[r]._image.height=1,this[r]._image.comp=2;const o=this[r]._image.array;for(let e=0;e<256;++e)o[e]=e<<8|e;return n.setup(),this[r].setup(),this.getDefaultTransferFunction=function(){return this[r]},Object.defineProperty(this,"getDefaultTransferFunction",{enumerable:!1}),this[r]}},s})),e("x_ite/Components/VolumeRendering/BlendedVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast","x_ite/DEBUG"],(function(e,t,n,o,i,r,s){"use strict";function a(e){o.call(this,e),this.addType(i.BlendedVolumeStyle)}return a.prototype=Object.assign(Object.create(o.prototype),{constructor:a,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"weightConstant1",new e.SFFloat(.5)),new t(i.inputOutput,"weightConstant2",new e.SFFloat(.5)),new t(i.inputOutput,"weightFunction1",new e.SFString("CONSTANT")),new t(i.inputOutput,"weightFunction2",new e.SFString("CONSTANT")),new t(i.inputOutput,"weightTransferFunction1",new e.SFNode),new t(i.inputOutput,"weightTransferFunction2",new e.SFNode),new t(i.inputOutput,"renderStyle",new e.SFNode),new t(i.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"BlendedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._weightTransferFunction1.addInterest("set_weightTransferFunction1__",this),this._weightTransferFunction2.addInterest("set_weightTransferFunction2__",this),this._renderStyle.addInterest("set_renderStyle__",this),this._voxels.addInterest("set_voxels__",this),this.set_weightTransferFunction1__(),this.set_weightTransferFunction2__(),this.set_renderStyle__(),this.set_voxels__())},addVolumeData:function(e){o.prototype.addVolumeData.call(this,e),this.renderStyleNode&&this.renderStyleNode.addVolumeData(e)},removeVolumeData:function(e){o.prototype.removeVolumeData.call(this,e),this.renderStyleNode&&this.renderStyleNode.removeVolumeData(e)},set_weightTransferFunction1__:function(){this.weightTransferFunction1Node=r(i.X3DTexture2DNode,this._weightTransferFunction1)},set_weightTransferFunction2__:function(){this.weightTransferFunction2Node=r(i.X3DTexture2DNode,this._weightTransferFunction2)},set_renderStyle__:function(){this.renderStyleNode&&(this.renderStyleNode.removeInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){this.renderStyleNode.removeVolumeData(e)}.bind(this))),this.renderStyleNode=r(i.X3DComposableVolumeRenderStyleNode,this._renderStyle),this.renderStyleNode&&(this.renderStyleNode.addInterest("addNodeEvent",this),this.getVolumeData().forEach(function(e){this.renderStyleNode.addVolumeData(e)}.bind(this)))},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=r(i.X3DTexture3DNode,this._voxels),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){this.getVolumeData().forEach(function(e){try{var t=e.getShader().getField("textureSize_"+this.getId());t.x=this.voxelsNode.getWidth(),t.y=this.voxelsNode.getHeight(),t.z=this.voxelsNode.getDepth()}catch(e){s&&console.error(e)}}.bind(this))},addShaderFields:function(t){if(this._enabled.getValue()){if(t.addUserDefinedField(i.inputOutput,"weightConstant1_"+this.getId(),this._weightConstant1.copy()),t.addUserDefinedField(i.inputOutput,"weightConstant2_"+this.getId(),this._weightConstant2.copy()),this.weightTransferFunction1Node&&t.addUserDefinedField(i.inputOutput,"weightTransferFunction1_"+this.getId(),new e.SFNode(this.weightTransferFunction1Node)),this.weightTransferFunction2Node&&t.addUserDefinedField(i.inputOutput,"weightTransferFunction2_"+this.getId(),new e.SFNode(this.weightTransferFunction2Node)),this.voxelsNode){var n=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());t.addUserDefinedField(i.inputOutput,"voxels_"+this.getId(),new e.SFNode(this.voxelsNode)),t.addUserDefinedField(i.inputOutput,"textureSize_"+this.getId(),n)}else t.addUserDefinedField(i.inputOutput,"textureSize_"+this.getId(),new e.SFVec3f);this.getBrowser().getDefaultBlendedVolumeStyle().addShaderFields(t),this.renderStyleNode&&this.renderStyleNode.addShaderFields(t)}},getUniformsText:function(){if(!this._enabled.getValue())return"";if(!this.voxelsNode)return"";var e="";e+="\n",e+="// BlendedVolumeStyle\n",e+="\n",e+="uniform float weightConstant1_"+this.getId()+";\n",e+="uniform float weightConstant2_"+this.getId()+";\n",this.weightTransferFunction1Node&&(e+="uniform sampler2D weightTransferFunction1_"+this.getId()+";\n"),this.weightTransferFunction2Node&&(e+="uniform sampler2D weightTransferFunction2_"+this.getId()+";\n"),e+="uniform sampler3D voxels_"+this.getId()+";\n",e+="uniform vec3 textureSize_"+this.getId()+";\n";var t=this.getBrowser().getDefaultBlendedVolumeStyle().getUniformsText();this.renderStyleNode&&(t+=this.renderStyleNode.getUniformsText()),e+="\n",e+=t=(t=t.replace(/x3d_Texture3D \[0\]/g,"voxels_"+this.getId())).replace(/x3d_TextureSize/g,"textureSize_"+this.getId()),e+="\n",e+="vec4\n",e+="getBlendedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 blendColor_"+this.getId()+" = texture (voxels_"+this.getId()+", texCoord);";var n=this.getBrowser().getDefaultBlendedVolumeStyle().getFunctionsText();switch(this.renderStyleNode&&(n+=this.renderStyleNode.getFunctionsText()),e+="\n",e+=n=n.replace(/textureColor/g,"blendColor_"+this.getId()),this._weightFunction1.getValue()){default:e+="\tfloat w1_"+this.getId()+" = weightConstant1_"+this.getId()+";\n";break;case"ALPHA0":e+="\tfloat w1_"+this.getId()+" = originalColor .a;\n";break;case"ALPHA1":e+="\tfloat w1_"+this.getId()+" = blendColor_ "+this.getId()+" .a;\n";break;case"ONE_MINUS_ALPHA0":e+="\tfloat w1_"+this.getId()+" = 1.0 - originalColor .a;\n";break;case"ONE_MINUS_ALPHA1":e+="\tfloat w1_"+this.getId()+" = 1.0 - blendColor_ "+this.getId()+" .a;\n";break;case"TABLE":this.weightTransferFunction1Node?e+="\tfloat w1_"+this.getId()+" = texture (weightTransferFunction1_"+this.getId()+", vec2 (originalColor .a, blendColor_"+this.getId()+" .a)) .r;\n":e+="\tfloat w1_"+this.getId()+" = weightConstant1_"+this.getId()+";\n"}switch(this._weightFunction2.getValue()){default:e+="\tfloat w2_"+this.getId()+" = weightConstant2_"+this.getId()+";\n";break;case"ALPHA0":e+="\tfloat w2_"+this.getId()+" = originalColor .a;\n";break;case"ALPHA1":e+="\tfloat w2_"+this.getId()+" = blendColor_ "+this.getId()+" .a;\n";break;case"ONE_MINUS_ALPHA0":e+="\tfloat w2_"+this.getId()+" = 1.0 - originalColor .a;\n";break;case"ONE_MINUS_ALPHA1":e+="\tfloat w2_"+this.getId()+" = 1.0 - blendColor_ "+this.getId()+" .a;\n";break;case"TABLE":this.weightTransferFunction2Node?e+="\tfloat w2_"+this.getId()+" = texture (weightTransferFunction2_"+this.getId()+", vec2 (originalColor .a, blendColor_"+this.getId()+" .a)) .r;\n":e+="\tfloat w2_"+this.getId()+" = weightConstant2_"+this.getId()+";\n"}return e+="\n",e+="\treturn clamp (originalColor * w1_"+this.getId()+" + blendColor_"+this.getId()+" * w2_"+this.getId()+", 0.0, 1.0);\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";if(!this.voxelsNode)return"";var e="";return e+="\n",e+="\t// BlendedVolumeStyle\n",e+="\n",e+="\ttextureColor = getBlendedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),a})),e("x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants"],(function(e,t,n,o,i){"use strict";function r(e){o.call(this,e),this.addType(i.BoundaryEnhancementVolumeStyle)}return r.prototype=Object.assign(Object.create(o.prototype),{constructor:r,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"retainedOpacity",new e.SFFloat(.2)),new t(i.inputOutput,"boundaryOpacity",new e.SFFloat(.9)),new t(i.inputOutput,"opacityFactor",new e.SFFloat(2))]),getTypeName:function(){return"BoundaryEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},addShaderFields:function(e){this._enabled.getValue()&&(e.addUserDefinedField(i.inputOutput,"retainedOpacity_"+this.getId(),this._retainedOpacity.copy()),e.addUserDefinedField(i.inputOutput,"boundaryOpacity_"+this.getId(),this._boundaryOpacity.copy()),e.addUserDefinedField(i.inputOutput,"opacityFactor_"+this.getId(),this._opacityFactor.copy()))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// BoundaryEnhancementVolumeStyle\n",e+="\n",e+="uniform float retainedOpacity_"+this.getId()+";\n",e+="uniform float boundaryOpacity_"+this.getId()+";\n",e+="uniform float opacityFactor_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getBoundaryEnhancementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tfloat f0 = texture (x3d_Texture3D [0], texCoord) .r;\n",e+="\tfloat f1 = texture (x3d_Texture3D [0], texCoord + vec3 (0.0, 0.0, 1.0 / x3d_TextureSize .z)) .r;\n",e+="\tfloat f = abs (f0 - f1);\n",e+="\n",e+="\tfloat retainedOpacity = retainedOpacity_"+this.getId()+";\n",e+="\tfloat boundaryOpacity = boundaryOpacity_"+this.getId()+";\n",e+="\tfloat opacityFactor = opacityFactor_"+this.getId()+";\n",e+="\n",e+="\treturn vec4 (originalColor .rgb, originalColor .a * (retainedOpacity + boundaryOpacity * pow (f, opacityFactor)));\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// BoundaryEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getBoundaryEnhancementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),r})),e("x_ite/Components/VolumeRendering/CartoonVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.CartoonVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"colorSteps",new e.SFInt32(4)),new t(i.inputOutput,"orthogonalColor",new e.SFColorRGBA(1,1,1,1)),new t(i.inputOutput,"parallelColor",new e.SFColorRGBA(0,0,0,1)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"CartoonVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._surfaceNormals.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this._surfaceNormals)},addShaderFields:function(t){this._enabled.getValue()&&(t.addUserDefinedField(i.inputOutput,"colorSteps_"+this.getId(),this._colorSteps.copy()),t.addUserDefinedField(i.inputOutput,"orthogonalColor_"+this.getId(),this._orthogonalColor.copy()),t.addUserDefinedField(i.inputOutput,"parallelColor_"+this.getId(),this._parallelColor.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// CartoonVolumeStyle\n",e+="\n",e+="uniform int colorSteps_"+this.getId()+";\n",e+="uniform vec4 orthogonalColor_"+this.getId()+";\n",e+="uniform vec4 parallelColor_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec3\n",e+="rgb2hsv_"+this.getId()+" (in vec3 color)\n",e+="{\n",e+="\tfloat h = 0.0;\n",e+="\tfloat s = 0.0;\n",e+="\tfloat v = 0.0;\n",e+="\n",e+="\tfloat min = min (min (color .r, color .g), color .b);\n",e+="\tfloat max = max (max (color .r, color .g), color .b);\n",e+="\tv = max; // value\n",e+="\n",e+="\tfloat delta = max - min;\n",e+="\n",e+="\tif (max != 0.0 && delta != 0.0)\n",e+="\t{\n",e+="\t\ts = delta / max; // s\n",e+="\n",e+="\t\tif (color .r == max)\n",e+="\t\t\th = (color .g - color .b) / delta; // between yellow & magenta\n",e+="\t\telse if (color .g == max)\n",e+="\t\t\th = 2.0 + (color .b - color .r) / delta; // between cyan & yellow\n",e+="\t\telse\n",e+="\t\t\th = 4.0 + (color .r - color .g) / delta; // between magenta & cyan\n",e+="\n",e+="\t\th *= M_PI / 3.0; // radiants\n",e+="\t\tif (h < 0.0)\n",e+="\t\t\th += M_PI * 2.0;\n",e+="\t}\n",e+="\telse\n",e+="\t\ts = h = 0.0; // s = 0, h is undefined\n",e+="\n",e+="\treturn vec3 (h, s, v);\n",e+="}\n",e+="\n",e+="vec3\n",e+="hsv2rgb_"+this.getId()+" (in vec3 hsv)\n",e+="{\n",e+="\tfloat h = hsv [0];\n",e+="\tfloat s = clamp (hsv [1], 0.0, 1.0);\n",e+="\tfloat v = clamp (hsv [2], 0.0, 1.0);\n",e+="\n",e+="\t// H is given on [0, 2 * Pi]. S and V are given on [0, 1].\n",e+="\t// RGB are each returned on [0, 1].\n",e+="\n",e+="\tif (s == 0.0)\n",e+="\t{\n",e+="\t\t// achromatic (grey)\n",e+="\t\treturn vec3 (v, v, v);\n",e+="\t}\n",e+="\telse\n",e+="\t{\n",e+="\t\tfloat w = (h * (180.0 / M_PI)) / 60.0; // sector 0 to 5\n",e+="\n",e+="\t\tfloat i = floor (w);\n",e+="\t\tfloat f = w - i; // factorial part of h\n",e+="\t\tfloat p = v * ( 1.0 - s );\n",e+="\t\tfloat q = v * ( 1.0 - s * f );\n",e+="\t\tfloat t = v * ( 1.0 - s * ( 1.0 - f ) );\n",e+="\n",e+="\t\tswitch (int (i) % 6)\n",e+="\t\t{\n",e+="\t\t\tcase 0: return vec3 (v, t, p);\n",e+="\t\t\tcase 1: return vec3 (q, v, p);\n",e+="\t\t\tcase 2: return vec3 (p, v, t);\n",e+="\t\t\tcase 3: return vec3 (p, q, v);\n",e+="\t\t\tcase 4: return vec3 (t, p, v);\n",e+="\t\t\tdefault: return vec3 (v, p, q);\n",e+="\t\t}\n",e+="\t}\n",e+="\n",e+="\treturn vec3 (0.0);\n",e+="}\n",e+="\n",e+="vec3\n",e+="mix_hsv_"+this.getId()+" (in vec3 a, in vec3 b, in float t)\n",e+="{\n",e+="\t// Linearely interpolate in HSV space between source color @a a and destination color @a b by an amount of @a t.\n",e+="\t// Source and destination color must be in HSV space.\n",e+="\n",e+="\tfloat ha = a [0];\n",e+="\tfloat sa = a [1];\n",e+="\tfloat va = a [2];\n",e+="\n",e+="\tfloat hb = b [0];\n",e+="\tfloat sb = b [1];\n",e+="\tfloat vb = b [2];\n",e+="\n",e+="\tif (sa == 0.0)\n",e+="\t\tha = hb;\n",e+="\n",e+="\tif (sb == 0.0)\n",e+="\t\thb = ha;\n",e+="\n",e+="\tfloat range = abs (hb - ha);\n",e+="\n",e+="\tif (range <= M_PI)\n",e+="\t{\n",e+="\t\tfloat h = ha + t * (hb - ha);\n",e+="\t\tfloat s = sa + t * (sb - sa);\n",e+="\t\tfloat v = va + t * (vb - va);\n",e+="\t\treturn vec3 (h, s, v);\n",e+="\t}\n",e+="\n",e+="\tfloat PI2 = M_PI * 2.0;\n",e+="\tfloat step = (PI2 - range) * t;\n",e+="\tfloat h = ha < hb ? ha - step : ha + step;\n",e+="\n",e+="\tif (h < 0.0)\n",e+="\t\th += PI2;\n",e+="\n",e+="\telse if (h > PI2)\n",e+="\t\th -= PI2;\n",e+="\n",e+="\tfloat s = sa + t * (sb - sa);\n",e+="\tfloat v = va + t * (vb - va);\n",e+="\treturn vec3 (h, s, v);\n",e+="}\n",e+="\n",e+="vec4\n",e+="getCartoonStyle_"+this.getId()+" (in vec4 originalColor, vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 orthogonalColor = orthogonalColor_"+this.getId()+";\n",e+="\tvec4 parallelColor = parallelColor_"+this.getId()+";\n",e+="\tint colorSteps = colorSteps_"+this.getId()+";\n",e+="\n",e+="\tfloat steps = clamp (float (colorSteps), 1.0, 64.0);\n",e+="\tfloat step = M_PI / 2.0 / steps;\n",e+="\tfloat cosTheta = min (dot (surfaceNormal .xyz, normalize (vertex)), 1.0);\n",e+="\n",e+="\tif (cosTheta < 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tfloat t = cos (min (floor (acos (cosTheta) / step) * (steps > 1.0 ? steps / (steps - 1.0) : 1.0), steps) * step);\n",e+="\tvec3 orthogonalHSV = rgb2hsv_"+this.getId()+" (orthogonalColor .rgb);\n",e+="\tvec3 parallelHSV = rgb2hsv_"+this.getId()+" (parallelColor .rgb);\n",e+="\n",e+="\treturn vec4 (hsv2rgb_"+this.getId()+" (mix_hsv_"+this.getId()+" (orthogonalHSV, parallelHSV, t)), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// CartoonVolumeStyle\n",e+="\n",e+="\ttextureColor = getCartoonStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/ComposedVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ComposedVolumeStyle),this.renderStyleNodes=[]}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"renderStyle",new e.MFNode)]),getTypeName:function(){return"ComposedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._renderStyle.addInterest("set_renderStyle__",this),this.set_renderStyle__())},addVolumeData:function(e){o.prototype.addVolumeData.call(this,e);for(var t=this.renderStyleNodes,n=0,i=t.length;n<i;++n){t[n].addVolumeData(e)}},removeVolumeData:function(e){o.prototype.removeVolumeData.call(this,e);for(var t=0,n=renderStyleNodes.length;t<n;++t){renderStyleNodes[t].removeVolumeData(e)}},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){(o=e[t]).removeInterest("addNodeEvent",this),this.getVolumeData().forEach((function(e){o.removeVolumeData(e)}))}e.length=0;for(t=0,n=this._renderStyle.length;t<n;++t){(o=r(i.X3DComposableVolumeRenderStyleNode,this._renderStyle[t]))&&e.push(o)}for(t=0,n=e.length;t<n;++t){var o;(o=e[t]).addInterest("addNodeEvent",this),this.getVolumeData().forEach((function(e){o.addVolumeData(e)}))}},addShaderFields:function(e){if(this._enabled.getValue())for(var t=this.renderStyleNodes,n=0,o=t.length;n<o;++n)t[n].addShaderFields(e)},getUniformsText:function(){if(!this._enabled.getValue())return"";for(var e=this.renderStyleNodes,t="",n=0,o=e.length;n<o;++n)t+=e[n].getUniformsText();t+="\n",t+="vec4\n",t+="getComposedStyle_"+this.getId()+" (in vec4 textureColor, in vec3 texCoord)\n",t+="{\n";for(n=0,o=e.length;n<o;++n)t+=e[n].getFunctionsText();return t+="\n",t+="\treturn textureColor;\n",t+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// ComposedVolumeStyle\n",e+="\n",e+="\ttextureColor = getComposedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.EdgeEnhancementVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"edgeColor",new e.SFColorRGBA(0,0,0,1)),new t(i.inputOutput,"gradientThreshold",new e.SFFloat(.4)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"EdgeEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._surfaceNormals.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this._surfaceNormals)},addShaderFields:function(t){this._enabled.getValue()&&(t.addUserDefinedField(i.inputOutput,"edgeColor_"+this.getId(),this._edgeColor.copy()),t.addUserDefinedField(i.inputOutput,"gradientThreshold_"+this.getId(),this._gradientThreshold.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// EdgeEnhancementVolumeStyle\n",e+="\n",e+="uniform vec4 edgeColor_"+this.getId()+";\n",e+="uniform float gradientThreshold_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getEdgeEnhacementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 edgeColor = edgeColor_"+this.getId()+";\n",e+="\tfloat gradientThreshold = gradientThreshold_"+this.getId()+";\n",e+="\n",e+="\tfloat angle = abs (dot (surfaceNormal .xyz, normalize (vertex)));\n",e+="\n",e+="\tif (angle >= cos (gradientThreshold))\n",e+="\t\treturn originalColor;\n",e+="\telse\n",e+="\t\treturn vec4 (mix (edgeColor .rgb, originalColor.rgb, angle), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// EdgeEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getEdgeEnhacementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/X3DVolumeDataNode",["x_ite/Fields","x_ite/Components/Core/X3DChildNode","x_ite/Components/Grouping/X3DBoundedObject","x_ite/Base/X3DConstants","x_ite/Browser/Core/TextureQuality","standard/Math/Numbers/Vector3"],(function(e,t,n,o,i,r){"use strict";function s(e){t.call(this,e),n.call(this,e),this.addType(o.X3DVolumeDataNode),this.proximitySensorNode=e.createNode("ProximitySensor",!1),this.transformNode=e.createNode("Transform",!1),this.shapeNode=e.createNode("Shape",!1),this.appearanceNode=e.createNode("Appearance",!1),this.textureTransformNode=e.createNode("TextureTransform3D",!1),this.geometryNode=e.createNode("QuadSet",!1),this.textureCoordinateNode=e.createNode("TextureCoordinate3D",!1),this.coordinateNode=e.createNode("Coordinate",!1),this.setCameraObject(!0)}return s.prototype=Object.assign(Object.create(t.prototype),n.prototype,{constructor:s,initialize:function(){t.prototype.initialize.call(this),n.prototype.initialize.call(this);var o=this.getBrowser(),i=o.getContext();o.getBrowserOptions()._TextureQuality.addInterest("set_dimensions__",this),i.getVersion()>=2&&(this._dimensions.addInterest("set_dimensions__",this),this.set_dimensions__()),this.appearanceNode.setPrivate(!0),this.proximitySensorNode._size=new e.SFVec3f(-1,-1,-1),this.transformNode._children=new e.MFNode(this.shapeNode),this.shapeNode._appearance=this.appearanceNode,this.shapeNode._geometry=this.geometryNode,this.appearanceNode._alphaMode="BLEND",this.appearanceNode._textureTransform=this.textureTransformNode,this.textureTransformNode._translation=new e.SFVec3f(.5,.5,.5),this.textureTransformNode._center=new e.SFVec3f(-.5,-.5,-.5),this.geometryNode._texCoord=this.textureCoordinateNode,this.geometryNode._coord=this.coordinateNode,this.coordinateNode.setup(),this.textureCoordinateNode.setup(),this.geometryNode.setup(),this.textureTransformNode.setup(),this.appearanceNode.setup(),this.shapeNode.setup(),this.transformNode.setup(),this.proximitySensorNode.setup(),this.proximitySensorNode._orientation_changed.addFieldInterest(this.transformNode._rotation),this.proximitySensorNode._orientation_changed.addFieldInterest(this.textureTransformNode._rotation),this.textureTransformNode.addInterest("set_textureTransform__",this)},getBBox:function(e,t){return this._bboxSize.getValue().equals(this.getDefaultBBoxSize())?e.set(this._dimensions.getValue(),r.Zero):e.set(this._bboxSize.getValue(),this._bboxCenter.getValue())},getAppearance:function(){return this.appearanceNode},setShader:function(t){this.getAppearance()._shaders[0]=t,t.addUserDefinedField(o.inputOutput,"x3d_TextureNormalMatrix",new e.SFMatrix3f),t.setup(),this.set_textureTransform__()},getShader:function(){var e=this.appearanceNode._shaders[0];return e?e.getValue():null},getNumPlanes:function(){switch(this.getBrowser().getBrowserOptions().getTextureQuality()){case i.LOW:return 200;case i.MEDIUM:return 400;case i.HIGH:return 600}return 200},set_dimensions__:function(){var t=this.getNumPlanes(),n=this._dimensions.getValue().abs(),o=n/2,i=[];this.coordinateNode._point.length=0;for(var r=0;r<t;++r){var s=r/(t-1)-.5;i.push(o,o,n*s,-o,o,n*s,-o,-o,n*s,o,-o,n*s)}this.coordinateNode._point=i,this.textureCoordinateNode._point=i,this.textureTransformNode._scale=new e.SFVec3f(1/this._dimensions.x,1/this._dimensions.y,1/this._dimensions.z)},set_textureTransform__:function(){var e=this.getShader();e&&e.getField("x3d_TextureNormalMatrix").setValue(this.textureTransformNode.getMatrix().submatrix.inverse().transpose())},traverse:function(e,t){this.proximitySensorNode.traverse(e,t),this.transformNode.traverse(e,t)}}),s})),e("text!x_ite/Browser/VolumeRendering/VolumeStyle.vs",[],(function(){return"#version 300 es\n\nprecision highp float;\nprecision highp int;\n\nuniform mat4 x3d_ProjectionMatrix;\nuniform mat4 x3d_ModelViewMatrix;\nuniform mat4 x3d_TextureMatrix [1];\n\nin float x3d_FogDepth;\nin vec4 x3d_TexCoord0;\nin vec4 x3d_Vertex;\n\nout float fogDepth;\nout vec3 vertex;\nout vec4 texCoord;\n\nvoid\nmain ()\n{\n vec4 position = x3d_ModelViewMatrix * x3d_Vertex;\n\n fogDepth = x3d_FogDepth;\n vertex = position .xyz;\n texCoord = x3d_TextureMatrix [0] * x3d_TexCoord0;\n\n gl_Position = x3d_ProjectionMatrix * position;\n}\n"})),e("text!x_ite/Browser/VolumeRendering/VolumeStyle.fs",[],(function(){return"#version 300 es\n\nprecision highp float;\nprecision highp int;\nprecision highp sampler3D;\n\nuniform int x3d_NumLights;\nuniform x3d_LightSourceParameters x3d_LightSource [x3d_MaxLights];\n\nuniform int x3d_NumTextures;\nuniform sampler3D x3d_Texture3D [1];\nuniform vec3 x3d_TextureSize;\n\nuniform mat3 x3d_TextureNormalMatrix;\n\nconst float M_PI = 3.14159265359;\n\nin float fogDepth;\nin vec3 vertex;\nin vec4 texCoord;\n\n\nuniform x3d_FogParameters x3d_Fog;\n\nfloat\ngetFogInterpolant ()\n{\n // Returns 0.0 for fog color and 1.0 for material color.\n\n if (x3d_Fog .type == x3d_None)\n return 1.0;\n\n if (x3d_Fog .fogCoord)\n return clamp (1.0 - fogDepth, 0.0, 1.0);\n\n float visibilityRange = x3d_Fog .visibilityRange;\n\n if (visibilityRange <= 0.0)\n return 1.0;\n\n float dV = length (x3d_Fog .matrix * vertex);\n\n if (dV >= visibilityRange)\n return 0.0;\n\n switch (x3d_Fog .type)\n {\n case x3d_LinearFog:\n {\n return (visibilityRange - dV) / visibilityRange;\n }\n case x3d_ExponentialFog:\n {\n return exp (-dV / (visibilityRange - dV));\n }\n default:\n {\n return 1.0;\n }\n }\n}\n\nvec3\ngetFogColor (const in vec3 color)\n{\n return mix (x3d_Fog .color, color, getFogInterpolant ());\n}\n\n// VOLUME_STYLES_UNIFORMS\n\nout vec4 x3d_FragColor;\n\n\nuniform int x3d_NumClipPlanes;\nuniform vec4 x3d_ClipPlane [x3d_MaxClipPlanes];\n\nvoid\nclip ()\n{\n for (int i = 0; i < x3d_MaxClipPlanes; ++ i)\n {\n if (i == x3d_NumClipPlanes)\n break;\n\n if (dot (vertex, x3d_ClipPlane [i] .xyz) - x3d_ClipPlane [i] .w < 0.0)\n discard;\n }\n}\n\nvec4\ngetTextureColor (in vec3 texCoord)\n{\n if (x3d_NumTextures == 0)\n discard;\n\n if (texCoord .s < 0.0 || texCoord .s > 1.0)\n discard;\n\n if (texCoord .t < 0.0 || texCoord .t > 1.0)\n discard;\n\n if (texCoord .p < 0.0 || texCoord .p > 1.0)\n discard;\n\n vec4 textureColor = texture (x3d_Texture3D [0], texCoord);\n\n // Apply volume styles.\n\n// VOLUME_STYLES_FUNCTIONS\n\n return textureColor;\n}\n\nvoid\nmain ()\n{\n clip ();\n\n x3d_FragColor = getTextureColor (texCoord .stp / texCoord .q);\n}\n"})),e("x_ite/Components/VolumeRendering/IsoSurfaceVolumeData",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Base/X3DConstants","x_ite/Base/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],(function(e,t,n,o,i,r,s,a,d,l,u){"use strict";function h(e){o.call(this,e),this.addType(s.IsoSurfaceVolumeData),this.renderStyleNodes=[]}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"contourStepSize",new e.SFFloat(0)),new t(s.inputOutput,"surfaceValues",new e.MFFloat),new t(s.inputOutput,"surfaceTolerance",new e.SFFloat(0)),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"renderStyle",new e.MFNode),new t(s.inputOutput,"gradients",new e.SFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"IsoSurfaceVolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._gradients.addInterest("set_gradients__",this),this._renderStyle.addInterest("set_renderStyle__",this),this._voxels.addFieldInterest(this.getAppearance()._texture),this._contourStepSize.addInterest("update",this),this._surfaceValues.addInterest("update",this),this._surfaceTolerance.addInterest("update",this),this._renderStyle.addInterest("update",this),this.getAppearance()._texture=this._voxels,this.set_gradients__(),this.set_renderStyle__(),this.set_voxels__(),this.update())},set_gradients__:function(){this.gradientsNode=a(s.X3DTexture3DNode,this._gradients)},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){(o=e[t]).removeInterest("update",this),o.removeVolumeData(this)}e.length=0;for(t=0,n=this._renderStyle.length;t<n;++t){(o=a(s.X3DComposableVolumeRenderStyleNode,this._renderStyle[t]))&&e.push(o)}for(t=0,n=e.length;t<n;++t){var o;(o=e[t]).addInterest("update",this),o.addVolumeData(this)}},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this._voxels),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(d,l))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),d=o.getFunctionsText();a+="\n",a+="uniform float surfaceValues ["+this._surfaceValues.length+"];\n",a+="uniform float surfaceTolerance;\n";for(var l=0,u=this.renderStyleNodes.length;l<u;++l)a+=this.renderStyleNodes[l].getUniformsText();if(d+="\n",d+="\t// IsoSurfaceVolumeData\n",d+="\n",this.gradientsNode?(a+="\n",a+="uniform sampler3D gradients;\n",d+="\tif (length (texture (gradients, texCoord) .xyz * 2.0 - 1.0) < surfaceTolerance)\n",d+="\t\tdiscard;\n"):(a+="\n",a+="vec4\n",a+="getNormal (in vec3 texCoord)\n",a+="{\n",a+="\tvec4 offset = vec4 (1.0 / x3d_TextureSize, 0.0);\n",a+="\tfloat i0 = texture (x3d_Texture3D [0], texCoord + offset .xww) .r;\n",a+="\tfloat i1 = texture (x3d_Texture3D [0], texCoord - offset .xww) .r;\n",a+="\tfloat i2 = texture (x3d_Texture3D [0], texCoord + offset .wyw) .r;\n",a+="\tfloat i3 = texture (x3d_Texture3D [0], texCoord - offset .wyw) .r;\n",a+="\tfloat i4 = texture (x3d_Texture3D [0], texCoord + offset .wwz) .r;\n",a+="\tfloat i5 = texture (x3d_Texture3D [0], texCoord - offset .wwz) .r;\n",a+="\tvec3 n = vec3 (i1 - i0, i3 - i2, i5 - i4);\n",a+="\n",a+="\treturn vec4 (normalize (x3d_TextureNormalMatrix * n), length (n));\n",a+="}\n",d+="\tif (getNormal (texCoord) .w < surfaceTolerance)\n",d+="\t\tdiscard;\n"),d+="\n",d+="\tfloat intensity = textureColor .r;\n",d+="\n",1===this._surfaceValues.length){var h=Math.abs(this._contourStepSize.getValue());if(0===h)d+="\tif (intensity > surfaceValues [0])\n",d+="\t{\n",d+="\t\ttextureColor = vec4 (vec3 (surfaceValues [0]), 1.0);\n",this.renderStyleNodes.length&&(d+=this.renderStyleNodes[0].getFunctionsText()),d+="\t}\n",d+="\telse\n",d+="\t{\n",d+="\t\tdiscard;\n",d+="\t}\n",d+="\n";else{for(var c=[],g=this._surfaceValues[0]-h;g>0;g-=h)c.unshift(g);c.push(this._surfaceValues[0]);for(g=this._surfaceValues[0]+h;g<1;g+=h)c.push(g);d+="\tif (false)\n",d+="\t{ }\n";for(l=surfaceValues_.length-1;l>=0;--l)d+="\telse if (intensity > "+c[l]+")\n",d+="\t{\n",d+="\t\ttextureColor = vec4 (vec3 ("+c[l]+"), 1.0);\n",this.renderStyleNodes.length&&(d+=this.renderStyleNodes[0].getFunctionsText()),d+="\t}\n";d+="\telse\n",d+="\t{\n",d+="\t\tdiscard;\n",d+="\t}\n",d+="\n"}}else{d+="\tif (false)\n",d+="\t{ }\n";for(l=this._surfaceValues.length-1;l>=0;--l){if(d+="\telse if (intensity > surfaceValues ["+l+"])\n",d+="\t{\n",d+="\t\ttextureColor = vec4 (vec3 (surfaceValues ["+l+"]), 1.0);\n",this.renderStyleNodes.length){var f=Math.min(l,this.renderStyleNodes.length-1);d+=this.renderStyleNodes[f].getFunctionsText()}d+="\t}\n"}d+="\telse\n",d+="\t{\n",d+="\t\tdiscard;\n",d+="\t}\n",d+="\n"}n=(n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a)).replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,d);var p=new r(this.getExecutionContext());p.setName("VolumeDataVertexShader"),p._url.push("data:x-shader/x-vertex,"+t),p.setup();var m=new r(this.getExecutionContext());m.setName("VolumeDataFragmentShader"),m._type="FRAGMENT",m._url.push("data:x-shader/x-fragment,"+n),m.setup();var _=new i(this.getExecutionContext());if(_.setName("VolumeDataShader"),_._language="GLSL",_._parts.push(p),_._parts.push(m),_.addUserDefinedField(s.inputOutput,"surfaceValues",this._surfaceValues.copy()),_.addUserDefinedField(s.inputOutput,"surfaceTolerance",this._surfaceTolerance.copy()),this.gradientsNode&&_.addUserDefinedField(s.inputOutput,"grandients",new e.SFNode(this.gradientsNode)),this.voxelsNode){var x=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());_.addUserDefinedField(s.inputOutput,"x3d_TextureSize",x)}else _.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);o.addShaderFields(_);for(l=0,u=this.renderStyleNodes.length;l<u;++l)this.renderStyleNodes[l].addShaderFields(_);return _}}),h})),e("x_ite/Components/VolumeRendering/ProjectionVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode","x_ite/Base/X3DConstants"],(function(e,t,n,o,i){"use strict";function r(e){o.call(this,e),this.addType(i.ProjectionVolumeStyle)}return r.prototype=Object.assign(Object.create(o.prototype),{constructor:r,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"type",new e.SFString("MAX")),new t(i.inputOutput,"intensityThreshold",new e.SFFloat(0))]),getTypeName:function(){return"ProjectionVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},addShaderFields:function(e){this._enabled.getValue()&&e.addUserDefinedField(i.inputOutput,"intensityThreshold_"+this.getId(),this._intensityThreshold.copy())},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";switch(e+="\n",e+="// ProjectionVolumeStyle\n",e+="\n",e+="uniform float intensityThreshold_"+this.getId()+";\n",e+="\n",e+="vec4\n",e+="getProjectionStyle_"+this.getId()+"(in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",this._type.getValue()){default:case"MAX":case"AVERAGE":e+="\tfloat projectionColor = 0.0;\n";break;case"MIN":e+="\tfloat projectionColor = 1.0;\n"}switch(e+="\tconst int samples = 32;\n",e+="\tvec3 step = normalize (x3d_TextureNormalMatrix * vec3 (0.0, 0.0, 1.0)) / float (samples);\n",e+="\tvec3 ray = texCoord - step * float (samples) * 0.5;\n",e+="\tbool first = false;\n",e+="\n",e+="\tfor (int i = 0; i < samples; ++ i, ray += step)\n",e+="\t{\n",e+="\t\tif (ray .s < 0.0 || ray .s > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (ray .t < 0.0 || ray .t > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (ray .p < 0.0 || ray .p > 1.0)\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tfloat intensity = texture (x3d_Texture3D [0], ray) .r;\n",e+="\n",this._type.getValue()){default:case"MAX":e+="\t\tif (intensity < intensityThreshold_"+this.getId()+")\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (intensityThreshold_"+this.getId()+" > 0.0 && first)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tif (intensity <= projectionColor)\n",e+="\t\t{\n",e+="\t\t\tfirst = true;\n",e+="\t\t\tcontinue;\n",e+="\t\t}\n",e+="\n",e+="\t\tprojectionColor = intensity;\n";break;case"MIN":e+="\t\tif (intensity < intensityThreshold_"+this.getId()+")\n",e+="\t\t\tcontinue;\n",e+="\n",e+="\t\tif (intensityThreshold_"+this.getId()+" > 0.0 && first)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tif (intensity >= projectionColor)\n",e+="\t\t{\n",e+="\t\t\tfirst = true;\n",e+="\t\t\tcontinue;\n",e+="\t\t}\n",e+="\n",e+="\t\tprojectionColor = intensity;\n";break;case"AVERAGE":e+="\t\tprojectionColor += intensity;\n"}return e+="\t}\n",e+="\n","AVERAGE"===this._type.getValue()&&(e+="\tprojectionColor /= float (samples);\n"),e+="\treturn vec4 (vec3 (projectionColor), originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// ProjectionVolumeStyle\n",e+="\n",e+="\ttextureColor = getProjectionStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),r})),e("x_ite/Components/VolumeRendering/SegmentedVolumeData",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Base/X3DConstants","x_ite/Base/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],(function(e,t,n,o,i,r,s,a,d,l,u){"use strict";function h(e){o.call(this,e),this.addType(s.SegmentedVolumeData),this.segmentIdentifiersNode=null,this.renderStyleNodes=[]}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"segmentEnabled",new e.MFBool),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"segmentIdentifiers",new e.SFNode),new t(s.inputOutput,"renderStyle",new e.MFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"SegmentedVolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._segmentIdentifiers.addInterest("set_segmentIdentifiers__",this),this._renderStyle.addInterest("set_renderStyle__",this),this._voxels.addFieldInterest(this.getAppearance()._texture),this._segmentEnabled.addInterest("update",this),this._segmentIdentifiers.addInterest("update",this),this._renderStyle.addInterest("update",this),this.getAppearance()._texture=this._voxels,this.set_segmentIdentifiers__(),this.set_renderStyle__(),this.set_voxels__(),this.update())},getSegmentEnabled:function(e){return!(e<this._segmentEnabled.length)||this._segmentEnabled[e]},set_segmentIdentifiers__:function(){this.segmentIdentifiersNode=a(s.X3DTexture3DNode,this._segmentIdentifiers)},set_renderStyle__:function(){for(var e=this.renderStyleNodes,t=0,n=e.length;t<n;++t){(o=e[t]).removeInterest("update",this),o.removeVolumeData(this)}e.length=0;for(t=0,n=this._renderStyle.length;t<n;++t){(o=a(s.X3DComposableVolumeRenderStyleNode,this._renderStyle[t]))&&e.push(o)}for(t=0,n=e.length;t<n;++t){var o;(o=e[t]).addInterest("update",this),o.addVolumeData(this)}},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this._voxels),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(d,l))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),d=o.getFunctionsText();if(this.segmentIdentifiersNode?(a+="\n",a+="uniform sampler3D segmentIdentifiers;\n",d+="\n",d+="\n",d+="\tint segment = int (texture (segmentIdentifiers, texCoord) .r * 255.0);\n"):d+="\tint segment = 0;\n",this.renderStyleNodes.length){d+="\n",d+="\tswitch (segment)\n",d+="\t{\n";for(var l=0,u=this.renderStyleNodes.length;l<u;++l)d+="\t\tcase "+l+":\n",d+="\t\t{\n",this.getSegmentEnabled(l)?(a+=this.renderStyleNodes[l].getUniformsText(),d+=this.renderStyleNodes[l].getFunctionsText(),d+="\t\t\tbreak;\n"):d+="\t\t\tdiscard;\n",d+="\t\t}\n";d+="\t}\n"}n=(n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a)).replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,d);var h=new r(this.getExecutionContext());h.setName("SegmentedVolumeDataVertexShader"),h._url.push("data:x-shader/x-vertex,"+t),h.setup();var c=new r(this.getExecutionContext());c.setName("SegmentedVolumeDataFragmentShader"),c._type="FRAGMENT",c._url.push("data:x-shader/x-fragment,"+n),c.setup();var g=new i(this.getExecutionContext());if(g.setName("SegmentedVolumeDataShader"),g._language="GLSL",g._parts.push(h),g._parts.push(c),this.voxelsNode){var f=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());g.addUserDefinedField(s.inputOutput,"x3d_TextureSize",f)}else g.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);this.segmentIdentifiersNode&&g.addUserDefinedField(s.inputOutput,"segmentIdentifiers",new e.SFNode(this.segmentIdentifiersNode)),o.addShaderFields(g);for(l=0,u=this.renderStyleNodes.length;l<u;++l)this.getSegmentEnabled(l)&&this.renderStyleNodes[l].addShaderFields(g);return g}}),h})),e("x_ite/Components/VolumeRendering/ShadedVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ShadedVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"lighting",new e.SFBool),new t(i.inputOutput,"shadows",new e.SFBool),new t(i.initializeOnly,"phaseFunction",new e.SFString("Henyey-Greenstein")),new t(i.inputOutput,"material",new e.SFNode),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"ShadedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._material.addInterest("set_material__",this),this._surfaceNormals.addInterest("set_surfaceNormals__",this),this.set_material__(),this.set_surfaceNormals__())},set_material__:function(){this.materialNode&&this.materialNode.removeInterest("addNodeEvent",this),this.materialNode=r(i.X3DMaterialNode,this._material),this.materialNode&&this.materialNode.addInterest("addNodeEvent",this)},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this._surfaceNormals)},addShaderFields:function(t){this._enabled.getValue()&&(this.materialNode&&(t.addUserDefinedField(i.inputOutput,"ambientIntensity_"+this.getId(),this.materialNode._ambientIntensity.copy()),t.addUserDefinedField(i.inputOutput,"diffuseColor_"+this.getId(),this.materialNode._diffuseColor.copy()),t.addUserDefinedField(i.inputOutput,"specularColor_"+this.getId(),this.materialNode._specularColor.copy()),t.addUserDefinedField(i.inputOutput,"emissiveColor_"+this.getId(),this.materialNode._emissiveColor.copy()),t.addUserDefinedField(i.inputOutput,"shininess_"+this.getId(),this.materialNode._shininess.copy()),t.addUserDefinedField(i.inputOutput,"transparency_"+this.getId(),this.materialNode._transparency.copy())),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// ShadedVolumeStyle\n",e+="\n",e+="uniform float ambientIntensity_"+this.getId()+";\n",e+="uniform vec3 diffuseColor_"+this.getId()+";\n",e+="uniform vec3 specularColor_"+this.getId()+";\n",e+="uniform vec3 emissiveColor_"+this.getId()+";\n",e+="uniform float shininess_"+this.getId()+";\n",e+="uniform float transparency_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="float\n",e+="getSpotFactor_"+this.getId()+" (const in float cutOffAngle, const in float beamWidth, const in vec3 L, const in vec3 d)\n",e+="{\n",e+="\tfloat spotAngle = acos (clamp (dot (-L, d), -1.0, 1.0));\n",e+="\n",e+="\tif (spotAngle >= cutOffAngle)\n",e+="\t\treturn 0.0;\n",e+="\telse if (spotAngle <= beamWidth)\n",e+="\t\treturn 1.0;\n",e+="\n",e+="\treturn (spotAngle - cutOffAngle) / (beamWidth - cutOffAngle);\n",e+="}\n",e+="\n",e+="vec4\n",e+="getShadedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec4 shadedColor = vec4 (0.0);\n",this._lighting.getValue()?(this.materialNode?(e+="\tvec3 diffuseFactor = diffuseColor_"+this.getId()+";\n",e+="\tvec3 ambientTerm = diffuseFactor * ambientIntensity_"+this.getId()+";\n",e+="\n",e+="\tshadedColor .a = originalColor .a * (1.0 - transparency_"+this.getId()+");\n"):(e+="\tvec3 diffuseFactor = originalColor .rgb;\n",e+="\tvec3 ambientTerm = vec3 (0.0);\n",e+="\n",e+="\tshadedColor .a = originalColor .a;\n"),e+="\n",e+="\tvec3 N = surfaceNormal .xyz;\n",e+="\tvec3 V = normalize (-vertex); // normalized vector from point on geometry to viewer's position\n",e+="\n",e+="\tfor (int i = 0; i < x3d_MaxLights; ++ i)\n",e+="\t{\n",e+="\t\tif (i == x3d_NumLights)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tx3d_LightSourceParameters light = x3d_LightSource [i];\n",e+="\n",e+="\t\tvec3 vL = light .location - vertex; // Light to fragment\n",e+="\t\tfloat dL = length (light .matrix * vL);\n",e+="\t\tbool di = light .type == x3d_DirectionalLight;\n",e+="\n",e+="\t\tif (di || dL <= light .radius)\n",e+="\t\t{\n",e+="\t\t\tvec3 d = light .direction;\n",e+="\t\t\tvec3 c = light .attenuation;\n",e+="\t\t\tvec3 L = di ? -d : normalize (vL); // Normalized vector from point on geometry to light source i position.\n",e+="\t\t\tvec3 H = normalize (L + V); // Specular term\n",e+="\n",e+="\t\t\tfloat lightAngle = max (dot (N, L), 0.0); // Angle between normal and light ray.\n",e+="\t\t\tvec3 diffuseTerm = diffuseFactor * lightAngle;\n",e+="\t\t\tfloat specularFactor = shininess_"+this.getId()+" > 0.0 ? pow (max (dot (N, H), 0.0), shininess_"+this.getId()+" * 128.0) : 1.0;\n",e+="\t\t\tvec3 specularTerm = light .intensity * specularColor_"+this.getId()+" * specularFactor;\n",e+="\n",e+="\t\t\tfloat attenuationFactor = di ? 1.0 : 1.0 / max (c [0] + c [1] * dL + c [2] * (dL * dL), 1.0);\n",e+="\t\t\tfloat spotFactor = light .type == x3d_SpotLight ? getSpotFactor_"+this.getId()+" (light .cutOffAngle, light .beamWidth, L, d) : 1.0;\n",e+="\t\t\tfloat attenuationSpotFactor = attenuationFactor * spotFactor;\n",e+="\t\t\tvec3 ambientColor = light .ambientIntensity * ambientTerm;\n",e+="\t\t\tvec3 diffuseSpecularColor = light .intensity * (diffuseTerm + specularTerm);\n",e+="\n",e+="\t\t\tshadedColor .rgb += attenuationSpotFactor * light .color * (ambientColor + diffuseSpecularColor);\n",e+="\t\t}\n",e+="\n",e+="\t\tshadedColor .rgb += emissiveColor_"+this.getId()+";\n",e+="\t\tshadedColor .rgb = getFogColor (shadedColor .rgb);\n",e+="\t}\n"):this.materialNode?(e+="\tshadedColor .rgb = diffuseColor_"+this.getId()+";\n",e+="\tshadedColor .a = originalColor .a * (1.0 - transparency_"+this.getId()+");\n"):e+="\tshadedColor = originalColor;\n",e+="\n",e+="\treturn shadedColor;\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// ShadedVolumeStyle\n",e+="\n",e+="\ttextureColor = getShadedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.SilhouetteEnhancementVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"silhouetteRetainedOpacity",new e.SFFloat(1)),new t(i.inputOutput,"silhouetteBoundaryOpacity",new e.SFFloat(0)),new t(i.inputOutput,"silhouetteSharpness",new e.SFFloat(.5)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"SilhouetteEnhancementVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._surfaceNormals.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this._surfaceNormals)},addShaderFields:function(t){this._enabled.getValue()&&(t.addUserDefinedField(i.inputOutput,"silhouetteRetainedOpacity_"+this.getId(),this._silhouetteRetainedOpacity.copy()),t.addUserDefinedField(i.inputOutput,"silhouetteBoundaryOpacity_"+this.getId(),this._silhouetteBoundaryOpacity.copy()),t.addUserDefinedField(i.inputOutput,"silhouetteSharpness_"+this.getId(),this._silhouetteSharpness.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// SilhouetteEnhancementVolumeStyle\n",e+="\n",e+="uniform float silhouetteRetainedOpacity_"+this.getId()+";\n",e+="uniform float silhouetteBoundaryOpacity_"+this.getId()+";\n",e+="uniform float silhouetteSharpness_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getSilhouetteEnhancementStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\t\n",e+="\tfloat silhouetteRetainedOpacity = silhouetteRetainedOpacity_"+this.getId()+";\n",e+="\tfloat silhouetteBoundaryOpacity = silhouetteBoundaryOpacity_"+this.getId()+";\n",e+="\tfloat silhouetteSharpness = silhouetteSharpness_"+this.getId()+";\n",e+="\n",e+="\treturn vec4 (originalColor .rgb, originalColor .a * (silhouetteRetainedOpacity + silhouetteBoundaryOpacity * pow (1.0 - abs (dot (surfaceNormal .xyz, normalize (vertex))), silhouetteSharpness)));\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// SilhouetteEnhancementVolumeStyle\n",e+="\n",e+="\ttextureColor = getSilhouetteEnhancementStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/ToneMappedVolumeStyle",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Base/X3DConstants","x_ite/Base/X3DCast"],(function(e,t,n,o,i,r){"use strict";function s(e){o.call(this,e),this.addType(i.ToneMappedVolumeStyle)}return s.prototype=Object.assign(Object.create(o.prototype),{constructor:s,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(i.inputOutput,"metadata",new e.SFNode),new t(i.inputOutput,"enabled",new e.SFBool(!0)),new t(i.inputOutput,"coolColor",new e.SFColorRGBA(0,0,1,0)),new t(i.inputOutput,"warmColor",new e.SFColorRGBA(1,1,0,0)),new t(i.inputOutput,"surfaceNormals",new e.SFNode)]),getTypeName:function(){return"ToneMappedVolumeStyle"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"renderStyle"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._surfaceNormals.addInterest("set_surfaceNormals__",this),this.set_surfaceNormals__())},set_surfaceNormals__:function(){this.surfaceNormalsNode=r(i.X3DTexture3DNode,this._surfaceNormals)},addShaderFields:function(t){this._enabled.getValue()&&(t.addUserDefinedField(i.inputOutput,"coolColor_"+this.getId(),this._coolColor.copy()),t.addUserDefinedField(i.inputOutput,"warmColor_"+this.getId(),this._warmColor.copy()),this.surfaceNormalsNode&&t.addUserDefinedField(i.inputOutput,"surfaceNormals_"+this.getId(),new e.SFNode(this.surfaceNormalsNode)))},getUniformsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="// ToneMappedVolumeStyle\n",e+="\n",e+="uniform vec4 coolColor_"+this.getId()+";\n",e+="uniform vec4 warmColor_"+this.getId()+";\n",e+=this.getNormalText(this.surfaceNormalsNode),e+="\n",e+="vec4\n",e+="getToneMappedStyle_"+this.getId()+" (in vec4 originalColor, in vec3 texCoord)\n",e+="{\n",e+="\tvec4 surfaceNormal = getNormal_"+this.getId()+" (texCoord);\n",e+="\n",e+="\tif (surfaceNormal .w == 0.0)\n",e+="\t\treturn vec4 (0.0);\n",e+="\n",e+="\tvec3 toneColor = vec3 (0.0);\n",e+="\tvec3 coolColor = coolColor_"+this.getId()+" .rgb;\n",e+="\tvec3 warmColor = warmColor_"+this.getId()+" .rgb;\n",e+="\n",e+="\tfor (int i = 0; i < x3d_MaxLights; ++ i)\n",e+="\t{\n",e+="\t\tif (i == x3d_NumLights)\n",e+="\t\t\tbreak;\n",e+="\n",e+="\t\tx3d_LightSourceParameters light = x3d_LightSource [i];\n",e+="\n",e+="\t\tvec3 L = light .type == x3d_DirectionalLight ? -light .direction : normalize (light .location - vertex);\n",e+="\t\tfloat colorFactor = (1.0 + dot (L, surfaceNormal .xyz)) * 0.5;\n",e+="\n",e+="\t\ttoneColor += mix (warmColor .rgb, coolColor .rgb, colorFactor);\n",e+="\t}\n",e+="\n",e+="\treturn vec4 (toneColor, originalColor .a);\n",e+="}\n"},getFunctionsText:function(){if(!this._enabled.getValue())return"";var e="";return e+="\n",e+="\t// ToneMappedVolumeStyle\n",e+="\n",e+="\ttextureColor = getToneMappedStyle_"+this.getId()+" (textureColor, texCoord);\n"}}),s})),e("x_ite/Components/VolumeRendering/VolumeData",["x_ite/Fields","x_ite/Base/X3DFieldDefinition","x_ite/Base/FieldDefinitionArray","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/Shaders/ComposedShader","x_ite/Components/Shaders/ShaderPart","x_ite/Base/X3DConstants","x_ite/Base/X3DCast","text!x_ite/Browser/VolumeRendering/VolumeStyle.vs","text!x_ite/Browser/VolumeRendering/VolumeStyle.fs","x_ite/DEBUG"],(function(e,t,n,o,i,r,s,a,d,l,u){"use strict";function h(e){o.call(this,e),this.addType(s.VolumeData),this.renderStyleNode=null}return h.prototype=Object.assign(Object.create(o.prototype),{constructor:h,[Symbol.for("X_ITE.X3DBaseNode.fieldDefinitions")]:new n([new t(s.inputOutput,"metadata",new e.SFNode),new t(s.inputOutput,"dimensions",new e.SFVec3f(1,1,1)),new t(s.inputOutput,"visible",new e.SFBool(!0)),new t(s.inputOutput,"bboxDisplay",new e.SFBool),new t(s.initializeOnly,"bboxCenter",new e.SFVec3f(0,0,0)),new t(s.initializeOnly,"bboxSize",new e.SFVec3f(-1,-1,-1)),new t(s.inputOutput,"renderStyle",new e.SFNode),new t(s.inputOutput,"voxels",new e.SFNode)]),getTypeName:function(){return"VolumeData"},getComponentName:function(){return"VolumeRendering"},getContainerField:function(){return"children"},initialize:function(){o.prototype.initialize.call(this),this.getBrowser().getContext().getVersion()<2||(this._renderStyle.addInterest("set_renderStyle__",this),this._voxels.addInterest("set_voxels__",this),this._voxels.addFieldInterest(this.getAppearance()._texture),this._renderStyle.addInterest("update",this),this.getAppearance()._texture=this._voxels,this.set_renderStyle__(),this.set_voxels__(),this.update())},set_renderStyle__:function(){this.renderStyleNode&&(this.renderStyleNode.removeInterest("update",this),this.renderStyleNode.removeVolumeData(this)),this.renderStyleNode=a(s.X3DVolumeRenderStyleNode,this._renderStyle),this.renderStyleNode&&(this.renderStyleNode.addInterest("update",this),this.renderStyleNode.addVolumeData(this))},set_voxels__:function(){this.voxelsNode&&this.voxelsNode.removeInterest("set_textureSize__",this),this.voxelsNode=a(s.X3DTexture3DNode,this._voxels),this.voxelsNode&&(this.voxelsNode.addInterest("set_textureSize__",this),this.set_textureSize__())},set_textureSize__:function(){try{var e=this.getShader().getField("x3d_TextureSize");e.x=this.voxelsNode.getWidth(),e.y=this.voxelsNode.getHeight(),e.z=this.voxelsNode.getDepth()}catch(e){u&&console.log(e.message)}},update:function(){this.setShader(this.createShader(d,l))},createShader:function(t,n){var o=this.getBrowser().getDefaultVolumeStyle(),a=o.getUniformsText(),d=o.getFunctionsText();this.renderStyleNode&&(a+=this.renderStyleNode.getUniformsText(),d+=this.renderStyleNode.getFunctionsText()),n=(n=n.replace(/\/\/ VOLUME_STYLES_UNIFORMS\n/,a)).replace(/\/\/ VOLUME_STYLES_FUNCTIONS\n/,d);var l=new r(this.getExecutionContext());l.setName("VolumeDataVertexShader"),l._url.push("data:x-shader/x-vertex,"+t),l.setup();var u=new r(this.getExecutionContext());u.setName("VolumeDataFragmentShader"),u._type="FRAGMENT",u._url.push("data:x-shader/x-fragment,"+n),u.setup();var h=new i(this.getExecutionContext());if(h.setName("VolumeDataShader"),h._language="GLSL",h._parts.push(l),h._parts.push(u),this.voxelsNode){var c=new e.SFVec3f(this.voxelsNode.getWidth(),this.voxelsNode.getHeight(),this.voxelsNode.getDepth());h.addUserDefinedField(s.inputOutput,"x3d_TextureSize",c)}else h.addUserDefinedField(s.inputOutput,"x3d_TextureSize",new e.SFVec3f);return o.addShaderFields(h),this.renderStyleNode&&this.renderStyleNode.addShaderFields(h),h}}),h})),e(t.getComponentUrl("volume-rendering"),["x_ite/Components","x_ite/Browser/VolumeRendering/X3DVolumeRenderingContext","x_ite/Components/VolumeRendering/BlendedVolumeStyle","x_ite/Components/VolumeRendering/BoundaryEnhancementVolumeStyle","x_ite/Components/VolumeRendering/CartoonVolumeStyle","x_ite/Components/VolumeRendering/ComposedVolumeStyle","x_ite/Components/VolumeRendering/EdgeEnhancementVolumeStyle","x_ite/Components/VolumeRendering/IsoSurfaceVolumeData","x_ite/Components/VolumeRendering/OpacityMapVolumeStyle","x_ite/Components/VolumeRendering/ProjectionVolumeStyle","x_ite/Components/VolumeRendering/SegmentedVolumeData","x_ite/Components/VolumeRendering/ShadedVolumeStyle","x_ite/Components/VolumeRendering/SilhouetteEnhancementVolumeStyle","x_ite/Components/VolumeRendering/ToneMappedVolumeStyle","x_ite/Components/VolumeRendering/VolumeData","x_ite/Components/VolumeRendering/X3DComposableVolumeRenderStyleNode","x_ite/Components/VolumeRendering/X3DVolumeDataNode","x_ite/Components/VolumeRendering/X3DVolumeRenderStyleNode",t.getComponentUrl("cad-geometry"),t.getComponentUrl("texturing-3d")],(function(e,t,n,o,i,r,s,a,d,l,u,h,c,g,f,p,m,_){"use strict";e.addComponent({name:"VolumeRendering",types:{BlendedVolumeStyle:n,BoundaryEnhancementVolumeStyle:o,CartoonVolumeStyle:i,ComposedVolumeStyle:r,EdgeEnhancementVolumeStyle:s,IsoSurfaceVolumeData:a,OpacityMapVolumeStyle:d,ProjectionVolumeStyle:l,SegmentedVolumeData:u,ShadedVolumeStyle:h,SilhouetteEnhancementVolumeStyle:c,ToneMappedVolumeStyle:g,VolumeData:f},abstractTypes:{X3DComposableVolumeRenderStyleNode:p,X3DVolumeDataNode:m,X3DVolumeRenderStyleNode:_},browser:t})}))}();
|