X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fwx%2Fsrc%2FbbwxLayoutTab.cxx;h=9bdcdaa46ed7cafc3da42e61eaf7cd0585041435;hb=4d3619bf05342807aec39f571d94e4aea2efa38b;hp=3bdfda97a092498224c4e8f90619afe587698a15;hpb=e4149b56dda0cfb15427533e6f573f09cd3ff74b;p=bbtk.git diff --git a/packages/wx/src/bbwxLayoutTab.cxx b/packages/wx/src/bbwxLayoutTab.cxx index 3bdfda9..9bdcdaa 100644 --- a/packages/wx/src/bbwxLayoutTab.cxx +++ b/packages/wx/src/bbwxLayoutTab.cxx @@ -1,33 +1,38 @@ -/*========================================================================= +/* + # --------------------------------------------------------------------- + # + # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image + # pour la SantÈ) + # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton + # Previous Authors : Laurent Guigues, Jean-Pierre Roux + # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil + # + # This software is governed by the CeCILL-B license under French law and + # abiding by the rules of distribution of free software. You can use, + # modify and/ or redistribute the software under the terms of the CeCILL-B + # license as circulated by CEA, CNRS and INRIA at the following URL + # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html + # or in the file LICENSE.txt. + # + # As a counterpart to the access to the source code and rights to copy, + # modify and redistribute granted by the license, users are provided only + # with a limited warranty and the software's author, the holder of the + # economic rights, and the successive licensors have only limited + # liability. + # + # The fact that you are presently reading this means that you have had + # knowledge of the CeCILL-B license and that you accept its terms. + # ------------------------------------------------------------------------ */ + + +/*========================================================================= Program: bbtk Module: $RCSfile: bbwxLayoutTab.cxx,v $ Language: C++ - Date: $Date: 2008/11/24 15:45:51 $ - Version: $Revision: 1.7 $ + Date: $Date: 2012/11/16 08:52:14 $ + Version: $Revision: 1.12 $ =========================================================================*/ -/* --------------------------------------------------------------------- - -* Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale) -* Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux -* -* This software is governed by the CeCILL-B license under French law and -* abiding by the rules of distribution of free software. You can use, -* modify and/ or redistribute the software under the terms of the CeCILL-B -* license as circulated by CEA, CNRS and INRIA at the following URL -* http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html -* or in the file LICENSE.txt. -* -* As a counterpart to the access to the source code and rights to copy, -* modify and redistribute granted by the license, users are provided only -* with a limited warranty and the software's author, the holder of the -* economic rights, and the successive licensors have only limited -* liability. -* -* The fact that you are presently reading this means that you have had -* knowledge of the CeCILL-B license and that you accept its terms. -* ------------------------------------------------------------------------ */ - /** * \file * \brief @@ -40,7 +45,7 @@ #include "bbwxLayoutTab.h" #include "bbwxPackage.h" #include "bbtkUtilities.h" - +#include "bbtkBlackBoxInputConnector.h" @@ -51,8 +56,9 @@ namespace bbwx BBTK_BLACK_BOX_IMPLEMENTATION(LayoutTab,bbtk::WxBlackBox); - void LayoutTab::bbUserConstructor() - { + //----------------------------------------------------------------- + void LayoutTab::bbUserSetDefaultValues() + { bbSetInputOrientation("TOP"); bbSetInputWidget1(NULL); bbSetInputWidget2(NULL); @@ -64,63 +70,123 @@ namespace bbwx bbSetInputWidget8(NULL); bbSetInputWidget9(NULL); } -/* - void LayoutTab::TryInsertWindow(wxNotebook *book, wxWindow *widgetchild ) + + //----------------------------------------------------------------- + void LayoutTab::bbUserInitializeProcessing() { - if (widgetchild!=NULL) - { - widgetchild->Reparent(book); - book->AddPage(widgetchild, widgetchild->GetName() ); - widgetchild->Show(); - } } -*/ - - void LayoutTab::Process() - { + + //----------------------------------------------------------------- + void LayoutTab::bbUserFinalizeProcessing() + { } + + //----------------------------------------------------------------- + void LayoutTab::TryInsertWindow(wxNotebook *book, const std::string& input ) + { + wxWindow* w = bbCreateWidgetOfInput(input,book); //panel); + if (w!=NULL) + { + book->AddPage(w,w->GetName()); + } + } + + + void LayoutTab::SetTitleTabs() + { + + std::vector vecTitle; + std::vector vecInputNameWidget; + vecInputNameWidget.push_back("Widget1"); + vecInputNameWidget.push_back("Widget2"); + vecInputNameWidget.push_back("Widget3"); + vecInputNameWidget.push_back("Widget4"); + vecInputNameWidget.push_back("Widget5"); + vecInputNameWidget.push_back("Widget6"); + vecInputNameWidget.push_back("Widget7"); + vecInputNameWidget.push_back("Widget8"); + vecInputNameWidget.push_back("Widget9"); + int iWidget,sizeVecInputNameWidget= vecInputNameWidget.size(); + for (iWidget=0; iWidgetsecond ; + if ( c->IsConnected() ) + { + // Get black box from + BlackBox::Pointer from = c->GetConnection()->GetBlackBoxFrom(); + typename WidgetBlackBox::Pointer wfrom + = boost::dynamic_pointer_cast >(from); + vecTitle.push_back( wfrom->bbGetInputWinTitle() ); + } // if c + } // for iWidget + + + wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); + if (w!=NULL) + { + int i,size=vecTitle.size(); + for (i=0; iSetPageText(i, wxString( vecTitle[i].c_str(),wxConvUTF8 ) ); + } // for i + } //w + } - - void LayoutTab::CreateWidget(wxWindow* parent) - { - long style = wxNB_TOP; - if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"0|T|TOP")==true) { style=wxNB_TOP; } - if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"1|R|RIGHT")==true) { style=wxNB_RIGHT; } - if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"2|B|BOTTOM")==true) { 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() ) ); - /* - TryInsertWindow(w,bbGetInputWidget1()); - TryInsertWindow(w,bbGetInputWidget2()); - TryInsertWindow(w,bbGetInputWidget3()); - TryInsertWindow(w,bbGetInputWidget4()); - TryInsertWindow(w,bbGetInputWidget5()); - TryInsertWindow(w,bbGetInputWidget6()); - TryInsertWindow(w,bbGetInputWidget7()); - TryInsertWindow(w,bbGetInputWidget8()); - TryInsertWindow(w,bbGetInputWidget9()); -*/ - - bbSetOutputWidget( w ); - } - + void LayoutTab::Process() + { + PutWinTitle(); + SetTitleTabs(); + } + + + void LayoutTab::CreateWidget(wxWindow* parent) + { + long style = wxNB_TOP; + if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"0|T|TOP")==true) + { style=wxNB_TOP; } + if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"1|R|RIGHT")==true) + { style=wxNB_RIGHT; } + if (bbtk::Utilities::loosematch(bbGetInputOrientation(),"2|B|BOTTOM")==true) + { 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() ) ); + + TryInsertWindow(w,"Widget1"); + TryInsertWindow(w,"Widget2"); + TryInsertWindow(w,"Widget3"); + TryInsertWindow(w,"Widget4"); + TryInsertWindow(w,"Widget5"); + TryInsertWindow(w,"Widget6"); + TryInsertWindow(w,"Widget7"); + TryInsertWindow(w,"Widget8"); + TryInsertWindow(w,"Widget9"); + + bbSetOutputWidget( w ); + } + + // This callback is necessary to get actual processing of the view // when window is shown void LayoutTab::OnShowWidget() { - bbGetOutputWidget()->Show(); - bbUserOnShowWidget("Widget1"); - bbUserOnShowWidget("Widget2"); - bbUserOnShowWidget("Widget3"); - bbUserOnShowWidget("Widget4"); - bbUserOnShowWidget("Widget5"); - bbUserOnShowWidget("Widget6"); - bbUserOnShowWidget("Widget7"); - bbUserOnShowWidget("Widget8"); - bbUserOnShowWidget("Widget9"); + wxNotebook* w = (wxNotebook*)bbGetOutputWidget(); + if (w) + { + if (w->GetPageCount()>0) + { + w->SetSelection(0); + for (unsigned int i=0; iGetPageCount(); ++i) w->AdvanceSelection(); + } + } + + }