]> Creatis software - creaMaracasVisu.git/blobdiff - lib/maracasVisuLib/src/interface/wxWindows/widgets/creaButtonContainer/view/listWx.cxx
#2516 creaMaracasVisu Feature New Normal - creaPanelButtonContainer ListPanel with...
[creaMaracasVisu.git] / lib / maracasVisuLib / src / interface / wxWindows / widgets / creaButtonContainer / view / listWx.cxx
index 868e331da4a37f8e2c5ed888493d8fc2b34a47b6..1ec058def25b119870de2f4ff80268cd75381b22 100644 (file)
@@ -24,6 +24,7 @@
 # ------------------------------------------------------------------------ */
 
 
+
 #include "listWx.h"
 
 namespace creaButtonContainer
@@ -31,17 +32,39 @@ namespace creaButtonContainer
        namespace view
        {
                // ----------------------------------------------------------------------------------
-               ListWx::ListWx( wxWindow* parent, wxWindowID id, ItemsMap iMap , TFunctor* functor ): wxListCtrl(parent,id)
+               ListWx::ListWx( wxWindow* parent, wxWindowID id,ItemsMap iMap , TFunctor* functor ):
+                               wxPanel(parent,id)
                {
+
+                       std::cout<< "MLER | ListWx::ListWx()" << std::endl;
                        this->m_itemsMap = iMap;
+
                        this->functor = functor;
+
+                       wxFlexGridSizer* sizer = new wxFlexGridSizer(1);
+                       sizer->Add( new  wxStaticText(this,-1, _("Lista")));
+                       sizer->AddGrowableCol(0);
+                       this->SetSizer(sizer);
+
+                       listBox = new wxListBox(this,-1);
+
+                       std::cout << "is ListBox"<< listBox->GetId()<< std::endl;
+               //      this->Connect( -1,wxEVT_COMMAND_CHOICE_SELECTED,
+                       //              (wxObjectEventFunction) (void (wxPanel::*)(wxEvent&))(&ListWx::ListEvent) );
+                       this->Connect(wxEVT_COMMAND_LISTBOX_DOUBLECLICKED,
+                                     wxCommandEventHandler(ListWx::ListEvent));
+
                        for (ItemsMap::iterator it=this->m_itemsMap.begin(); it!=this->m_itemsMap.end(); ++it)
                        {
+
                                std::string key = it->first;
-                               long index = this->InsertItem(0,  wxString::From8BitData(key.c_str()));
-                               //this->Connect( index, wxEVT_LIST_ITEM_SELECTED,
-                                       //                                          (wxObjectEventFunction) &ListWx::ButtonEvent );
+
+                               listBox->Append( wxString(key.c_str(), wxConvUTF8));
+
                        }
+                       sizer->Add(listBox,1,wxGROW);
+
+
                }
 
                // ----------------------------------------------------------------------------------
@@ -50,12 +73,27 @@ namespace creaButtonContainer
                }
 
                void
-               ListWx::ButtonEvent( wxCommandEvent& event )
+               ListWx::ListEvent( wxCommandEvent& event )
                {
                        try
                        {
-                               //MLDR - Aqui necesita el nombre de la funcion para poderla ejecutar
-                               this->functor->Call("PanelButtonContainer::GenericButtonEvent");
+                               std::cout<< "MLER | ListWx::ListEvent( wxListEvent& event )" << std::endl;
+
+                       //      wxString itemNom = this->GetString(this->GetSelection());
+
+                       //      std::string itemNomC = std::string(itemNom.mb_str());
+
+                               //this->functor->Call(itemNomC);
+
+                               int iSelection;
+                               iSelection = listBox->GetSelection();
+
+                               wxString itemNom = listBox->GetString(iSelection);
+                               std::string itemNomC = std::string(itemNom.mb_str());
+
+                               this->functor->Call(itemNomC);
+                               std::cout<<"mmmmmmmmmmmmmmmmmmmmmmm"<<std::endl;
+
                        }//yrt
                        catch ( const std::exception& e )
                        {
@@ -67,3 +105,5 @@ namespace creaButtonContainer
        // ----------------------------------------------------------------------------------
        }//ecapseman
 }//ecapseman
+
+