This ensures that the expected events are given even after the widget is recreated due to a change of some controls on its page (and not because it's recreated by one of the menu commands in the parent frame). We also don't need to connect to these events from WidgetsFrame any longer (and, in fact, doing it would be wrong as we'd connect twice), which simplifies its code.
224 lines
7 KiB
C++
224 lines
7 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Program: wxWidgets Widgets Sample
|
|
// Name: editlbox.cpp
|
|
// Purpose: Part of the widgets sample showing wxEditableListbox
|
|
// Author: Francesco Montorsi
|
|
// Created: 8/2/2009
|
|
// Copyright: (c) 2009 Francesco Montorsi
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// ============================================================================
|
|
// declarations
|
|
// ============================================================================
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// headers
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// for compilers that support precompilation, includes "wx/wx.h".
|
|
#include "wx/wxprec.h"
|
|
|
|
|
|
#if wxUSE_EDITABLELISTBOX
|
|
|
|
// for all others, include the necessary headers
|
|
#ifndef WX_PRECOMP
|
|
#include "wx/log.h"
|
|
|
|
#include "wx/bitmap.h"
|
|
#include "wx/button.h"
|
|
#include "wx/checkbox.h"
|
|
#include "wx/combobox.h"
|
|
#include "wx/listbox.h"
|
|
#include "wx/radiobox.h"
|
|
#include "wx/statbox.h"
|
|
#include "wx/textctrl.h"
|
|
#endif
|
|
|
|
#include "wx/sizer.h"
|
|
#include "wx/editlbox.h"
|
|
#include "wx/listctrl.h"
|
|
|
|
#include "itemcontainer.h"
|
|
#include "widgets.h"
|
|
|
|
#include "icons/listbox.xpm"
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// constants
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// control ids
|
|
enum
|
|
{
|
|
EditableListboxPage_Reset = wxID_HIGHEST,
|
|
EditableListboxPage_Listbox,
|
|
EditableListboxPage_ContainerTests
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// EditableListboxWidgetsPage
|
|
// ----------------------------------------------------------------------------
|
|
|
|
class EditableListboxWidgetsPage : public WidgetsPage
|
|
{
|
|
public:
|
|
EditableListboxWidgetsPage(WidgetsBookCtrl *book, wxImageList *imaglist);
|
|
|
|
virtual wxWindow *GetWidget() const override { return m_lbox->GetListCtrl(); }
|
|
virtual void RecreateWidget() override { CreateLbox(); }
|
|
|
|
// lazy creation of the content
|
|
virtual void CreateContent() override;
|
|
|
|
protected:
|
|
// event handlers
|
|
void OnButtonReset(wxCommandEvent& event);
|
|
void OnCheckBox(wxCommandEvent& event);
|
|
|
|
// reset the listbox parameters
|
|
void Reset();
|
|
|
|
// (re)create the listbox
|
|
void CreateLbox();
|
|
|
|
// the checkboxes
|
|
wxCheckBox *m_chkAllowNew,
|
|
*m_chkAllowEdit,
|
|
*m_chkAllowDelete,
|
|
*m_chkAllowNoReorder;
|
|
|
|
wxEditableListBox
|
|
*m_lbox;
|
|
|
|
wxSizer *m_sizerLbox;
|
|
|
|
private:
|
|
wxDECLARE_EVENT_TABLE();
|
|
DECLARE_WIDGETS_PAGE(EditableListboxWidgetsPage)
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// event tables
|
|
// ----------------------------------------------------------------------------
|
|
|
|
wxBEGIN_EVENT_TABLE(EditableListboxWidgetsPage, WidgetsPage)
|
|
EVT_BUTTON(EditableListboxPage_Reset, EditableListboxWidgetsPage::OnButtonReset)
|
|
EVT_CHECKBOX(wxID_ANY, EditableListboxWidgetsPage::OnCheckBox)
|
|
wxEND_EVENT_TABLE()
|
|
|
|
// ============================================================================
|
|
// implementation
|
|
// ============================================================================
|
|
|
|
IMPLEMENT_WIDGETS_PAGE(EditableListboxWidgetsPage, "EditableListbox", GENERIC_CTRLS);
|
|
|
|
EditableListboxWidgetsPage::EditableListboxWidgetsPage(WidgetsBookCtrl *book,
|
|
wxImageList *imaglist)
|
|
: WidgetsPage(book, imaglist, listbox_xpm)
|
|
{
|
|
|
|
}
|
|
|
|
void EditableListboxWidgetsPage::CreateContent()
|
|
{
|
|
/*
|
|
What we create here is a frame having 2 panes: style pane is the
|
|
leftmost one and the pane containing the listbox itself to the right
|
|
*/
|
|
wxSizer *sizerTop = new wxBoxSizer(wxHORIZONTAL);
|
|
|
|
// left pane
|
|
wxStaticBoxSizer *sizerLeft = new wxStaticBoxSizer(wxVERTICAL, this, "&Set listbox parameters");
|
|
wxStaticBox* const sizerLeftBox = sizerLeft->GetStaticBox();
|
|
|
|
m_chkAllowNew = CreateCheckBoxAndAddToSizer(sizerLeft, "Allow new items", wxID_ANY, sizerLeftBox);
|
|
m_chkAllowEdit = CreateCheckBoxAndAddToSizer(sizerLeft, "Allow editing items", wxID_ANY, sizerLeftBox);
|
|
m_chkAllowDelete = CreateCheckBoxAndAddToSizer(sizerLeft, "Allow deleting items", wxID_ANY, sizerLeftBox);
|
|
m_chkAllowNoReorder = CreateCheckBoxAndAddToSizer(sizerLeft, "Block user reordering", wxID_ANY, sizerLeftBox);
|
|
|
|
wxButton *btn = new wxButton(sizerLeftBox, EditableListboxPage_Reset, "&Reset");
|
|
sizerLeft->Add(btn, 0, wxALIGN_CENTRE_HORIZONTAL | wxALL, 15);
|
|
|
|
// right pane
|
|
wxSizer *sizerRight = new wxBoxSizer(wxVERTICAL);
|
|
m_lbox = new wxEditableListBox(this, EditableListboxPage_Listbox,
|
|
_("Match these wildcards:"),
|
|
wxDefaultPosition, wxDefaultSize, 0);
|
|
sizerRight->Add(m_lbox, 1, wxGROW | wxALL, 5);
|
|
sizerRight->SetMinSize(150, 0);
|
|
m_sizerLbox = sizerRight; // save it to modify it later
|
|
|
|
// the 3 panes panes compose the window
|
|
sizerTop->Add(sizerLeft, 0, wxGROW | (wxALL & ~wxLEFT), 10);
|
|
sizerTop->Add(sizerRight, 1, wxGROW | (wxALL & ~wxRIGHT), 10);
|
|
|
|
// final initializations
|
|
Reset();
|
|
|
|
SetSizer(sizerTop);
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// operations
|
|
// ----------------------------------------------------------------------------
|
|
|
|
void EditableListboxWidgetsPage::Reset()
|
|
{
|
|
m_chkAllowNew->SetValue(false);
|
|
m_chkAllowEdit->SetValue(false);
|
|
m_chkAllowDelete->SetValue(false);
|
|
m_chkAllowNoReorder->SetValue(false);
|
|
}
|
|
|
|
void EditableListboxWidgetsPage::CreateLbox()
|
|
{
|
|
long flags = GetAttrs().m_defaultFlags;
|
|
|
|
if ( m_chkAllowNew->GetValue() )
|
|
flags |= wxEL_ALLOW_NEW;
|
|
if ( m_chkAllowEdit->GetValue() )
|
|
flags |= wxEL_ALLOW_EDIT;
|
|
if ( m_chkAllowDelete->GetValue() )
|
|
flags |= wxEL_ALLOW_DELETE;
|
|
if ( m_chkAllowNoReorder->GetValue() )
|
|
flags |= wxEL_NO_REORDER;
|
|
|
|
wxArrayString items;
|
|
if ( m_lbox )
|
|
{
|
|
m_lbox->GetStrings(items);
|
|
m_sizerLbox->Detach( m_lbox );
|
|
delete m_lbox;
|
|
}
|
|
|
|
m_lbox = new wxEditableListBox(this, EditableListboxPage_Listbox,
|
|
_("Match these wildcards:"),
|
|
wxDefaultPosition, wxDefaultSize,
|
|
flags);
|
|
|
|
NotifyWidgetRecreation(m_lbox);
|
|
|
|
m_lbox->SetStrings(items);
|
|
m_sizerLbox->Add(m_lbox, 1, wxGROW | wxALL, 5);
|
|
m_sizerLbox->Layout();
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// event handlers
|
|
// ----------------------------------------------------------------------------
|
|
|
|
void EditableListboxWidgetsPage::OnButtonReset(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
Reset();
|
|
|
|
CreateLbox();
|
|
}
|
|
|
|
void EditableListboxWidgetsPage::OnCheckBox(wxCommandEvent& WXUNUSED(event))
|
|
{
|
|
CreateLbox();
|
|
}
|
|
|
|
#endif // wxUSE_EDITABLELISTBOX
|