- if (mwxwidget != NULL)
- {
- 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);
+ 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);