X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fwx%2Fsrc%2FbbwxLayoutSplit.cxx;h=94c0e48ae9d1745370ec49779b676f148b6c860c;hb=628ffd12c8c2b53346866015dae6603e37643be3;hp=6b554c932ca714dab292a95832426f4682d3d48b;hpb=6575a389b71b1b85c79e4444885becb76ecf16e4;p=bbtk.git diff --git a/packages/wx/src/bbwxLayoutSplit.cxx b/packages/wx/src/bbwxLayoutSplit.cxx index 6b554c9..94c0e48 100644 --- a/packages/wx/src/bbwxLayoutSplit.cxx +++ b/packages/wx/src/bbwxLayoutSplit.cxx @@ -2,8 +2,8 @@ Program: bbtk Module: $RCSfile: bbwxLayoutSplit.cxx,v $ Language: C++ - Date: $Date: 2008/10/17 08:18:32 $ - Version: $Revision: 1.5 $ + Date: $Date: 2010/04/08 14:38:00 $ + Version: $Revision: 1.13 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -46,21 +46,32 @@ namespace bbwx BBTK_ADD_BLACK_BOX_TO_PACKAGE(wx,LayoutSplit); BBTK_BLACK_BOX_IMPLEMENTATION(LayoutSplit,bbtk::WxBlackBox); - void LayoutSplit::bbUserConstructor() - { - bbSetInputOrientation("VERTICAL"); - bbSetInputProportion(50); - bbSetInputWidget1(NULL); - bbSetInputWidget2(NULL); - } - + //----------------------------------------------------------------- + void LayoutSplit::bbUserSetDefaultValues() + { + bbSetInputOrientation("VERTICAL"); + bbSetInputProportion(50); + bbSetInputWidget1(NULL); + bbSetInputWidget2(NULL); + } + + //----------------------------------------------------------------- + void LayoutSplit::bbUserInitializeProcessing() + { + } + + //----------------------------------------------------------------- + void LayoutSplit::bbUserFinalizeProcessing() + { + } + void LayoutSplit::Process() { } - void LayoutSplit::CreateWidget() + void LayoutSplit::CreateWidget(wxWindow* parent) { - wxSplitterWindow* w = new wxSplitterWindow(bbGetWxParent(), + wxSplitterWindow* w = new wxSplitterWindow(parent, //bbGetWxParent(), -1, wxDefaultPosition, wxDefaultSize, @@ -68,30 +79,51 @@ namespace bbwx wxSP_3D | wxSP_LIVE_UPDATE ); w->SetName( bbtk::std2wx( bbGetInputWinTitle() ) ); - wxWindow* w1 = bbGetInputWidget1(); + w->SetMinimumPaneSize(2); +/* + wxWindow* w1 = bbGetInputWidget1(); wxWindow* w2 = bbGetInputWidget2(); if (w1==NULL) { w1=new wxPanel(bbGetWxParent()); } if (w2==NULL) { w2=new wxPanel(bbGetWxParent()); } w1->Reparent(w); w2->Reparent(w); - int orientation=0; + */ + + wxWindow* w1 = bbCreateWidgetOfInput("Widget1",w); + wxWindow* w2 = bbCreateWidgetOfInput("Widget2",w); + if (w1==NULL) { w1=new wxPanel(parent); } + if (w2==NULL) { w2=new wxPanel(parent); } + + int orientation=0; if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"0|H|HORIZONTAL")==true) { orientation=0; } - if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"1|V|VERTICAL")==true) { orientation=1; } + if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"1|V|VERTICAL")==true) { orientation=1; } + if (orientation==1) { w->SplitHorizontally( w1, w2, 100); } else { w->SplitVertically( w1, w2, 100); } - + bbSetOutputWidget( w ); } // This callback is necessary to get actual processing of the view // when window is shown - void LayoutSplit::bbUserOnShow() + void LayoutSplit::OnShowWidget() { + // std::cout << "LayoutSplit::OnShowWidget()" << std::endl; + if (bbGetOutputWidget()==0) + { + return; + //bbtkError("LayoutSplit::OnShowWidget() : Output Widget == 0 !"); + } wxSplitterWindow* win = (wxSplitterWindow*)bbGetOutputWidget(); int w,h; + if (win==0) + { + return; + // bbtkError("LayoutSplit::OnShowWidget() : win == 0 !"); + } win->GetClientSize(&w,&h); int pos = 100; if (bbtk::Utilities::loosematch(bbGetInputOrientation(), @@ -103,10 +135,10 @@ namespace bbwx { pos = (int)(h * bbGetInputProportion() * 0.01); } + // std::cout << "pos = "<SetSashPosition(pos,true); - bbUserOnShowWidget("Widget1"); - bbUserOnShowWidget("Widget2"); + }