From 6f48c23a9bdcfe238c88d81f5dd9b514c85c3c58 Mon Sep 17 00:00:00 2001 From: jean-pierre roux Date: Fri, 21 Nov 2008 18:58:45 +0000 Subject: [PATCH] creaMaracasVisu is now gdcm-free and libIDO-free (hope so!) --- CMakeLists.txt | 4 +- bbtk/CMakeLists.txt | 8 +- lib/maracasVisuLib/CMakeLists.txt | 2 +- .../wxWindows/wxMaracasDataBrowser.cxx | 389 -------- .../wxWindows/wxMaracasDataBrowser.h | 70 -- .../wxWindows/wxMaracasEmptyPanel_3.cxx | 867 ------------------ .../wxWindows/wxMaracasEmptyPanel_3.h | 106 --- 7 files changed, 7 insertions(+), 1439 deletions(-) delete mode 100644 lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.cxx delete mode 100644 lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.h delete mode 100644 lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.cxx delete mode 100644 lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 66c124b..9385358 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -24,8 +24,8 @@ IF (crea_FOUND) ENDIF(crea_FOUND) CREA_PREVENT_IN_SOURCE_BUILD() -SET(USE_GDCM ON) -SET(USE_GDCM_VTK ON) +#SET(USE_GDCM ON) +#SET(USE_GDCM_VTK ON) SET(USE_WXWIDGETS ON) SET(USE_VTK ON) SET(USE_ITK ON) diff --git a/bbtk/CMakeLists.txt b/bbtk/CMakeLists.txt index 0ccc6db..047d4e3 100644 --- a/bbtk/CMakeLists.txt +++ b/bbtk/CMakeLists.txt @@ -42,7 +42,7 @@ SET(${BBTK_PACKAGE_NAME}_BUILD_VERSION 0) # UNCOMMENT EACH LIBRARY NEEDED (WILL BE FOUND AND USED AUTOMATICALLY) SET(${BBTK_PACKAGE_NAME}_USE_VTK ON) SET(${BBTK_PACKAGE_NAME}_USE_ITK ON) - SET(${BBTK_PACKAGE_NAME}_USE_GDCM ON) +# SET(${BBTK_PACKAGE_NAME}_USE_GDCM ON) # SET(${BBTK_PACKAGE_NAME}_USE_GSMIS ON) SET(${BBTK_PACKAGE_NAME}_USE_WXWIDGETS ON) #=========================================================================== @@ -118,9 +118,9 @@ SET(${BBTK_PACKAGE_NAME}_INCLUDE_DIRS ) #=========================================================================== -FIND_PATH( libIdo_DIR libidobin $ENV{LIBIDO_PATH} ) -FIND_PACKAGE(libIdo) -INCLUDE_DIRECTORIES(${LIBIDO_INCLUDE_PATH}) +#FIND_PATH( libIdo_DIR libidobin $ENV{LIBIDO_PATH} ) +#FIND_PACKAGE(libIdo) +#INCLUDE_DIRECTORIES(${LIBIDO_INCLUDE_PATH}) #=========================================================================== INCLUDE_DIRECTORIES( diff --git a/lib/maracasVisuLib/CMakeLists.txt b/lib/maracasVisuLib/CMakeLists.txt index 0fb02b1..2f83238 100644 --- a/lib/maracasVisuLib/CMakeLists.txt +++ b/lib/maracasVisuLib/CMakeLists.txt @@ -34,7 +34,7 @@ IF ( BUILD_${LIBRARY_NAME} ) ../../../ ) #message(jhcl\n\n ${crea_LIBRARIES}) - INCLUDE(include/Modules/MARACAS_Find_LIBIDO.cmake) + #INCLUDE(include/Modules/MARACAS_Find_LIBIDO.cmake) #SET(CREA_LIBRARIES C:/creaBin/Debug/crea.lib) #FIND_PACKAGE(crea) #jhcl-End=========================================================================== diff --git a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.cxx b/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.cxx deleted file mode 100644 index 87669d6..0000000 --- a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.cxx +++ /dev/null @@ -1,389 +0,0 @@ -/*========================================================================= - - Program: wxMaracas - Module: $RCSfile: wxMaracasDataBrowser.cxx,v $ - Language: C++ - Date: $Date: 2008/10/31 16:32:09 $ - Version: $Revision: 1.1 $ - - Copyright: (c) 2002, 2003 - License: - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notice for more information. - -=========================================================================*/ - -#include "wxMaracasFrame02.h" -#include "wxMaracasDataBrowser.h" - -#include "marGdcmDicom.h" - - -#include "gdcmDocument.h" -#include "gdcmDicomDir.h" -#include "gdcmDicomDirPatient.h" -#include "gdcmDicomDirStudy.h" -#include "gdcmDicomDirSerie.h" -#include "gdcmDicomDirImage.h" -#include "gdcmTS.h" - - - -//------------------------------------------------------------------------- - -class wxDlgDefineRegionZ : public wxDialog { -public : - wxDlgDefineRegionZ(wxWindow *parent,int maxSize, wxString title); - int GetIniSlice(); - int GetEndSlice(); - void OnIni(wxScrollEvent& event); - void OnEnd(wxScrollEvent& event); - - wxSlider *sldIni; - wxSlider *sldEnd; -private : -}; - -//------------------------------------------------------------------------- -//------------------------------------------------------------------------- -//------------------------------------------------------------------------- - -wxDlgDefineRegionZ::wxDlgDefineRegionZ(wxWindow *parent,int maxSize, wxString title) -: wxDialog(parent, -1, title){ - - sldIni = new wxSlider(this, -1, 0 , 0, maxSize, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL | wxSL_LABELS ); - sldEnd = new wxSlider(this, -1, maxSize, 0, maxSize, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL | wxSL_LABELS ); - wxStaticText *text1 = new wxStaticText(this, -1, _T("Start : ")); - wxStaticText *text2 = new wxStaticText(this, -1, _T("End : ")); - wxButton *btnOk = new wxButton(this, wxID_OK , _T("OK")); - wxButton *btnCancel = new wxButton(this, wxID_CANCEL , _T("CANCEL")); - - sldIni->SetSize(300,20); - sldEnd->SetSize(300,20); - - wxFlexGridSizer *sizer = new wxFlexGridSizer(2); - sizer->Add(text1); - sizer->Add(sldIni); - sizer->Add(text2); - sizer->Add(sldEnd); - sizer->Add(btnOk); - sizer->Add(btnCancel); - this->SetSizer(sizer); - this->SetSize(450,200); - - this->Connect(sldIni->GetId() , wxEVT_COMMAND_SLIDER_UPDATED , (wxObjectEventFunction) &wxDlgDefineRegionZ::OnIni ); - this->Connect(sldEnd->GetId() , wxEVT_COMMAND_SLIDER_UPDATED , (wxObjectEventFunction) &wxDlgDefineRegionZ::OnEnd ); -} - -//------------------------------------------------------------------------- - -int wxDlgDefineRegionZ::GetIniSlice(){ - return sldIni->GetValue(); -} - -//------------------------------------------------------------------------- - -int wxDlgDefineRegionZ::GetEndSlice(){ - return sldEnd->GetValue(); -} - -//------------------------------------------------------------------------- - -void wxDlgDefineRegionZ::OnIni(wxScrollEvent& event){ - if (sldIni->GetValue() > sldEnd->GetValue() ){ - sldEnd->SetValue(sldIni->GetValue() ); - } -} - -//------------------------------------------------------------------------- - -void wxDlgDefineRegionZ::OnEnd(wxScrollEvent& event){ - if (sldIni->GetValue() > sldEnd->GetValue() ){ - sldIni->SetValue(sldEnd->GetValue() ); - } -} - - - -//------------------------------------------------------------------------- -//------------------------------------------------------------------------- -//------------------------------------------------------------------------- - - -BEGIN_EVENT_TABLE( wxMaracasDataBrowser, wxPanel ) - EVT_BUTTON( ID_BUTTON_CHANGEDIR , wxMaracasDataBrowser::OnChangeDir ) - EVT_BUTTON( ID_BUTTON_CHANGEDICOMFILE , wxMaracasDataBrowser::OnChangeDicomFile ) - EVT_BUTTON( ID_BUTTON_CREATEDICOMFILE , wxMaracasDataBrowser::OnCreateDicomFile ) - - EVT_LIST_ITEM_SELECTED( ID_STUDIES_LIST, wxMaracasDataBrowser::OnStudySelected ) - EVT_LIST_ITEM_SELECTED( ID_SERIES_LIST , wxMaracasDataBrowser::OnSerieSelected ) - EVT_LIST_ITEM_ACTIVATED( ID_SERIES_LIST , wxMaracasDataBrowser::OnActivated ) -END_EVENT_TABLE( ); - -//------------------------------------------------------------------------- -wxMaracasDataBrowser::wxMaracasDataBrowser( wxFrame* parent, marInterface* mar, wxWindowID id ) - : wxPanel( parent, id, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL ) -{ - _mar = mar; - frame_parent = parent; - - _splitter = new wxSplitterWindow( this, -1, wxDefaultPosition, wxSize( 1200, 800 ), wxSP_3D ); - - _studies = new wxListCtrl( _splitter, ID_STUDIES_LIST, wxDefaultPosition, wxSize(100,100), wxLC_REPORT ); - _studies->InsertColumn( 0, _T("Patient's name" )); - _studies->InsertColumn( 1, _T("Patient's ID" )); - _studies->InsertColumn( 2, _T("Study's name" )); - _studies->InsertColumn( 3, _T("Study's ID" )); - _studies->InsertColumn( 4, _T("Study's date" )); - _studies->InsertColumn( 5, _T("Study's time" )); - _studies->InsertColumn( 6, _T("Study's description" )); - - _series = new wxListCtrl( _splitter, ID_SERIES_LIST, wxDefaultPosition, wxSize(100,100), wxLC_REPORT ); - _series->InsertColumn( 0, _T("Serie's name" )); - _series->InsertColumn( 1, _T("Serie's ID" )); - _series->InsertColumn( 2, _T("Serie's date" )); - _series->InsertColumn( 3, _T("Serie's time" )); - _series->InsertColumn( 4, _T("Modality" )); - _series->InsertColumn( 5, _T("Body part examined" )); - _series->InsertColumn( 6, _T("Serie's description" )); - _series->InsertColumn( 7, _T("Serie's diagnostic" )); - _series->InsertColumn( 8, _T("Institution name" )); - _series->InsertColumn( 9, _T("Number of images" )); - - _splitter->SplitHorizontally( _studies, _series); - - wxFlexGridSizer *szTop = new wxFlexGridSizer( 1 ); - - wxButton *btnChangeDir = new wxButton(this,ID_BUTTON_CHANGEDIR,_T("Change Directory")) ; - wxButton *btnChangeDicomFile = new wxButton(this,ID_BUTTON_CHANGEDICOMFILE,_T("Change DICOMDIR file")) ; - wxButton *btnCreateDicomFile = new wxButton(this,ID_BUTTON_CREATEDICOMFILE,_T("Create DICOMDIR file")) ; - - btnChangeDir->SetSize(150,25); - btnChangeDicomFile->SetSize(150,25); - btnCreateDicomFile->SetSize(150,25); - - szTop->Add( btnChangeDicomFile , 0 , wxALL, 10); - szTop->Add( btnCreateDicomFile , 0 , wxALL, 10); - szTop->Add( btnChangeDir , 0 , wxALL, 10); - - - - wxFlexGridSizer *szVertical = new wxFlexGridSizer( 2 ); - szVertical->Add( szTop, 1, wxALL|wxEXPAND , 0 ); - szVertical->Add( _splitter, 1, wxALL|wxEXPAND , 0 ); - - this->SetSizer( szVertical ); - this->SetAutoLayout( true ); - this->Layout(); - - szTop->Fit( this ); - szTop->SetSizeHints( this ); -// _splitter->SetMinimumPaneSize( 50 ); - _splitter->SetSashPosition(500,true); - - _parseDir=false; - -} -//---------------------------------------------------------------------------- -void wxMaracasDataBrowser::CreateDicomFile(){ - marGdcmDicom *gdcmDicom = (marGdcmDicom*)_mar->_dicom; - wxBusyCursor wait; - gdcmDicom->CreateDicomFile(); -} -//------------------------------------------------------------------------- -void wxMaracasDataBrowser::LoadData( ){ - wxBusyCursor wait; - long tmp; - int it = 0; - - _studies->Hide( ); - _series->Hide( ); - _studies->DeleteAllItems( ); - _series->DeleteAllItems( ); - - marGdcmDicom *gdcmDicom = (marGdcmDicom*)_mar->_dicom; - gdcmDicom->FillDicomInfo(_parseDir); - GDCM_NAME_SPACE::DicomDir *dicomDir = gdcmDicom->getGdcmDicomDir(); - GDCM_NAME_SPACE::DicomDirPatient *pa; - GDCM_NAME_SPACE::DicomDirStudy *st; - - pa = dicomDir->GetFirstPatient(); - while (pa){ // on degouline les PATIENT de ce DICOMDIR - st = pa->GetFirstStudy(); - while ( st ) { // on degouline les STUDY de ce patient - tmp = _studies->InsertItem( it, wxString(pa->GetEntryString (0x0010, 0x0010).c_str(), wxConvUTF8) , 0 ); // Patient's Name - _studies->SetItemData( tmp, it ); - _studies->SetItem( it, 1, wxString(pa->GetEntryString (0x0010, 0x0020).c_str(), wxConvUTF8) ); // ID_Patient_ID - _studies->SetItem( it, 2, wxString(st->GetEntryString (0x0020, 0x000d).c_str(), wxConvUTF8) ); // ID_Study_Instance_UID - _studies->SetItem( it, 3, wxString(st->GetEntryString (0x0020, 0x0010).c_str(), wxConvUTF8) ); // ID_Study_ID - _studies->SetItem( it, 4, wxString(st->GetEntryString (0x0008, 0x0020).c_str(), wxConvUTF8) ); // ID_Study_Date - _studies->SetItem( it, 5, wxString(st->GetEntryString (0x0008, 0x0030).c_str(), wxConvUTF8) ); // ID_Study_Time - _studies->SetItem( it, 6, wxString(st->GetEntryString (0x0008, 0x1030).c_str(), wxConvUTF8) ); // ID_Study_Description - it++; - st = pa->GetNextStudy(); - } - pa = dicomDir->GetNextPatient(); - } - - _studies->Show( ); _series->Show( ); -} - - -//---------------------------------------------------------------------------- -void wxMaracasDataBrowser::LoadDicomData(int type, wxString msg){ - wxString dirHome = _mar->_parameters->getStringParam( - marParameters::e_dicom_images_directory ); - wxDirDialog dialog( this, msg, - ( !dirHome.IsEmpty( ) )? dirHome: wxGetHomeDir( ) ); - - if( dialog.ShowModal( ) == wxID_OK ){ - _mar->_parameters->setStringParam( - marParameters::e_dicom_images_directory, dialog.GetPath( ) ); - _mar->saveParameters( ); - if (type==1){ - _parseDir=true; - this->LoadData(); - } - if (type==2){ - _parseDir=false; - this->LoadData(); - } - if (type==3){ - this->CreateDicomFile(); - _parseDir=false; - this->LoadData(); - } - } -} -//---------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnChangeDir( wxCommandEvent& event ){ - this->LoadDicomData(1,_T("Choose a directory...")); -} -//---------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnChangeDicomFile( wxCommandEvent& event ){ - this->LoadDicomData(2,_T("Choose a DICOM directory...")); -} -//---------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnCreateDicomFile( wxCommandEvent& event ){ - this->LoadDicomData(3,_T("Create a DICOM file. Choose a directory...")); -} -//------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnStudySelected( wxListEvent& event ){ - int it=0; - int maxCount=event.GetIndex(); - marGdcmDicom *gdcmDicom = (marGdcmDicom*)_mar->_dicom; - GDCM_NAME_SPACE::DicomDir *dicomDir = gdcmDicom->getGdcmDicomDir(); - GDCM_NAME_SPACE::DicomDirPatient *pa; - GDCM_NAME_SPACE::DicomDirStudy *st; - GDCM_NAME_SPACE::DicomDirSerie *se; - GDCM_NAME_SPACE::DicomDirImage *im; - - bool ok=true; - pa = dicomDir->GetFirstPatient(); - while ((pa) && (ok==true)){ // on degouline les PATIENT de ce DICOMDIR - st = pa->GetFirstStudy(); - while ((st) && (ok==true)) { // on degouline les STUDY de ce patient - if (it==maxCount) { - gdcmDicom->setActualPatient( pa ); - gdcmDicom->setActualStudy( st ); - ok=false; - } - it++; - if (ok==true) { - st = pa->GetNextStudy(); - } - } - pa = dicomDir->GetNextPatient(); - } - - _series->DeleteAllItems( ); - long tmp; - it=0; - - se = st->GetFirstSerie(); - while ( se ) { // on degouline les SERIES de cette study - tmp = _series->InsertItem( it, wxString(se->GetEntryString(0x0020, 0x000e).c_str(), wxConvUTF8) , 0 ); // ID_Series_Instance_UID - _series->SetItemData( tmp, it ); - _series->SetItem( it, 1, wxString(se->GetEntryString(0x0020, 0x0011).c_str(), wxConvUTF8 )); // ID_Series_Number - _series->SetItem( it, 2, wxString(se->GetEntryString(0x0008, 0x0021).c_str(), wxConvUTF8 )); // ID_Series_Date - _series->SetItem( it, 3, wxString(se->GetEntryString(0x0008, 0x0031).c_str(), wxConvUTF8 )); // ID_Series_Time - _series->SetItem( it, 4, wxString(se->GetEntryString(0x0008, 0x0060).c_str(), wxConvUTF8 )); // ID_Modality - _series->SetItem( it, 5, wxString(se->GetEntryString(0x0018, 0x0015).c_str(), wxConvUTF8 )); // ID_Body_Part_Examined - _series->SetItem( it, 6, wxString(se->GetEntryString(0x0008, 0x103e).c_str(), wxConvUTF8 )); // ID_Series_Description -// _series->SetItem( it, 7, wxString(se->GetEntryString(0x0008, 0x1080).c_str(), wxConvUTF8 )); // ID_Admitting_Diagnoses_Description -// _series->SetItem( it, 8, wxString(se->GetEntryString(0x0008, 0x0080).c_str(), wxConvUTF8 )); // ID_Institution_Name - int numOfImg = 0; - im = se->GetFirstImage(); - while ( im ) { // on degouline les Images de cette serie - numOfImg++; - im = se->GetNextImage(); - } - wxString strNumOfImg; - strNumOfImg.sprintf(_T("%d"),numOfImg); - _series->SetItem( it, 9, strNumOfImg ); // number of images in the serie - - it++; - se = st->GetNextSerie(); - } - - //re-disable - frame_parent->GetToolBar()->EnableTool(ID_TOOLBAR_IMAGE_BROWSER, false); - - - -} -//------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnSerieSelected( wxListEvent& event ){ - marGdcmDicom *gdcmDicom = (marGdcmDicom*)_mar->_dicom; - GDCM_NAME_SPACE::DicomDirStudy *st = gdcmDicom->getActualStudy(); - GDCM_NAME_SPACE::DicomDirSerie *se; - - int it = 0; - int maxCount = event.GetIndex(); - se = st->GetFirstSerie(); - bool ok=true; - while ( (se) && (ok==true) ) { // on degouline les SERIES de cette study - if (it==maxCount){ - gdcmDicom->setActualSerie( se ); - ok=false; - } - it++; - se = st->GetNextSerie(); - } - frame_parent->GetToolBar()->EnableTool(ID_TOOLBAR_IMAGE_BROWSER, true); -} -//------------------------------------------------------------------------- -void wxMaracasDataBrowser::OnActivated( wxListEvent& event ) -{ - - bool ok=false; - marGdcmDicom *gdcmDicom = (marGdcmDicom*)_mar->_dicom; - GDCM_NAME_SPACE::DicomDirSerie *se; - GDCM_NAME_SPACE::DicomDirImage *im; - int numOfImg = 0; - - se = gdcmDicom->getActualSerie(); - im = se->GetFirstImage(); - while ( im ) { // on degouline les Images de cette serie - numOfImg++; - im = se->GetNextImage(); - } - - wxDlgDefineRegionZ *wxdlgdefineregionZ = new wxDlgDefineRegionZ(this,numOfImg, _T("Define Z region")); - if (wxdlgdefineregionZ->ShowModal() == wxID_OK ){ - gdcmDicom->setIniSlice( wxdlgdefineregionZ->GetIniSlice() ); - gdcmDicom->setEndSlice( wxdlgdefineregionZ->GetEndSlice() ); - ok=true; - } - wxdlgdefineregionZ->Destroy(); - - if (ok==true){ - wxCommandEvent _evt( wxEVT_COMMAND_MENU_SELECTED ,ID_TOOLBAR_IMAGE_BROWSER ); - ProcessEvent(_evt); - } - -} -// EOF - wxDataBrowser.cxx - diff --git a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.h b/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.h deleted file mode 100644 index 364dea2..0000000 --- a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasDataBrowser.h +++ /dev/null @@ -1,70 +0,0 @@ -/*========================================================================= - - Program: wxMaracas - Module: $RCSfile: wxMaracasDataBrowser.h,v $ - Language: C++ - Date: $Date: 2008/10/31 16:32:09 $ - Version: $Revision: 1.1 $ - - Copyright: (c) 2002, 2003 - License: - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notice for more information. - -=========================================================================*/ - -#ifndef __WX__DATA__BROWSER__ -#define __WX__DATA__BROWSER__ - -#include -#include -#include -#include - -#include - -/** - * \brief Panel class showing patient name etc... - */ -class wxMaracasDataBrowser : public wxPanel -{ -public: - wxMaracasDataBrowser( wxFrame* parent, marInterface* mar, wxWindowID id = -1 ); - - void LoadData( ); - void CreateDicomFile( ); - - void LoadDicomData(int type, wxString msg); - void OnChangeDir( wxCommandEvent& event ); - void OnChangeDicomFile( wxCommandEvent& event ); - void OnCreateDicomFile( wxCommandEvent& event ); - void OnStudySelected( wxListEvent& event ); - void OnSerieSelected( wxListEvent& event ); - void OnActivated( wxListEvent& event ); - -private: - - bool _parseDir; - - wxSplitterWindow *_splitter; - wxListCtrl *_studies; - wxListCtrl *_series; - marInterface *_mar; - wxFrame *frame_parent; - - DECLARE_EVENT_TABLE( ); - -}; - -enum -{ - ID_STUDIES_LIST = 0x2000, - ID_SERIES_LIST = 0x2001, - ID_BUTTON_CHANGEDIR = 0x2002, - ID_BUTTON_CHANGEDICOMFILE = 0x2003, - ID_BUTTON_CREATEDICOMFILE = 0x2004, -}; - -#endif // __WX__DATA__BROWSER__ diff --git a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.cxx b/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.cxx deleted file mode 100644 index f0feddd..0000000 --- a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.cxx +++ /dev/null @@ -1,867 +0,0 @@ -/*========================================================================= - - Program: wxMaracas - Module: $RCSfile: wxMaracasEmptyPanel_3.cxx,v $ - Language: C++ - Date: $Date: 2008/10/31 16:32:10 $ - Version: $Revision: 1.1 $ - - Copyright: (c) 2002, 2003 - License: - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notice for more information. - -=========================================================================*/ - - - -#include "wxMaracasEmptyPanel_3.h" - -#include -#include -#include "vtkGdcmReader.h" -#include -#include "marGdcmDicom.h" -#include - -#define PI 3.14159265358979323846 - -wxMaracasEmptyPanel_3::wxMaracasEmptyPanel_3( wxWindow* parent ) -: wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL) -{ - // Create the main frame window - _emptyPanel_3_Widget = new wxEmptyPanel_3_Widget( this); - wxBoxSizer* szTop = new wxBoxSizer( wxVERTICAL ); - szTop->Add( _emptyPanel_3_Widget, 1 , wxEXPAND | wxALL , 0 ); - szTop->Fit( this ); - szTop->SetSizeHints( this ); - this->SetAutoLayout( true ); - this->SetSizer( szTop ); - this->Layout(); -} -//---------------------------------------------------------------------------- -wxMaracasEmptyPanel_3::~wxMaracasEmptyPanel_3( ) -{ - // Nothing -} -//---------------------------------------------------------------------------- -void wxMaracasEmptyPanel_3::ConfigureVTK( marImageData *marimagedata ) -{ - _emptyPanel_3_Widget->ConfigureVTK(marimagedata); -} - - - - - -//---------------------------------------------------------------------------- -//---------------------------------------------------------------------------- -//---------------------------------------------------------------------------- - - - - - -void GetAng(double &angX,double &angY,double &angZ,double positionVec[]) -{ -// double PI=3.14159265358979323846; - double x,y,z; - x = positionVec[0]; - y = positionVec[1]; - z = positionVec[2]; - - angZ = -atan2( y , x )*180/PI; - angY = -atan2( z , sqrt( x*x + y*y ) )*180/PI; - - - vtkTransform *transform = vtkTransform::New(); - transform->Identity(); - transform->RotateY( angY ); - transform->RotateZ( angZ ); - - double in[4],out[4]; - in[0] = positionVec[3]; - in[1] = positionVec[4]; - in[2] = positionVec[5]; - in[3] = 1; - - transform->MultiplyPoint(in,out); - - transform->Delete(); - - x = out[0] ; - y = out[1] ; - z = out[2] ; - - angX = -atan2(z,y)*180/PI; - -//-- -FILE *ff=fopen("c:/Temp/PIXEL_EED.txt","a+"); - - vtkTransform *transform2 = vtkTransform::New(); - transform2->Identity(); - transform2->RotateX( angX ); - transform2->RotateY( -angY ); - transform2->RotateZ( angZ ); - in[0] = (double)positionVec[0]; - in[1] = (double)positionVec[1]; - in[2] = (double)positionVec[2];; - in[3] = 1; - transform2->MultiplyPoint(in,out); -fprintf(ff,">>>> vx=( %f , %f , %f ) ",out[0],out[1],out[2]); - - in[0] = (double)positionVec[3]; - in[1] = (double)positionVec[4]; - in[2] = (double)positionVec[5]; - in[3] = 1; - transform2->MultiplyPoint(in,out); -fprintf(ff,"vy=( %f , %f , %f )\n",out[0],out[1],out[2]); - transform2->Delete(); -fclose(ff); - -} - - - - -//---------------------------------------------------------------------------- -//---------------------------------------------------------------------------- -//---------------------------------------------------------------------------- - - -BEGIN_EVENT_TABLE( wxMaracasEmptyPanel_4, wxPanel ) - EVT_MENU( 12121, wxMaracasEmptyPanel_4::OnRefreshView ) - EVT_MENU( 12122, wxMaracasEmptyPanel_4::OnDClickLeft ) -END_EVENT_TABLE( ); - - -wxMaracasEmptyPanel_4::wxMaracasEmptyPanel_4( wxWindow* parent ) -: wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL) -{ - - _vtkbasedata1 = NULL; - _vtkbasedata2 = NULL; - _wxvtk2Dbaseview1 = NULL; - _wxvtk2Dbaseview2 = NULL; - - wxSplitterWindow * splitPanel = new wxSplitterWindow(this,-1); - wxPanel *imagePanel = CreateImagePanel(splitPanel); - wxPanel *panelControl = CreateControlPanel_Algo(splitPanel); - - splitPanel->SplitVertically( imagePanel , panelControl , 2 ); -// splitPanel->FitInside(); - - - // Create the main frame window - wxBoxSizer* szTop = new wxBoxSizer( wxHORIZONTAL ); - szTop->Add( splitPanel , 1 , wxEXPAND | wxALL , 0 ); - szTop->Fit( this ); - szTop->SetSizeHints( this ); - this->SetAutoLayout( true ); - this->SetSizer( szTop ); - this->Layout(); -} - -//---------------------------------------------------------------------------- - -wxMaracasEmptyPanel_4::~wxMaracasEmptyPanel_4() -{ - delete _wxvtk2Dbaseview1; - delete _wxvtk2Dbaseview2; -// delete _vtkbasedata1; -// delete _vtkbasedata2; -} - - - -//---------------------------------------------------------------------------- - -wxPanel* wxMaracasEmptyPanel_4::CreateImagePanel(wxWindow *parent) -{ - wxPanel *panel = new wxPanel(parent,-1); - - _panelImage1 = new wxPanel(panel,-1); - _panelImage2 = new wxPanel(panel,-1); - - wxBoxSizer *topsizer1 = new wxBoxSizer(wxVERTICAL ); - _panelImage1->SetSizer(topsizer1); - - wxBoxSizer *topsizer2 = new wxBoxSizer(wxVERTICAL ); - _panelImage2->SetSizer(topsizer2); - - // Create the main frame window - wxBoxSizer* szTop = new wxBoxSizer( wxHORIZONTAL ); - szTop->Add( _panelImage1 , 1 , wxEXPAND | wxALL , 0 ); - szTop->Add( _panelImage2 , 1 , wxEXPAND | wxALL , 0 ); - szTop->Fit( panel ); - szTop->SetSizeHints( panel ); - panel->SetAutoLayout( true ); - panel->SetSizer( szTop ); - panel->Layout(); - return panel; - -} - - -//---------------------------------------------------------------------------- - -wxPanel* wxMaracasEmptyPanel_4::CreateControlPanel_Algo(wxWindow *parent) -{ - wxPanel *panel = new wxPanel(parent,-1); - - wxBoxSizer *szTop = new wxBoxSizer(wxVERTICAL ); - - _rb1 = new wxRadioButton(panel,-1,_T("Algo. 1")); - _rb2 = new wxRadioButton(panel,-1,_T("Algo. 2")); - _rb3 = new wxRadioButton(panel,-1,_T("Algo. 3")); - - _rb1->SetValue(true); - - szTop->Add( _rb1 , 1 , wxEXPAND | wxALL , 0 ); - szTop->Add( _rb2 , 1 , wxEXPAND | wxALL , 0 ); - szTop->Add( _rb3 , 1 , wxEXPAND | wxALL , 0 ); - szTop->Fit( parent ); - szTop->SetSizeHints( parent ); - panel->SetAutoLayout( true ); - panel->SetSizer( szTop ); - panel->Layout(); - - return panel; -} - -//---------------------------------------------------------------------------- - -void wxMaracasEmptyPanel_4::OnRefreshView(wxCommandEvent & event) // virtual -{ - - int pIn[4],pOut[4]; - pIn[0] = (int)(_vtkbasedata1->GetX()); - pIn[1] = (int)(_vtkbasedata1->GetY()); - pIn[2] = (int)(_vtkbasedata1->GetZ()); - pIn[2] = 0; - pIn[3] = 1; - - if (_rb1->GetValue()==true) - { - TranformPixel1(pIn,pOut, &_infoImg1,&_infoImg2); - } - if (_rb2->GetValue()==true) - { - TranformPixel2(pIn,pOut, &_infoImg1,&_infoImg2); - } - if (_rb3->GetValue()==true) - { - TranformPixel3(pIn,pOut, &_infoImg1,&_infoImg2); - } - - -FILE *ff=fopen("c:/Temp/PIXEL_EED.txt","a+"); -fprintf(ff,"-) %d %d %d \n" ,pIn[0] ,pIn[1] ,pIn[2] ); -fprintf(ff,"1) %d %d %d \n" ,pOut[0],pOut[1],pOut[2] ); -//TranformPixel2(pIn,pOut, &_infoImg1,&_infoImg2); -//fprintf(ff,"2) %d %d %d \n\n" ,pOut[0],pOut[1],pOut[2] ); -fclose(ff); - - _vtkbasedata2->SetX( pOut[0] ); - _vtkbasedata2->SetY( pOut[1] ); - _vtkbasedata2->SetZ( 0 ); - - - - if (_wxvtk2Dbaseview1!=NULL) - { - _wxvtk2Dbaseview1->RefreshView(); - } - if (_wxvtk2Dbaseview2!=NULL) - { - _wxvtk2Dbaseview2->Refresh(); - _wxvtk2Dbaseview2->RefreshView(); - } -} -//---------------------------------------------------------------------------- -void wxMaracasEmptyPanel_4::OnDClickLeft(wxCommandEvent & event) // virtual -{ -} -//---------------------------------------------------------------------------- -void wxMaracasEmptyPanel_4::ConfigureVTK( ) -{ - char filename1[255]; - char filename2[255]; - FILE *ff=fopen("c:/temp/filename.txt","r"); - fscanf(ff, "%s ",filename1); - fscanf(ff, "%s ",filename2); - fclose(ff); - - ConfigureImage(filename1,_panelImage1,1); - ConfigureImage(filename2,_panelImage2,2); -} -//---------------------------------------------------------------------------- -void wxMaracasEmptyPanel_4::ConfigureImage( char *fileName,wxPanel *panelImage, int ventana) -{ - vtkMPRBaseData *vtkbasedata; - wxVtkMPR2DView *wxvtk2Dbaseview; - - struct InfoImag * infoImage; - - if (ventana==1) - { - vtkbasedata = _vtkbasedata1; - wxvtk2Dbaseview = _wxvtk2Dbaseview1; - infoImage=&_infoImg1; - } else { - vtkbasedata = _vtkbasedata2; - wxvtk2Dbaseview = _wxvtk2Dbaseview2; - infoImage=&_infoImg2; - } - - - // Read header file - GDCM_NAME_SPACE::File *gdcmFile = GDCM_NAME_SPACE::File::New(); - gdcmFile->SetLoadMode( GDCM_NAME_SPACE::LD_NOSHADOW ); - gdcmFile->SetFileName( fileName ); - bool ok = gdcmFile->Load(); - long int offset = gdcmFile->GetPixelOffset(); - int dim[3]; - dim[0]=gdcmFile->GetXSize(); - dim[1]=gdcmFile->GetYSize(); - dim[2]=1; - - infoImage->Spacing[0]=gdcmFile->GetXSpacing(); - infoImage->Spacing[1]=gdcmFile->GetYSpacing(); - infoImage->ImPoPa[0]=gdcmFile->GetXOrigin(); - infoImage->ImPoPa[1]=gdcmFile->GetYOrigin(); - infoImage->ImPoPa[2]=gdcmFile->GetZOrigin(); - - float iop[6]; - gdcmFile->GetImageOrientationPatient(iop); - infoImage->ImOrPa[0]=iop[0]; - infoImage->ImOrPa[1]=iop[1]; - infoImage->ImOrPa[2]=iop[2]; - infoImage->ImOrPa[3]=iop[3]; - infoImage->ImOrPa[4]=iop[4]; - infoImage->ImOrPa[5]=iop[5]; - - - gdcmFile->Delete(); - - // Memory allocation - vtkImageData *imageData = vtkImageData::New(); - imageData->SetDimensions ( dim ); - imageData->SetScalarTypeToUnsignedShort(); - imageData->AllocateScalars(); - imageData->Update(); - marImageData *marimagedata = new marImageData(imageData); - - // Read Image - marGdcmDicom margdcmdicom; - void *p_vol = imageData->GetScalarPointer(0,0,0); - margdcmdicom.loadFileDicom( p_vol , dim , fileName ); - - if (vtkbasedata) { delete vtkbasedata; } - if (wxvtk2Dbaseview) { delete wxvtk2Dbaseview; } - - vtkbasedata = new vtkMPRBaseData(); - -wxWidgetMesure2D *widgetMesure = new wxWidgetMesure2D(panelImage); -wxvtk2Dbaseview = new wxVtkMPR2DView( widgetMesure,2 ); - -// wxvtk2Dbaseview = new wxVtkMPR2DView( panelImage,2 ); - - - vtkbasedata->SetMarImageData( marimagedata ); - wxvtk2Dbaseview->SetVtkBaseData(vtkbasedata); - wxvtk2Dbaseview->Configure(); - - widgetMesure -> ConfigureA(wxvtk2Dbaseview); - widgetMesure -> SetMesureScale( infoImage->Spacing[0] ); - - - wxVTKRenderWindowInteractor *imagePanel = wxvtk2Dbaseview->GetWxVTKRenderWindowInteractor(); - - vtkbasedata->SetX( dim[0]/2 ); - vtkbasedata->SetY( dim[1]/2 ); - vtkbasedata->SetZ( 0 ); - - wxSizer *sizer=panelImage->GetSizer(); -// sizer-> Add( imagePanel ,1,wxGROW ,0); - sizer-> Add( widgetMesure ,1,wxGROW ,0); - - panelImage->SetAutoLayout(true); - panelImage->Layout(); - - wxvtk2Dbaseview->Refresh(); - - if (ventana==1) - { - _vtkbasedata1 = vtkbasedata; - _wxvtk2Dbaseview1 = wxvtk2Dbaseview; - _widgetMesure1 = widgetMesure; - } else { - _vtkbasedata2 = vtkbasedata; - _wxvtk2Dbaseview2 = wxvtk2Dbaseview; - _widgetMesure2 = widgetMesure; - } -} - - - -//----------------------------------------------------------------------------- - - -void wxMaracasEmptyPanel_4::TranformPixel1(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2) -{ - vtkTransform *transform = vtkTransform::New(); - transform->Identity(); - - double ang1X,ang1Y,ang1Z; - double ang2X,ang2Y,ang2Z; - double in[4],out[4]; - - GetAng(ang1X,ang1Y,ang1Z,infoImg1->ImOrPa); - GetAng(ang2X,ang2Y,ang2Z,infoImg2->ImOrPa); - - // Transformation - transform->Scale( 1/infoImg2->Spacing[0] , 1/infoImg2->Spacing[1] , 1 ); - transform->RotateX( ang2X ); - transform->RotateY( -ang2Y ); - transform->RotateZ( ang2Z ); - transform->Translate( -infoImg2->ImPoPa[0] , -infoImg2->ImPoPa[1] , -infoImg2->ImPoPa[2] ); - transform->Translate( infoImg1->ImPoPa[0] , infoImg1->ImPoPa[1] , infoImg1->ImPoPa[2] ); - transform->RotateZ( -ang1Z ); - transform->RotateY( ang1Y ); - transform->RotateX( -ang1X ); - transform->Scale( infoImg1->Spacing[0] , infoImg1->Spacing[1] , 1 ); - - in[0] = (double)pIn[0]; - in[1] = (double)pIn[1]; - in[2] = 0; - in[3] = 1; - - transform->MultiplyPoint(in,out); - - transform->Delete(); - - pOut[0] = (int)(out[0] + 0.5); - pOut[1] = (int)(out[1] + 0.5); - pOut[2] = (int)(out[2] + 0.5); -} - - - -//----------------------------------------------------------------------------- - -void wxMaracasEmptyPanel_4::TranformPixel2(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2) -{ - double in[4],out[4]; - - //Scale 1 - double src_pos_x = (double)pIn[0] * infoImg1->Spacing[0]; - double src_pos_y = (double)pIn[1] * infoImg1->Spacing[1]; - double src_pos_z = (double)pIn[2] * 1; - - - -//Rotation 1 -double dst_nrm_dircos_x; -double dst_nrm_dircos_y; -double dst_nrm_dircos_z; - -double dst_pos_x; -double dst_pos_y; -double dst_pos_z; - -double dst_row_dircos_x = infoImg1->ImOrPa[0]; -double dst_row_dircos_y = infoImg1->ImOrPa[1]; -double dst_row_dircos_z = infoImg1->ImOrPa[2]; - -double dst_col_dircos_x = infoImg1->ImOrPa[3]; -double dst_col_dircos_y = infoImg1->ImOrPa[4]; -double dst_col_dircos_z = infoImg1->ImOrPa[5]; - -dst_nrm_dircos_x = dst_row_dircos_y * dst_col_dircos_z - dst_row_dircos_z * dst_col_dircos_y; -dst_nrm_dircos_y = dst_row_dircos_z * dst_col_dircos_x - dst_row_dircos_x * dst_col_dircos_z; -dst_nrm_dircos_z = dst_row_dircos_x * dst_col_dircos_y - dst_row_dircos_y * dst_col_dircos_x; - - -dst_pos_x = dst_row_dircos_x * src_pos_x - + dst_row_dircos_y * src_pos_y - + dst_row_dircos_z * src_pos_z; - -dst_pos_y = dst_col_dircos_x * src_pos_x - + dst_col_dircos_y * src_pos_y - + dst_col_dircos_z * src_pos_z; - -dst_pos_z = dst_nrm_dircos_x * src_pos_x - + dst_nrm_dircos_y * src_pos_y - + dst_nrm_dircos_z * src_pos_z; - -//Translation 1 -dst_pos_x = dst_pos_x + infoImg1->ImPoPa[0]; -dst_pos_y = dst_pos_y + infoImg1->ImPoPa[1]; -dst_pos_z = dst_pos_z + infoImg1->ImPoPa[2]; - -//Tranalacion - 2 -dst_pos_x = dst_pos_x - infoImg2->ImPoPa[0]; -dst_pos_y = dst_pos_y - infoImg2->ImPoPa[1]; -dst_pos_z = dst_pos_z - infoImg2->ImPoPa[2]; - - -//Rotation - 2 -dst_row_dircos_x = infoImg2->ImOrPa[0]; -dst_row_dircos_y = infoImg2->ImOrPa[1]; -dst_row_dircos_z = infoImg2->ImOrPa[2]; - -dst_col_dircos_x = infoImg2->ImOrPa[3]; -dst_col_dircos_y = infoImg2->ImOrPa[4]; -dst_col_dircos_z = infoImg2->ImOrPa[5]; - -dst_nrm_dircos_x = dst_row_dircos_y * dst_col_dircos_z - dst_row_dircos_z * dst_col_dircos_y; -dst_nrm_dircos_y = dst_row_dircos_z * dst_col_dircos_x - dst_row_dircos_x * dst_col_dircos_z; -dst_nrm_dircos_z = dst_row_dircos_x * dst_col_dircos_y - dst_row_dircos_y * dst_col_dircos_x; - - -in[0] = dst_pos_x; -in[1] = dst_pos_y; -in[2] = dst_pos_z; -in[3] = 1; -vtkMatrix4x4 *mat=vtkMatrix4x4::New(); -mat->Identity (); - -/* -mat->SetElement(0,0,dst_row_dircos_x); -mat->SetElement(0,1,dst_row_dircos_y); -mat->SetElement(0,2,dst_row_dircos_z); -mat->SetElement(0,3,0); - -mat->SetElement(1,0,dst_col_dircos_x); -mat->SetElement(1,1,dst_col_dircos_y); -mat->SetElement(1,2,dst_col_dircos_z); -mat->SetElement(1,3,0); - -mat->SetElement(2,0,dst_nrm_dircos_x); -mat->SetElement(2,1,dst_nrm_dircos_y); -mat->SetElement(2,2,dst_nrm_dircos_z); -mat->SetElement(2,3,0); - -mat->SetElement(3,0,0); -mat->SetElement(3,1,0); -mat->SetElement(3,2,0); -mat->SetElement(3,3,1); - -*/ - -mat->SetElement(0,0,dst_row_dircos_x); -mat->SetElement(1,0,dst_row_dircos_y); -mat->SetElement(2,0,dst_row_dircos_z); -mat->SetElement(3,0,0); - -mat->SetElement(0,1,dst_col_dircos_x); -mat->SetElement(1,1,dst_col_dircos_y); -mat->SetElement(2,1,dst_col_dircos_z); -mat->SetElement(3,1,0); - -mat->SetElement(0,2,dst_nrm_dircos_x); -mat->SetElement(1,2,dst_nrm_dircos_y); -mat->SetElement(2,2,dst_nrm_dircos_z); -mat->SetElement(3,2,0); - -mat->SetElement(0,3,0); -mat->SetElement(1,3,0); -mat->SetElement(2,3,0); -mat->SetElement(3,3,1); - - - - -/* -vtkTransform *transform2 = vtkTransform::New(); -transform2->Identity(); -transform2->SetMatrix(mat); -transform2->Update(); -*/ - - -vtkMatrix4x4 *matB = vtkMatrix4x4::New(); -vtkTransform *transform3 = vtkTransform::New(); -matB->Identity (); -mat->Invert(mat,matB); -//transform2->GetInverse(matB); -transform3->SetMatrix(matB); -transform3->Update(); - -double res=0; -FILE *hh=fopen("c:/Temp/Matrix.txt","w"); -for (int i=0; i<4; i++) -{ - for (int j=0; j<4; j++) - { - res=0; - for (int ii=0;ii<4;ii++) - { - res = res + mat->GetElement(ii,j) * matB->GetElement(i,ii); - } - fprintf(hh,"%f ",res); - } -} -fclose(hh); - -transform3->MultiplyPoint(in,out); -transform3->Delete(); -mat->Delete(); -matB->Delete(); - - //Scale 1/2 -out[0] = out[0] / infoImg2->Spacing[0]; -out[1] = out[1] / infoImg2->Spacing[1]; -out[2] = out[2] / 1.0; - -//-- - -pOut[0] = (int)(out[0] + 0.5); -pOut[1] = (int)(out[1] + 0.5); -pOut[2] = (int)(out[2] + 0.5); -} - - - -//----------------------------------------------------------------------------- - -void wxMaracasEmptyPanel_4::TranformPixel2a(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2) -{ - double in[4],out[4]; - - //Scale 1 - double src_pos_x = (double)pIn[0] * infoImg1->Spacing[0]; - double src_pos_y = (double)pIn[1] * infoImg1->Spacing[1]; - double src_pos_z = (double)pIn[2] * 1; - - - -//Rotation 1 -double dst_nrm_dircos_x; -double dst_nrm_dircos_y; -double dst_nrm_dircos_z; - -double dst_pos_x; -double dst_pos_y; -double dst_pos_z; - -double dst_row_dircos_x = infoImg1->ImOrPa[0]; -double dst_row_dircos_y = infoImg1->ImOrPa[1]; -double dst_row_dircos_z = infoImg1->ImOrPa[2]; - -double dst_col_dircos_x = infoImg1->ImOrPa[3]; -double dst_col_dircos_y = infoImg1->ImOrPa[4]; -double dst_col_dircos_z = infoImg1->ImOrPa[5]; - -dst_nrm_dircos_x = dst_row_dircos_y * dst_col_dircos_z - dst_row_dircos_z * dst_col_dircos_y; -dst_nrm_dircos_y = dst_row_dircos_z * dst_col_dircos_x - dst_row_dircos_x * dst_col_dircos_z; -dst_nrm_dircos_z = dst_row_dircos_x * dst_col_dircos_y - dst_row_dircos_y * dst_col_dircos_x; - -in[0] = src_pos_x; -in[1] = src_pos_y; -in[2] = src_pos_z; -in[3] = 0; -vtkMatrix4x4 *mat=vtkMatrix4x4::New(); - -mat->SetElement(0,0,dst_row_dircos_x); -mat->SetElement(0,1,dst_row_dircos_y); -mat->SetElement(0,2,dst_row_dircos_z); -mat->SetElement(0,3,0); - -mat->SetElement(1,0,dst_col_dircos_x); -mat->SetElement(1,1,dst_col_dircos_y); -mat->SetElement(1,2,dst_col_dircos_z); -mat->SetElement(1,3,0); - -mat->SetElement(2,0,dst_nrm_dircos_x); -mat->SetElement(2,1,dst_nrm_dircos_y); -mat->SetElement(2,2,dst_nrm_dircos_z); -mat->SetElement(2,3,0); - -mat->SetElement(3,0,0); -mat->SetElement(3,1,0); -mat->SetElement(3,2,0); -mat->SetElement(3,3,1); - -/* - -mat->SetElement(0,0,dst_row_dircos_x); -mat->SetElement(1,0,dst_row_dircos_y); -mat->SetElement(2,0,dst_row_dircos_z); -mat->SetElement(3,0,0); - -mat->SetElement(0,1,dst_col_dircos_x); -mat->SetElement(1,1,dst_col_dircos_y); -mat->SetElement(2,1,dst_col_dircos_z); -mat->SetElement(3,1,0); - -mat->SetElement(0,2,dst_nrm_dircos_x); -mat->SetElement(1,2,dst_nrm_dircos_y); -mat->SetElement(2,2,dst_nrm_dircos_z); -mat->SetElement(3,2,0); - -mat->SetElement(0,3,0); -mat->SetElement(1,3,0); -mat->SetElement(2,3,0); -mat->SetElement(3,3,1); -*/ - -vtkMatrix4x4 *matB = vtkMatrix4x4::New(); -vtkTransform *transform3 = vtkTransform::New(); -mat->Invert(mat,matB); -transform3->SetMatrix(matB); -transform3->Update(); - -double res=0; -FILE *hh=fopen("c:/Temp/Matrix.txt","w"); -for (int i=0; i<4; i++) -{ - for (int j=0; j<4; j++) - { - res=0; - for (int ii=0;ii<4;ii++) - { - res = res + mat->GetElement(ii,j) * matB->GetElement(i,ii); - } - fprintf(hh,"%f ",res); - } -} -fclose(hh); - -transform3->MultiplyPoint(in,out); -transform3->Delete(); -mat->Delete(); -matB->Delete(); - - -//Translation 1 -dst_pos_x = out[0] + infoImg1->ImPoPa[0]; -dst_pos_y = out[0] + infoImg1->ImPoPa[1]; -dst_pos_z = out[0] + infoImg1->ImPoPa[2]; - -//Tranalacion - 2 -src_pos_x = dst_pos_x - infoImg2->ImPoPa[0]; -src_pos_y = dst_pos_y - infoImg2->ImPoPa[1]; -src_pos_z = dst_pos_z - infoImg2->ImPoPa[2]; - - - - -//Rotation - 2 -dst_row_dircos_x = infoImg2->ImOrPa[0]; -dst_row_dircos_y = infoImg2->ImOrPa[1]; -dst_row_dircos_z = infoImg2->ImOrPa[2]; - -dst_col_dircos_x = infoImg2->ImOrPa[3]; -dst_col_dircos_y = infoImg2->ImOrPa[4]; -dst_col_dircos_z = infoImg2->ImOrPa[5]; - -dst_nrm_dircos_x = dst_row_dircos_y * dst_col_dircos_z - dst_row_dircos_z * dst_col_dircos_y; -dst_nrm_dircos_y = dst_row_dircos_z * dst_col_dircos_x - dst_row_dircos_x * dst_col_dircos_z; -dst_nrm_dircos_z = dst_row_dircos_x * dst_col_dircos_y - dst_row_dircos_y * dst_col_dircos_x; - - -dst_pos_x = dst_row_dircos_x * src_pos_x - + dst_row_dircos_y * src_pos_y - + dst_row_dircos_z * src_pos_z; - -dst_pos_y = dst_col_dircos_x * src_pos_x - + dst_col_dircos_y * src_pos_y - + dst_col_dircos_z * src_pos_z; - -dst_pos_z = dst_nrm_dircos_x * src_pos_x - + dst_nrm_dircos_y * src_pos_y - + dst_nrm_dircos_z * src_pos_z; - - - - //Scale 1/2 -out[0]=dst_pos_x / infoImg2->Spacing[0]; -out[1]=dst_pos_y / infoImg2->Spacing[1]; -out[2]=dst_pos_z / 1.0; - -//-- - -pOut[0] = (int)(out[0] + 0.5); -pOut[1] = (int)(out[1] + 0.5); -pOut[2] = (int)(out[2] + 0.5); -} - - -//---------------------------------------------------------------------------- - - -void wxMaracasEmptyPanel_4::TranformPixel3(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2) -{ - - manualPoint *p1a = _widgetMesure1->GetManualContourModel()->GetManualPoint(0); - manualPoint *p1b = _widgetMesure1->GetManualContourModel()->GetManualPoint(1); - - manualPoint *p2a = _widgetMesure2->GetManualContourModel()->GetManualPoint(0); - manualPoint *p2b = _widgetMesure2->GetManualContourModel()->GetManualPoint(1); - - double pp1aX = p1a->GetX() * infoImg1->Spacing[0]; - double pp1aY = p1a->GetY() * infoImg1->Spacing[1]; - double pp1bX = p1b->GetX() * infoImg1->Spacing[0]; - double pp1bY = p1b->GetY() * infoImg1->Spacing[1]; - - double pp2aX = p2a->GetX() * infoImg2->Spacing[0]; - double pp2aY = p2a->GetY() * infoImg2->Spacing[1]; - double pp2bX = p2b->GetX() * infoImg2->Spacing[0]; - double pp2bY = p2b->GetY() * infoImg2->Spacing[1]; - - double ang1= atan2( pp1bY-pp1aY , pp1bX-pp1aX )*180/PI; - double ang2= atan2( pp2bY-pp2aY , pp2bX-pp2aX )*180/PI; - - double in[4],inB[4],out[4]; - in[0] = (double)pIn[0] * infoImg1->Spacing[0]; - in[1] = (double)pIn[1] * infoImg1->Spacing[1]; - in[2] = 0; - in[3] = 1; - - in[0]=in[0]-pp1aX; - in[1]=in[1]-pp1aY; - - vtkTransform *transform; - transform = vtkTransform::New(); - transform->Identity(); -// transform->RotateZ( ang2 ); - transform->RotateZ( -ang1 ); - transform->MultiplyPoint(in,out); - transform->Delete(); - - inB[0] = out[0]; - inB[1] = out[1]; - inB[2] = out[2]; - inB[3] = out[3]; - vtkTransform *transform2; - transform2 = vtkTransform::New(); - transform2->Identity(); - transform2->RotateZ( ang2 ); -// transform2->RotateZ( ang1 ); - transform2->MultiplyPoint(inB,out); - transform2->Delete(); - - out[0] = out[0] + pp2aX; - out[1] = out[1] + pp2aY; - - out[0] = out[0] / infoImg2->Spacing[0]; - out[1] = out[1] / infoImg2->Spacing[1]; - - pOut[0]= (int)(out[0] + 0.5); - pOut[1]= (int)(out[1] + 0.5); - pOut[2]= 0; - - - -} - - -// EOF - wxMaracasEmptyPanel_3.cxx - - - - diff --git a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.h b/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.h deleted file mode 100644 index d174efd..0000000 --- a/lib/maracasVisuLib/src/interface/wxWindows/wxMaracasEmptyPanel_3.h +++ /dev/null @@ -1,106 +0,0 @@ -/*========================================================================= - - Program: wxMaracas - Module: $RCSfile: wxMaracasEmptyPanel_3.h,v $ - Language: C++ - Date: $Date: 2008/10/31 16:32:10 $ - Version: $Revision: 1.1 $ - - Copyright: (c) 2002, 2003 - License: - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notice for more information. - -=========================================================================*/ - -#ifndef __WX__MARACAS__EmptyPanel__3__HXX__ -#define __WX__MARACAS__EmptyPanel__3__HXX__ - - -#include -#include - -#include "vtkImageData.h" - -#include "widgets/wxEmptyPanel_3_Widget.h" - -#include "widgets/wxMPRBaseData.h" -#include "widgets/wxVtkBaseView.h" - - -class wxMaracasEmptyPanel_3 : public wxPanel -{ -public: - wxMaracasEmptyPanel_3( wxWindow* parent ); - ~wxMaracasEmptyPanel_3( ); - void ConfigureVTK(marImageData *marimagedata); -private: - wxEmptyPanel_3_Widget* _emptyPanel_3_Widget; -}; - - - -struct InfoImag { - - int RowCol[2]; - double ImPoPa[3]; - double ImOrPa[6]; - double Spacing[2]; - -}; - - - -class wxMaracasEmptyPanel_4: public wxPanel -{ -public: - wxMaracasEmptyPanel_4( wxWindow* parent); - ~wxMaracasEmptyPanel_4( ); - void ConfigureVTK(); -private: - - wxWidgetMesure2D *_widgetMesure1; - wxWidgetMesure2D *_widgetMesure2; - - - wxRadioButton *_rb1; - wxRadioButton *_rb2; - wxRadioButton *_rb3; - - struct InfoImag _infoImg1; - struct InfoImag _infoImg2; - - wxPanel *_panelImage1; - wxPanel *_panelImage2; - - vtkMPRBaseData *_vtkbasedata1; - vtkMPRBaseData *_vtkbasedata2; - - wxVtkMPR2DView *_wxvtk2Dbaseview1; - wxVtkMPR2DView *_wxvtk2Dbaseview2; - void ConfigureImage( char *fileName, wxPanel *panelImage, int ventana); - virtual void OnRefreshView(wxCommandEvent & event); - virtual void OnDClickLeft(wxCommandEvent & event); - - wxPanel* CreateControlPanel_Algo(wxWindow *parent); - wxPanel* CreateImagePanel(wxWindow *parent); - - - void TranformPixel1(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2); - void TranformPixel2(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2); - void TranformPixel3(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2); - void TranformPixel2a(int pIn[], int pOut[], struct InfoImag *infoImg1, struct InfoImag *infoImg2); - - - -DECLARE_EVENT_TABLE( ); - -}; - - - -#endif // __WX__MARACAS__EmptyPanel__3__HXX__ - -// EOF - wxMaracasEmptyPanel_3.h -- 2.47.1