X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkKWBlackBox.cxx;h=6994d8bcc5386662726e619c0ff308762a0f8fb3;hb=69437e387d771c8fb0b43994dc550e725811b4c3;hp=501ebef7d2707b894d53ac9e78d9fb09e9511d29;hpb=ba1cc70dcdd708b3de57e6e41b3263c1baa5ea58;p=bbtk.git diff --git a/kernel/src/bbtkKWBlackBox.cxx b/kernel/src/bbtkKWBlackBox.cxx index 501ebef..6994d8b 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/02 10:21:40 $ - Version: $Revision: 1.3 $ + Date: $Date: 2008/12/11 09:50:35 $ + Version: $Revision: 1.7 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -39,70 +39,13 @@ #include "bbtkKWBlackBox.h" +#include "bbtkBlackBoxOutputConnector.h" #include "vtkKWBlackBoxDialog.h" namespace bbtk { - - - /* - //========================================================================= - // KWBlackBoxWidgetEventHandler - //========================================================================= - - //========================================================================= - KWBlackBoxWidgetEventHandler:: - KWBlackBoxWidgetEventHandler( KWBlackBox::Pointer box, - vtkKWWidget *widget ) - : - mBox(box), - mWindow(widget) - { - bbtkDebugMessage("kw",9,"KWBlackBoxWidgetEventHandler::KWBlackBoxWidgetEventHandler("<bbGetFullName()<<")"<bbSetWidgetEventHandler(this); - - Connect ( mWindow->GetId(), - kwEVT_DESTROY, - (kwObjectEventFunction) - (void (kwEvtHandler::*)(kwWindowDestroyEvent& c)) - &KWBlackBoxWidgetEventHandler::OnWindowDestroy ); - - mWindow->PushEventHandler(this); - - } - //========================================================================= - - //========================================================================= - KWBlackBoxWidgetEventHandler::~KWBlackBoxWidgetEventHandler() - { - if (mBox.expired()) return; - bbtkDebugMessage("kw",9, - "KWBlackBoxWidgetEventHandler::~KWBlackBoxWidgetEventHandler() [" - <bbGetFullName()<<"]"<bbSetWidgetEventHandler(0); - } - //========================================================================= - - //========================================================================= - void KWBlackBoxWidgetEventHandler::OnWindowDestroy(kwWindowDestroyEvent&) - { - if (mBox.expired()) return; - bbtkDebugMessage("kw",9,"KWBlackBoxWidgetEventHandler::OnWindowDestroy() [" - <bbGetFullName()<<"]"<bbSetOutputWidget(0); - mBox.lock()->bbSetModifiedStatus(); - } - //========================================================================= - - - */ - - - - //========================================================================= // KWBlackBox //========================================================================= @@ -163,155 +106,15 @@ namespace bbtk bbSetOutputWidget(0); // bbSetWidgetEventHandler(0); - bbSetUpdateTransferedToParent(false); - } - //========================================================================= - - //========================================================================= - /// Main processing method of the box. - void KWBlackBox::bbExecute(bool force) - { - bbtkDebugMessageInc("process",2, - "=> KWBlackBox::bbExecute("<<(int)force<<") [" - <second->GetConnectionVector().size() != 0 ) - { - bbtkDebugMessage("process",3, - "-> Output 'Widget' connected : transfering execution to parent" - <second->GetConnectionVector().front() //.lock() - ->GetBlackBoxTo()->bbExecute(force); - - } - // else call 'standard' BlackBox execution method - else - { - BlackBox::bbExecute(force); - } - // - - bbtkDebugMessageDec("process",2, - "<= KWBlackBox::bbExecute() [" - < KWBlackBox::bbBackwardUpdate(" - <<(caller?caller->GetFullName():"0")<<") [" - <GetFullName():"0")<<") [" - <second->GetConnectionVector().size() != 0 ) - - { - BlackBox::Pointer to = - i->second->GetConnectionVector()[0]->GetBlackBoxTo(); - - if (caller) - { - bbtkDebugMessage("process",3, - "-> Output 'Widget' connected to '" - <bbGetFullName()<<"' - caller->to = '" - <GetBlackBoxTo()->bbGetFullName() - <<"'" - < Output 'Widget' connected to '" - <bbGetFullName()<<"'" - <GetBlackBoxTo() != to)&& - (!bbGetUpdateTransferedToParent())&& - (!to->bbGetExecuting()) - ) - ) - { - bbtkDebugMessage("process",3, - " ... Transfering update order to parent" - <second->GetConnectionVector().front() //.lock() - ->GetBlackBoxTo()->bbExecute(false); - } - else - { - bbSetUpdateTransferedToParent(false); - bbtkDebugMessage("process",3, - " ... No need to transfer to parent" - <GetBlackBoxFromOutput()!="Widget")) - ) - { - } - */ - // call 'standard' BlackBox execution method - if (!bbGetUpdateTransferedToParent()) - { - AtomicBlackBox::bbBackwardUpdate(caller); - } - - bbtkDebugMessageDec("process",3, - "<= KWBlackBox::bbBackwardUpdate() [" - <bbUserCreateWidget(); - this->bbUserProcess(); - bbShowWindow(); - // this->bbUserOnShow(); -*/ + this->bbUserProcess(); // If output widget not connected create the window @@ -349,12 +152,16 @@ namespace bbtk KW::GetApplication()->AddWindow((vtkKWWindowBase*)win); win->Create(); win->SetResizable(0,0); - bbUserCreateWidget(win->GetFrame()); + bbUserCreateWidget(win->GetFrame()); KW::GetApplication()->Script("place %s -x 0 -y 0 -width %d -height %d", bbGetOutputWidget()->GetWidgetName(), bbGetInputWinWidth(), bbGetInputWinHeight()); + + + + /* bbGetOutputWidget()->SetParent(win); @@ -404,47 +211,9 @@ namespace bbtk } //========================================================================= - - /* - // LG 24/11/08 : New widget pipeline - void KWBlackBox::bbCreateWidgetAndEventHandler(vtkKWWidget* parent) - { - if (bbGetOutputWidget()==0) - { - this->bbUserCreateWidget(parent); - } - - // If Event Handler for the widget does not exist or is obsolete : create it - - if (bbGetOutputWidget()!=0) - { - if (bbGetWidgetEventHandler()==0) - { - bbtkDebugMessage("kw",3, - "-> No widget event handler : creating one" - <(), - bbGetOutputWidget()); - } - else if ( ! bbGetWidgetEventHandler()->IsHandlerOf - ( bbGetOutputWidget() ) ) - { - bbtkDebugMessage("kw",3, - "-> Obsolete widget event handler : re-creating one" - <(), - bbGetOutputWidget()); - } - // Sets the name of the vtkKWWidget to the input WinTitle - bbGetOutputWidget()->SetName(bbtk::std2kw(bbGetInputWinTitle())); - } - - } - - */ - - vtkKWWidget* KWBlackBox::bbCreateWidgetOfInput(const std::string& in, vtkKWWidget* parent) + + //================================================================== + vtkKWWidget* KWBlackBox::bbCreateWidgetOfInput(const std::string& in, vtkKWFrame* parent) { vtkKWWidget* w = 0; // If input is connected @@ -463,128 +232,7 @@ namespace bbtk } return w; } - - -/* - //================================================================== - /// Specific methods for window creation during pipeline execution - /// Shows the window associated to the box - /// (called after bbProcess during bbExecute) - void KWBlackBox::bbShowWindow() - { - bbtkDebugMessageInc("kw",1,"=> KWBlackBox::bbShowWindow() [" - < No widget event handler : creating one" - <(), - bbGetOutputWidget()); - } - else if ( ! bbGetWidgetEventHandler()->IsHandlerOf - ( bbGetOutputWidget() ) ) - { - bbtkDebugMessage("kw",3, - "-> Obsolete widget event handler : re-creating one" - <(), - bbGetOutputWidget()); - } - // Sets the name of the vtkKWWidget to the input WinTitle - bbGetOutputWidget()->SetName(bbtk::std2kw(bbGetInputWinTitle())); - } - - // If the output 'Widget' is connected then it's gonna - // be captured by its parent window : nothing to do - if ( (*bbGetOutputConnectorMap().find("Widget")).second - ->GetConnectionVector().size() != 0 ) - { - - bbtkDebugMessage("kw",2, - "-> Output 'Widget' connected : nothing to do" - < Window already exists" - < Widget exists : creating the window" - <(), - // bbGetKWParent(), - // LG 24/11/08 : New widget pipeline - KW::GetTopWindow(), - std2kw( bbGetInputWinTitle() + " - bbtk (c) CREATIS LRMN"), - kwSize( bbGetInputWinWidth() , bbGetInputWinHeight() ) ); - } - // Input WinDialog set to false : creating a Frame - else - { - bbtkDebugMessage("process",2, - " Input WinDialog set to false : creating a Frame" - <(), - // bbGetKWParent(), - // LG 24/11/08 : New widget pipeline - KW::GetTopWindow(), - std2kw( bbGetInputWinTitle() + " - bbtk (c) CREATIS LRMN"), - kwSize( bbGetInputWinWidth() , bbGetInputWinHeight() ) ); - } - - } - // No window nor widget : error - else - { - bbtkError("KWBlackBox::bbShowWindow() [" - <IsShown()) - { - show->bbShow(); - } - else - { - bbtkDebugMessage("kw",2,"-> Already shown : nothing to do"<