2 #include <creaImageIOWxViewer.h>
3 #include <creaImageIOSystem.h>
6 #include <vtkRenderer.h>
7 #include <vtkImageData.h>
9 #include <creaMessageManager.h>
19 //=====================================================================
21 //=====================================================================
22 class WxViewerPlayer: public wxThread
25 WxViewerPlayer(WxViewer* v) :
30 // void SetImagesToPlay(std::vector<vtkImageData*> im);
31 // void ShowImage(vtkImageData* v);
32 // void StartIterator();
36 //std::vector<vtkImageData*> mImagesToPlay;
37 //vtkImageViewer2* mViewer;
38 /// Associated wxvtk interactor
39 //crea::creawxVTKRenderWindowInteractor *mInteractor;
40 //std::vector<vtkImageData*>::iterator i;
43 // int mx1,mx2,my1,my2,mz1,mz2;
44 // double mspx,mspy,mspz;
47 //=====================================================================
53 //=====================================================================
55 WxViewer::WxViewer(wxWindow *parent,
65 wxMutexLocker lock(mMutex);
66 GimmickDebugMessage(1,"WxViewer::WxViewer"
69 wxBoxSizer *topsizer = new wxBoxSizer(wxVERTICAL);
74 mInteractor = new crea::creawxVTKRenderWindowInteractor(this,-1);
75 mInteractor->UseCaptureMouseOn();
77 mViewer = vtkImageViewer2::New();
78 mViewer->SetupInteractor ( mInteractor );
82 mPlayer = new WxViewerPlayer(this); //images, mViewer, mInteractor, this);
86 topsizer-> Add( mInteractor ,1,wxGROW ,0);
90 //=====================================================================
92 //=====================================================================
96 wxMutexLocker lock(mMutex);
97 GimmickDebugMessage(1,"WxViewer::~WxViewer"
100 // TO DO : desallocate cleanly
102 // delete mInteractor;
104 //=====================================================================
107 //================================================================
109 void WxViewer::SetImage(int i, vtkImageData* im)
111 wxMutexLocker lock(mMutex);
112 GimmickDebugMessage(5,"WxViewer::SetImage "<<i+1<<"/"<<images.size()
116 // if (images[i]!=0) images[i]->UnRegister(NULL);
118 // if (im!=0) im->Register(NULL);
122 //================================================================
126 //================================================================
128 bool WxViewer::ImagesEmpty()
130 wxMutexLocker lock(mMutex);
131 return images.empty();
133 //================================================================
135 //================================================================
137 void WxViewer::SetMovieSize(unsigned int si)
139 wxMutexLocker lock(mMutex);
140 GimmickDebugMessage(5,"WxViewer::SetMovieSize("<<(int)si<<")"
142 for (unsigned int i=0;i<images.size();++i)
146 // images[i]->UnRegister(NULL);
150 for (unsigned int i=0;i<si;++i) images.push_back(0);
153 //================================================================
155 //================================================================
157 void WxViewer::ShowNextImage()
159 wxMutexLocker lock(mMutex);
160 GimmickMessage(1,"WxViewer::ShowNextImage() "
162 <<images.size()<<std::endl);
163 if (mCurrent<images.size())
165 ShowImage(images[mCurrent]);
168 if (mCurrent >= images.size()) mCurrent = 0;
170 //================================================================
175 //=====================================================================
176 void WxViewer::ShowImage(vtkImageData* im)
178 GimmickDebugMessage(5,"WxViewer::ShowImage"
182 mViewer->SetInput(im);
183 mViewer->SetSlice( 0 );
185 int x1,x2,y1,y2,z1,z2;
189 im->GetSpacing(spx,spy,spz);
190 im->GetExtent (x1,x2,y1,y2,z1,z2);
192 std::cout << "-----------------------------"<<std::endl;
193 std::cout << x1 << "-"<<x2<<std::endl;
194 std::cout << y1 << "-"<<y2<<std::endl;
195 std::cout << z1 << "-"<<z2<<std::endl;
196 std::cout << spx << "-"<<spy<<"-"<<spz<<std::endl;
220 double *range = im->GetScalarRange();
221 mViewer->SetColorWindow(range[1] - range[0]);
222 mViewer->SetColorLevel(0.5 * (range[1] + range[0]));
224 mViewer->GetRenderer()->ResetCamera();
228 mViewer->GetRenderer()->ComputeVisiblePropBounds(bounds);
231 std::cout <<"bounds : "<<bounds[0]<<","
236 <<bounds[5]<<std::endl;
239 mViewer->GetRenderer()->ResetCameraClippingRange(bounds);
241 vtkCamera *camera = mViewer->GetRenderer()->GetActiveCamera();
243 camera->SetViewUp ( spx*0, -spy*1, spz*0);
244 camera->SetPosition( spx*(x1+x2)/2, spy*(y1+y2)/2, spz*10000000);
245 camera->SetFocalPoint ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0);
247 camera->ComputeViewPlaneNormal();
248 camera->SetParallelScale( spx*(x2-x1)/2.0 );
250 camera->Roll ( 180 );
255 // mInteractor->Refresh();
256 //mInteractor->Render();
257 // mViewer->Render();
261 //================================================================
263 //==================================================
264 void WxViewer::OnInternalIdle()
266 // mInteractor->Refresh();
267 mInteractor->Render();
271 //=================================================
274 // BEGIN_EVENT_TABLE(WxGimmickFrame, wxDialog)
276 //================================================================
278 //========================================================================
279 //========================================================================
280 //========================================================================
281 //========================================================================
282 //========================================================================
283 //========================================================================
284 //========================================================================
285 //========================================================================
287 void* WxViewerPlayer::Entry()
290 GimmickMessage(1,"WxViewerPlayer::Entry()"<<std::endl);
294 mWxViewer->ShowNextImage();
296 endwait = clock () + 0.2 * CLOCKS_PER_SEC ;
297 while (clock() < endwait) {}
299 for(i=mImagesToPlay.begin();i!=mImagesToPlay.end();++i)
301 if(i!=mImagesToPlay.end())
304 GimmickMessage(1,"ThreadedMovie next image"<<std::endl);
308 endwait = clock () + 0.2 * CLOCKS_PER_SEC ;
309 while (clock() < endwait) {}
318 //=====================================================================
320 //=====================================================================
321 void WxViewerPlayer::OnExit()
323 GimmickMessage(1,"WxViewerPlayer::OnExit() "<<std::endl);
326 //=====================================================================
329 } // EO namespace creaImageIO