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;
196 typedef std::pair< unsigned int, SoRef<SoShape> > IdShapePair;
198 const std::vector<IdShapePair>& getInternalShapeListForThisVr(
const SoVolumeRender* vr)
const;
216 std::vector<SbVec3f> vertices;
226 SoLDMVirtualTexture* texID;
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);
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);