180 virtual bool affectsPath()
const;
182 static void initClass();
183 static void exitClass();
185 void addVolume(
SoState* state,
const SoVolumeRender* vr, SoLDMVirtualTexture* vt,
SbVec3f planeNormal,
int vpScale,
float sliceDensity);
187 VGState getVGState()
const {
return m_vgState; };
190 int getEdgeDetectFragDataId()
const;
192 float getSliceDensity(
const SoVolumeRender* vr)
const;
194 SoVolumeRenderingQuality* getVRQ(
const SoVolumeRender* vr)
const;
196 typedef std::pair< unsigned int, SoRef<SoShape> > IdShapePair;
198 const std::vector<IdShapePair>& getInternalShapeListForThisVr(
const SoVolumeRender* vr)
const;
202 virtual void GLRenderBelowPath(SoGLRenderAction* action);
204 virtual void GLRenderInPath(SoGLRenderAction* action);
216 std::vector<SbVec3f> vertices;
217 const SoVolumeRender* vr;
218 Slice(
float distance,
int numVertices, SbVec3f* vertices,
const SoVolumeRender* vr);
223 const SoVolumeRender* vr;
225 SoVolumeRenderingQuality* vrq;
226 SoLDMVirtualTexture* texID;
230 SbMatrix viewingMatrix;
232 bool operator==(
const SoVolumeRender* _vr)
const
234 return this->vr == _vr;
238 typedef std::vector<VRInfo> VRInfoList;
239 typedef std::map< const SoVolumeRender*, std::vector< IdShapePair > > VRContinuousShapeMap;
241 std::map < const SoVolumeRender*, SoRef<SoVolumeRenderingQuality> > m_vrVrqMap;
243 VRContinuousShapeMap m_vrContinuousShapeMap;
245 SoVolumeOffscreenImpl* m_volumeOffscreenImpl;
248 SoVRImageSpaceEffects* m_imageSpaceEffects;
253 SoRef<SoShape> buildShapeSlices(
const SoVolumeRender* vr,
unsigned int orderedShapeId,
unsigned int id,
const std::vector<SbVec3f>& vertices);
256 VRInfoList m_vrInfoList;
261 std::vector<Slice*> m_slices;
264 void renderSlices(SoState *state);
265 static bool compareSlice(
const Slice*s1,
const Slice*s2);
273 bool preRender(SoGLRenderAction *action,
int &numberOfVolume);
277 void postRender(SoGLRenderAction *action,
int numberOfVolume);
283 void beginOffscreenRendering( SoGLRenderAction* action );
289 void endOffscreenRendering( SoGLRenderAction* action );
293 bool needRttEdgeDetect(SoState* state)
const;
297 int getEdgeDetect2DMethod(SoState* state)
const;
300 int getLowResolutionScale()
const;
303 void updateVRQ(
int bitmask, std::vector<int>& bitMaskVector);
306 void restoreVRQ(
const std::vector<int>& bitMaskVector);