- point.clear();
- point.push_back((int)mwxwidget->GetX());
- point.push_back((int)mwxwidget->GetY());
- point.push_back((int)mwxwidget->GetZ());
- bbSetOutputPoint(point);
-
-// WxBlackBox::Process();
- mwxwidget->SetImage( bbGetInputIn() );
- wxVtkBaseView *wvbv1 = mwxwidget->GetwxVtkBaseView(1);
- wxVtkBaseView *wvbv2 = mwxwidget->GetwxVtkBaseView(2);
- wxVtkBaseView *wvbv3 = mwxwidget->GetwxVtkBaseView(3);
- wxVtkBaseView *wvbv4 = mwxwidget->GetwxVtkBaseView(4);
-
- //wxwidget->RefreshView();
-
- bbSetOutputwxVtkBaseView1( wvbv1 );
- bbSetOutputwxVtkBaseView2( wvbv2 );
- bbSetOutputwxVtkBaseView3( wvbv3 );
- bbSetOutputwxVtkBaseView4( wvbv4 );
- if (wvbv1!=NULL) { bbSetOutputRenderer1( wvbv1->GetRenderer() ); }
- if (wvbv2!=NULL) { bbSetOutputRenderer2( wvbv2->GetRenderer() ); }
- if (wvbv3!=NULL) { bbSetOutputRenderer3( wvbv3->GetRenderer() ); }
- if (wvbv4!=NULL) { bbSetOutputRenderer4( wvbv4->GetRenderer() ); }
+ vtkImageData* img = bbGetInputIn();
+/*
+ double spc[3];
+ img->GetSpacing(spc);
+ printf ("EED ViewerNV::Process A %f %f %f \n", spc[0], spc[1], spc[2] );
+ img->SetSpacing( 1,1,1 );
+ img->Update( );
+ img->GetSpacing(spc);
+ img->PrintSelf(std::cout,(vtkIndent)2);
+ img->Print(std::cout);
+ printf ("EED ViewerNV::Process B %f %f %f \n", spc[0], spc[1], spc[2] );
+*/
+ std::vector<int> type = bbGetInputnTypeView();
+
+
+ if(img != NULL && _mwxwidget != NULL){
+ if(!compareVectors(type, _currenttype)){
+ _mwxwidget->SetType(&type);
+ _mwxwidget->UpdateLayout(img);
+ }else if (img != _currentimg){
+ _mwxwidget->SetImage(img);
+ }
+
+ _mwxwidget->RefreshView();
+
+ _currenttype = type;
+ _currentimg = img;
+
+ _point.clear();
+ _point.push_back((int)_mwxwidget->GetX());
+ _point.push_back((int)_mwxwidget->GetY());
+ _point.push_back((int)_mwxwidget->GetZ());
+ bbSetOutputPoint(_point);
+
+ // WxBlackBox::Process();
+// mwxwidget->SetImage(img );
+ wxVtkBaseView *wvbv1 = _mwxwidget->GetwxVtkBaseView(1);
+ wxVtkBaseView *wvbv2 = _mwxwidget->GetwxVtkBaseView(2);
+ wxVtkBaseView *wvbv3 = _mwxwidget->GetwxVtkBaseView(3);
+ wxVtkBaseView *wvbv4 = _mwxwidget->GetwxVtkBaseView(4);
+
+ //wxwidget->RefreshView();
+
+ bbSetOutputwxVtkBaseView1( wvbv1 );
+ bbSetOutputwxVtkBaseView2( wvbv2 );
+ bbSetOutputwxVtkBaseView3( wvbv3 );
+ bbSetOutputwxVtkBaseView4( wvbv4 );
+ if (wvbv1!=NULL) { bbSetOutputRenderer1( wvbv1->GetRenderer() ); }
+ if (wvbv2!=NULL) { bbSetOutputRenderer2( wvbv2->GetRenderer() ); }
+ if (wvbv3!=NULL) { bbSetOutputRenderer3( wvbv3->GetRenderer() ); }
+ if (wvbv4!=NULL) { bbSetOutputRenderer4( wvbv4->GetRenderer() ); }
+
+ if (wvbv1!=NULL)
+ {
+ bbSetOutputInteractor1( wvbv1->GetWxVTKRenderWindowInteractor() );
+ updateObservers();
+ }
+
+ if(bbGetInputColorFunction()!=NULL)
+ {
+ _mwxwidget->setColorTransferFunction(bbGetInputColorFunction());
+ }
+
+
+ if( (bbGetInputColorLevel()!=-1) && (bbGetInputWindowLevel()!=-1))
+ {
+ if(bbGetInputColorLevel() == 0)
+ {
+ _mwxwidget->SetColorWindowLevel( bbGetInputWindowLevel() , 0.1 );
+ }else{
+ _mwxwidget->SetColorWindowLevel( bbGetInputWindowLevel() , bbGetInputColorLevel() );
+ }
+ }
+ }// mwxwidget != NULL