Open Inventor Release 2025.1.0
 
Loading...
Searching...
No Matches
SoVolumeRenderingQuality.h
1/*=======================================================================
2 *** THE CONTENT OF THIS WORK IS PROPRIETARY TO FEI S.A.S, (FEI S.A.S.), ***
3 *** AND IS DISTRIBUTED UNDER A LICENSE AGREEMENT. ***
4 *** ***
5 *** REPRODUCTION, DISCLOSURE, OR USE, IN WHOLE OR IN PART, OTHER THAN AS ***
6 *** SPECIFIED IN THE LICENSE ARE NOT TO BE UNDERTAKEN EXCEPT WITH PRIOR ***
7 *** WRITTEN AUTHORIZATION OF FEI S.A.S. ***
8 *** ***
9 *** RESTRICTED RIGHTS LEGEND ***
10 *** USE, DUPLICATION, OR DISCLOSURE BY THE GOVERNMENT OF THE CONTENT OF THIS ***
11 *** WORK OR RELATED DOCUMENTATION IS SUBJECT TO RESTRICTIONS AS SET FORTH IN ***
12 *** SUBPARAGRAPH (C)(1) OF THE COMMERCIAL COMPUTER SOFTWARE RESTRICTED RIGHT ***
13 *** CLAUSE AT FAR 52.227-19 OR SUBPARAGRAPH (C)(1)(II) OF THE RIGHTS IN ***
14 *** TECHNICAL DATA AND COMPUTER SOFTWARE CLAUSE AT DFARS 52.227-7013. ***
15 *** ***
16 *** COPYRIGHT (C) 1996-2025 BY FEI S.A.S, ***
17 *** BORDEAUX, FRANCE ***
18 *** ALL RIGHTS RESERVED ***
19**=======================================================================*/
20/*=======================================================================
21** Author : Benjamin GRANGE (Aug 2005)
22**=======================================================================*/
23
24
25#ifndef _SO_VOLUME_QUALITY_H_
26#define _SO_VOLUME_QUALITY_H_
27
28
29#include <Inventor/SbBasic.h>
30#include <Inventor/fields/SoMFNode.h>
31#include <Inventor/fields/SoSFBitMask.h>
32#include <Inventor/fields/SoSFColor.h>
33#include <Inventor/fields/SoSFFloat.h>
34#include <Inventor/nodes/SoNode.h>
35#include <Inventor/nodes/SoSubNode.h>
36#include <Inventor/nodes/SoGroup.h>
37#include <VolumeViz/nodes/SoVolumeShader.h>
38
39/*----------------------------------------------------------------------------*/
41class SoVertexShader;
43class SoVolumeShader;
45
327
329
330public:
333 {
339 LOW = 0,
340
347
354#ifndef HIDDEN_FROM_DOC
355 LAST_GRADIENT_QUALITY
356#endif
357 };
358
367
369 DEPTH = 1 << 1,
370
374 GRADIENT = 1 << 2
375 };
376
381
411
431
445
455
468
476
486
499
507
516
525
534
543
555
565
580
592
607
614
622
634
651
661
669
677
695
739
740#if 1
741SoDEPRECATED
751
752#endif
753
754#if 1
755
757 /** @deprecated @DEPRECATED_SINCE_OIV 10000 @BR No longer used. OPENGL mode is always used. */SoDEPRECATED enum LightingModel
758 {
761 };
762SoDEPRECATED
773
774#endif
775
776#ifndef HIDDEN_FROM_DOC
777 private:
778
780 enum ShadowingMethod
781 {
783 SHADOW_MAP,
784
791 RAYCASTING,
792 };
793
798 SoSFEnum shadowingMethod;
799
801 SoSFFloat AORadius;
803 SoSFFloat AONumSample;
805 SoSFFloat AOKernelSize;
807 SoSFBool AOUseNormal;
809 SoSFBool AOShowAO;
811 SoSFBool AOShowNormal;
812
813 void GLRender(SoGLRenderAction *action);
814 virtual void doAction(SoAction *action);
815 virtual void notify(SoNotList* list);
816
817 // Initializes the classes.
818 static void initClass();
819 static void exitClass();
820
822 GradientQuality getGradientMethod(SoState* state) const;
823
825 SbBool hasEdgeDetect2d(SoState* state) const;
826
828 SbBool hasAmbientOcclusion(SoState* state) const;
829
831 SbBool hasDeferredLighting(SoState* state) const;
832
834 SbBool hasCubicInterpolation(SoState* state) const;
835
837 SbBool hasBoundaryOpacity(SoState* state) const;
838
840 virtual void installTextures(SoGLRenderAction* action);
841
843 virtual SbBool isRaycastingEnabled(SoState* state) const;
844
846 virtual void allocateTextureUnit(SoGLRenderAction *action) const;
847
849 SbBool isVoxelizedRenderingEnabled(SoState* state) const;
850
852 virtual bool isInterpolationActive(SoGLRenderAction* action);
853
855 virtual bool isColorInterpolationEnabled(SoState* state);
856
858 bool isPreintegratedEnabled(SoState* state) const;
859
861 void setRemovePhysicalQuality( bool removePhysicalQuality );
862
864 void setRenderMode( SoVolumeRender::RenderMode renderMode ) { m_renderMode = renderMode; }
865private:
866
868
869#endif
870
871private:
872
873 static const float DEFAULT_INNER_EDGE_THRESHOLD;
874 static const float DEFAULT_OUTTER_EDGE_THRESHOLD;
875
877 void checkAndUpdateEdge2DSupport(SoGLRenderAction* action);
878
880 SbBool hasEdgeColoring(SoState* state) const;
881
886 void clampEdgeDetect2dFields();
887
888 SoNodeDependencies* m_transferFunctionCache;
889
893 SoRef<SoGroup> m_preIntegratedScene;
894 SoGroup* m_preIntegratedTexPlaceHolder;
895 SoTextureUnit* m_preIntegratedTexUnit;
896
898 bool m_removePhysicalQuality;
899
901 SoVolumeRender::RenderMode m_renderMode;
902};
903/*----------------------------------------------------------------------------*/
904
905#endif /*_SO_VOLUME_QUALITY_H_*/
906
907
Abstract base class for all actions.
Definition SoAction.h:132
<a href="IconLegend.html"><img src="extTGS.gif" alt="VSG extension" border="0"></a> Node that define...
Renders a scene graph using Open Inventor's Render Engine.
This class is a cache handler that can be used to monitor the modifications made to elements or field...
Single-value field containing a set of bit flags.
Field containing a single Boolean value.
Definition SoSFBool.h:79
Field containing an RGB color.
Definition SoSFColor.h:82
Field containing an enumerated value.
Definition SoSFEnum.h:89
Field containing a floating-point value.
Definition SoSFFloat.h:78
Traversal state.
Definition SoState.h:74
<a href="IconLegend.html"><img src="extLDM.gif" alt="Large Data Management" border="0"></a> Describe...
<a href="IconLegend.html"><img src="extTGS.gif" alt="VSG extension" border="0"></a> Node that define...
RenderMode
Composition mode.
SoSFColor voxelOutlineColor
When voxelOutline is TRUE, this value specifies the voxel outline color.
SoSFBool edgeColoring
Enable edge coloring.
SoSFBool preIntegrated
Enable pre-integrated volume rendering.
SoSFBool jittering
Enable jittering.
SoSFBool voxelizedRendering
If true, SoVolumeRender displays voxels as individual cubes.
SoSFFloat voxelOutlineThreshold
When voxelOutline is TRUE, this threshold specifies the minimum size of a voxel, in screen pixels,...
SoSFFloat edgeThreshold
If this value is low, more edges will be detected.
SoSFFloat unnormalizedGradientExponent
When unnormalizedGradientExponent is not 0, surfaces with high gradients will be more lighted than su...
SoSFBool ambientOcclusion
If true, apply an ambient occlusion effect (default is FALSE).
SoSFBool boundaryOpacity
Enable boundary opacity.
SoSFFloat edgeDetect2DOuterThreshold
Increase this value to decrease noise on edges in the volume.
SoDEPRECATED SoSFBool cubicInterpolation
Enable cubic interpolation of data values.
SoSFBool lighting
Enable gradient based lighting (computed on the GPU).
SoDEPRECATED SoSFEnum lightingModel
Sets the lighting model.
SoSFBool edgeDetect2D
Enable 2D edge detection.
LightingModel
Available Lighting Model mode.
SoSFBitMask edgeDetect2DMethod
Method used for 2D edge detection.
SoSFFloat boundaryOpacityThreshold
Applies when boundaryOpacity is TRUE.
SoSFFloat segmentedInterpolationThreshold
Defines the iso distance used when segmentedInterpolation is true.
SoSFColor edgeColor
Color used to draw edges when edgeColoring or edgeDetect2D is TRUE.
SoVolumeRenderingQuality()
Constructor.
SoSFFloat gradientThreshold
Ignore all gradients with a magnitude less than the specified threshold.
SoSFFloat boundaryOpacityIntensity
Applies when boundaryOpacity is TRUE.
SoSFBool deferredLighting
Enable screen space lighting (computed on the GPU).
SoSFFloat edgeDetect2DInnerThreshold
Increase this value to decrease noise on silhouette edges.
SoSFFloat surfaceScalarExponent
If this field is greater than or equal to 1, a surface with a small gradient will be less lighted tha...
SoSFFloat voxelOutlineWidth
When voxelOutline is TRUE, this value specifies the voxel outline width in pixels.
SoSFBool colorInterpolation
Controls interpolation of data values used for color lookup.
SoSFBool voxelOutline
If true, draw the outline of voxels (default is false).
SoSFBool segmentedInterpolation
Allow correct interpolation when rendering segmented data.
GradientQuality
Gradient Quality mode.
@ MEDIUM
Use the central difference technique to compute the gradient.
@ HIGH
Use a Sobel filter to compute the gradient.
@ LOW
Use the forward difference technique to compute the gradient.
EdgeDetect2DMethod
The edge detection algorithm used when edgeDetect2D is TRUE, can work on the image luminance,...
@ DEPTH
Edge detection will use the image's depth buffer.
@ LUMINANCE
Edge detection will use the image's luminance.
@ GRADIENT
Edge detection will use the volume's gradient.
SoSFEnum gradientQuality
Specifies the algorithm used to compute gradients, for example, normals for lighting.
<a href="IconLegend.html"><img src="extVR.gif" alt="VolumeViz" border="0"></a> Shader node for volum...
SoVolumeShader()
Constructor.
int SbBool
Boolean type.
Definition SbBase.h:87