X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=vv%2FvvImageContour.cxx;h=4fecf93e9371f52703dfc9634899547f74965f11;hb=8b313bf2cfa92434e47f20e3e30566b7a27e70e7;hp=173bde0e900e9f80b28cdf5c85bf87d906b8afb7;hpb=c2aaedddfc2ad8a9cefcbfcb6b67556198121984;p=clitk.git diff --git a/vv/vvImageContour.cxx b/vv/vvImageContour.cxx index 173bde0..4fecf93 100644 --- a/vv/vvImageContour.cxx +++ b/vv/vvImageContour.cxx @@ -37,6 +37,7 @@ vvImageContour::vvImageContour() SetPreserveMemoryModeEnabled(true); mPreviousOrientation = -1; mDepth = 1.0; + mSlice = 0; } //------------------------------------------------------------------------------ @@ -44,8 +45,24 @@ vvImageContour::vvImageContour() //------------------------------------------------------------------------------ vvImageContour::~vvImageContour() { - for (unsigned int i = 0; i < mSlicer->GetImage()->GetVTKImages().size(); i++) { - mSlicer->GetRenderer()->RemoveActor(mSquaresActorList[i]); + mSquaresActorList.clear(); +} +//------------------------------------------------------------------------------ + + +//------------------------------------------------------------------------------ +void vvImageContour::RemoveActors() +{ + for (unsigned int i = 0; i < mSquaresActorList.size(); i++) { + if (mSlicer != 0) { + if (mSlicer!= NULL) { + if (mSlicer->GetRenderer() != NULL) { + if (mSquaresActorList[i] != NULL) { + mSlicer->GetRenderer()->RemoveActor(mSquaresActorList[i]); + } + } + } + } } } //------------------------------------------------------------------------------ @@ -63,7 +80,7 @@ void vvImageContour::SetSlicer(vvSlicer * slicer) { //------------------------------------------------------------------------------ -void vvImageContour::SetImage(vvImage * image) { +void vvImageContour::SetImage(vvImage::Pointer image) { for (unsigned int numImage = 0; numImage < image->GetVTKImages().size(); numImage++) { mClipperList[numImage]->SetInput(image->GetVTKImages()[numImage]); } @@ -134,6 +151,20 @@ void vvImageContour::ShowActors() { //------------------------------------------------------------------------------ +//------------------------------------------------------------------------------ +void vvImageContour::SetDepth(double d) +{ + mDepth = d; + // Move the actor to be visible + double position[3] = {0, 0, 0}; + int orientation = ComputeCurrentOrientation(); + position[orientation] = -mDepth; + + for(unsigned int i=0; iSetPosition(position); +} +//------------------------------------------------------------------------------ + //------------------------------------------------------------------------------ void vvImageContour::Update(double value) { if (!mSlicer) return; @@ -338,9 +369,11 @@ void vvImageContour::UpdateActor(vtkActor * actor, if (mHiddenImageIsUsed) delete extent2; // Move the actor to be visible - double position[3] = {0, 0, 0}; - position[orientation] = -mDepth; - actor->SetPosition(position); + SetDepth(mDepth); + // double position[3] = {0, 0, 0}; + // DD(mDepth); + // position[orientation] = -mDepth; + // actor->SetPosition(position); mapper->Update(); }