From 26f06d2da9f31bca99fe2266d5b7e5c38a00bdbb Mon Sep 17 00:00:00 2001 From: donadio Date: Tue, 14 Apr 2009 17:19:34 +0000 Subject: [PATCH] *** empty log message *** --- data/Icons/Threshold.png | Bin 0 -> 1457 bytes .../interfMainPanel.cxx | 3 - .../interfNewContourMenu.cxx | 7 +- .../interfNewContourMenu.h | 2 +- .../wxContourMainFrame.cxx | 64 +++++++++------- .../wxContourMainFrame.h | 11 ++- .../wxThresholdPanel.cxx | 40 ++++++++++ .../wxThresholdPanel.h | 70 ++++++++++++++++++ 8 files changed, 161 insertions(+), 36 deletions(-) create mode 100644 data/Icons/Threshold.png create mode 100644 lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.cxx create mode 100644 lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.h diff --git a/data/Icons/Threshold.png b/data/Icons/Threshold.png new file mode 100644 index 0000000000000000000000000000000000000000..cb6d36e03dfc32eb17857f22eb50393d2a8f66ac GIT binary patch literal 1457 zcmeIx|5MU;0LSsSnO|mkip)h;hITo%VL6klReniX(k&*LW^H9!T8L&kGQZ3mYNX8| z)^#1{6fepRMa`CGiOAP#iYapnJHc;+iX?DAf{1>0{=9!-kGto8@OsrG;*NQG_;~;T zJh2J!CjkJ#>$y7v0D6!KX#jwYmt#-F0?}SyfdIH#awPIGonj*0#2`_V)IUj*dT`J$v=)6_?BH?d|39 zcx3VjgE4vQ)*_8&U@)c_3{72~hQs-j#hT@C^j%$A9?vF~GWq-_xx5#GUI+vNp-?Ci ziNs=&SS*%EB>nyU0|Nt6sdR8~aA;^qCXnl|LZMVDRVvlQ#DrA(acF2w zsf2VonZYm$K?7E+3WA0qNCrV85Tu%#nwp-To|&0ZtJNBfW_ET~qgl{uwF?UiI-O3h z*BjPBcKfu$F#|ywheK~P8qH?2#bUNtEK5sER;$%$ge;ads}-`@tPo^@pe38lw!FM- zx7+OYWxL(JvJP@M9ILCV4hOWhwgy2E_}_nIMqXnB06w{vaOMX9Ho?|&D!-IQ2LQN{ zuqQBX3J)(&B$ATa^2PdBNSIVoQeGD6MtVUeNK7YOC57QIr;vpaVG(Hd+{|tOHh5#> zV^1CU_U?%FG(6VZ&6u!p+oK9k7zfz}gLyyjA%sdO=k`@JrUC(l1oIt+i@&~oX$^n5 zOTvAx|1w&s8eicW^ot*gk*`gP9*$Zbwo~c`uQVI9wbaMY=`>Z`&pg7KT4XvZtoc1+2q{)+^zZYj)1}Lk~#f{xE9kv zc>tbSH^}M`cz)J{@L3hU6fH)C3sba8c==P)OVLQ^Fe-c*KDQiv@`IW>S5{0fSC1+0 zOLqN5IB=_5Sr}9s6vf!wY<^1)rJt?o_HnI?b9-1{fkJG4Bq8pz<-4229u05E$9^8r z_{OnxojIFtXP2VSVusK5k7fl%yM7e-j{n~ECe39$3xUfGH!-T7M}@g0Wjon1m!bs9 z*KV1lLn|nspwZxjn!59e@)XYTN9rKi^LtSl_ngP&_P+@N*iXN{C|Q6?&Rq!4`D!;U zL9xs_#4afDb zfFDcZ8GS~*&Uz$mOVQgscbMm$_G9=szpXbzDW2O|s5?LLCe3EAz3*!7ux3_L1Nb)% a?zeh9p4Wb7s8;S-A0HNji*Gx6q2gbZ&VOM5 literal 0 HcmV?d00001 diff --git a/lib/Interface_Icons_NDimensions/interfMainPanel.cxx b/lib/Interface_Icons_NDimensions/interfMainPanel.cxx index 47f7637..4b8c16e 100644 --- a/lib/Interface_Icons_NDimensions/interfMainPanel.cxx +++ b/lib/Interface_Icons_NDimensions/interfMainPanel.cxx @@ -721,7 +721,6 @@ void interfMainPanel::onThresholdPressed() { if(thresholdShown) { - wxContourMainFrame::getInstance()->refLineHide(); thresholdShown=false; panelThreshold->onThresholdStop(); @@ -730,9 +729,7 @@ void interfMainPanel::onThresholdPressed() else if (!thresholdShown) { - wxContourMainFrame::getInstance()->refLineShow(); thresholdShown=true; - showPanel(thresholdPanel); } } diff --git a/lib/Interface_Icons_NDimensions/interfNewContourMenu.cxx b/lib/Interface_Icons_NDimensions/interfNewContourMenu.cxx index 697ed98..257fe8c 100644 --- a/lib/Interface_Icons_NDimensions/interfNewContourMenu.cxx +++ b/lib/Interface_Icons_NDimensions/interfNewContourMenu.cxx @@ -43,12 +43,12 @@ void interfNewContourMenu::initButtons(wxEvtHandler* evtHandler) { nom.push_back("Create a Line"); funct.push_back((wxObjectEventFunction) &interfNewContourMenu::onCreateContourLine); hand.push_back(this); - +/* path.push_back(datadir + "/Line.png"); nom.push_back("Create Points"); funct.push_back((wxObjectEventFunction) &interfNewContourMenu::onCreateContourPoints); hand.push_back(this); - +*/ this->addButtons(path, nom); this->setVectorFunction(funct); @@ -90,7 +90,8 @@ void interfNewContourMenu::onCreateContourCircle( wxCommandEvent& event ){ void interfNewContourMenu::onCreateContourLine( wxCommandEvent& event ){ interfMainPanel::getInstance()->onCreateContourLine(); } - +/* void interfNewContourMenu::onCreateContourPoints( wxCommandEvent& event ){ interfMainPanel::getInstance()->onCreateContourLine(); } +*/ \ No newline at end of file diff --git a/lib/Interface_Icons_NDimensions/interfNewContourMenu.h b/lib/Interface_Icons_NDimensions/interfNewContourMenu.h index 1a6364e..21c1b5a 100644 --- a/lib/Interface_Icons_NDimensions/interfNewContourMenu.h +++ b/lib/Interface_Icons_NDimensions/interfNewContourMenu.h @@ -46,7 +46,7 @@ private: **/ void onCreateContourLine( wxCommandEvent& event ); - void onCreateContourPoints( wxCommandEvent& event ); + //void onCreateContourPoints( wxCommandEvent& event ); }; diff --git a/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.cxx b/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.cxx index bb5f01f..d21f9a5 100644 --- a/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.cxx +++ b/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.cxx @@ -112,7 +112,7 @@ void wxContourMainFrame::setVectImages( std::vector images ){ std::vector conceptNameVect; std::vector conceptSizeVect; - wxAuiNotebook * notebook = this->createNotebook(); + notebook = this->createNotebook(); kernelManager = new KernelManagerContour( images , _datadir+"/data/" , strCreaContourDataTmp ); @@ -133,7 +133,7 @@ void wxContourMainFrame::setVectImages( std::vector images ){ //*******************changeInstant(); _theViewPanel->setVerticalConcept( "Axe Depth", data->getMinValue(), data->getMaxValue(), data->getMinShowedValue(), data->getMaxShowedValue(), data->getActualValue() ); - this->configurePanels( notebook ); + this->configurePanels( ); } @@ -199,47 +199,32 @@ void wxContourMainFrame::setVectImages( std::vector images ){ //------------------------------------------------------------------------------------------------------------ // Creational and initialization methods //------------------------------------------------------------------------------------------------------------ - bool wxContourMainFrame :: configurePanels(wxAuiNotebook* theNoteBook) + bool wxContourMainFrame :: configurePanels( ) { bool configured = _theViewPanel!=NULL; configured &= _theViewPanel!=NULL; if( _theViewPanel!=NULL ) { - theNoteBook->AddPage( _theViewPanel, wxT(" View ") ); + notebook->AddPage( _theViewPanel, wxT(" View ") ); m_mgr.Update(); } if( configured ) { - theNoteBook->AddPage( _instantPanel, wxT("Instant Page") ); + notebook->AddPage( _instantPanel, wxT("Instant Page") ); m_mgr.Update(); } - m_mgr.AddPane(theNoteBook, wxAuiPaneInfo().Name(wxT("notebook_content")).CenterPane().PaneBorder(false)); + m_mgr.AddPane(notebook, wxAuiPaneInfo().Name(wxT("notebook_content")).CenterPane().PaneBorder(false)); m_mgr.Update(); -/* configured &= _buttonsBar!=NULL; - if( _buttonsBar!=NULL ) - { - m_mgr.AddPane(_buttonsBar, wxAuiPaneInfo(). - Name(wxT("TB")).Caption(wxT("Buttons Bar")). - ToolbarPane().Top(). - LeftDockable( ).RightDockable( false ).CloseButton(false)); - m_mgr.Update(); - }*/ - //CreateStatusBar(); - + SetMinSize(wxSize(300,300)); m_mgr.Update(); return configured; } - void wxContourMainFrame :: setNotebook( wxAuiNotebook * noteBook ) - { - - } - //------------------------------------------------------------------------------------------------------------ // Attributes getters and setters //------------------------------------------------------------------------------------------------------------ @@ -1708,7 +1693,7 @@ void wxContourMainFrame::onThreshold(int minVal, int maxVal) //Lookup Table vtkLookupTable *lookup = vtkLookupTable::New(); - lookup->SetNumberOfTableValues(range[1]); + lookup->SetNumberOfTableValues(range[1]+1); lookup->SetTableRange(range); lookup->SetAlphaRange(0, 1); lookup->SetValueRange(0, 1); @@ -1716,9 +1701,12 @@ void wxContourMainFrame::onThreshold(int minVal, int maxVal) lookup->SetRampToLinear( ); + //Assign a fake color for the upper image, and set the white as transparent for(int i = range[0]; i < range[1]; i++) { + //std::cout<<"Int equal: " << i << std::endl; + if( i >= minVal && i <= maxVal ) { lookup->SetTableValue(i, 1.0, 0.0, 0.0, 1); @@ -1736,19 +1724,43 @@ void wxContourMainFrame::onThreshold(int minVal, int maxVal) lookup->Build( ); vtkImageMapToColors *mapperImage = vtkImageMapToColors::New( ); - mapperImage->SetInput( img ); mapperImage->SetLookupTable( lookup ); + mapperImage->SetInput( img ); + //mapperImage->SetOutputFormatToRGBA( ); vtkImageActor * upperImageActor = vtkImageActor::New( ); upperImageActor->SetInput( mapperImage->GetOutput() ); upperImageActor->SetOpacity( 1 ); - //viewer->SetInput( myImage ); viewer->GetRenderer()->AddActor( myActor );ACTOR!!! + vtkImageViewer2* viewer = vtkImageViewer2::New(); + viewer->SetInput( upperImageActor->GetInput() ); + viewer->SetColorLevel((range[1]-range[0])/2); + viewer->SetColorWindow(range[1]); + viewer->GetRenderer()->AddActor( upperImageActor ); + viewer->Render(); + + //wxThresholdPanel * panel = new wxThresholdPanel( viewer, notebook ); + + //onThresholdPanel(panel); + + RefreshInterface(); //baseImageActor = vtkImageActor::New( ); //baseImageActor->SetInput( mBox->bbGetInputImage1() ); +} - RefreshInterface(); + +bool wxContourMainFrame::onThresholdPanel(wxPanel* panel) + { + bool configured = panel!=NULL; + configured &= panel!=NULL; + + if( configured ) + { + notebook->AddPage( panel, wxT(" Threshold "), true ); + m_mgr.Update(); + } + return configured; } void wxContourMainFrame::showAxis(bool show) diff --git a/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.h b/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.h index 0bcb36c..981eb92 100644 --- a/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.h +++ b/lib/Interface_ManagerContour_NDimensions/wxContourMainFrame.h @@ -27,6 +27,7 @@ //#include "wxVtkBaseView_SceneManager.h" #include "wxInstantChooserPanel.h" #include "wxContourViewPanel.h" +#include "wxThresholdPanel.h" @@ -136,9 +137,7 @@ class wxContourMainFrame : public wxPanel { void setVectImages( std::vector images ); - bool configurePanels(wxAuiNotebook * theNoteBook ); - - void setNotebook( wxAuiNotebook * theNoteBook ); + bool configurePanels( ); wxAuiNotebook * createNotebook(); @@ -262,6 +261,10 @@ class wxContourMainFrame : public wxPanel { void onThreshold(int minVal, int maxVal); + bool onThresholdPanel(wxPanel* panel); + +//==================================================================================================== + void showAxis(bool show); void onRigidPressed(); @@ -336,6 +339,8 @@ private: wxArrayString m_perspectives; wxMenu* m_perspectives_menu; */ + + wxAuiNotebook * notebook; long m_notebook_style; long m_notebook_theme; int _numberOfVariablesStatistics; diff --git a/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.cxx b/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.cxx new file mode 100644 index 0000000..9914cee --- /dev/null +++ b/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.cxx @@ -0,0 +1,40 @@ +//---------------------------------------------------------------------------------------------------------------- +// Class definition include +//---------------------------------------------------------------------------------------------------------------- +#include "wxThresholdPanel.h" + + +//---------------------------------------------------------------------------------------------------------------- +// Other includes +//---------------------------------------------------------------------------------------------------------------- + + //------------------------------------------------------------------------------------------------------------ + // Constructors & Destructors + //------------------------------------------------------------------------------------------------------------ + + wxThresholdPanel :: wxThresholdPanel ( vtkImageViewer2 * theViewer, wxWindow *parent, const wxPoint& pos, const wxSize& size,long style, int vertStart, int vertEnd, int horzStart, int horzEnd ) + :wxPanel(parent, -1, pos, size, style) + { + //wxBoxSizer *topsizer = new wxBoxSizer(wxVERTICAL); + + vtkRenderWindowInteractor *iren = vtkRenderWindowInteractor::New(); + theViewer->SetupInteractor(iren); + + //crea::creawxVTKRenderWindowInteractor * mInteractor = new crea::creawxVTKRenderWindowInteractor(this,-1); + //mInteractor->UseCaptureMouseOn(); + //theViewer->SetupInteractor ( mInteractor ); + + //theViewer->Render(); + //theViewer->GetRenderer()->ResetCamera(); + + //topsizer-> Add( iren ,1,wxGROW ,0); + SetAutoLayout( true ); + //SetSizer( topsizer ); + Layout(); + } + + + wxThresholdPanel :: ~wxThresholdPanel() + { + + } \ No newline at end of file diff --git a/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.h b/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.h new file mode 100644 index 0000000..4815a25 --- /dev/null +++ b/lib/Interface_ManagerContour_NDimensions/wxThresholdPanel.h @@ -0,0 +1,70 @@ +#ifndef __wxThresholdPanel_INCLUDED_H__ +#define __wxThresholdPanel_INCLUDED_H__ + + +// ----------------------------------------------------------------------------------------------------------- +// WX headers inclusion. +// For compilers that support precompilation, includes . +// ----------------------------------------------------------------------------------------------------------- + +#include +#ifdef __BORLANDC__ +#pragma hdrstop +#endif +#ifndef WX_PRECOMP +#include +#endif + + +//------------------------------------------------------------------------------------------------------------ +// Includes +//------------------------------------------------------------------------------------------------------------ + +#include "creawxVTKRenderWindowInteractor.h" +#include "vtkImageViewer2.h" +#include "vtkRenderWindowInteractor.h" + +//------------------------------------------------------------------------------------------------------------ +// Class definition +//------------------------------------------------------------------------------------------------------------ + +class wxThresholdPanel : public wxPanel +{ +public: + + //------------------------------------------------------------------------------------------------------------ + // Constructors & Destructors + //------------------------------------------------------------------------------------------------------------ + + wxThresholdPanel( vtkImageViewer2 * theViewer, wxWindow *parent, const wxPoint& pos=wxDefaultPosition, const wxSize& size = wxDefaultSize,long style= wxDEFAULT_FRAME_STYLE | wxSUNKEN_BORDER, int vertStart=1, int vertEnd=1, int horzStart=1, int horzEnd=1 ); + + ~wxThresholdPanel(); + + //------------------------------------------------------------------------------------------------------------ + // Creational and initialization methods + //------------------------------------------------------------------------------------------------------------ + + + //------------------------------------------------------------------------------------------------------------ + // Methods for capturing events from the horizontal bar + //------------------------------------------------------------------------------------------------------------ + + + + //------------------------------------------------------------------------------------------------------------ + // Other functional methods + //------------------------------------------------------------------------------------------------------------ + + + + //------------------------------------------------------------------------------------------------------------ + // Attributtes + //------------------------------------------------------------------------------------------------------------ +private: + + //------------------------------------------------------------------------------------------------------------ + // Private methods + //------------------------------------------------------------------------------------------------------------ + +}; +#endif -- 2.47.1