X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fwx%2Fsrc%2FbbwxLayoutTab.cxx;h=3655a772c23dd7c17ce0d47d8c245b300775d623;hb=aaa8070f20da168c0ef2f8aa94c30015386cd100;hp=639281af23eb74860925699de05a7eb992397e93;hpb=f1f889cb5984a875203fb13008977d8bcc740258;p=bbtk.git diff --git a/packages/wx/src/bbwxLayoutTab.cxx b/packages/wx/src/bbwxLayoutTab.cxx index 639281a..3655a77 100644 --- a/packages/wx/src/bbwxLayoutTab.cxx +++ b/packages/wx/src/bbwxLayoutTab.cxx @@ -51,9 +51,62 @@ namespace bbwx { - BBTK_ADD_BLACK_BOX_TO_PACKAGE(wx , LayoutTab); + + + //-------------------------------------------------------------------------- + class TabWidget : public wxPanel + { + public: + TabWidget(LayoutTab* box, wxWindow *parent, long style); + ~TabWidget(); + void OnTabChange( wxEvent& ); + wxNotebook* GetmwxNotebook(); + private: + LayoutTab *mBox; + wxNotebook *mwxNotebook; + }; + + + TabWidget::TabWidget(LayoutTab* box, + wxWindow *parent,long style ) + : wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL), + mBox(box) + { + wxPanel *panel = this; + mwxNotebook = new wxNotebook(panel, //bbGetWxParent(), + -1, + wxDefaultPosition, + wxDefaultSize, + style ); + Connect( mwxNotebook->GetId(), wxEVT_NOTEBOOK_PAGE_CHANGED , + (wxObjectEventFunction) + (void (wxPanel::*)(wxEvent&)) + &TabWidget::OnTabChange ); + wxBoxSizer *sizer = new wxBoxSizer(wxHORIZONTAL); + sizer -> Add( mwxNotebook,1,wxGROW,0 ); + panel -> SetSizer(sizer); + panel -> SetAutoLayout(true); + panel -> Layout(); + } + TabWidget::~TabWidget() + { + } + + void TabWidget::OnTabChange( wxEvent& ) + { + mBox->bbSetOutputSelection( mwxNotebook->GetSelection() ); + mBox->bbSignalOutputModification(); + } +wxNotebook* TabWidget::GetmwxNotebook() +{ + return mwxNotebook; +} + + + + BBTK_ADD_BLACK_BOX_TO_PACKAGE(wx , LayoutTab); BBTK_BLACK_BOX_IMPLEMENTATION(LayoutTab,bbtk::WxBlackBox); //----------------------------------------------------------------- @@ -84,17 +137,16 @@ namespace bbwx //----------------------------------------------------------------- void LayoutTab::TryInsertWindow(wxNotebook *book, const std::string& input ) { - wxWindow* w = bbCreateWidgetOfInput(input,book); //panel); + wxWindow* w = bbCreateWidgetOfInput(input,book); if (w!=NULL) { book->AddPage(w,w->GetName()); - } + } // if w } - void LayoutTab::SetTitleTabs() - { - +void LayoutTab::SetTitleTabs() +{ std::vector vecTitle; std::vector vecInputNameWidget; vecInputNameWidget.push_back("Widget1"); @@ -119,26 +171,29 @@ namespace bbwx } // if c } // for iWidget - - wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); - if (w!=NULL) +//EED2020-04-06 +// wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); + TabWidget *tabwidget=(TabWidget*)bbGetOutputWidget(); + if (tabwidget!=NULL) { - int i,size=vecTitle.size(); - for (i=0; iGetmwxNotebook(); + if (w!=NULL) { - w->SetPageText(i, wxString( vecTitle[i].c_str(),wxConvUTF8 ) ); - } // for i - } //w + int i,size=vecTitle.size(); + for (i=0; iSetPageText(i, wxString( vecTitle[i].c_str(),wxConvUTF8 ) ); + } // for i + } //w + } // if tabwidget } - void LayoutTab::Process() { PutWinTitle(); SetTitleTabs(); } - - + void LayoutTab::CreateWidget(wxWindow* parent) { long style = wxNB_TOP; @@ -150,13 +205,20 @@ namespace bbwx { style=wxNB_BOTTOM; } if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"3|L|LEFT")==true) { style=wxNB_LEFT; } - wxNotebook *w = new wxNotebook(parent, //bbGetWxParent(), - -1, - wxDefaultPosition, - wxDefaultSize, - style ); - w->SetName( bbtk::std2wx( bbGetInputWinTitle() ) ); - + +//EED2020-04-06 +// wxNotebook *w = new wxNotebook(parent, //bbGetWxParent(), +// -1, +// wxDefaultPosition, +// wxDefaultSize, +// style ); +// + TabWidget *tabwidget = new TabWidget (this, parent, style ); + tabwidget->SetName( bbtk::std2wx( bbGetInputWinTitle() ) ); + wxNotebook *w = tabwidget->GetmwxNotebook(); + +//EED2020-04-06 +// w->SetName( bbtk::std2wx( bbGetInputWinTitle() ) ); TryInsertWindow(w,"Widget1"); TryInsertWindow(w,"Widget2"); TryInsertWindow(w,"Widget3"); @@ -166,27 +228,32 @@ namespace bbwx TryInsertWindow(w,"Widget7"); TryInsertWindow(w,"Widget8"); TryInsertWindow(w,"Widget9"); - - bbSetOutputWidget( w ); + +//EED2020-04-06 +// bbSetOutputWidget( w ); + bbSetOutputWidget( tabwidget ); } - // This callback is necessary to get actual processing of the view - // when window is shown - void LayoutTab::OnShowWidget() - { - wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); - if (w) - { - if (w->GetPageCount()>0) - { - w->SetSelection(0); - for (unsigned int i=0; iGetPageCount(); ++i) w->AdvanceSelection(); - } - } - - - } + // This callback is necessary to get actual processing of the view +// when window is shown +void LayoutTab::OnShowWidget() +{ +//EED2020-04-06 +// wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); + wxNotebook* w = ((TabWidget*)bbGetOutputWidget())->GetmwxNotebook(); + if (w) + { + if (w->GetPageCount()>0) + { + w->SetSelection(0); + for (unsigned int i=0; iGetPageCount(); ++i) + { + w->AdvanceSelection(); + } // for + } // if PageCount + } // if w +} }//namespace bbwx