X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FmaracasVisuLib%2Fsrc%2Finterface%2FwxWindows%2Fwidgets%2FwxMaracasRenderTabbedPanel.cpp;h=fd6463b8b8b17a90615aac22737a93ad95912d55;hb=5a27c495a6c3899102f76eb029b6aadcee4121c1;hp=3daafe07a8f322eb3bb8654bb83c600662b4ce10;hpb=28c74ab5eb531ce001260e9bc3fcb0151fcfc56b;p=creaMaracasVisu.git diff --git a/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxMaracasRenderTabbedPanel.cpp b/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxMaracasRenderTabbedPanel.cpp index 3daafe0..fd6463b 100644 --- a/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxMaracasRenderTabbedPanel.cpp +++ b/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxMaracasRenderTabbedPanel.cpp @@ -1,111 +1,144 @@ #include "wxMaracasRenderTabbedPanel.h" + #include "HistogramDialogComboBox.h" +#include "wxMaracasMultipleVolumeRendererPanel.h" +#include "wxMaracasSurfaceRenderingPanel.h" +#include "wxMaracasSurfaceRenderingProp3DMHD.h" +#include "wxMaracasMultipleVolumeRendererManagerData.h" +#include "wxMaracasDialog_NViewers.h" +#include "wxVtkMPR3DViewCntrlPanel.h" #include +#include +#include #include + #include "Color.xpm" +//#include "creaSystem.h" +#include "creaWx.h" + + BEGIN_EVENT_TABLE( wxMaracasRenderTabbedPanel, wxPanel ) + EVT_MENU( 12121, wxMaracasRenderTabbedPanel::OnRefreshView ) + //EVT_MENU( 12122, wxMaracasRenderTabbedPanel::OnDClickLeft ) + END_EVENT_TABLE( ); /** -** +** Class constructor **/ -wxMaracasRenderTabbedPanel::wxMaracasRenderTabbedPanel(wxWindow* parent/*, wxMaracasMultipleVolumeRendererManager* _volmanager, wxMaracasSurfaceRenderingManager* _surrendmanager1, wxMaracasSurfaceRenderingManager* _surrendmanager2, - wxMaracasSurfaceRenderingManager* _surrendmanager3, wxString pathfile, wxString filename*/) -: wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize) +wxMaracasRenderTabbedPanel::wxMaracasRenderTabbedPanel(wxWindow* parent, int id, wxVtk3DBaseView* _baseView) + : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize) { - //_propid = propid; - volmanager = new wxMaracasMultipleVolumeRendererManager(); + _id = id; + baseView = _baseView; + dialog = NULL; + + volmanager = new wxMaracasMultipleVolumeRendererManager(); surrendmanager1 = new wxMaracasSurfaceRenderingManager(); surrendmanager2 = new wxMaracasSurfaceRenderingManager(); surrendmanager3 = new wxMaracasSurfaceRenderingManager(); +} + +/** +** Class Destructor +**/ +wxMaracasRenderTabbedPanel::~wxMaracasRenderTabbedPanel() +{ + //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorV(_propid, false); + //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSA(_propid, false); + //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSB(_propid, false); + //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSC(_propid, false); + addRemoveActorMPR(false); + if( vtkmpr3Ddataviewer ) { delete vtkmpr3Ddataviewer; } + if( mwxvtkmpr3Dview ) { delete mwxvtkmpr3Dview; } + this->deleteVolume(_id); + delete dialog; + delete wxtabs; } /** -** +** Initializes rendered images, and creates and adds elements to the panel **/ -void wxMaracasRenderTabbedPanel::createControls(wxString pathfile, wxString filename) +void wxMaracasRenderTabbedPanel::createControls(vtkImageData* inImg, std::string pathfile, std::string filename) { - //wxPanel* up = new wxPanel(this, wxID_ANY); wxFlexGridSizer* sizerrenderprop = new wxFlexGridSizer(1); - - //wxString choices[2]; - //choices[0] = wxString(_T("On")); - //choices[1] = wxString(_T("Off")); - wxFlexGridSizer* sizercheck = new wxFlexGridSizer(2); + + wxFlexGridSizer* sizercheck = new wxFlexGridSizer(3); checkboxVol = new wxCheckBox(this,-1,wxString(_T("Volume Rendering"))); Connect(checkboxVol->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onCheckBoxVChange); - checkboxVol->SetValue(true); + checkboxVol->SetValue(false); sizercheck->Add(checkboxVol, wxFIXED_MINSIZE); - //wxString choices[2]; - //choices[0] = wxString(_T("On")); - //choices[1] = wxString(_T("Off")); checkboxSA = new wxCheckBox(this,-1,wxString(_T("Surface Rendering A"))); Connect(checkboxSA->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onCheckBoxSAChange); - checkboxSA->SetValue(true); + checkboxSA->SetValue(false); + sizercheck->Add(checkboxSA, wxFIXED_MINSIZE); - sizercheck->Add(checkboxSA, wxFIXED_MINSIZE); + checkboxViewer = new wxCheckBox(this,-1,wxString(_T("MPR"))); + Connect(checkboxViewer->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onMPROptions); + checkboxViewer->SetValue(true); + sizercheck->Add(checkboxViewer, wxFIXED_MINSIZE); - //wxString choices[2]; - //choices[0] = wxString(_T("On")); - //choices[1] = wxString(_T("Off")); checkboxSB = new wxCheckBox(this,-1,wxString(_T("Surface Rendering B"))); Connect(checkboxSB->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onCheckBoxSBChange); - checkboxSB->SetValue(true); - + checkboxSB->SetValue(false); sizercheck->Add(checkboxSB, wxFIXED_MINSIZE); - //wxString choices[2]; - //choices[0] = wxString(_T("On")); - //choices[1] = wxString(_T("Off")); checkboxSC = new wxCheckBox(this,-1,wxString(_T("Surface Rendering C"))); Connect(checkboxSC->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onCheckBoxSCChange); - checkboxSC->SetValue(true); - + checkboxSC->SetValue(false); sizercheck->Add(checkboxSC, wxFIXED_MINSIZE); + + sizercheck->Add(new wxStaticText(this, -1,_T("")), wxFIXED_MINSIZE); + + wxButton* _openParameters = new wxButton(this, -1, wxString(_T("Apply Transformation"))); + Connect(_openParameters->GetId(), wxEVT_COMMAND_BUTTON_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onOpenParameters); + sizercheck->Add(_openParameters,wxFIXED_MINSIZE); + + wxButton* _openCutter = new wxButton(this, -1, wxString(_T("Open Cutter View"))); + Connect(_openCutter->GetId(), wxEVT_COMMAND_BUTTON_CLICKED, (wxObjectEventFunction)&wxMaracasRenderTabbedPanel::onOpenCutter); + sizercheck->Add(_openCutter,wxFIXED_MINSIZE); sizerrenderprop->Add(sizercheck, wxFIXED_MINSIZE); - //up->SetSizer(sizerup, true); - //up->SetAutoLayout( true ); wxtabs = new wxNotebook(this, -1); - std::string s = std::string(pathfile.mb_str()); - vtkImageData* img1 = volmanager->getImageData(s); - vtkImageData* img2 = surrendmanager1->getImageData(s); - vtkImageData* img3 = surrendmanager2->getImageData(s); - vtkImageData* img4 = surrendmanager3->getImageData(s); - if(img1!=NULL) + if(inImg == NULL) { - - s = std::string(filename.mb_str()); - addVolume(img1, s); - addSurface1(img2, s); - addSurface2(img3, s); - addSurface3(img4, s); + vtkImageData* img = volmanager->getImageData(pathfile); + //vtkImageData* img1 = surrendmanager1->getImageData(pathfile); + //vtkImageData* img2 = surrendmanager2->getImageData(pathfile); + //vtkImageData* img3 = surrendmanager3->getImageData(pathfile); + if(img!=NULL /*&& img1!=NULL && img2!=NULL && img3!=NULL*/) + { + addVolume(img, filename); + addSurface1(img, filename); + addSurface2(img, filename); + addSurface3(img, filename); + addMPROptions(); + volname = crea::std2wx(filename); + wxtabs->Refresh(); + } + } + else + { + addVolume(inImg, filename); + addSurface1(inImg, filename); + addSurface2(inImg, filename); + addSurface3(inImg, filename); wxtabs->Refresh(); } - //wxFlexGridSizer* sizerrenderprop = new wxFlexGridSizer(2,1,5); - //sizerrenderprop->Add(up, wxFIXED_MINSIZE); - - sizerrenderprop->Add(wxtabs, wxFIXED_MINSIZE); + sizerrenderprop->Add(wxtabs, wxSizerFlags().Expand().Center()); this->SetSizer(sizerrenderprop, true); this->SetAutoLayout( true ); - } -wxMaracasRenderTabbedPanel::~wxMaracasRenderTabbedPanel() -{ - //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorV(_propid, false); - //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSA(_propid, false); - //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSB(_propid, false); - //wxMaracasRenderTabbedPanel::getInstance()->addRemoveActorSC(_propid, false); - //wxMaracasRenderTabbedPanel::getInstance()->deleteVolume(_propid); - delete wxtabs; -} +/** +** Sets given renderer +**/ void wxMaracasRenderTabbedPanel::setRenderer(vtkRenderer* renderer) { volmanager->setRenderer(renderer); @@ -114,19 +147,22 @@ void wxMaracasRenderTabbedPanel::setRenderer(vtkRenderer* renderer) surrendmanager3->setRenderer(renderer); } -/* -* -*/ +/** +** Adds a volume using Volume Rendering +**/ void wxMaracasRenderTabbedPanel::addVolume(vtkImageData* img, std::string dataname) { try { - int _propidV = volmanager->addVolume(img, dataname); + int _propidV = volmanager->addVolume(_id, img, dataname); if(_propidV!=-1) { - controlpanV = new wxMaracasMultipleVolumeRendererPanel(wxtabs, _propidV, img, true); - wxtabs->AddPage(controlpanV, _T("Volume Rendering"), true); - updateVolume(); + wxMaracasMultipleVolumeRendererPanel* controlpanV = new wxMaracasMultipleVolumeRendererPanel(wxtabs, _propidV, img, true); + wxtabs->AddPage(controlpanV, _T("Vol Rendering"), true); + controlpanV->updateVolume(); + wxtabs->GetPage(0)->Disable(); + + volmanager->addRemoveActor(this->getPropIdV(), checkboxSC->GetValue()); } } catch(char* str) @@ -134,21 +170,28 @@ void wxMaracasRenderTabbedPanel::addVolume(vtkImageData* img, std::string datana std::cout << "Exception : " << str << '\n'; wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); diag->ShowModal(); + delete diag; } } +/** +** Adds a volume using surface rendering +**/ void wxMaracasRenderTabbedPanel::addSurface1(vtkImageData* img, std::string dataname) { try { - int _propidSA = surrendmanager1->addPropMHD(img, dataname); + int _propidSA = surrendmanager1->addPropMHD(_id, img, dataname); if(_propidSA!=-1) { - controlpanSA = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSA, true, 1); + wxMaracasSurfaceRenderingPanel* controlpanSA = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSA, true, 1); int maxiso = surrendmanager1->getMaxIsoValue(_propidSA); ((wxMaracasSurfaceRenderingProp3DMHD*)controlpanSA)->createControls(maxiso); - wxtabs->AddPage(controlpanSA, _T("Surf Rendering A")); + wxtabs->AddPage(controlpanSA, _T("SR A")); + wxtabs->GetPage(1)->Disable(); + + surrendmanager1->addRemoveActor(this->getPropIdV(), checkboxSC->GetValue()); } } catch(char* str) @@ -156,20 +199,27 @@ void wxMaracasRenderTabbedPanel::addSurface1(vtkImageData* img, std::string data std::cout << "Exception : " << str << '\n'; wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); diag->ShowModal(); + delete diag; } } +/** +** Adds a volume using surface rendering +**/ void wxMaracasRenderTabbedPanel::addSurface2(vtkImageData* img, std::string dataname) { try { - int _propidSB = surrendmanager2->addPropMHD(img, dataname); + int _propidSB = surrendmanager2->addPropMHD(_id, img, dataname); if(_propidSB!=-1) { - controlpanSB = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSB, true, 2); + wxMaracasSurfaceRenderingPanel* controlpanSB = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSB, true, 2); int maxiso = surrendmanager2->getMaxIsoValue(_propidSB); ((wxMaracasSurfaceRenderingProp3DMHD*)controlpanSB)->createControls(maxiso); - wxtabs->AddPage(controlpanSB, _T("Surf Rendering B")); + wxtabs->AddPage(controlpanSB, _T("SR B")); + wxtabs->GetPage(2)->Disable(); + + surrendmanager2->addRemoveActor(this->getPropIdV(), checkboxSC->GetValue()); } } @@ -178,21 +228,28 @@ void wxMaracasRenderTabbedPanel::addSurface2(vtkImageData* img, std::string data std::cout << "Exception : " << str << '\n'; wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); diag->ShowModal(); + delete diag; } } +/** +** Adds a volume using Surface Rendering +**/ void wxMaracasRenderTabbedPanel::addSurface3(vtkImageData* img, std::string dataname) { try { - _propidSC = surrendmanager3->addPropMHD(img, dataname); + int _propidSC = surrendmanager3->addPropMHD(_id, img, dataname); if(_propidSC!=-1) { - controlpanSC = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSC, true, 3); + wxMaracasSurfaceRenderingPanel* controlpanSC = new wxMaracasSurfaceRenderingProp3DMHD(wxtabs, _propidSC, true, 3); int maxiso = surrendmanager3->getMaxIsoValue(_propidSC); ((wxMaracasSurfaceRenderingProp3DMHD*)controlpanSC)->createControls(maxiso); - wxtabs->AddPage(controlpanSC, _T("Surf Rendering C")); + wxtabs->AddPage(controlpanSC, _T("SR C")); + wxtabs->GetPage(3)->Disable(); + + surrendmanager3->addRemoveActor(this->getPropIdV(), checkboxSC->GetValue()); } } catch(char* str) @@ -200,7 +257,111 @@ void wxMaracasRenderTabbedPanel::addSurface3(vtkImageData* img, std::string data std::cout << "Exception : " << str << '\n'; wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); diag->ShowModal(); + delete diag; + } +} + +/** +** +**/ +void wxMaracasRenderTabbedPanel::addMPROptions() +{ + //Panel Construction + vtkMPRBaseData* mvtkmprbasedata = new vtkMPRBaseData(); + marImageData* marimagedata = new marImageData( getVolImage() ); + mvtkmprbasedata ->SetMarImageData(marimagedata); + + mwxvtkmpr3Dview = new wxVtkMPR3DView( baseView ); + + vtkmpr3Ddataviewer = new vtkMPR3DDataViewer(); + + wxPanel *panelControl = new wxPanel(wxtabs,-1); + controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, true); + + wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1); + sizerCtrol ->Add(controlPanelMPR3D, 1, wxALL|wxEXPAND, 2); + + panelControl->SetAutoLayout(true); + panelControl->SetSizer(sizerCtrol); + panelControl->SetSize(400,350); + panelControl->Layout(); + + //Configure MPR + int x = 0,y = 0,z = 0; + int ext[6]; + ext[0] = 0; + ext[1] = 0; + ext[2] = 0; + ext[3] = 0; + ext[4] = 0; + ext[5] = 0; + + double org[3],spc[3]; + org[0] = 0; + org[1] = 0; + org[2] = 0; + spc[0] = 0; + spc[1] = 0; + spc[2] = 0; + + if (mvtkmprbasedata!=NULL) + { + mvtkmprbasedata->Configure(); + /*x = mvtkmprbasedata -> GetMaxPositionX()/2; + y = mvtkmprbasedata -> GetMaxPositionY()/2; + z = mvtkmprbasedata -> GetMaxPositionZ()/2; */ + + if(mvtkmprbasedata->GetImageData() != NULL) + { + mvtkmprbasedata->GetImageData()->GetExtent(ext); + mvtkmprbasedata->GetImageData()->GetOrigin(org); + mvtkmprbasedata->GetImageData()->GetSpacing(spc); + + x = (ext[0]+ext[1])/2; + y = (ext[2]+ext[3])/2; + z = (ext[4]+ext[5])/2; + + mvtkmprbasedata->SetX( x ); + mvtkmprbasedata->SetY( y ); + mvtkmprbasedata->SetZ( z ); + } + else + { + mvtkmprbasedata->SetX( 0 ); + mvtkmprbasedata->SetY( 0 ); + mvtkmprbasedata->SetZ( 0 ); + } + } + + if (baseView!=NULL) + { + baseView ->Configure(); + } + + if (vtkmpr3Ddataviewer !=NULL) + { + vtkmpr3Ddataviewer ->SetVtkMPRBaseData(mvtkmprbasedata); + vtkmpr3Ddataviewer ->Configure(); + } + if (mwxvtkmpr3Dview !=NULL) + { + mwxvtkmpr3Dview ->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer); + mwxvtkmpr3Dview ->Configure(); + mwxvtkmpr3Dview ->ResetCamera(ext,org,spc); + vtkInteractorStyleBaseView* vtkInteractorBV = (vtkInteractorStyleBaseView*)mwxvtkmpr3Dview->GetWxvtk3Dbaseview()->GetInteractorStyleBaseView(); + vtkInteractorBV->AddParentToReport(this); } + + int id = 4; + wxtabs->AddPage(panelControl, _T("MPR")); + wxtabs->GetPage(id)->Enable(); + wxtabs->SetSelection(id); + + ((wxVtkMPR3DViewCntrlPanel*)controlPanelMPR3D)->SetVisibleZ(true); + ((wxVtkMPR3DViewCntrlPanel*)controlPanelMPR3D)->SetVisibleXYZ(true); + mwxvtkmpr3Dview->showOutlineActor(true); + mwxvtkmpr3Dview->Refresh(); + } /** @@ -208,10 +369,20 @@ void wxMaracasRenderTabbedPanel::addSurface3(vtkImageData* img, std::string data **/ void wxMaracasRenderTabbedPanel::deleteVolume(int volid) { - volmanager->deleteActor(volid); - surrendmanager1->deleteActor(volid); - surrendmanager2->deleteActor(volid); - surrendmanager3->deleteActor(volid); + try + { + volmanager->deleteActor(volid); + surrendmanager1->deleteActor(volid); + surrendmanager2->deleteActor(volid); + surrendmanager3->deleteActor(volid); + } + catch(char* str) + { + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** @@ -219,7 +390,16 @@ void wxMaracasRenderTabbedPanel::deleteVolume(int volid) **/ void wxMaracasRenderTabbedPanel::addRemoveActorV(int id, bool addremove) { - volmanager->addRemoveActor(id, addremove); + try{ + volmanager->addRemoveActor(id, addremove); + + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** @@ -227,7 +407,15 @@ void wxMaracasRenderTabbedPanel::addRemoveActorV(int id, bool addremove) **/ void wxMaracasRenderTabbedPanel::addRemoveActorSA(int id, bool addremove) { - surrendmanager1->addRemoveActor(id, addremove); + try{ + surrendmanager1->addRemoveActor(id, addremove); + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** @@ -235,7 +423,15 @@ void wxMaracasRenderTabbedPanel::addRemoveActorSA(int id, bool addremove) **/ void wxMaracasRenderTabbedPanel::addRemoveActorSB(int id, bool addremove) { - surrendmanager2->addRemoveActor(id, addremove); + try{ + surrendmanager2->addRemoveActor(id, addremove); + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** @@ -243,8 +439,59 @@ void wxMaracasRenderTabbedPanel::addRemoveActorSB(int id, bool addremove) **/ void wxMaracasRenderTabbedPanel::addRemoveActorSC(int id, bool addremove) { - surrendmanager3->addRemoveActor(id, addremove); -} + try{ + surrendmanager3->addRemoveActor(id, addremove); + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } +} + +void wxMaracasRenderTabbedPanel::addRemoveActorMPR(bool addremove) +{ + int id = 4; + wxtabs->SetSelection(id); + if(addremove) + { + wxtabs->GetPage(id)->Enable(); + + bool valueX = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleX(); + bool valueY = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleY(); + bool valueZ = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleZ(); + bool valueXYZ = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleXYZ(); + bool valuePlane = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisiblePlane(); + + mwxvtkmpr3Dview->VisibleImageActor( 0, valueX ); + mwxvtkmpr3Dview->VisibleImageActor( 1, valueY ); + mwxvtkmpr3Dview->VisibleImageActor( 2, valueZ ); + mwxvtkmpr3Dview->VisiblePointWidget(valueXYZ); + mwxvtkmpr3Dview->VisiblePlaneWidget(valuePlane); + mwxvtkmpr3Dview->showOutlineActor(true); + + mwxvtkmpr3Dview->Refresh(); + + + } + else + { + wxtabs->GetPage(id)->Disable(); + + mwxvtkmpr3Dview->VisiblePointWidget(false); + mwxvtkmpr3Dview->VisiblePlaneWidget(false); + mwxvtkmpr3Dview->VisibleImageActor(0, false ); + mwxvtkmpr3Dview->VisibleImageActor(1, false ); + mwxvtkmpr3Dview->VisibleImageActor(2, false ); + mwxvtkmpr3Dview->showOutlineActor(false); + mwxvtkmpr3Dview->Refresh(); + + wxCommandEvent newevent1(wxEVT_COMMAND_MENU_SELECTED,12121); // Refresh + mwxvtkmpr3Dview->GetWxvtk3Dbaseview()->GetWxVTKRenderWindowInteractor()->GetParent()->ProcessEvent(newevent1); + } +} + /** ** Sets color points values for the given volume rendering identified by parameter: volumeid @@ -259,7 +506,16 @@ void wxMaracasRenderTabbedPanel::SetValuesColorPointsFunction(int volid, std::ve **/ void wxMaracasRenderTabbedPanel::SetValuesPointsFunction(int volid, std::vector greylevel, std::vector values) { - volmanager->setVolumeOpacity(volid, greylevel, values); + try{ + volmanager->setVolumeOpacity(volid, greylevel, values); + } + catch(char* str) + { + wxString s( str,wxConvUTF8 ); + wxMessageDialog* diag = new wxMessageDialog(this, s, s, wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** @@ -381,121 +637,265 @@ void wxMaracasRenderTabbedPanel::changeColorC(int propid, double red, double gre } /** -** +** Method called when VolumeRendering checkbox status changes: Either shows or hides VolumeRendering image **/ -void wxMaracasRenderTabbedPanel::onUpdate(wxCommandEvent& event) +void wxMaracasRenderTabbedPanel::onCheckBoxVChange(wxCommandEvent& event) { - updateVolume(); + try{ + volmanager->addRemoveActor(this->getPropIdV(), checkboxVol->GetValue()); + + int id = 0; + wxtabs->SetSelection(id); + + if(checkboxVol->GetValue()) + { + wxtabs->GetPage(id)->Enable(); + } + else + { + wxtabs->GetPage(id)->Disable(); + } + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** -** +** Method called when SurfaceRendering A checkbox status changes: Either shows or hides SurfaceRendering image **/ -void wxMaracasRenderTabbedPanel::updateVolume() -{ - /*Temporarily disabled*/ +void wxMaracasRenderTabbedPanel::onCheckBoxSAChange(wxCommandEvent& event) +{ + try{ + surrendmanager1->addRemoveActor(this->getPropIdV(), checkboxSA->GetValue()); - std::vector greylevelcolors; - std::vector red; - std::vector green; - std::vector blue; + int id = 1; + wxtabs->SetSelection(id); - std::vector greylevel; - std::vector values; + if(checkboxSA->GetValue()) + { + wxtabs->GetPage(id)->Enable(); - HistogramDialogComboBox* histo = controlpanV->getMwxwidget(); - histo->GetValuesColorPointsFunction(greylevelcolors, red, green, blue); - histo->GetValuesPointsFunction(greylevel, values); + } + else + { + wxtabs->GetPage(id)->Disable(); + } + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } +} +/** +** Method called when SurfaceRendering B checkbox status changes: Either shows or hides SurfaceRendering B image +**/ +void wxMaracasRenderTabbedPanel::onCheckBoxSBChange(wxCommandEvent& event) +{ + try{ + surrendmanager2->addRemoveActor(this->getPropIdV(), checkboxSB->GetValue()); - volmanager->setVolumeColor(controlpanV->getPropId(), greylevelcolors, red, green, blue); - volmanager->setVolumeOpacity(controlpanV->getPropId(), greylevel, values); - //wxMaracasMultipleVolumeRendererView::getInstance()->SetValuesColorPointsFunction(this->_propid, greylevelcolors, red, green, blue); - //wxMaracasMultipleVolumeRendererView::getInstance()->SetValuesPointsFunction(this->_propid, greylevel, values); + int id = 2; + wxtabs->SetSelection(id); + if(checkboxSB->GetValue()) + { + wxtabs->GetPage(id)->Enable(); + } + else + { + wxtabs->GetPage(id)->Disable(); + } + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** -** +** Method called when SurfaceRendering C checkbox status changes: Either shows or hides SurfaceRendering C image **/ -void wxMaracasRenderTabbedPanel::onColorChange(wxCommandEvent& event) +void wxMaracasRenderTabbedPanel::onCheckBoxSCChange(wxCommandEvent& event) { - /*Temporarily disabled*/ + try{ + surrendmanager3->addRemoveActor(this->getPropIdV(), checkboxSC->GetValue()); - //if(mwxwidget->ShowModal()==wxID_OK){ - //updateVolume(); - // mwxwidget->Show(false); - //} + int id = 3; + wxtabs->SetSelection(id); + + if(checkboxSC->GetValue()) + { + wxtabs->GetPage(id)->Enable(); + } + else + { + wxtabs->GetPage(id)->Disable(); + } + } + catch(char* str){ + std::cout << "Exception : " << str << '\n'; + wxMessageDialog* diag = new wxMessageDialog(this, wxString(str,wxConvUTF8 ), wxString(str,wxConvUTF8 ), wxICON_ERROR); + diag->ShowModal(); + delete diag; + } } /** -** +** Method called when MPR checkbox status changes: Either shows or hides actors **/ -void wxMaracasRenderTabbedPanel::onViewImage(wxCommandEvent& event) +void wxMaracasRenderTabbedPanel::onMPROptions(wxCommandEvent& event) { - + addRemoveActorMPR(checkboxViewer->IsChecked()); + /* + int id = 4; + wxtabs->SetSelection(id); + if(checkboxViewer->IsChecked()) + { + + wxtabs->GetPage(id)->Enable(); + + bool valueX = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleX(); + bool valueY = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleY(); + bool valueZ = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleZ(); + bool valueXYZ = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisibleXYZ(); + bool valuePlane = ((wxVtkMPR3DViewCntrlPanel*) controlPanelMPR3D)->GetVisiblePlane(); + + mwxvtkmpr3Dview->VisibleImageActor( 0, valueX ); + mwxvtkmpr3Dview->VisibleImageActor( 1, valueY ); + mwxvtkmpr3Dview->VisibleImageActor( 2, valueZ ); + mwxvtkmpr3Dview->VisiblePointWidget(valueXYZ); + mwxvtkmpr3Dview->VisiblePlaneWidget(valuePlane); + mwxvtkmpr3Dview->showOutlineActor(true); + + mwxvtkmpr3Dview->Refresh(); + + + } + else + { + wxtabs->GetPage(id)->Disable(); + + mwxvtkmpr3Dview->VisiblePointWidget(false); + mwxvtkmpr3Dview->VisiblePlaneWidget(false); + mwxvtkmpr3Dview->VisibleImageActor(0, false ); + mwxvtkmpr3Dview->VisibleImageActor(1, false ); + mwxvtkmpr3Dview->VisibleImageActor(2, false ); + mwxvtkmpr3Dview->showOutlineActor(false); + mwxvtkmpr3Dview->Refresh(); + + wxCommandEvent newevent1(wxEVT_COMMAND_MENU_SELECTED,12121); // Refresh + mwxvtkmpr3Dview->GetWxvtk3Dbaseview()->GetWxVTKRenderWindowInteractor()->GetParent()->ProcessEvent(newevent1); + }*/ +} + +void wxMaracasRenderTabbedPanel::OnRefreshView(wxCommandEvent & event) +{ + printf("CPR wxMaracasRenderTabbedPanel::OnRefreshView \n"); + mwxvtkmpr3Dview->RefreshView(); + + wxCommandEvent newevent1(wxEVT_COMMAND_MENU_SELECTED,12121); // Refresh + mwxvtkmpr3Dview->GetWxvtk3Dbaseview()->GetWxVTKRenderWindowInteractor()->GetParent()->ProcessEvent(newevent1); } /** -** Method called when VolumeRendering checkbox status changes: Either shows or hides VolumeRendering image +** **/ -void wxMaracasRenderTabbedPanel::onCheckBoxVChange(wxCommandEvent& event) -{ - volmanager->addRemoveActor(this->getPropIdV(), checkboxVol->GetValue()); +void wxMaracasRenderTabbedPanel::onOpenParameters(wxCommandEvent& event){ + if(dialog == NULL) + { + dialog = new wxMaracasRenderImageManagementPanel(this, volmanager, surrendmanager1, surrendmanager2, surrendmanager3, volname, _id); + dialog->SetSize(460, 580); + dialog->Show(); + } + else if(dialog != NULL) + { + dialog->Show(); + } } /** -** Method called when SurfaceRendering A checkbox status changes: Either shows or hides SurfaceRendering image +** **/ -void wxMaracasRenderTabbedPanel::onCheckBoxSAChange(wxCommandEvent& event) +void wxMaracasRenderTabbedPanel::onOpenCutter(wxCommandEvent& event) { - surrendmanager1->addRemoveActor(this->getPropIdSA(), checkboxSA->GetValue()); + vtkImageData* img = getVolImage(); + std::vector type; + type.push_back(5); + type.push_back(1); + type.push_back(2); + type.push_back(0); + + wxMaracasDialog_NViewers* dialog1 = new wxMaracasDialog_NViewers(this, img, &type, wxString(_T("Cut Module") )); + //dialog1->SetSize(800, 700); + + /**std::string path = crea::System::GetDllAppPath("bbcreaMaracasVisu.dll"); + cutter = CutModelMainPanel::getInstance(dialog1->getinternalPanel(), path); + cutter->setRenderer( dialog1->getViewer()->GetwxVtkBaseView(1)->GetRenderer() ); + cutter->setInteractor( dialog1->getViewer()->GetwxVtkBaseView(1)->GetWxVTKRenderWindowInteractor() ); + cutter->setImageData(getVolImage()); + **/ + //dialog1->AddPanel(cutter); + dialog1->Show(); } /** -** Method called when SurfaceRendering B checkbox status changes: Either shows or hides SurfaceRendering B image +** Gets volume rendering image asociated to the given ID **/ -void wxMaracasRenderTabbedPanel::onCheckBoxSBChange(wxCommandEvent& event) +void wxMaracasRenderTabbedPanel::onColorChange(wxCommandEvent& event) { - surrendmanager2->addRemoveActor(this->getPropIdSB(), checkboxSB->GetValue()); + /*Temporarily disabled*/ + + //if(mwxwidget->ShowModal()==wxID_OK){ + //updateVolume(); + // mwxwidget->Show(false); + //} } /** -** Method called when SurfaceRendering C checkbox status changes: Either shows or hides SurfaceRendering C image +** **/ -void wxMaracasRenderTabbedPanel::onCheckBoxSCChange(wxCommandEvent& event) +vtkImageData* wxMaracasRenderTabbedPanel::getVolImage() { - surrendmanager3->addRemoveActor(this->getPropIdSC(), checkboxSC->GetValue()); + return volmanager->getImageData(); } /** -** +** Gets surface rendering A image asociated to the given ID **/ -int wxMaracasRenderTabbedPanel::getPropIdV() -{ - return _propidV; +vtkImageData* wxMaracasRenderTabbedPanel::getSurfAImage() +{ + return surrendmanager1->getImageData(); } /** -** +** Gets surface rendering B image asociated to the given ID **/ -int wxMaracasRenderTabbedPanel::getPropIdSA() -{ - return _propidSA; +vtkImageData* wxMaracasRenderTabbedPanel::getSurfBImage() +{ + return surrendmanager2->getImageData(); } /** -** +** Gets surface rendering C image asociated to the given ID **/ -int wxMaracasRenderTabbedPanel::getPropIdSB() -{ - return _propidSB; +vtkImageData* wxMaracasRenderTabbedPanel::getSurfCImage() +{ + return surrendmanager3->getImageData(); } /** ** **/ -int wxMaracasRenderTabbedPanel::getPropIdSC() +int wxMaracasRenderTabbedPanel::getPropIdV() { - return _propidSC; -} \ No newline at end of file + return _id; +}