1 /*=========================================================================
2 Program: vv http://www.creatis.insa-lyon.fr/rio/vv
5 - University of LYON http://www.universite-lyon.fr/
6 - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
7 - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr
9 This software is distributed WITHOUT ANY WARRANTY; without even
10 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11 PURPOSE. See the copyright notices for more information.
13 It is distributed under dual licence
15 - BSD See included LICENSE.txt file
16 - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
17 ======================================================================-====*/
19 #include "vvSlicerManager.h"
22 #include "vvSlicerManagerCommand.h"
23 #include "vvInteractorStyleNavigator.h"
24 #include "vvLandmarks.h"
25 #include "vvImageReader.h"
26 #include "vvImageReader.h"
28 #include "vvImageMapToWLColors.h"
29 #include "vvBlendImageActor.h"
31 #include <vtkImageActor.h>
32 #include <vtkImageData.h>
33 #include <vtkRenderWindow.h>
34 #include <vtkRendererCollection.h>
35 #include <vtkRenderWindowInteractor.h>
36 #include <vtkImageMapToWindowLevelColors.h>
37 #include <vtkWindowLevelLookupTable.h>
38 #include <vtkColorTransferFunction.h>
39 #include <vtkImageClip.h>
40 #include <vtkLODActor.h>
41 #include <vtkPointData.h>
42 #include <vtksys/SystemTools.hxx>
44 //----------------------------------------------------------------------------
45 vvSlicerManager::vvSlicerManager(int numberOfSlicers)
54 mType = UNDEFINEDIMAGETYPE;
68 mOverlayReader = NULL;
73 for ( int i = 0; i < numberOfSlicers; i++) {
74 vvSlicer *slicer = vvSlicer::New();
75 mSlicers.push_back(slicer);
77 mPreviousSlice.resize(numberOfSlicers);
78 mPreviousTSlice.resize(numberOfSlicers);
80 //----------------------------------------------------------------------------
83 //----------------------------------------------------------------------------
84 vvSlicerManager::~vvSlicerManager()
86 for ( unsigned int i = 0; i < mSlicers.size(); i++)
88 if (mSlicers[i] != NULL)
89 mSlicers[i]->Delete();
101 delete mOverlayReader;
105 delete mFusionReader;
110 //----------------------------------------------------------------------------
113 //------------------------------------------------------------------------------
114 void vvSlicerManager::SetFilename(std::string f) {
116 for(unsigned int i=0; i<mSlicers.size(); i++) {
117 mSlicers[i]->SetFileName(f);
120 //------------------------------------------------------------------------------
123 //----------------------------------------------------------------------------
124 void vvSlicerManager::AddContour(vvMesh::Pointer contour,bool propagate)
126 for ( unsigned int i = 0; i < mSlicers.size(); i++)
128 mSlicers[i]->AddContour(contour,propagate);
131 //----------------------------------------------------------------------------
134 //----------------------------------------------------------------------------
135 void vvSlicerManager::ToggleContourSuperposition()
137 for ( unsigned int i = 0; i < mSlicers.size(); i++)
138 mSlicers[i]->ToggleContourSuperposition();
140 //----------------------------------------------------------------------------
143 //----------------------------------------------------------------------------
144 bool vvSlicerManager::SetImage(std::string filename, LoadedImageType type, int n)
146 mFileName = filename;
149 mReader = new vvImageReader;
150 std::vector<std::string> filenames;
151 filenames.push_back(filename);
152 mReader->SetInputFilenames(filenames);
153 mReader->Update(type);
155 mFileName = vtksys::SystemTools::GetFilenameName(mFileName);
156 mBaseFileName = vtksys::SystemTools::GetFilenameName(vtksys::SystemTools::GetFilenameWithoutLastExtension(mFileName));
157 // DD(mBaseFileName);
158 mBaseFileNameNumber = n;
160 if (mReader->GetLastError().size() == 0)
162 mImage=mReader->GetOutput();
163 for ( unsigned int i = 0; i < mSlicers.size(); i++)
165 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
166 mSlicers[i]->SetImage(mReader->GetOutput());
167 // DD(mSlicers[i]->GetFileName());
172 mLastError = mReader->GetLastError();
177 mFileName.append("_"+clitk::toString(n));
181 //----------------------------------------------------------------------------
184 //----------------------------------------------------------------------------
185 void vvSlicerManager::SetImage(vvImage::Pointer image)
188 for (unsigned int i = 0; i < mSlicers.size();i++)
190 mSlicers[i]->SetImage(image);
193 //----------------------------------------------------------------------------
196 //----------------------------------------------------------------------------
197 bool vvSlicerManager::SetImages(std::vector<std::string> filenames,LoadedImageType type, int n)
200 std::string fileWithoutExtension = vtksys::SystemTools::GetFilenameWithoutExtension(filenames[0]);
202 fileWithoutExtension += "_dicom";
203 else if (type == MERGED)
204 fileWithoutExtension += "_merged";
205 else if (type == MERGEDWITHTIME)
206 fileWithoutExtension += "_merged_wt";
208 mFileName = vtksys::SystemTools::GetFilenameName(mFileName);
209 mFileName = fileWithoutExtension + vtksys::SystemTools::GetFilenameExtension(filenames[0]);
211 mReader = new vvImageReader;
212 mReader->SetInputFilenames(filenames);
213 mReader->Update(type);
215 mBaseFileName = vtksys::SystemTools::GetFilenameName(vtksys::SystemTools::GetFilenameWithoutLastExtension(mFileName));
216 // DD(mBaseFileName);
217 mBaseFileNameNumber = n;
219 if (mReader->GetLastError().size() == 0)
221 mImage=mReader->GetOutput();
222 for ( unsigned int i = 0; i < mSlicers.size(); i++)
224 mSlicers[i]->SetFileName(fileWithoutExtension);
225 mSlicers[i]->SetImage(mReader->GetOutput());
230 mLastError = mReader->GetLastError();
235 mFileName.append("_"+clitk::toString(n));
240 //----------------------------------------------------------------------------
243 //----------------------------------------------------------------------------
244 bool vvSlicerManager::SetOverlay(std::string filename,int dim, std::string component)
246 mOverlayName = filename;
247 mOverlayComponent = component;
248 if (dim > mImage->GetNumberOfDimensions())
250 mLastError = " Overlay dimension cannot be greater then reference image!";
253 if (mOverlayReader == NULL)
254 mOverlayReader = new vvImageReader;
255 std::vector<std::string> filenames;
256 filenames.push_back(filename);
257 mOverlayReader->SetInputFilenames(filenames);
258 mOverlayReader->Update(mImage->GetNumberOfDimensions(),component.c_str(),mType);
259 if (mOverlayReader->GetLastError().size() == 0)
261 for ( unsigned int i = 0; i < mSlicers.size(); i++)
263 mSlicers[i]->SetOverlay(mOverlayReader->GetOutput());
268 mLastError = mOverlayReader->GetLastError();
273 //----------------------------------------------------------------------------
276 //----------------------------------------------------------------------------
277 bool vvSlicerManager::SetFusion(std::string filename,int dim, std::string component)
279 mFusionName = filename;
280 mFusionComponent = component;
281 if (dim > mImage->GetNumberOfDimensions())
283 mLastError = " Overlay dimension cannot be greater then reference image!";
286 if (mFusionReader == NULL)
287 mFusionReader = new vvImageReader;
288 std::vector<std::string> filenames;
289 filenames.push_back(filename);
290 mFusionReader->SetInputFilenames(filenames);
291 mFusionReader->Update(mImage->GetNumberOfDimensions(),component.c_str(),mType);
292 if (mFusionReader->GetLastError().size() == 0)
294 for ( unsigned int i = 0; i < mSlicers.size(); i++)
296 mSlicers[i]->SetFusion(mFusionReader->GetOutput());
301 mLastError = mFusionReader->GetLastError();
304 double *fusRange = mFusionReader->GetOutput()->GetVTKImages()[0]->GetScalarRange();
305 mFusionLevel = (fusRange[0]+fusRange[1])/2;
306 mFusionWindow = fusRange[1]-fusRange[0];
309 //----------------------------------------------------------------------------
312 //----------------------------------------------------------------------------
313 bool vvSlicerManager::SetVF(std::string filename)
315 if (mVectorReader == NULL)
316 mVectorReader = new vvImageReader;
317 mVectorReader->SetInputFilename(filename);
318 mVectorReader->Update(VECTORFIELD);
319 if (mVectorReader->GetLastError().size() != 0)
321 mLastError = mVectorReader->GetLastError();
325 return SetVF(mVectorReader->GetOutput(),filename);
327 //----------------------------------------------------------------------------
330 //----------------------------------------------------------------------------
331 bool vvSlicerManager::SetVF(vvImage::Pointer vf,std::string filename)
333 if (vf->GetNumberOfDimensions() > mImage->GetNumberOfDimensions()) {
334 mLastError = "Sorry, vector field dimension cannot be greater then reference image.";
337 if (vf->GetNumberOfDimensions() == 4) {
338 // DD(vf->GetSpacing()[3]);
339 // DD(mImage->GetSpacing()[3]);
340 // DD(vf->GetOrigin()[3]);
341 // DD(mImage->GetOrigin()[3]);
342 if (vf->GetSpacing()[3] != mImage->GetSpacing()[3]) {
343 mLastError = "Sorry, vector field time spacing cannot be different from time spacing of the reference image.";
346 if (vf->GetOrigin()[3] != mImage->GetOrigin()[3]) {
347 mLastError = "Sorry, vector field time origin cannot be different from time origin of the reference image.";
353 for ( unsigned int i = 0; i < mSlicers.size(); i++) {
354 mSlicers[i]->SetVF(vf);
358 //----------------------------------------------------------------------------
361 //----------------------------------------------------------------------------
362 void vvSlicerManager::SetExtractedImage(std::string filename,vvImage::Pointer image, int slice)
364 mFileName = filename;
365 mImage = vvImage::New();
366 if (image->GetNumberOfDimensions() == 4)
368 mImage->AddImage(image->GetVTKImages()[slice]);
369 for ( unsigned int i = 0; i < mSlicers.size(); i++)
371 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
372 mSlicers[i]->SetImage(mImage);
377 vtkImageClip* clipper = vtkImageClip::New();
379 image->GetVTKImages()[0]->GetWholeExtent(extent);
380 clipper->SetInput(image->GetVTKImages()[0]);
381 clipper->SetOutputWholeExtent(extent[0],extent[1],extent[2],extent[3],slice,slice);
383 mImage->AddImage(clipper->GetOutput());
384 for ( unsigned int i = 0; i < mSlicers.size(); i++)
386 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
387 mSlicers[i]->SetImage(mImage);
392 //----------------------------------------------------------------------------
395 //----------------------------------------------------------------------------
396 vvSlicer* vvSlicerManager::GetSlicer(int i)
400 //----------------------------------------------------------------------------
403 //----------------------------------------------------------------------------
404 void vvSlicerManager::UpdateSlicer(int num, bool state)
406 if (mSlicers[num]->GetImage())
407 mSlicers[num]->SetDisplayMode(state);
409 //----------------------------------------------------------------------------
412 //----------------------------------------------------------------------------
413 void vvSlicerManager::SetSlicerWindow(int i, vtkRenderWindow* RW)
415 mSlicers[i]->SetRenderWindow(i,RW);
417 //----------------------------------------------------------------------------
420 //----------------------------------------------------------------------------
421 void vvSlicerManager::SetInteractorStyleNavigator(int i, vtkInteractorStyle* style)
423 vvSlicerManagerCommand *smc = vvSlicerManagerCommand::New();
425 smc->SetSlicerNumber(i);
426 mSlicers[i]->GetRenderWindow()->GetInteractor()->SetInteractorStyle(style);
428 mSlicers[i]->GetRenderWindow()->GetInteractor()->
429 GetInteractorStyle()->AddObserver(vtkCommand::KeyPressEvent, smc);
430 mSlicers[i]->GetRenderWindow()->GetInteractor()->
431 GetInteractorStyle()->AddObserver(vtkCommand::WindowLevelEvent, smc);
432 mSlicers[i]->GetRenderWindow()->GetInteractor()->
433 GetInteractorStyle()->AddObserver(vtkCommand::EndWindowLevelEvent, smc);
434 mSlicers[i]->GetRenderWindow()->GetInteractor()->
435 GetInteractorStyle()->AddObserver(vtkCommand::StartWindowLevelEvent, smc);
436 mSlicers[i]->GetRenderWindow()->GetInteractor()->
437 GetInteractorStyle()->AddObserver(vtkCommand::PickEvent, smc);
438 mSlicers[i]->GetRenderWindow()->GetInteractor()->
439 GetInteractorStyle()->AddObserver(vtkCommand::StartPickEvent, smc);
440 mSlicers[i]->GetRenderWindow()->GetInteractor()->
441 GetInteractorStyle()->AddObserver(vtkCommand::LeaveEvent, smc);
442 mSlicers[i]->GetRenderWindow()->GetInteractor()->
443 GetInteractorStyle()->AddObserver(vtkCommand::UserEvent, smc);
444 mSlicers[i]->GetRenderWindow()->GetInteractor()->
445 GetInteractorStyle()->AddObserver(vtkCommand::MouseWheelForwardEvent, smc);
446 mSlicers[i]->GetRenderWindow()->GetInteractor()->
447 GetInteractorStyle()->AddObserver(vtkCommand::MouseWheelBackwardEvent, smc);
448 // mSlicers[i]->GetRenderWindow()->GetInteractor()->
449 // GetInteractorStyle()->AddObserver(vtkCommand::LeftButtonReleaseEvent, smc);
450 mSlicers[i]->GetRenderWindow()->GetInteractor()->
451 GetInteractorStyle()->AddObserver(vtkCommand::EndPickEvent, smc);
454 //----------------------------------------------------------------------------
457 //----------------------------------------------------------------------------
458 void vvSlicerManager::LeftButtonReleaseEvent(int slicer) {
459 emit LeftButtonReleaseSignal(slicer);
461 //----------------------------------------------------------------------------
464 //----------------------------------------------------------------------------
465 void vvSlicerManager::SetTSlice(int slice)
469 else if (slice > mSlicers[0]->GetTMax())
470 slice = mSlicers[0]->GetTMax();
472 mLandmarks->SetTime(slice);
473 for ( unsigned int i = 0; i < mSlicers.size(); i++)
475 if (slice != mSlicers[i]->GetTSlice()) {
476 mSlicers[i]->SetTSlice(slice);
477 if (mSlicers[i]->GetImageActor()->GetVisibility())
482 //----------------------------------------------------------------------------
485 //----------------------------------------------------------------------------
486 void vvSlicerManager::SetNextTSlice(int originating_slicer)
488 int t = mSlicers[0]->GetTSlice();
490 if (t > mSlicers[0]->GetTMax())
492 // DD("SetNextTSlice");
493 // DD(originating_slicer);
495 emit UpdateTSlice(originating_slicer,t);
497 //----------------------------------------------------------------------------
500 //----------------------------------------------------------------------------
501 void vvSlicerManager::SetPreviousTSlice(int originating_slicer)
503 int t = mSlicers[0]->GetTSlice();
506 t = mSlicers[0]->GetTMax();
507 emit UpdateTSlice(originating_slicer,t);
509 //----------------------------------------------------------------------------
512 //----------------------------------------------------------------------------
513 void vvSlicerManager::ToggleInterpolation()
515 bool interpolate=!(mSlicers[0]->GetImageActor()->GetInterpolate());
516 for ( unsigned int i = 0; i < mSlicers.size(); i++)
518 mSlicers[i]->GetImageActor()->SetInterpolate(interpolate);
521 //----------------------------------------------------------------------------
524 //----------------------------------------------------------------------------
525 void vvSlicerManager::SetTSliceInSlicer(int tslice, int slicer)
529 else if (tslice > mSlicers[slicer]->GetTMax())
530 tslice = mSlicers[slicer]->GetTMax();
532 mLandmarks->SetTime(tslice);
534 if (mSlicers[slicer]->GetTSlice() == tslice) return;
536 mSlicers[slicer]->SetTSlice(tslice);
537 if (mSlicers[slicer]->GetImageActor()->GetVisibility())
538 UpdateTSlice(slicer);
540 //----------------------------------------------------------------------------
543 //----------------------------------------------------------------------------
544 void vvSlicerManager::SetColorWindow(double s)
546 for ( unsigned int i = 0; i < mSlicers.size(); i++)
548 mSlicers[i]->SetColorWindow(s);
551 //----------------------------------------------------------------------------
554 //----------------------------------------------------------------------------
555 void vvSlicerManager::SetColorLevel(double s)
557 for ( unsigned int i = 0; i < mSlicers.size(); i++)
559 mSlicers[i]->SetColorLevel(s);
562 //----------------------------------------------------------------------------
564 //----------------------------------------------------------------------------
565 void vvSlicerManager::SetCursorVisibility(int s)
567 for ( unsigned int i = 0; i < mSlicers.size(); i++)
569 mSlicers[i]->SetCursorVisibility(s);
572 //----------------------------------------------------------------------------
575 //----------------------------------------------------------------------------
576 void vvSlicerManager::SetOpacity(int i, double factor)
578 mSlicers[i]->SetOpacity(1/factor);
580 //----------------------------------------------------------------------------
583 //----------------------------------------------------------------------------
584 void vvSlicerManager::UpdateViews(int current,int slicer)
586 // DD("UpdateViews");
590 double x = (mSlicers[slicer]->GetCurrentPosition()[0] - mSlicers[slicer]->GetInput()->GetOrigin()[0])
591 /mSlicers[slicer]->GetInput()->GetSpacing()[0];
592 double y = (mSlicers[slicer]->GetCurrentPosition()[1] - mSlicers[slicer]->GetInput()->GetOrigin()[1])
593 /mSlicers[slicer]->GetInput()->GetSpacing()[1];
594 double z = (mSlicers[slicer]->GetCurrentPosition()[2] - mSlicers[slicer]->GetInput()->GetOrigin()[2])
595 /mSlicers[slicer]->GetInput()->GetSpacing()[2];
597 if (x >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
598 x <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
599 y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
600 y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
601 z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
602 z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
604 mSlicers[slicer]->UpdateCursorPosition();
605 mSlicers[slicer]->SetCursorColor(10,212,255);
607 switch (mSlicers[slicer]->GetSliceOrientation())
609 case vtkImageViewer2::SLICE_ORIENTATION_XY:
610 if (mSlicers[slicer]->GetSlice() == (int)floor(z))
611 mSlicers[slicer]->Render();
613 mSlicers[slicer]->SetSlice((int)floor(z));
616 case vtkImageViewer2::SLICE_ORIENTATION_XZ:
617 if (mSlicers[slicer]->GetSlice() == (int)floor(y))
618 mSlicers[slicer]->Render();
620 mSlicers[slicer]->SetSlice((int)floor(y));
623 case vtkImageViewer2::SLICE_ORIENTATION_YZ:
624 if (mSlicers[slicer]->GetSlice() == (int)floor(x))
625 mSlicers[slicer]->Render();
627 mSlicers[slicer]->SetSlice((int)floor(x));
631 for ( unsigned int i = 0; i < mSlicers.size(); i++)
633 if (i != (unsigned int)slicer && mSlicers[i]->GetImageActor()->GetVisibility()
634 && mSlicers[i]->GetRenderWindow()->GetSize()[0] > 2
635 && mSlicers[i]->GetRenderWindow()->GetSize()[1] > 2)
637 mSlicers[i]->SetCurrentPosition(mSlicers[slicer]->GetCurrentPosition()[0],
638 mSlicers[slicer]->GetCurrentPosition()[1],
639 mSlicers[slicer]->GetCurrentPosition()[2],
640 mSlicers[slicer]->GetTSlice());
641 mSlicers[i]->UpdateCursorPosition();
642 if (current) //do not display corner annotation if image is the one picked
644 mSlicers[i]->SetCurrentPosition(-VTK_DOUBLE_MAX,-VTK_DOUBLE_MAX,
645 -VTK_DOUBLE_MAX, mSlicers[slicer]->GetTSlice());
646 mSlicers[i]->SetCursorColor(255,10,212);
650 mSlicers[i]->SetCursorColor(150,10,282);
652 switch (mSlicers[i]->GetSliceOrientation())
654 case vtkImageViewer2::SLICE_ORIENTATION_XY:
655 if (mSlicers[i]->GetSlice() == (int)floor(z))
656 mSlicers[i]->Render();
658 mSlicers[i]->SetSlice((int)floor(z));
661 case vtkImageViewer2::SLICE_ORIENTATION_XZ:
662 if (mSlicers[i]->GetSlice() == (int)floor(y))
663 mSlicers[i]->Render();
665 mSlicers[i]->SetSlice((int)floor(y));
668 case vtkImageViewer2::SLICE_ORIENTATION_YZ:
669 if (mSlicers[i]->GetSlice() == (int)floor(x))
670 mSlicers[i]->Render();
672 mSlicers[i]->SetSlice((int)floor(x));
675 // DD("UpdateViews::");
683 //----------------------------------------------------------------------------
686 //----------------------------------------------------------------------------
687 void vvSlicerManager::UpdateLinked(int slicer)
689 double x = (mSlicers[slicer]->GetCurrentPosition()[0] - mSlicers[slicer]->GetInput()->GetOrigin()[0])
690 /mSlicers[slicer]->GetInput()->GetSpacing()[0];
691 double y = (mSlicers[slicer]->GetCurrentPosition()[1] - mSlicers[slicer]->GetInput()->GetOrigin()[1])
692 /mSlicers[slicer]->GetInput()->GetSpacing()[1];
693 double z = (mSlicers[slicer]->GetCurrentPosition()[2] - mSlicers[slicer]->GetInput()->GetOrigin()[2])
694 /mSlicers[slicer]->GetInput()->GetSpacing()[2];
696 if (x >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
697 x <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
698 y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
699 y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
700 z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
701 z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
703 for (std::list<std::string>::const_iterator i = mLinkedId.begin(); i != mLinkedId.end(); i++)
705 emit UpdateLinkManager(*i, slicer,mSlicers[slicer]->GetCurrentPosition()[0],
706 mSlicers[slicer]->GetCurrentPosition()[1],
707 mSlicers[slicer]->GetCurrentPosition()[2],mSlicers[slicer]->GetTSlice());
711 //----------------------------------------------------------------------------
714 //----------------------------------------------------------------------------
715 double vvSlicerManager::GetColorWindow()
718 return mSlicers[0]->GetColorWindow();
721 //----------------------------------------------------------------------------
724 //----------------------------------------------------------------------------
725 double vvSlicerManager::GetColorLevel()
728 return mSlicers[0]->GetColorLevel();
731 //----------------------------------------------------------------------------
734 //----------------------------------------------------------------------------
735 void vvSlicerManager::Render()
737 // DD("vvSlicerManager::Render");
738 for ( unsigned int i = 0; i < mSlicers.size(); i++)
741 mSlicers[i]->Render();
744 //----------------------------------------------------------------------------
747 //----------------------------------------------------------------------------
748 void vvSlicerManager::GenerateDefaultLookupTable()
751 SetColorMap(mColorMap);
753 //----------------------------------------------------------------------------
756 //----------------------------------------------------------------------------
757 void vvSlicerManager::Reload()
759 mReader->Update(mType);
760 mImage=mReader->GetOutput();
761 for ( unsigned int i = 0; i < mSlicers.size(); i++)
763 mSlicers[i]->SetImage(mImage);
766 //----------------------------------------------------------------------------
769 //----------------------------------------------------------------------------
770 void vvSlicerManager::ReloadFusion()
772 mFusionReader->Update();
773 for ( unsigned int i = 0; i < mSlicers.size(); i++)
775 mSlicers[i]->SetFusion(mFusionReader->GetOutput());
776 mSlicers[i]->Render();
779 //----------------------------------------------------------------------------
782 //----------------------------------------------------------------------------
783 void vvSlicerManager::ReloadOverlay()
785 mOverlayReader->Update();
786 for ( unsigned int i = 0; i < mSlicers.size(); i++)
788 mSlicers[i]->SetOverlay(mOverlayReader->GetOutput());
789 mSlicers[i]->Render();
792 //----------------------------------------------------------------------------
795 //----------------------------------------------------------------------------
796 void vvSlicerManager::ReloadVF()
798 mVectorReader->Update(VECTORFIELD); //deletes the old images through the VF::Init() function
799 mVF=mVectorReader->GetOutput();
800 for ( unsigned int i = 0; i < mSlicers.size(); i++)
802 mSlicers[i]->SetVF(mVF);
803 mSlicers[i]->Render();
806 //----------------------------------------------------------------------------
809 //----------------------------------------------------------------------------
810 void vvSlicerManager::RemoveActor(const std::string& actor_type, int overlay_index)
812 for (unsigned int i = 0; i < mSlicers.size();i++)
814 mSlicers[i]->RemoveActor(actor_type,overlay_index);
816 if (actor_type=="vector")
820 delete mVectorReader;
825 //----------------------------------------------------------------------------
828 //----------------------------------------------------------------------------
829 void vvSlicerManager::RemoveActors()
831 ///This method leaks a few objects. See RemoveActor for what a correct implementation would look like
832 for ( unsigned int i = 0; i < mSlicers.size(); i++)
834 mSlicers[i]->SetDisplayMode(0);
835 mSlicers[i]->GetRenderer()->RemoveActor(mSlicers[i]->GetImageActor());
838 //----------------------------------------------------------------------------
841 //----------------------------------------------------------------------------
842 void vvSlicerManager::UpdateInfoOnCursorPosition(int slicer)
844 // int view = mSlicers[slicer]->GetSliceOrientation();
845 // int slice = mSlicers[slicer]->GetSlice();
846 double x = mSlicers[slicer]->GetCursorPosition()[0];
847 double y = mSlicers[slicer]->GetCursorPosition()[1];
848 double z = mSlicers[slicer]->GetCursorPosition()[2];
849 double X = (x - mSlicers[slicer]->GetInput()->GetOrigin()[0])/
850 mSlicers[slicer]->GetInput()->GetSpacing()[0];
851 double Y = (y - mSlicers[slicer]->GetInput()->GetOrigin()[1])/
852 mSlicers[slicer]->GetInput()->GetSpacing()[1];
853 double Z = (z - mSlicers[slicer]->GetInput()->GetOrigin()[2])/
854 mSlicers[slicer]->GetInput()->GetSpacing()[2];
855 double value = -VTK_DOUBLE_MAX;
857 double xVec=0, yVec=0, zVec=0, valueVec=0;
860 double valueOver=0, valueFus=0;
861 if (X >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
862 X <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
863 Y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
864 Y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
865 Z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
866 Z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
868 value = mSlicers[slicer]->GetInput()->GetScalarComponentAsDouble(
872 if (mSlicers[slicer]->GetVFActor() && mSlicers[slicer]->GetVFActor()->GetVisibility())
875 unsigned int currentTime = mSlicers[slicer]->GetTSlice();
876 vtkImageData *vf = NULL;
878 if (mSlicers[slicer]->GetVF()->GetVTKImages().size() > currentTime)
879 vf = mSlicers[slicer]->GetVF()->GetVTKImages()[currentTime];
881 vf = mSlicers[slicer]->GetVF()->GetVTKImages()[0];
885 double Xvf = (x - vf->GetOrigin()[0])/ vf->GetSpacing()[0];
886 double Yvf = (y - vf->GetOrigin()[1])/ vf->GetSpacing()[1];
887 double Zvf = (z - vf->GetOrigin()[2])/ vf->GetSpacing()[2];
888 xVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),0);
889 yVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),1);
890 zVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),2);
891 valueVec = sqrt(xVec*xVec + yVec*yVec + zVec*zVec);
894 if (mSlicers[slicer]->GetOverlayActor() && mSlicers[slicer]->GetOverlayActor()->GetVisibility())
897 double Xover = (x - mSlicers[slicer]->GetOverlay()->GetOrigin()[0])
898 /mSlicers[slicer]->GetOverlay()->GetSpacing()[0];
899 double Yover = (y - mSlicers[slicer]->GetOverlay()->GetOrigin()[1])
900 /mSlicers[slicer]->GetOverlay()->GetSpacing()[1];
901 double Zover = (z - mSlicers[slicer]->GetOverlay()->GetOrigin()[2])
902 /mSlicers[slicer]->GetOverlay()->GetSpacing()[2];
903 if (Xover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[0] &&
904 Xover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[1] &&
905 Yover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[2] &&
906 Yover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[3] &&
907 Zover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[4] &&
908 Zover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[5])
910 valueOver = static_cast<vtkImageData*>(mSlicers[slicer]->GetOverlayMapper()->GetInput())->
911 GetScalarComponentAsDouble(
914 (int)floor(Zover),0);
917 if (mSlicers[slicer]->GetFusionActor() && mSlicers[slicer]->GetFusionActor()->GetVisibility())
920 double Xfus = (x - mSlicers[slicer]->GetFusion()->GetOrigin()[0])
921 /mSlicers[slicer]->GetFusion()->GetSpacing()[0];
922 double Yfus = (y - mSlicers[slicer]->GetFusion()->GetOrigin()[1])
923 /mSlicers[slicer]->GetFusion()->GetSpacing()[1];
924 double Zfus = (z - mSlicers[slicer]->GetFusion()->GetOrigin()[2])
925 /mSlicers[slicer]->GetFusion()->GetSpacing()[2];
926 if (Xfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[0] &&
927 Xfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[1] &&
928 Yfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[2] &&
929 Yfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[3] &&
930 Zfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[4] &&
931 Zfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[5])
933 valueFus = static_cast<vtkImageData*>(mSlicers[slicer]->GetFusionMapper()->GetInput())->
934 GetScalarComponentAsDouble(
940 emit UpdatePosition(mSlicers[slicer]->GetCursorVisibility(),
942 emit UpdateVector(displayVec,xVec, yVec, zVec, valueVec);
943 emit UpdateOverlay(displayOver,valueOver,value);
944 emit UpdateFusion(displayFus,valueFus);
945 for (unsigned int i = 0; i < mSlicers.size(); i++)
947 if (mSlicers[i]->GetImageActor()->GetVisibility() == 1)
948 emit UpdateWindows(i,mSlicers[i]->GetSliceOrientation(),mSlicers[i]->GetSlice());
950 emit UpdateWindows(i,-1,-1);
954 //----------------------------------------------------------------------------
957 //----------------------------------------------------------------------------
958 void vvSlicerManager::Activated()
960 emit currentImageChanged(mId);
962 //----------------------------------------------------------------------------
965 //----------------------------------------------------------------------------
966 void vvSlicerManager::UpdateWindowLevel()
968 emit WindowLevelChanged(mSlicers[0]->GetColorWindow(),mSlicers[0]->GetColorLevel(),mPreset,mColorMap);
970 //----------------------------------------------------------------------------
973 //----------------------------------------------------------------------------
974 void vvSlicerManager::UpdateSlice(int slicer)
976 // DD("vvSlicerManager::UpdateSlice emit UpdateSlice");
978 // DD(mSlicers[slicer]->GetSlice());
979 if (mPreviousSlice[slicer] == mSlicers[slicer]->GetSlice()) {
980 //DD("============= NOTHING");
983 emit UpdateSlice(slicer, mSlicers[slicer]->GetSlice());
984 mSlicers[slicer]->Render(); // DS <-- I add this, this could/must be the only Render ...
985 mPreviousSlice[slicer] = mSlicers[slicer]->GetSlice();
987 //----------------------------------------------------------------------------
990 //----------------------------------------------------------------------------
991 void vvSlicerManager::UpdateTSlice(int slicer)
993 // DD("vvSlicerManager::UpdateTSlice emit UpdateTSlice");
995 // DD(mSlicers[slicer]->GetTSlice());
996 // DD(mSlicers[slicer]->GetSlice());
997 if (mPreviousSlice[slicer] == mSlicers[slicer]->GetSlice()) {
998 if (mPreviousTSlice[slicer] == mSlicers[slicer]->GetTSlice()) {
999 // DD("************** NOTHING ***********");
1003 mPreviousSlice[slicer] = mSlicers[slicer]->GetSlice();
1004 mPreviousTSlice[slicer] = mSlicers[slicer]->GetTSlice();
1005 emit UpdateTSlice(slicer,mSlicers[slicer]->GetTSlice());
1007 //----------------------------------------------------------------------------
1010 //----------------------------------------------------------------------------
1011 void vvSlicerManager::UpdateSliceRange(int slicer)
1013 emit UpdateSliceRange(slicer,
1014 mSlicers[slicer]->GetSliceRange()[0], mSlicers[slicer]->GetSliceRange()[1],
1015 0,mSlicers[slicer]->GetTMax());
1017 //----------------------------------------------------------------------------
1020 //----------------------------------------------------------------------------
1021 void vvSlicerManager::SetPreset(int preset)
1023 //vtkLookupTable* LUT = static_cast<vtkLookupTable*>(mSlicers[0]->GetWindowLevel()->GetLookupTable());
1024 double window = mSlicers[0]->GetColorWindow();
1025 double level = mSlicers[0]->GetColorLevel();
1027 std::string component_type=mImage->GetScalarTypeAsString();
1031 if (component_type == "unsigned_char")
1036 else if (component_type == "short")
1044 mImage->GetScalarRange(range);
1045 window = range[1] - range[0];
1046 level = (range[1] + range[0])* 0.5;
1077 this->SetColorWindow(window);
1078 this->SetColorLevel(level);
1085 //----------------------------------------------------------------------------
1088 //----------------------------------------------------------------------------
1089 void vvSlicerManager::SetLocalColorWindowing(const int slicer)
1092 this->mSlicers[slicer]->GetExtremasAroundMousePointer(min, max);
1093 this->SetColorWindow(max-min);
1094 this->SetColorLevel(0.5*(min+max));
1095 this->UpdateWindowLevel();
1098 //----------------------------------------------------------------------------
1101 //----------------------------------------------------------------------------
1102 void vvSlicerManager::SetColorMap()
1104 SetColorMap(mColorMap);
1106 //----------------------------------------------------------------------------
1109 //----------------------------------------------------------------------------
1110 void vvSlicerManager::SetColorMap(int colormap)
1113 range[0] = mSlicers[0]->GetInput()->GetScalarRange()[0];
1114 range[1] = mSlicers[0]->GetInput()->GetScalarRange()[1];
1116 double window = mSlicers[0]->GetWindowLevel()->GetWindow();
1117 double level = mSlicers[0]->GetWindowLevel()->GetLevel();
1119 vtkLookupTable* LUT = static_cast<vtkLookupTable*>(mSlicers[0]->GetWindowLevel()->GetLookupTable());
1129 LUT = vtkLookupTable::New();
1130 LUT->SetValueRange(0,1);
1131 LUT->SetSaturationRange(1,1);
1132 LUT->SetHueRange(0,0.18);
1136 LUT = vtkLookupTable::New();
1137 LUT->SetValueRange(0,1);
1138 LUT->SetSaturationRange(1,1);
1139 LUT->SetHueRange(0.4,0.80);
1143 LUT = vtkLookupTable::New();
1144 LUT->SetValueRange(0,1);
1145 LUT->SetSaturationRange(1,1);
1146 LUT->SetHueRange(0,1);
1150 LUT = vtkLookupTable::New();
1151 LUT->SetValueRange(0.,1);
1152 LUT->SetSaturationRange(1,1);
1153 LUT->SetHueRange(1,0.1);
1154 //LUT->SetRampToLinear();
1159 LUT->SetTableRange(level-fabs(window)/4,level+fabs(window)/4);
1162 vtkLookupTable* fusLUT = NULL;
1163 if (mSlicers[0]->GetFusion())
1165 fusLUT = vtkLookupTable::New();
1166 double fusRange [2];
1167 fusRange[0] = mFusionLevel - mFusionWindow/2;
1168 fusRange[1] = mFusionLevel + mFusionWindow/2;
1169 fusLUT->SetTableRange(fusRange[0],fusRange[1]);
1170 fusLUT->SetValueRange(1,1);
1171 fusLUT->SetSaturationRange(1,1);
1172 if (mFusionColorMap == 1)
1173 fusLUT->SetHueRange(0,0.18);
1174 else if (mFusionColorMap == 2)
1175 fusLUT->SetHueRange(0.4,0.80);
1176 else if (mFusionColorMap == 3)
1177 fusLUT->SetHueRange(0,1);
1179 if (mFusionColorMap == 0)
1182 for ( unsigned int i = 0; i < mSlicers.size(); i++) {
1183 if (mSlicers[i]->GetOverlay() && mSlicers[i]->GetOverlayActor()->GetVisibility()) {
1184 vtkLookupTable* supLUT = vtkLookupTable::New();
1185 supLUT->SetTableRange(range[0],range[1]);
1186 supLUT->SetValueRange(1,1);
1187 supLUT->SetSaturationRange(1,1);
1188 supLUT->SetHueRange(double(mOverlayColor)/360,double(mOverlayColor)/360);
1190 vtkLookupTable* invLUT = vtkLookupTable::New();
1191 invLUT->SetTableRange(range[0],range[1]);
1192 invLUT->SetValueRange(1,1);
1193 invLUT->SetSaturationRange(1,1);
1194 invLUT->SetHueRange(double((mOverlayColor+180)%360)/360,double((mOverlayColor+180)%360)/360);
1196 dynamic_cast<vvImageMapToWLColors*>(mSlicers[i]->GetWindowLevel())
1197 ->SetWindowLevelMode(true);
1198 mSlicers[i]->GetWindowLevel()->SetLookupTable(supLUT);
1199 mSlicers[i]->GetOverlayMapper()->SetLookupTable(invLUT);
1203 else if (mSlicers[i]->GetOverlay())
1205 //dynamic_cast<vvImageMapToWLColors*>(mSlicers[i]->GetWindowLevel())
1206 //->SetWindowLevelMode(false);
1207 mSlicers[i]->GetWindowLevel()->SetLookupTable(LUT);
1211 mSlicers[i]->GetWindowLevel()->SetLookupTable(LUT);
1213 if (mSlicers[i]->GetFusion() && mSlicers[i]->GetFusionActor()->GetVisibility())
1215 mSlicers[i]->GetFusionActor()->SetOpacity(double(mFusionOpacity)/100);
1216 mSlicers[i]->GetFusionMapper()->SetLookupTable(fusLUT);
1222 mColorMap = colormap;
1224 //----------------------------------------------------------------------------
1227 //----------------------------------------------------------------------------
1228 vvLandmarks* vvSlicerManager::GetLandmarks()
1230 if (mLandmarks == NULL)
1232 mLandmarks = new vvLandmarks(mSlicers[0]->GetTMax()+1);
1233 for (unsigned int i = 0; i < mSlicers.size(); i++)
1234 mSlicers[i]->SetLandmarks(mLandmarks);
1238 //----------------------------------------------------------------------------
1241 //----------------------------------------------------------------------------
1242 void vvSlicerManager::AddLandmark(float x,float y,float z,float t)
1244 double x_index = (x - mSlicers[0]->GetInput()->GetOrigin()[0])/mSlicers[0]->GetInput()->GetSpacing()[0];
1245 double y_index = (y - mSlicers[0]->GetInput()->GetOrigin()[1])/mSlicers[0]->GetInput()->GetSpacing()[1];
1246 double z_index = (z - mSlicers[0]->GetInput()->GetOrigin()[2])/mSlicers[0]->GetInput()->GetSpacing()[2];
1247 double value = mSlicers[0]->GetInput()->GetScalarComponentAsDouble(
1251 this->GetLandmarks()->AddLandmark(x,y,z,t,value);
1252 emit LandmarkAdded();
1254 //----------------------------------------------------------------------------
1256 //----------------------------------------------------------------------------
1257 void vvSlicerManager::PrevImage(int slicer)
1259 emit ChangeImageWithIndexOffset(this, slicer, -1);
1261 //----------------------------------------------------------------------------
1264 //----------------------------------------------------------------------------
1265 void vvSlicerManager::NextImage(int slicer)
1267 emit ChangeImageWithIndexOffset(this, slicer, 1);
1269 //----------------------------------------------------------------------------
1272 //----------------------------------------------------------------------------
1273 void vvSlicerManager::VerticalSliderHasChanged(int slicer, int slice) {
1274 emit AVerticalSliderHasChanged(slicer, slice);
1277 //----------------------------------------------------------------------------