Program: bbtk
Module: $RCSfile: bbwxInputText.cxx,v $
Language: C++
- Date: $Date: 2008/12/12 08:55:23 $
- Version: $Revision: 1.5 $
+ 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
{
-
-
-
-
-
+
//--------------------------------------------------------------------------
class InputTextWidget : wxPanel
{
~InputTextWidget();
std::string GetValue();
+ void SetValue(std::string value);
+
+ void OnTextEnter(wxCommandEvent& event);
void OnTextUpdate(wxCommandEvent& event);
void SetTitle(wxString);
//------------------------------------------------------------------------
//------------------------------------------------------------------------
-
-
-
InputTextWidget::InputTextWidget(InputText* box,
wxWindow *parent,
wxString In,
{
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();
}
//-------------------------------------------------------------------------
{
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_ADD_BLACK_BOX_TO_PACKAGE(wx, InputText);
+ 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() );
}
{
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_