X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkKWBlackBox.cxx;h=11f2c32552d81d7c89794ed92cb437f70a3529b5;hb=1688b52778caa9985ecea38aad38341817e0401a;hp=6994d8bcc5386662726e619c0ff308762a0f8fb3;hpb=bfd7e9034cbfd9c535e98ccb302c08e5e42da8c6;p=bbtk.git diff --git a/kernel/src/bbtkKWBlackBox.cxx b/kernel/src/bbtkKWBlackBox.cxx index 6994d8b..11f2c32 100644 --- a/kernel/src/bbtkKWBlackBox.cxx +++ b/kernel/src/bbtkKWBlackBox.cxx @@ -2,8 +2,8 @@ Program: bbtk Module: $RCSfile: bbtkKWBlackBox.cxx,v $ Language: C++ - Date: $Date: 2008/12/11 09:50:35 $ - Version: $Revision: 1.7 $ + Date: $Date: 2010/01/14 13:17:27 $ + Version: $Revision: 1.10 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -34,18 +34,12 @@ #ifdef USE_KWWIDGETS - - - - #include "bbtkKWBlackBox.h" #include "bbtkBlackBoxOutputConnector.h" #include "vtkKWBlackBoxDialog.h" - namespace bbtk { - //========================================================================= // KWBlackBox //========================================================================= @@ -54,166 +48,48 @@ namespace bbtk //========================================================================= //========================================================================= //========================================================================= - BBTK_BLACK_BOX_IMPLEMENTATION(KWBlackBox,AtomicBlackBox); + BBTK_BLACK_BOX_IMPLEMENTATION(KWBlackBox,WidgetBlackBox); //========================================================================= - //========================================================================= - void KWBlackBox::bbUserConstructor() - { - bbtkDebugMessage("Kernel",9,"KWBlackBox::bbUserConstructor()"< KWBlackBox::bbUserDestructor() ["<bbClose(); - bbSetWindow(0); - } - bbtkDebugMessage("kw",9,"<== KWBlackBox::bbUserDestructor() ["<bbSetBlackBox( GetThisPointer()); + KW::GetApplication()->AddWindow((vtkKWWindowBase*)win); + win->Create(); + win->SetResizable(0,0); + + bbUserCreateWidget(win->GetFrame()); + /* + KW::GetApplication()->Script + ("pack %s -expand yes -fill both", + bbGetOutputWidget()->GetWidgetName()); + */ + + KW::GetApplication()->Script("place %s -x 0 -y 0 -width %d -height %d", + bbGetOutputWidget()->GetWidgetName(), + bbGetInputWinWidth(), + bbGetInputWinHeight()); } - //========================================================================= - + //================================================================== - - //========================================================================= - /** - * \brief Initialize the attributes of the class - * - */ - void KWBlackBox::bbInitAttributes() + //================================================================== + /// Callback for creating a Frame window + void WxBlackBox::bbCreateFrameWindow() { - bbmWindow = 0; - // bbmWidget = 0; - // bbSetInputWinParent(0); - bbSetInputWinTitle(bbGetName()); - bbSetInputWinWidth(800); - bbSetInputWinHeight(800); - bbSetInputWinDialog(false); - bbSetOutputWidget(0); - - // bbSetWidgetEventHandler(0); - // bbSetUpdateTransferedToParent(false); + bbtkWarning("KW: Frame windows not supported: creating a Dialog!"); + bbCreateDialogWindow(); } - //========================================================================= - - - //========================================================================= - void KWBlackBox::bbProcess() - { - - this->bbUserProcess(); - - // If output widget not connected create the window - if ( (*bbGetOutputConnectorMap().find("Widget")).second - ->GetConnectionVector().size() == 0 ) - { - Window* show = 0; - // If the window already exists : no need creating it - if (bbGetWindow()!=0) - { - bbtkDebugMessage("kw",2, - "-> Window already exists" - < Creating the window" - <bbSetBlackBox( GetThisPointer()); - KW::GetApplication()->AddWindow((vtkKWWindowBase*)win); - win->Create(); - win->SetResizable(0,0); - - bbUserCreateWidget(win->GetFrame()); - KW::GetApplication()->Script("place %s -x 0 -y 0 -width %d -height %d", - bbGetOutputWidget()->GetWidgetName(), - bbGetInputWinWidth(), - bbGetInputWinHeight()); - - - - + //================================================================== - /* - bbGetOutputWidget()->SetParent(win); - bbGetOutputWidget()->Create(); - KW::GetApplication()->Script("pack %s -side left -anchor c -expand y", - - //"pack %s -side top -anchor nw -expand y -fill none -padx 2 -pady 2", - bbGetOutputWidget()->GetWidgetName()); - */ - /* - } - - // Input WinDialog set to false : creating a Frame - else - { - bbtkDebugMessage("process",2, - " Input WinDialog set to false : creating a Frame" - <bbSetBlackBox( GetThisPointer()); - // win->SetName( bbGetInputWinTitle() + " - bbtk (c) CREATIS LRMN" ); - // win->SetWidth( bbGetInputWinWidth() ); - // win->SetHeight( bbGetInputWinHeight() ); - KW::GetApplication()->AddWindow((vtkKWWindowBase*)win); - win->Create(); - - bbGetOutputWidget()->SetParent(win); - bbGetOutputWidget()->Create(); - KW::GetApplication()->Script("pack %s -side top -anchor nw -expand y -fill none -padx 2 -pady 2", - bbGetOutputWidget()->GetWidgetName()); } - */ - - // win->Invoke(); - } - - // Show the window - - show->bbShow(); - // std::cout << "KW::GetApplication()->Start();"<Start(); - // std::cout << "AFTER KW::GetApplication()->Start();"< KWBlackBox::bbHideWindow() [" - <bbHide(); - - bbtkDebugMessageDec("kw",2,"<= KWBlackBox::bbHideWindow() [" - < KWBlackBox::bbCloseWindow() [" - <bbClose(); - - bbtkDebugMessageDec("kw",2,"<= KWBlackBox::bbCloseWindow() [" - <second->GetConnectionVector().size() != 0 ) - { - return boost::static_pointer_cast - (i->second->GetConnectionVector().front() //.lock() - ->GetBlackBoxTo())->bbGetContainingWindow(); - } - return 0; - } - //================================================================== - - - //================================================================== - bool KWBlackBox::bbIsShown() - { - if (bbGetContainingWindow()!=0) - return bbGetContainingWindow()->bbIsShown(); - return false; - } + // void KWBlackBox::InitWindowManagerIfNeeded() { KW:: + void KWBlackBox::IncNbWindowsAlive() { KW::IncNbWindowsAlive(); } + void KWBlackBox::DecNbWindowsAlive() { KW::DecNbWindowsAlive(); } + int KWBlackBox::GetNbWindowsAlive() { return KW::GetNbWindowsAlive(); } + bool KWBlackBox::IsSomeWindowAlive() { return KW::IsSomeWindowAlive(); } + + void KWBlackBox::IncNbWindowsShown() { KW::IncNbWindowsShown(); } + void KWBlackBox::DecNbWindowsShown() { KW::DecNbWindowsShown(); } + int KWBlackBox::GetNbWindowsShown() { return KW::GetNbWindowsShown(); } + bool KWBlackBox::IsSomeWindowShown() { return KW::GetNbWindowsShown(); } //================================================================== - - + }//namespace bbtk - #endif