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"
30 #include <vtkImageActor.h>
31 #include <vtkImageData.h>
32 #include <vtkRenderWindow.h>
33 #include <vtkRendererCollection.h>
34 #include <vtkRenderWindowInteractor.h>
35 #include <vtkImageMapToWindowLevelColors.h>
36 #include <vtkWindowLevelLookupTable.h>
37 #include <vtkColorTransferFunction.h>
38 #include <vtkImageClip.h>
39 #include <vtkLODActor.h>
40 #include <vtkPointData.h>
41 #include <vtksys/SystemTools.hxx>
43 //----------------------------------------------------------------------------
44 vvSlicerManager::vvSlicerManager(int numberOfSlicers)
53 mType = UNDEFINEDIMAGETYPE;
67 mOverlayReader = NULL;
72 for ( int i = 0; i < numberOfSlicers; i++) {
73 vvSlicer *slicer = vvSlicer::New();
74 mSlicers.push_back(slicer);
76 mPreviousSlice.resize(numberOfSlicers);
77 mPreviousTSlice.resize(numberOfSlicers);
79 //----------------------------------------------------------------------------
82 //----------------------------------------------------------------------------
83 vvSlicerManager::~vvSlicerManager()
85 for ( unsigned int i = 0; i < mSlicers.size(); i++)
87 if (mSlicers[i] != NULL)
88 mSlicers[i]->Delete();
100 delete mOverlayReader;
104 delete mFusionReader;
109 //----------------------------------------------------------------------------
112 //------------------------------------------------------------------------------
113 void vvSlicerManager::SetFilename(std::string f) {
115 for(unsigned int i=0; i<mSlicers.size(); i++) {
116 mSlicers[i]->SetFileName(f);
119 //------------------------------------------------------------------------------
122 //----------------------------------------------------------------------------
123 void vvSlicerManager::AddContour(vvMesh::Pointer contour,bool propagate)
125 for ( unsigned int i = 0; i < mSlicers.size(); i++)
127 mSlicers[i]->AddContour(contour,propagate);
130 //----------------------------------------------------------------------------
133 //----------------------------------------------------------------------------
134 void vvSlicerManager::ToggleContourSuperposition()
136 for ( unsigned int i = 0; i < mSlicers.size(); i++)
137 mSlicers[i]->ToggleContourSuperposition();
139 //----------------------------------------------------------------------------
142 //----------------------------------------------------------------------------
143 bool vvSlicerManager::SetImage(std::string filename, LoadedImageType type, int n)
145 mFileName = filename;
148 mReader = new vvImageReader;
149 std::vector<std::string> filenames;
150 filenames.push_back(filename);
151 mReader->SetInputFilenames(filenames);
152 mReader->Update(type);
154 mFileName = vtksys::SystemTools::GetFilenameName(mFileName);
155 mBaseFileName = vtksys::SystemTools::GetFilenameName(vtksys::SystemTools::GetFilenameWithoutLastExtension(mFileName));
156 // DD(mBaseFileName);
157 mBaseFileNameNumber = n;
159 if (mReader->GetLastError().size() == 0)
161 mImage=mReader->GetOutput();
162 for ( unsigned int i = 0; i < mSlicers.size(); i++)
164 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
165 mSlicers[i]->SetImage(mReader->GetOutput());
166 // DD(mSlicers[i]->GetFileName());
171 mLastError = mReader->GetLastError();
176 mFileName.append("_"+clitk::toString(n));
180 //----------------------------------------------------------------------------
183 //----------------------------------------------------------------------------
184 void vvSlicerManager::SetImage(vvImage::Pointer image)
187 for (unsigned int i = 0; i < mSlicers.size();i++)
189 mSlicers[i]->SetImage(image);
192 //----------------------------------------------------------------------------
195 //----------------------------------------------------------------------------
196 bool vvSlicerManager::SetImages(std::vector<std::string> filenames,LoadedImageType type, int n)
199 std::string fileWithoutExtension = vtksys::SystemTools::GetFilenameWithoutExtension(filenames[0]);
201 fileWithoutExtension += "_dicom";
202 else if (type == MERGED)
203 fileWithoutExtension += "_merged";
204 else if (type == MERGEDWITHTIME)
205 fileWithoutExtension += "_merged_wt";
207 mFileName = vtksys::SystemTools::GetFilenameName(mFileName);
208 mFileName = fileWithoutExtension + vtksys::SystemTools::GetFilenameExtension(filenames[0]);
210 mReader = new vvImageReader;
211 mReader->SetInputFilenames(filenames);
212 mReader->Update(type);
214 mBaseFileName = vtksys::SystemTools::GetFilenameName(vtksys::SystemTools::GetFilenameWithoutLastExtension(mFileName));
215 // DD(mBaseFileName);
216 mBaseFileNameNumber = n;
218 if (mReader->GetLastError().size() == 0)
220 mImage=mReader->GetOutput();
221 for ( unsigned int i = 0; i < mSlicers.size(); i++)
223 mSlicers[i]->SetFileName(fileWithoutExtension);
224 mSlicers[i]->SetImage(mReader->GetOutput());
229 mLastError = mReader->GetLastError();
234 mFileName.append("_"+clitk::toString(n));
239 //----------------------------------------------------------------------------
242 //----------------------------------------------------------------------------
243 bool vvSlicerManager::SetOverlay(std::string filename,int dim, std::string component)
245 mOverlayName = filename;
246 mOverlayComponent = component;
247 if (dim > mImage->GetNumberOfDimensions())
249 mLastError = " Overlay dimension cannot be greater then reference image!";
252 if (mOverlayReader == NULL)
253 mOverlayReader = new vvImageReader;
254 std::vector<std::string> filenames;
255 filenames.push_back(filename);
256 mOverlayReader->SetInputFilenames(filenames);
257 mOverlayReader->Update(mImage->GetNumberOfDimensions(),component.c_str(),mType);
258 if (mOverlayReader->GetLastError().size() == 0)
260 for ( unsigned int i = 0; i < mSlicers.size(); i++)
262 mSlicers[i]->SetOverlay(mOverlayReader->GetOutput());
267 mLastError = mOverlayReader->GetLastError();
272 //----------------------------------------------------------------------------
275 //----------------------------------------------------------------------------
276 bool vvSlicerManager::SetFusion(std::string filename,int dim, std::string component)
278 mFusionName = filename;
279 mFusionComponent = component;
280 if (dim > mImage->GetNumberOfDimensions())
282 mLastError = " Overlay dimension cannot be greater then reference image!";
285 if (mFusionReader == NULL)
286 mFusionReader = new vvImageReader;
287 std::vector<std::string> filenames;
288 filenames.push_back(filename);
289 mFusionReader->SetInputFilenames(filenames);
290 mFusionReader->Update(mImage->GetNumberOfDimensions(),component.c_str(),mType);
291 if (mFusionReader->GetLastError().size() == 0)
293 for ( unsigned int i = 0; i < mSlicers.size(); i++)
295 mSlicers[i]->SetFusion(mFusionReader->GetOutput());
300 mLastError = mFusionReader->GetLastError();
303 double *fusRange = mFusionReader->GetOutput()->GetVTKImages()[0]->GetScalarRange();
304 mFusionLevel = (fusRange[0]+fusRange[1])/2;
305 mFusionWindow = fusRange[1]-fusRange[0];
308 //----------------------------------------------------------------------------
311 //----------------------------------------------------------------------------
312 bool vvSlicerManager::SetVF(std::string filename)
314 if (mVectorReader == NULL)
315 mVectorReader = new vvImageReader;
316 mVectorReader->SetInputFilename(filename);
317 mVectorReader->Update(VECTORFIELD);
318 if (mVectorReader->GetLastError().size() != 0)
320 mLastError = mVectorReader->GetLastError();
324 return SetVF(mVectorReader->GetOutput(),filename);
326 //----------------------------------------------------------------------------
329 //----------------------------------------------------------------------------
330 bool vvSlicerManager::SetVF(vvImage::Pointer vf,std::string filename)
332 if (vf->GetNumberOfDimensions() > mImage->GetNumberOfDimensions()) {
333 mLastError = "Sorry, vector field dimension cannot be greater then reference image.";
336 if (vf->GetNumberOfDimensions() == 4) {
337 // DD(vf->GetSpacing()[3]);
338 // DD(mImage->GetSpacing()[3]);
339 // DD(vf->GetOrigin()[3]);
340 // DD(mImage->GetOrigin()[3]);
341 if (vf->GetSpacing()[3] != mImage->GetSpacing()[3]) {
342 mLastError = "Sorry, vector field time spacing cannot be different from time spacing of the reference image.";
345 if (vf->GetOrigin()[3] != mImage->GetOrigin()[3]) {
346 mLastError = "Sorry, vector field time origin cannot be different from time origin of the reference image.";
352 for ( unsigned int i = 0; i < mSlicers.size(); i++) {
353 mSlicers[i]->SetVF(vf);
357 //----------------------------------------------------------------------------
360 //----------------------------------------------------------------------------
361 void vvSlicerManager::SetExtractedImage(std::string filename,vvImage::Pointer image, int slice)
363 mFileName = filename;
364 mImage = vvImage::New();
365 if (image->GetNumberOfDimensions() == 4)
367 mImage->AddImage(image->GetVTKImages()[slice]);
368 for ( unsigned int i = 0; i < mSlicers.size(); i++)
370 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
371 mSlicers[i]->SetImage(mImage);
376 vtkImageClip* clipper = vtkImageClip::New();
378 image->GetVTKImages()[0]->GetWholeExtent(extent);
379 clipper->SetInput(image->GetVTKImages()[0]);
380 clipper->SetOutputWholeExtent(extent[0],extent[1],extent[2],extent[3],slice,slice);
382 mImage->AddImage(clipper->GetOutput());
383 for ( unsigned int i = 0; i < mSlicers.size(); i++)
385 mSlicers[i]->SetFileName(vtksys::SystemTools::GetFilenameWithoutLastExtension(filename));
386 mSlicers[i]->SetImage(mImage);
391 //----------------------------------------------------------------------------
394 //----------------------------------------------------------------------------
395 vvSlicer* vvSlicerManager::GetSlicer(int i)
399 //----------------------------------------------------------------------------
402 //----------------------------------------------------------------------------
403 void vvSlicerManager::UpdateSlicer(int num, bool state)
405 if (mSlicers[num]->GetImage())
406 mSlicers[num]->SetDisplayMode(state);
408 //----------------------------------------------------------------------------
411 //----------------------------------------------------------------------------
412 void vvSlicerManager::SetSlicerWindow(int i, vtkRenderWindow* RW)
414 mSlicers[i]->SetRenderWindow(i,RW);
416 //----------------------------------------------------------------------------
419 //----------------------------------------------------------------------------
420 void vvSlicerManager::SetInteractorStyleNavigator(int i, vtkInteractorStyle* style)
422 vvSlicerManagerCommand *smc = vvSlicerManagerCommand::New();
424 smc->SetSlicerNumber(i);
425 mSlicers[i]->GetRenderWindow()->GetInteractor()->SetInteractorStyle(style);
427 mSlicers[i]->GetRenderWindow()->GetInteractor()->
428 GetInteractorStyle()->AddObserver(vtkCommand::KeyPressEvent, smc);
429 mSlicers[i]->GetRenderWindow()->GetInteractor()->
430 GetInteractorStyle()->AddObserver(vtkCommand::WindowLevelEvent, smc);
431 mSlicers[i]->GetRenderWindow()->GetInteractor()->
432 GetInteractorStyle()->AddObserver(vtkCommand::EndWindowLevelEvent, smc);
433 mSlicers[i]->GetRenderWindow()->GetInteractor()->
434 GetInteractorStyle()->AddObserver(vtkCommand::StartWindowLevelEvent, smc);
435 mSlicers[i]->GetRenderWindow()->GetInteractor()->
436 GetInteractorStyle()->AddObserver(vtkCommand::PickEvent, smc);
437 mSlicers[i]->GetRenderWindow()->GetInteractor()->
438 GetInteractorStyle()->AddObserver(vtkCommand::StartPickEvent, smc);
439 mSlicers[i]->GetRenderWindow()->GetInteractor()->
440 GetInteractorStyle()->AddObserver(vtkCommand::LeaveEvent, smc);
441 mSlicers[i]->GetRenderWindow()->GetInteractor()->
442 GetInteractorStyle()->AddObserver(vtkCommand::UserEvent, smc);
443 mSlicers[i]->GetRenderWindow()->GetInteractor()->
444 GetInteractorStyle()->AddObserver(vtkCommand::MouseWheelForwardEvent, smc);
445 mSlicers[i]->GetRenderWindow()->GetInteractor()->
446 GetInteractorStyle()->AddObserver(vtkCommand::MouseWheelBackwardEvent, smc);
447 // mSlicers[i]->GetRenderWindow()->GetInteractor()->
448 // GetInteractorStyle()->AddObserver(vtkCommand::LeftButtonReleaseEvent, smc);
449 mSlicers[i]->GetRenderWindow()->GetInteractor()->
450 GetInteractorStyle()->AddObserver(vtkCommand::EndPickEvent, smc);
453 //----------------------------------------------------------------------------
456 //----------------------------------------------------------------------------
457 void vvSlicerManager::LeftButtonReleaseEvent(int slicer) {
458 emit LeftButtonReleaseSignal(slicer);
460 //----------------------------------------------------------------------------
463 //----------------------------------------------------------------------------
464 void vvSlicerManager::SetTSlice(int slice)
468 else if (slice > mSlicers[0]->GetTMax())
469 slice = mSlicers[0]->GetTMax();
471 mLandmarks->SetTime(slice);
472 for ( unsigned int i = 0; i < mSlicers.size(); i++)
474 if (slice != mSlicers[i]->GetTSlice()) {
475 mSlicers[i]->SetTSlice(slice);
476 if (mSlicers[i]->GetImageActor()->GetVisibility())
481 //----------------------------------------------------------------------------
484 //----------------------------------------------------------------------------
485 void vvSlicerManager::SetNextTSlice(int originating_slicer)
487 int t = mSlicers[0]->GetTSlice();
489 if (t > mSlicers[0]->GetTMax())
491 // DD("SetNextTSlice");
492 // DD(originating_slicer);
494 emit UpdateTSlice(originating_slicer,t);
496 //----------------------------------------------------------------------------
499 //----------------------------------------------------------------------------
500 void vvSlicerManager::SetPreviousTSlice(int originating_slicer)
502 int t = mSlicers[0]->GetTSlice();
505 t = mSlicers[0]->GetTMax();
506 emit UpdateTSlice(originating_slicer,t);
508 //----------------------------------------------------------------------------
511 //----------------------------------------------------------------------------
512 void vvSlicerManager::ToggleInterpolation()
514 bool interpolate=!(mSlicers[0]->GetImageActor()->GetInterpolate());
515 for ( unsigned int i = 0; i < mSlicers.size(); i++)
517 mSlicers[i]->GetImageActor()->SetInterpolate(interpolate);
520 //----------------------------------------------------------------------------
523 //----------------------------------------------------------------------------
524 void vvSlicerManager::SetTSliceInSlicer(int tslice, int slicer)
528 else if (tslice > mSlicers[slicer]->GetTMax())
529 tslice = mSlicers[slicer]->GetTMax();
531 mLandmarks->SetTime(tslice);
533 if (mSlicers[slicer]->GetTSlice() == tslice) return;
535 mSlicers[slicer]->SetTSlice(tslice);
536 if (mSlicers[slicer]->GetImageActor()->GetVisibility())
537 UpdateTSlice(slicer);
539 //----------------------------------------------------------------------------
542 //----------------------------------------------------------------------------
543 void vvSlicerManager::SetColorWindow(double s)
545 for ( unsigned int i = 0; i < mSlicers.size(); i++)
547 mSlicers[i]->SetColorWindow(s);
550 //----------------------------------------------------------------------------
553 //----------------------------------------------------------------------------
554 void vvSlicerManager::SetColorLevel(double s)
556 for ( unsigned int i = 0; i < mSlicers.size(); i++)
558 mSlicers[i]->SetColorLevel(s);
561 //----------------------------------------------------------------------------
563 //----------------------------------------------------------------------------
564 void vvSlicerManager::SetCursorVisibility(int s)
566 for ( unsigned int i = 0; i < mSlicers.size(); i++)
568 mSlicers[i]->SetCursorVisibility(s);
571 //----------------------------------------------------------------------------
574 //----------------------------------------------------------------------------
575 void vvSlicerManager::SetOpacity(int i, double factor)
577 mSlicers[i]->SetOpacity(1/factor);
579 //----------------------------------------------------------------------------
582 //----------------------------------------------------------------------------
583 void vvSlicerManager::UpdateViews(int current,int slicer)
585 // DD("UpdateViews");
589 double x = (mSlicers[slicer]->GetCurrentPosition()[0] - mSlicers[slicer]->GetInput()->GetOrigin()[0])
590 /mSlicers[slicer]->GetInput()->GetSpacing()[0];
591 double y = (mSlicers[slicer]->GetCurrentPosition()[1] - mSlicers[slicer]->GetInput()->GetOrigin()[1])
592 /mSlicers[slicer]->GetInput()->GetSpacing()[1];
593 double z = (mSlicers[slicer]->GetCurrentPosition()[2] - mSlicers[slicer]->GetInput()->GetOrigin()[2])
594 /mSlicers[slicer]->GetInput()->GetSpacing()[2];
596 if (x >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
597 x <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
598 y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
599 y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
600 z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
601 z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
603 mSlicers[slicer]->UpdateCursorPosition();
604 mSlicers[slicer]->SetCursorColor(10,212,255);
606 switch (mSlicers[slicer]->GetSliceOrientation())
608 case vtkImageViewer2::SLICE_ORIENTATION_XY:
609 if (mSlicers[slicer]->GetSlice() == (int)floor(z))
610 mSlicers[slicer]->Render();
612 mSlicers[slicer]->SetSlice((int)floor(z));
615 case vtkImageViewer2::SLICE_ORIENTATION_XZ:
616 if (mSlicers[slicer]->GetSlice() == (int)floor(y))
617 mSlicers[slicer]->Render();
619 mSlicers[slicer]->SetSlice((int)floor(y));
622 case vtkImageViewer2::SLICE_ORIENTATION_YZ:
623 if (mSlicers[slicer]->GetSlice() == (int)floor(x))
624 mSlicers[slicer]->Render();
626 mSlicers[slicer]->SetSlice((int)floor(x));
630 for ( unsigned int i = 0; i < mSlicers.size(); i++)
632 if (i != (unsigned int)slicer && mSlicers[i]->GetImageActor()->GetVisibility()
633 && mSlicers[i]->GetRenderWindow()->GetSize()[0] > 2
634 && mSlicers[i]->GetRenderWindow()->GetSize()[1] > 2)
636 mSlicers[i]->SetCurrentPosition(mSlicers[slicer]->GetCurrentPosition()[0],
637 mSlicers[slicer]->GetCurrentPosition()[1],
638 mSlicers[slicer]->GetCurrentPosition()[2],
639 mSlicers[slicer]->GetTSlice());
640 mSlicers[i]->UpdateCursorPosition();
641 if (current) //do not display corner annotation if image is the one picked
643 mSlicers[i]->SetCurrentPosition(-VTK_DOUBLE_MAX,-VTK_DOUBLE_MAX,
644 -VTK_DOUBLE_MAX, mSlicers[slicer]->GetTSlice());
645 mSlicers[i]->SetCursorColor(255,10,212);
649 mSlicers[i]->SetCursorColor(150,10,282);
651 switch (mSlicers[i]->GetSliceOrientation())
653 case vtkImageViewer2::SLICE_ORIENTATION_XY:
654 if (mSlicers[i]->GetSlice() == (int)floor(z))
655 mSlicers[i]->Render();
657 mSlicers[i]->SetSlice((int)floor(z));
660 case vtkImageViewer2::SLICE_ORIENTATION_XZ:
661 if (mSlicers[i]->GetSlice() == (int)floor(y))
662 mSlicers[i]->Render();
664 mSlicers[i]->SetSlice((int)floor(y));
667 case vtkImageViewer2::SLICE_ORIENTATION_YZ:
668 if (mSlicers[i]->GetSlice() == (int)floor(x))
669 mSlicers[i]->Render();
671 mSlicers[i]->SetSlice((int)floor(x));
674 // DD("UpdateViews::");
682 //----------------------------------------------------------------------------
685 //----------------------------------------------------------------------------
686 void vvSlicerManager::UpdateLinked(int slicer)
688 double x = (mSlicers[slicer]->GetCurrentPosition()[0] - mSlicers[slicer]->GetInput()->GetOrigin()[0])
689 /mSlicers[slicer]->GetInput()->GetSpacing()[0];
690 double y = (mSlicers[slicer]->GetCurrentPosition()[1] - mSlicers[slicer]->GetInput()->GetOrigin()[1])
691 /mSlicers[slicer]->GetInput()->GetSpacing()[1];
692 double z = (mSlicers[slicer]->GetCurrentPosition()[2] - mSlicers[slicer]->GetInput()->GetOrigin()[2])
693 /mSlicers[slicer]->GetInput()->GetSpacing()[2];
695 if (x >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
696 x <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
697 y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
698 y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
699 z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
700 z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
702 for (std::list<std::string>::const_iterator i = mLinkedId.begin(); i != mLinkedId.end(); i++)
704 emit UpdateLinkManager(*i, slicer,mSlicers[slicer]->GetCurrentPosition()[0],
705 mSlicers[slicer]->GetCurrentPosition()[1],
706 mSlicers[slicer]->GetCurrentPosition()[2],mSlicers[slicer]->GetTSlice());
710 //----------------------------------------------------------------------------
713 //----------------------------------------------------------------------------
714 double vvSlicerManager::GetColorWindow()
717 return mSlicers[0]->GetColorWindow();
720 //----------------------------------------------------------------------------
723 //----------------------------------------------------------------------------
724 double vvSlicerManager::GetColorLevel()
727 return mSlicers[0]->GetColorLevel();
730 //----------------------------------------------------------------------------
733 //----------------------------------------------------------------------------
734 void vvSlicerManager::Render()
736 // DD("vvSlicerManager::Render");
737 for ( unsigned int i = 0; i < mSlicers.size(); i++)
740 mSlicers[i]->Render();
743 //----------------------------------------------------------------------------
746 //----------------------------------------------------------------------------
747 void vvSlicerManager::GenerateDefaultLookupTable()
750 SetColorMap(mColorMap);
752 //----------------------------------------------------------------------------
755 //----------------------------------------------------------------------------
756 void vvSlicerManager::Reload()
758 mReader->Update(mType);
759 mImage=mReader->GetOutput();
760 for ( unsigned int i = 0; i < mSlicers.size(); i++)
762 mSlicers[i]->SetImage(mImage);
765 //----------------------------------------------------------------------------
768 //----------------------------------------------------------------------------
769 void vvSlicerManager::ReloadFusion()
771 mFusionReader->Update();
772 for ( unsigned int i = 0; i < mSlicers.size(); i++)
774 mSlicers[i]->SetFusion(mFusionReader->GetOutput());
775 mSlicers[i]->Render();
778 //----------------------------------------------------------------------------
781 //----------------------------------------------------------------------------
782 void vvSlicerManager::ReloadOverlay()
784 mOverlayReader->Update();
785 for ( unsigned int i = 0; i < mSlicers.size(); i++)
787 mSlicers[i]->SetOverlay(mOverlayReader->GetOutput());
788 mSlicers[i]->Render();
791 //----------------------------------------------------------------------------
794 //----------------------------------------------------------------------------
795 void vvSlicerManager::ReloadVF()
797 mVectorReader->Update(VECTORFIELD); //deletes the old images through the VF::Init() function
798 mVF=mVectorReader->GetOutput();
799 for ( unsigned int i = 0; i < mSlicers.size(); i++)
801 mSlicers[i]->SetVF(mVF);
802 mSlicers[i]->Render();
805 //----------------------------------------------------------------------------
808 //----------------------------------------------------------------------------
809 void vvSlicerManager::RemoveActor(const std::string& actor_type, int overlay_index)
811 for (unsigned int i = 0; i < mSlicers.size();i++)
813 mSlicers[i]->RemoveActor(actor_type,overlay_index);
815 if (actor_type=="vector")
819 delete mVectorReader;
824 //----------------------------------------------------------------------------
827 //----------------------------------------------------------------------------
828 void vvSlicerManager::RemoveActors()
830 ///This method leaks a few objects. See RemoveActor for what a correct implementation would look like
831 for ( unsigned int i = 0; i < mSlicers.size(); i++)
833 mSlicers[i]->SetDisplayMode(0);
834 mSlicers[i]->GetRenderer()->RemoveActor(mSlicers[i]->GetImageActor());
837 //----------------------------------------------------------------------------
840 //----------------------------------------------------------------------------
841 void vvSlicerManager::UpdateInfoOnCursorPosition(int slicer)
843 // int view = mSlicers[slicer]->GetSliceOrientation();
844 // int slice = mSlicers[slicer]->GetSlice();
845 double x = mSlicers[slicer]->GetCursorPosition()[0];
846 double y = mSlicers[slicer]->GetCursorPosition()[1];
847 double z = mSlicers[slicer]->GetCursorPosition()[2];
848 double X = (x - mSlicers[slicer]->GetInput()->GetOrigin()[0])/
849 mSlicers[slicer]->GetInput()->GetSpacing()[0];
850 double Y = (y - mSlicers[slicer]->GetInput()->GetOrigin()[1])/
851 mSlicers[slicer]->GetInput()->GetSpacing()[1];
852 double Z = (z - mSlicers[slicer]->GetInput()->GetOrigin()[2])/
853 mSlicers[slicer]->GetInput()->GetSpacing()[2];
854 double value = -VTK_DOUBLE_MAX;
856 double xVec=0, yVec=0, zVec=0, valueVec=0;
859 double valueOver=0, valueFus=0;
860 if (X >= mSlicers[slicer]->GetInput()->GetWholeExtent()[0] &&
861 X <= mSlicers[slicer]->GetInput()->GetWholeExtent()[1] &&
862 Y >= mSlicers[slicer]->GetInput()->GetWholeExtent()[2] &&
863 Y <= mSlicers[slicer]->GetInput()->GetWholeExtent()[3] &&
864 Z >= mSlicers[slicer]->GetInput()->GetWholeExtent()[4] &&
865 Z <= mSlicers[slicer]->GetInput()->GetWholeExtent()[5])
867 value = mSlicers[slicer]->GetInput()->GetScalarComponentAsDouble(
871 if (mSlicers[slicer]->GetVFActor() && mSlicers[slicer]->GetVFActor()->GetVisibility())
874 unsigned int currentTime = mSlicers[slicer]->GetTSlice();
875 vtkImageData *vf = NULL;
877 if (mSlicers[slicer]->GetVF()->GetVTKImages().size() > currentTime)
878 vf = mSlicers[slicer]->GetVF()->GetVTKImages()[currentTime];
880 vf = mSlicers[slicer]->GetVF()->GetVTKImages()[0];
884 double Xvf = (x - vf->GetOrigin()[0])/ vf->GetSpacing()[0];
885 double Yvf = (y - vf->GetOrigin()[1])/ vf->GetSpacing()[1];
886 double Zvf = (z - vf->GetOrigin()[2])/ vf->GetSpacing()[2];
887 xVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),0);
888 yVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),1);
889 zVec = vf->GetScalarComponentAsDouble( (int)floor(Xvf), (int)floor(Yvf), (int)floor(Zvf),2);
890 valueVec = sqrt(xVec*xVec + yVec*yVec + zVec*zVec);
893 if (mSlicers[slicer]->GetOverlayActor() && mSlicers[slicer]->GetOverlayActor()->GetVisibility())
896 double Xover = (x - mSlicers[slicer]->GetOverlay()->GetOrigin()[0])
897 /mSlicers[slicer]->GetOverlay()->GetSpacing()[0];
898 double Yover = (y - mSlicers[slicer]->GetOverlay()->GetOrigin()[1])
899 /mSlicers[slicer]->GetOverlay()->GetSpacing()[1];
900 double Zover = (z - mSlicers[slicer]->GetOverlay()->GetOrigin()[2])
901 /mSlicers[slicer]->GetOverlay()->GetSpacing()[2];
902 if (Xover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[0] &&
903 Xover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[1] &&
904 Yover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[2] &&
905 Yover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[3] &&
906 Zover >= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[4] &&
907 Zover <= mSlicers[slicer]->GetOverlayMapper()->GetInput()->GetWholeExtent()[5])
909 valueOver = static_cast<vtkImageData*>(mSlicers[slicer]->GetOverlayMapper()->GetInput())->
910 GetScalarComponentAsDouble(
913 (int)floor(Zover),0);
916 if (mSlicers[slicer]->GetFusionActor() && mSlicers[slicer]->GetFusionActor()->GetVisibility())
919 double Xfus = (x - mSlicers[slicer]->GetFusion()->GetOrigin()[0])
920 /mSlicers[slicer]->GetFusion()->GetSpacing()[0];
921 double Yfus = (y - mSlicers[slicer]->GetFusion()->GetOrigin()[1])
922 /mSlicers[slicer]->GetFusion()->GetSpacing()[1];
923 double Zfus = (z - mSlicers[slicer]->GetFusion()->GetOrigin()[2])
924 /mSlicers[slicer]->GetFusion()->GetSpacing()[2];
925 if (Xfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[0] &&
926 Xfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[1] &&
927 Yfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[2] &&
928 Yfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[3] &&
929 Zfus >= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[4] &&
930 Zfus <= mSlicers[slicer]->GetFusionMapper()->GetInput()->GetWholeExtent()[5])
932 valueFus = static_cast<vtkImageData*>(mSlicers[slicer]->GetFusionMapper()->GetInput())->
933 GetScalarComponentAsDouble(
939 emit UpdatePosition(mSlicers[slicer]->GetCursorVisibility(),
941 emit UpdateVector(displayVec,xVec, yVec, zVec, valueVec);
942 emit UpdateOverlay(displayOver,valueOver,value);
943 emit UpdateFusion(displayFus,valueFus);
944 for (unsigned int i = 0; i < mSlicers.size(); i++)
946 if (mSlicers[i]->GetImageActor()->GetVisibility() == 1)
947 emit UpdateWindows(i,mSlicers[i]->GetSliceOrientation(),mSlicers[i]->GetSlice());
949 emit UpdateWindows(i,-1,-1);
953 //----------------------------------------------------------------------------
956 //----------------------------------------------------------------------------
957 void vvSlicerManager::Activated()
959 emit currentImageChanged(mId);
961 //----------------------------------------------------------------------------
964 //----------------------------------------------------------------------------
965 void vvSlicerManager::UpdateWindowLevel()
967 emit WindowLevelChanged(mSlicers[0]->GetColorWindow(),mSlicers[0]->GetColorLevel(),mPreset,mColorMap);
969 //----------------------------------------------------------------------------
972 //----------------------------------------------------------------------------
973 void vvSlicerManager::UpdateSlice(int slicer)
975 // DD("vvSlicerManager::UpdateSlice emit UpdateSlice");
977 // DD(mSlicers[slicer]->GetSlice());
978 if (mPreviousSlice[slicer] == mSlicers[slicer]->GetSlice()) {
979 //DD("============= NOTHING");
982 emit UpdateSlice(slicer, mSlicers[slicer]->GetSlice());
983 mSlicers[slicer]->Render(); // DS <-- I add this, this could/must be the only Render ...
984 mPreviousSlice[slicer] = mSlicers[slicer]->GetSlice();
986 //----------------------------------------------------------------------------
989 //----------------------------------------------------------------------------
990 void vvSlicerManager::UpdateTSlice(int slicer)
992 // DD("vvSlicerManager::UpdateTSlice emit UpdateTSlice");
994 // DD(mSlicers[slicer]->GetTSlice());
995 // DD(mSlicers[slicer]->GetSlice());
996 if (mPreviousSlice[slicer] == mSlicers[slicer]->GetSlice()) {
997 if (mPreviousTSlice[slicer] == mSlicers[slicer]->GetTSlice()) {
998 // DD("************** NOTHING ***********");
1002 mPreviousSlice[slicer] = mSlicers[slicer]->GetSlice();
1003 mPreviousTSlice[slicer] = mSlicers[slicer]->GetTSlice();
1004 emit UpdateTSlice(slicer,mSlicers[slicer]->GetTSlice());
1006 //----------------------------------------------------------------------------
1009 //----------------------------------------------------------------------------
1010 void vvSlicerManager::UpdateSliceRange(int slicer)
1012 emit UpdateSliceRange(slicer,
1013 mSlicers[slicer]->GetSliceRange()[0], mSlicers[slicer]->GetSliceRange()[1],
1014 0,mSlicers[slicer]->GetTMax());
1016 //----------------------------------------------------------------------------
1019 //----------------------------------------------------------------------------
1020 void vvSlicerManager::SetPreset(int preset)
1022 //vtkLookupTable* LUT = static_cast<vtkLookupTable*>(mSlicers[0]->GetWindowLevel()->GetLookupTable());
1023 double window = mSlicers[0]->GetColorWindow();
1024 double level = mSlicers[0]->GetColorLevel();
1026 std::string component_type=mImage->GetScalarTypeAsString();
1030 if (component_type == "unsigned_char")
1035 else if (component_type == "short")
1043 mImage->GetScalarRange(range);
1044 window = range[1] - range[0];
1045 level = (range[1] + range[0])* 0.5;
1076 this->SetColorWindow(window);
1077 this->SetColorLevel(level);
1084 //----------------------------------------------------------------------------
1087 //----------------------------------------------------------------------------
1088 void vvSlicerManager::SetLocalColorWindowing(const int slicer)
1091 this->mSlicers[slicer]->GetExtremasAroundMousePointer(min, max);
1092 this->SetColorWindow(max-min);
1093 this->SetColorLevel(0.5*(min+max));
1094 this->UpdateWindowLevel();
1097 //----------------------------------------------------------------------------
1100 //----------------------------------------------------------------------------
1101 void vvSlicerManager::SetColorMap()
1103 SetColorMap(mColorMap);
1105 //----------------------------------------------------------------------------
1108 //----------------------------------------------------------------------------
1109 void vvSlicerManager::SetColorMap(int colormap)
1112 range[0] = mSlicers[0]->GetInput()->GetScalarRange()[0];
1113 range[1] = mSlicers[0]->GetInput()->GetScalarRange()[1];
1115 double window = mSlicers[0]->GetWindowLevel()->GetWindow();
1116 double level = mSlicers[0]->GetWindowLevel()->GetLevel();
1118 vtkLookupTable* LUT = static_cast<vtkLookupTable*>(mSlicers[0]->GetWindowLevel()->GetLookupTable());
1128 LUT = vtkLookupTable::New();
1129 LUT->SetValueRange(0,1);
1130 LUT->SetSaturationRange(1,1);
1131 LUT->SetHueRange(0,0.18);
1135 LUT = vtkLookupTable::New();
1136 LUT->SetValueRange(0,1);
1137 LUT->SetSaturationRange(1,1);
1138 LUT->SetHueRange(0.4,0.80);
1142 LUT = vtkLookupTable::New();
1143 LUT->SetValueRange(0,1);
1144 LUT->SetSaturationRange(1,1);
1145 LUT->SetHueRange(0,1);
1149 LUT = vtkLookupTable::New();
1150 LUT->SetValueRange(0.,1);
1151 LUT->SetSaturationRange(1,1);
1152 LUT->SetHueRange(1,0.1);
1153 //LUT->SetRampToLinear();
1158 LUT->SetTableRange(level-fabs(window)/4,level+fabs(window)/4);
1161 vtkLookupTable* fusLUT = NULL;
1162 if (mSlicers[0]->GetFusion())
1164 fusLUT = vtkLookupTable::New();
1165 double fusRange [2];
1166 fusRange[0] = mFusionLevel - mFusionWindow/2;
1167 fusRange[1] = mFusionLevel + mFusionWindow/2;
1168 fusLUT->SetTableRange(fusRange[0],fusRange[1]);
1169 fusLUT->SetValueRange(1,1);
1170 fusLUT->SetSaturationRange(1,1);
1171 if (mFusionColorMap == 1)
1172 fusLUT->SetHueRange(0,0.18);
1173 else if (mFusionColorMap == 2)
1174 fusLUT->SetHueRange(0.4,0.80);
1175 else if (mFusionColorMap == 3)
1176 fusLUT->SetHueRange(0,1);
1178 if (mFusionColorMap == 0)
1181 for ( unsigned int i = 0; i < mSlicers.size(); i++) {
1182 if (mSlicers[i]->GetOverlay() && mSlicers[i]->GetOverlayActor()->GetVisibility()) {
1183 vtkLookupTable* supLUT = vtkLookupTable::New();
1184 supLUT->SetTableRange(range[0],range[1]);
1185 supLUT->SetValueRange(1,1);
1186 supLUT->SetSaturationRange(1,1);
1187 supLUT->SetHueRange(double(mOverlayColor)/360,double(mOverlayColor)/360);
1189 vtkLookupTable* invLUT = vtkLookupTable::New();
1190 invLUT->SetTableRange(range[0],range[1]);
1191 invLUT->SetValueRange(1,1);
1192 invLUT->SetSaturationRange(1,1);
1193 invLUT->SetHueRange(double((mOverlayColor+180)%360)/360,double((mOverlayColor+180)%360)/360);
1195 dynamic_cast<vvImageMapToWLColors*>(mSlicers[i]->GetWindowLevel())
1196 ->SetWindowLevelMode(true);
1197 mSlicers[i]->GetWindowLevel()->SetLookupTable(supLUT);
1198 mSlicers[i]->GetOverlayMapper()->SetLookupTable(invLUT);
1202 else if (mSlicers[i]->GetOverlay())
1204 //dynamic_cast<vvImageMapToWLColors*>(mSlicers[i]->GetWindowLevel())
1205 //->SetWindowLevelMode(false);
1206 mSlicers[i]->GetWindowLevel()->SetLookupTable(LUT);
1210 mSlicers[i]->GetWindowLevel()->SetLookupTable(LUT);
1212 if (mSlicers[i]->GetFusion() && mSlicers[i]->GetFusionActor()->GetVisibility())
1214 mSlicers[i]->GetFusionActor()->SetOpacity(double(mFusionOpacity)/100);
1215 mSlicers[i]->GetFusionMapper()->SetLookupTable(fusLUT);
1221 mColorMap = colormap;
1223 //----------------------------------------------------------------------------
1226 //----------------------------------------------------------------------------
1227 vvLandmarks* vvSlicerManager::GetLandmarks()
1229 if (mLandmarks == NULL)
1231 mLandmarks = new vvLandmarks(mSlicers[0]->GetTMax()+1);
1232 for (unsigned int i = 0; i < mSlicers.size(); i++)
1233 mSlicers[i]->SetLandmarks(mLandmarks);
1237 //----------------------------------------------------------------------------
1240 //----------------------------------------------------------------------------
1241 void vvSlicerManager::AddLandmark(float x,float y,float z,float t)
1243 double x_index = (x - mSlicers[0]->GetInput()->GetOrigin()[0])/mSlicers[0]->GetInput()->GetSpacing()[0];
1244 double y_index = (y - mSlicers[0]->GetInput()->GetOrigin()[1])/mSlicers[0]->GetInput()->GetSpacing()[1];
1245 double z_index = (z - mSlicers[0]->GetInput()->GetOrigin()[2])/mSlicers[0]->GetInput()->GetSpacing()[2];
1246 double value = mSlicers[0]->GetInput()->GetScalarComponentAsDouble(
1250 this->GetLandmarks()->AddLandmark(x,y,z,t,value);
1251 emit LandmarkAdded();
1253 //----------------------------------------------------------------------------
1255 //----------------------------------------------------------------------------
1256 void vvSlicerManager::PrevImage(int slicer)
1258 emit ChangeImageWithIndexOffset(this, slicer, -1);
1260 //----------------------------------------------------------------------------
1263 //----------------------------------------------------------------------------
1264 void vvSlicerManager::NextImage(int slicer)
1266 emit ChangeImageWithIndexOffset(this, slicer, 1);
1268 //----------------------------------------------------------------------------
1271 //----------------------------------------------------------------------------
1272 void vvSlicerManager::VerticalSliderHasChanged(int slicer, int slice) {
1273 emit AVerticalSliderHasChanged(slicer, slice);
1276 //----------------------------------------------------------------------------