]> Creatis software - bbtk.git/blobdiff - packages/wx/src/bbwxComboBox.cxx
#3043 BBTK Bug New Normal - FilesFromDirectoryBox missing directories AND Refresh...
[bbtk.git] / packages / wx / src / bbwxComboBox.cxx
index 234a0e6c2444949c38f7fa14a22ec1b3207661f0..051cfea7f811e319419dd19f680f106263040d0f 100644 (file)
@@ -20,22 +20,20 @@ namespace bbwx
   {
   public:
        ComboBoxWidget( ComboBox* box, wxWindow *parent, 
-                      int iSelection, 
-                      std::string title, 
-                      std::vector< std::string > lstIn, 
-                                                        int typeForm );
-
+                    int iSelection, 
+                    std::string title, 
+                    std::vector< std::string > lstIn, 
+                                       int typeForm );
        ~ComboBoxWidget();
-
+       void OnComboBox(int iSelection);
        void OnComboBox(wxEvent& event);
        void FillItems( int iSelection, std::vector< std::string > lstIn);
 
-
   private:
-    int                                mTypeForm;
+    int                        mTypeForm;
     ComboBox           *mBox;
-        wxListBox              *wxlistbox;
-        wxChoice               *wxchoice;
+       wxListBox               *wxlistbox;
+       wxChoice                *wxchoice;
   };
   
 
@@ -56,12 +54,10 @@ namespace bbwx
     mBox(box),
     mTypeForm(typeForm)
   {
-   wxPanel     *panel          = this;
+       wxPanel         *panel          = this;
        wxlistbox                               = NULL;
-       wxchoice                                        = NULL;
-   int i;
-
-
+       wxchoice                                = NULL;
+       int i;
 
     //---------------------------------------------------------------------
     // 2) Insertion of the components in the window
@@ -74,8 +70,7 @@ namespace bbwx
     }
     sizer->AddGrowableCol(0);
     panel->SetSizer(sizer);
-
-   
+               
     //---------------------------------------------------------------------
     // 1) Creation de wxChoise widget
 
@@ -102,11 +97,8 @@ namespace bbwx
                wxchoice->SetSelection(iSelection);
                   sizer->Add( wxchoice,1,wxGROW ); 
                }
-
-
 //    panel->SetAutoLayout(true);
 //    panel->Layout();
-
   }
   //-------------------------------------------------------------------------
   
@@ -114,6 +106,17 @@ namespace bbwx
   {
   }
 
+
+  //--------------------------------------------------------------------------
+  void ComboBoxWidget::OnComboBox(int iSelection)
+  {
+    mBox->bbSetInputSelection( iSelection );
+    mBox->bbSetOutputOut( iSelection );
+    mBox->bbSetOutputOutString(    bbtk::wx2std( wxchoice->GetString(iSelection) )     );
+    mBox->bbSignalOutputModification("Out");
+    mBox->bbSignalOutputModification("OutString");
+  }
+
   //--------------------------------------------------------------------------
   void ComboBoxWidget::OnComboBox(wxEvent& event)
   {
@@ -124,14 +127,8 @@ namespace bbwx
         } else {
                 iSelection = wxchoice->GetSelection();
         }
-
-    mBox->bbSetInputSelection( iSelection );
-    mBox->bbSetOutputOut( iSelection );
-    mBox->bbSetOutputOutString(    bbtk::wx2std( wxchoice->GetString(iSelection) )     );
-    mBox->bbSignalOutputModification("Out");
-    mBox->bbSignalOutputModification("OutString");
+        OnComboBox(iSelection);
   }
-
 //--------------------------------------------------------------------------
   void ComboBoxWidget::FillItems(
                int iSelection,
@@ -142,10 +139,12 @@ namespace bbwx
                if (mTypeForm==1)
                {
                        wxlistbox->Clear();
+
                for (i=0;i<lstIn.size(); i++)
                {
                                wxlistbox->Append(  bbtk::std2wx( lstIn[i] )  ); 
                        } // for i
+
                wxlistbox->SetSelection(iSelection);
                } else {
                        wxchoice->Clear();
@@ -164,8 +163,16 @@ BBTK_BLACK_BOX_IMPLEMENTATION(ComboBox,bbtk::WxBlackBox);
 //===== 
 void ComboBox::Process()
 {
-               ComboBoxWidget *w = (ComboBoxWidget*)bbGetOutputWidget();
-               w->FillItems( bbGetInputSelection(),bbGetInputIn() );
+       int iSelection = bbGetInputSelection();
+       if (bbGetInputSelection() >= bbGetInputIn().size()) { iSelection=bbGetInputIn().size()-1; }
+       ComboBoxWidget *w = (ComboBoxWidget*)bbGetOutputWidget();
+       w->FillItems( iSelection, bbGetInputIn() );
+    bbSetInputSelection( iSelection );
+    bbSetOutputOut( iSelection );
+    bbSetOutputOutString( bbGetInputIn()[ iSelection ] );
+//    bbSignalOutputModification("Out");
+//    bbSignalOutputModification("OutString");
+
 }
 
 //===== 
@@ -180,7 +187,7 @@ void ComboBox::CreateWidget(wxWindow* parent)
 
     ComboBoxWidget *w = new ComboBoxWidget(
                                this,
-                                                                       parent,
+                                                       parent,
                                bbGetInputSelection() ,
                                bbGetInputTitle(),
                                bbGetInputIn(),