]> Creatis software - bbtk.git/blobdiff - packages/wx/src/bbwxInputText.cxx
no message
[bbtk.git] / packages / wx / src / bbwxInputText.cxx
index 49559feb696beccec36381a417df4a794c4916f1..66058c39062b91b7dfaa87d00eaa4beb6b34e020 100644 (file)
@@ -2,8 +2,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbwxInputText.cxx,v $
   Language:  C++
-  Date:      $Date: 2008/11/24 15:45:51 $
-  Version:   $Revision: 1.4 $
+  Date:      $Date: 2011/07/22 12:30:31 $
+  Version:   $Revision: 1.12 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
  *  \brief 
  */
 
-
 #ifdef _USE_WXWIDGETS_
 
-
 #include "bbwxInputText.h"
 #include "bbwxPackage.h"
 //#include <wx/dialog.h>
 
 
-       
-
-
 namespace bbwx
 {
-  BBTK_ADD_BLACK_BOX_TO_PACKAGE(wx,InputText);
-  
+  //--------------------------------------------------------------------------
+  class InputTextWidget : wxPanel
+  {
+  public:
+    InputTextWidget(InputText* box, wxWindow *parent,
+                   wxString In, wxString title);
+    ~InputTextWidget();
+
+    std::string GetValue();
+       void SetValue(std::string value);
+
+    void OnTextEnter(wxCommandEvent& event);
+    void OnTextUpdate(wxCommandEvent& event);
+
+    void SetTitle(wxString);
+
+  private:
+    InputText    *mBox;
+    wxTextCtrl  *mwxTextCtrl;
+    wxStaticText *mwxTitle;
+  };
   
+  //------------------------------------------------------------------------
+  //------------------------------------------------------------------------
+  //------------------------------------------------------------------------
+
   InputTextWidget::InputTextWidget(InputText* box,
                                   wxWindow *parent, 
                                   wxString In, 
@@ -59,30 +78,31 @@ namespace bbwx
   {
     wxPanel                    *panel  = this;
     
-    mwxTextCtrl = new wxTextCtrl( panel, -1, In,
-                                 wxDefaultPosition, wxSize(800,20));
+    mwxTextCtrl = new wxTextCtrl( panel, -1, In,wxDefaultPosition, wxSize(800,20),wxTE_PROCESS_ENTER);
+    Connect( mwxTextCtrl->GetId(),  wxEVT_COMMAND_TEXT_ENTER, 
+            (wxObjectEventFunction) 
+            (wxEventFunction)
+            (wxCommandEventFunction) 
+            (void (wxPanel::*)(wxCommandEvent&))
+            &InputTextWidget::OnTextEnter ); 
+
     Connect( mwxTextCtrl->GetId(),  wxEVT_COMMAND_TEXT_UPDATED, 
             (wxObjectEventFunction) 
             (wxEventFunction)
             (wxCommandEventFunction) 
             (void (wxPanel::*)(wxCommandEvent&))
             &InputTextWidget::OnTextUpdate ); 
-    
-    
+
+
     wxFlexGridSizer *sizer     = new wxFlexGridSizer(1);
-    /*
-      if (title!=_T(""))
-      {
-    */
-    mwxTitle = new wxStaticText(panel,-1, title ); 
-    sizer      -> Add( mwxTitle ); 
-    //   }
-    sizer      -> Add( mwxTextCtrl,1,wxGROW ); 
-    sizer      -> AddGrowableCol(0);
+    mwxTitle = new wxStaticText(panel, -1, title ); 
+    sizer-> Add( mwxTitle ); 
+    sizer-> Add( mwxTextCtrl, 1, wxGROW ); 
+    sizer-> AddGrowableCol(0);
     
-    panel      -> SetSizer(sizer);
-    panel      -> SetAutoLayout(true);
-    panel      -> Layout();
+    panel-> SetSizer(sizer);
+    panel-> SetAutoLayout(true);
+    panel-> Layout();
 
   }
   //-------------------------------------------------------------------------
@@ -104,42 +124,79 @@ namespace bbwx
   { 
     return bbtk::wx2std ( mwxTextCtrl->GetValue() );
   }
-
+       
+  void InputTextWidget::SetValue(std::string value)
+  { 
+       mwxTextCtrl->SetValue( bbtk::std2wx(value) ) ;
+  }
+       
   //--------------------------------------------------------------------------
   void InputTextWidget::OnTextUpdate(wxCommandEvent& event)
   {
-    mBox->bbSetOutputOut( GetValue() );
-    mBox->bbSetInputIn( GetValue() );
-    mBox->bbSignalOutputModification("Out");
+       if (mBox->bbGetInputReactiveOnKeystroke()==2){
+           mBox->bbSetOutputOut( GetValue() );
+           mBox->bbSetInputIn( GetValue() );
+           mBox->bbSignalOutputModification("Out");
+       }
   }
 
+  //--------------------------------------------------------------------------
+  void InputTextWidget::OnTextEnter(wxCommandEvent& event)
+  {
+       if (mBox->bbGetInputReactiveOnKeystroke()==1){
+           mBox->bbSetOutputOut( GetValue() );
+               mBox->bbSetInputIn( GetValue() );
+               mBox->bbSignalOutputModification("Out");
+       }
+  }
+
+
   //--------------------------------------------------------------------------
   //-------------------------------------------------------------------------
   //--------------------------------------------------------------------------
   //--------------------------------------------------------------------------
 
+  BBTK_ADD_BLACK_BOX_TO_PACKAGE(wx, InputText);
+  BBTK_BLACK_BOX_IMPLEMENTATION(InputText, bbtk::WxBlackBox);
 
-  BBTK_BLACK_BOX_IMPLEMENTATION(InputText,bbtk::WxBlackBox);
-
-
-
-  void InputText::bbUserConstructor() 
-  { 
-    bbSetInputTitle("");
-    bbSetInputIn("");
-         bbSetOutputWidget(0);
-  }
   
+       //-----------------------------------------------------------------     
+       void InputText::bbUserSetDefaultValues()
+       {
+               firsttime=true;
+               bbSetInputTitle("");
+               bbSetInputIn("");
+               bbSetOutputWidget(0);
+               bbSetInputReactiveOnKeystroke(2);
+       }
+       
+       //-----------------------------------------------------------------     
+       void InputText::bbUserInitializeProcessing()
+       {
+       }
+       
+       //-----------------------------------------------------------------     
+       void InputText::bbUserFinalizeProcessing()
+       {
+       }
 
+       
+       //-----------------------------------------------------------------     
   void InputText::Process() 
   { 
     InputTextWidget *w=(InputTextWidget *)bbGetOutputWidget();
        if (w) 
        {
-               bbSetInputIn( w->GetValue() );
+               if (firsttime==true)
+               {
+                       firsttime=false;
+                       w->SetValue(  bbGetInputIn().c_str() );
+               }
                w->SetTitle( bbtk::std2wx ( bbGetInputTitle() ) );
+               bbSetOutputOut( w->GetValue() );
+       } else {
+         bbSetOutputOut( "<VOID>" );
        }
-       bbSetOutputOut( bbGetInputIn() );
   }
   
 
@@ -148,15 +205,11 @@ namespace bbwx
   {
     bbSetOutputWidget
       ( (wxWindow*) new InputTextWidget(this, //bbGetWxParent(),
-                                                                               parent,
-                                                                               bbtk::std2wx ( bbGetInputIn() ) , 
-                                                                               bbtk::std2wx ( bbGetInputTitle() ) ) );
-       
+                                       parent,
+                                       bbtk::std2wx ( bbGetInputIn() ) , 
+                                       bbtk::std2wx ( bbGetInputTitle() ) ) ); 
   }
 
-
-
-
 }//namespace bbtk
 
 #endif // _USE_WXWIDGETS_