[ 1515213
] Combo sample improvements.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@39968 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -78,6 +78,8 @@ public:
|
|||||||
void OnQuit(wxCommandEvent& event);
|
void OnQuit(wxCommandEvent& event);
|
||||||
void OnAbout(wxCommandEvent& event);
|
void OnAbout(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnShowComparison( wxCommandEvent& event );
|
||||||
|
|
||||||
// log wxComboCtrl events
|
// log wxComboCtrl events
|
||||||
void OnComboBoxUpdate( wxCommandEvent& event );
|
void OnComboBoxUpdate( wxCommandEvent& event );
|
||||||
|
|
||||||
@@ -85,6 +87,9 @@ protected:
|
|||||||
wxTextCtrl* m_logWin;
|
wxTextCtrl* m_logWin;
|
||||||
wxLog* m_logOld;
|
wxLog* m_logOld;
|
||||||
|
|
||||||
|
// Common list of items for all dialogs.
|
||||||
|
wxArrayString m_arrItems;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// any class wishing to process wxWidgets events must use this macro
|
// any class wishing to process wxWidgets events must use this macro
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
@@ -97,6 +102,8 @@ private:
|
|||||||
// IDs for the controls and the menu commands
|
// IDs for the controls and the menu commands
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
|
ComboControl_Compare = wxID_HIGHEST,
|
||||||
|
|
||||||
// menu items
|
// menu items
|
||||||
ComboControl_Quit = wxID_EXIT,
|
ComboControl_Quit = wxID_EXIT,
|
||||||
|
|
||||||
@@ -117,8 +124,9 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|||||||
EVT_TEXT(wxID_ANY,MyFrame::OnComboBoxUpdate)
|
EVT_TEXT(wxID_ANY,MyFrame::OnComboBoxUpdate)
|
||||||
EVT_COMBOBOX(wxID_ANY,MyFrame::OnComboBoxUpdate)
|
EVT_COMBOBOX(wxID_ANY,MyFrame::OnComboBoxUpdate)
|
||||||
|
|
||||||
EVT_MENU(ComboControl_Quit, MyFrame::OnQuit)
|
EVT_MENU(ComboControl_Compare, MyFrame::OnShowComparison)
|
||||||
EVT_MENU(ComboControl_About, MyFrame::OnAbout)
|
EVT_MENU(ComboControl_Quit, MyFrame::OnQuit)
|
||||||
|
EVT_MENU(ComboControl_About, MyFrame::OnAbout)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// Create a new application object: this macro will allow wxWidgets to create
|
// Create a new application object: this macro will allow wxWidgets to create
|
||||||
@@ -140,7 +148,7 @@ IMPLEMENT_APP(MyApp)
|
|||||||
bool MyApp::OnInit()
|
bool MyApp::OnInit()
|
||||||
{
|
{
|
||||||
// create the main application window
|
// create the main application window
|
||||||
MyFrame *frame = new MyFrame(_T("wxComboCtrl Sample"));
|
MyFrame *frame = new MyFrame(_T("wxComboCtrl and wxOwnerDrawnComboBox Sample"));
|
||||||
|
|
||||||
// and show it (the frames, unlike simple controls, are not shown when
|
// and show it (the frames, unlike simple controls, are not shown when
|
||||||
// created initially)
|
// created initially)
|
||||||
@@ -153,6 +161,105 @@ bool MyApp::OnInit()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxOwnerDrawnComboBox with custom paint list items
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxPenStyleComboBox : public wxOwnerDrawnComboBox
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual void OnDrawItem( wxDC& dc,
|
||||||
|
const wxRect& rect,
|
||||||
|
int item,
|
||||||
|
int flags ) const
|
||||||
|
{
|
||||||
|
if ( item == wxNOT_FOUND )
|
||||||
|
return;
|
||||||
|
|
||||||
|
wxRect r(rect);
|
||||||
|
r.Deflate(3);
|
||||||
|
r.height -= 2;
|
||||||
|
|
||||||
|
int penStyle = wxSOLID;
|
||||||
|
if ( item == 1 )
|
||||||
|
penStyle = wxTRANSPARENT;
|
||||||
|
else if ( item == 2 )
|
||||||
|
penStyle = wxDOT;
|
||||||
|
else if ( item == 3 )
|
||||||
|
penStyle = wxLONG_DASH;
|
||||||
|
else if ( item == 4 )
|
||||||
|
penStyle = wxSHORT_DASH;
|
||||||
|
else if ( item == 5 )
|
||||||
|
penStyle = wxDOT_DASH;
|
||||||
|
else if ( item == 6 )
|
||||||
|
penStyle = wxBDIAGONAL_HATCH;
|
||||||
|
else if ( item == 7 )
|
||||||
|
penStyle = wxCROSSDIAG_HATCH;
|
||||||
|
else if ( item == 8 )
|
||||||
|
penStyle = wxFDIAGONAL_HATCH;
|
||||||
|
else if ( item == 9 )
|
||||||
|
penStyle = wxCROSS_HATCH;
|
||||||
|
else if ( item == 10 )
|
||||||
|
penStyle = wxHORIZONTAL_HATCH;
|
||||||
|
else if ( item == 11 )
|
||||||
|
penStyle = wxVERTICAL_HATCH;
|
||||||
|
|
||||||
|
wxPen pen( dc.GetTextForeground(), 3, penStyle );
|
||||||
|
|
||||||
|
// Get text colour as pen colour
|
||||||
|
dc.SetPen( pen );
|
||||||
|
|
||||||
|
if ( !(flags & wxODCB_PAINTING_CONTROL) )
|
||||||
|
{
|
||||||
|
dc.DrawText(GetString( item ),
|
||||||
|
r.x + 3,
|
||||||
|
(r.y + 0) + ( (r.height/2) - dc.GetCharHeight() )/2
|
||||||
|
);
|
||||||
|
|
||||||
|
dc.DrawLine( r.x+5, r.y+((r.height/4)*3), r.x+r.width - 5, r.y+((r.height/4)*3) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dc.DrawLine( r.x+5, r.y+r.height/2, r.x+r.width - 5, r.y+r.height/2 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void OnDrawBackground( wxDC& dc, const wxRect& rect,
|
||||||
|
int item, int flags ) const
|
||||||
|
{
|
||||||
|
|
||||||
|
// If item is selected or even, use the default rendering.
|
||||||
|
if ( GetVListBoxComboPopup()->IsCurrent((size_t)item) ||
|
||||||
|
(item & 1) == 0 )
|
||||||
|
{
|
||||||
|
wxOwnerDrawnComboBox::OnDrawBackground(dc,rect,item,flags);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Otherwise, draw every other background with different colour.
|
||||||
|
wxColour bgCol(240,240,250);
|
||||||
|
dc.SetBrush(wxBrush(bgCol));
|
||||||
|
dc.SetPen(wxPen(bgCol));
|
||||||
|
dc.DrawRectangle(rect);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual wxCoord OnMeasureItem( size_t item ) const
|
||||||
|
{
|
||||||
|
// Simply demonstrate the ability to have variable-height items
|
||||||
|
if ( item & 1 )
|
||||||
|
return 36;
|
||||||
|
else
|
||||||
|
return 24;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual wxCoord OnMeasureItemWidth( size_t WXUNUSED(item) ) const
|
||||||
|
{
|
||||||
|
return -1; // default - will be measured from text width
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxListView Custom popup interface
|
// wxListView Custom popup interface
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -163,14 +270,6 @@ class ListViewComboPopup : public wxListView, public wxComboPopup
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/*
|
|
||||||
ListViewComboPopup(wxComboCtrlBase* combo)
|
|
||||||
: wxListView(), wxComboPopup(combo)
|
|
||||||
{
|
|
||||||
m_value = -1;
|
|
||||||
m_itemHere = -1; // hot item in list
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
virtual void Init()
|
virtual void Init()
|
||||||
{
|
{
|
||||||
m_value = -1;
|
m_value = -1;
|
||||||
@@ -265,13 +364,6 @@ class TreeCtrlComboPopup : public wxTreeCtrl, public wxComboPopup
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/*
|
|
||||||
TreeCtrlComboPopup(wxComboCtrlBase* combo)
|
|
||||||
: wxTreeCtrl(), wxComboPopup(combo)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
virtual void Init()
|
virtual void Init()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@@ -393,81 +485,6 @@ BEGIN_EVENT_TABLE(TreeCtrlComboPopup, wxTreeCtrl)
|
|||||||
EVT_LEFT_DOWN(TreeCtrlComboPopup::OnMouseClick)
|
EVT_LEFT_DOWN(TreeCtrlComboPopup::OnMouseClick)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxOwnerDrawnComboBox with custom paint list items
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class wxPenStyleComboBox : public wxOwnerDrawnComboBox
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual void OnDrawItem( wxDC& dc,
|
|
||||||
const wxRect& rect,
|
|
||||||
int item,
|
|
||||||
int flags ) const
|
|
||||||
{
|
|
||||||
if ( item == wxNOT_FOUND )
|
|
||||||
return;
|
|
||||||
|
|
||||||
wxRect r(rect);
|
|
||||||
r.Deflate(3);
|
|
||||||
r.height -= 2;
|
|
||||||
|
|
||||||
int pen_style = wxSOLID;
|
|
||||||
if ( item == 1 )
|
|
||||||
pen_style = wxTRANSPARENT;
|
|
||||||
else if ( item == 2 )
|
|
||||||
pen_style = wxDOT;
|
|
||||||
else if ( item == 3 )
|
|
||||||
pen_style = wxLONG_DASH;
|
|
||||||
else if ( item == 4 )
|
|
||||||
pen_style = wxSHORT_DASH;
|
|
||||||
else if ( item == 5 )
|
|
||||||
pen_style = wxDOT_DASH;
|
|
||||||
else if ( item == 6 )
|
|
||||||
pen_style = wxBDIAGONAL_HATCH;
|
|
||||||
else if ( item == 7 )
|
|
||||||
pen_style = wxCROSSDIAG_HATCH;
|
|
||||||
else if ( item == 8 )
|
|
||||||
pen_style = wxFDIAGONAL_HATCH;
|
|
||||||
else if ( item == 9 )
|
|
||||||
pen_style = wxCROSS_HATCH;
|
|
||||||
else if ( item == 10 )
|
|
||||||
pen_style = wxHORIZONTAL_HATCH;
|
|
||||||
else if ( item == 11 )
|
|
||||||
pen_style = wxVERTICAL_HATCH;
|
|
||||||
|
|
||||||
wxPen pen( dc.GetTextForeground(), 3, pen_style );
|
|
||||||
|
|
||||||
// Get text colour as pen colour
|
|
||||||
dc.SetPen ( pen );
|
|
||||||
|
|
||||||
if ( !(flags & wxODCB_PAINTING_CONTROL) )
|
|
||||||
{
|
|
||||||
dc.DrawText(GetString( item ),
|
|
||||||
r.x + 3,
|
|
||||||
(r.y + 0) + ( (r.height/2) - dc.GetCharHeight() )/2
|
|
||||||
);
|
|
||||||
|
|
||||||
dc.DrawLine( r.x+5, r.y+((r.height/4)*3), r.x+r.width - 5, r.y+((r.height/4)*3) );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
dc.DrawLine( r.x+5, r.y+r.height/2, r.x+r.width - 5, r.y+r.height/2 );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual wxCoord OnMeasureItem( size_t WXUNUSED(item) ) const
|
|
||||||
{
|
|
||||||
return 24;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual wxCoord OnMeasureItemWidth( size_t WXUNUSED(item) ) const
|
|
||||||
{
|
|
||||||
return -1; // default - will be measured from text width
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxComboCtrl with entirely custom button action (opens file dialog)
|
// wxComboCtrl with entirely custom button action (opens file dialog)
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -559,7 +576,6 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
wxBoxSizer* topRowSizer;
|
wxBoxSizer* topRowSizer;
|
||||||
wxBoxSizer* colSizer;
|
wxBoxSizer* colSizer;
|
||||||
wxBoxSizer* rowSizer;
|
wxBoxSizer* rowSizer;
|
||||||
wxStaticBoxSizer* groupSizer;
|
|
||||||
|
|
||||||
// set the frame icon
|
// set the frame icon
|
||||||
SetIcon(wxICON(sample));
|
SetIcon(wxICON(sample));
|
||||||
@@ -572,6 +588,9 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
wxMenu *helpMenu = new wxMenu;
|
wxMenu *helpMenu = new wxMenu;
|
||||||
helpMenu->Append(ComboControl_About, _T("&About...\tF1"), _T("Show about dialog"));
|
helpMenu->Append(ComboControl_About, _T("&About...\tF1"), _T("Show about dialog"));
|
||||||
|
|
||||||
|
fileMenu->Append(ComboControl_Compare, _T("&Compare against wxComboBox..."),
|
||||||
|
_T("Show some wxOwnerDrawnComboBoxes side-by-side with native wxComboBoxes."));
|
||||||
|
fileMenu->AppendSeparator();
|
||||||
fileMenu->Append(ComboControl_Quit, _T("E&xit\tAlt-X"), _T("Quit this program"));
|
fileMenu->Append(ComboControl_Quit, _T("E&xit\tAlt-X"), _T("Quit this program"));
|
||||||
|
|
||||||
// now append the freshly created menu to the menu bar...
|
// now append the freshly created menu to the menu bar...
|
||||||
@@ -601,160 +620,36 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
colSizer = new wxBoxSizer( wxVERTICAL );
|
colSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
|
|
||||||
// Make sure GetFeatures is implemented
|
|
||||||
int features = wxComboCtrl::GetFeatures();
|
|
||||||
wxLogDebug(wxT("wxComboCtrl features: 0x%X (all features: 0x%X)"),
|
|
||||||
features,wxComboCtrlFeatures::All);
|
|
||||||
|
|
||||||
|
|
||||||
wxComboBox* cb;
|
|
||||||
wxComboCtrl* cc;
|
wxComboCtrl* cc;
|
||||||
wxGenericComboControl* gcc;
|
wxGenericComboControl* gcc;
|
||||||
wxOwnerDrawnComboBox* odc;
|
wxOwnerDrawnComboBox* odc;
|
||||||
|
|
||||||
// Create common strings array
|
// Create common strings array
|
||||||
wxArrayString arrItems;
|
m_arrItems.Add( wxT("Solid") );
|
||||||
arrItems.Add( wxT("Solid") );
|
m_arrItems.Add( wxT("Transparent") );
|
||||||
arrItems.Add( wxT("Transparent") );
|
m_arrItems.Add( wxT("Dot") );
|
||||||
arrItems.Add( wxT("Dot") );
|
m_arrItems.Add( wxT("Long Dash") );
|
||||||
arrItems.Add( wxT("Long Dash") );
|
m_arrItems.Add( wxT("Short Dash") );
|
||||||
arrItems.Add( wxT("Short Dash") );
|
m_arrItems.Add( wxT("Dot Dash") );
|
||||||
arrItems.Add( wxT("Dot Dash") );
|
m_arrItems.Add( wxT("Backward Diagonal Hatch") );
|
||||||
arrItems.Add( wxT("Backward Diagonal Hatch") );
|
m_arrItems.Add( wxT("Cross-diagonal Hatch") );
|
||||||
arrItems.Add( wxT("Cross-diagonal Hatch") );
|
m_arrItems.Add( wxT("Forward Diagonal Hatch") );
|
||||||
arrItems.Add( wxT("Forward Diagonal Hatch") );
|
m_arrItems.Add( wxT("Cross Hatch") );
|
||||||
arrItems.Add( wxT("Cross Hatch") );
|
m_arrItems.Add( wxT("Horizontal Hatch") );
|
||||||
arrItems.Add( wxT("Horizontal Hatch") );
|
m_arrItems.Add( wxT("Vertical Hatch") );
|
||||||
arrItems.Add( wxT("Vertical Hatch") );
|
|
||||||
|
|
||||||
int border = 4;
|
|
||||||
|
|
||||||
//
|
|
||||||
// Show some wxOwnerDrawComboBoxes for comparison
|
|
||||||
//
|
|
||||||
rowSizer = new wxBoxSizer(wxHORIZONTAL);
|
|
||||||
|
|
||||||
groupSizer = new wxStaticBoxSizer(new wxStaticBox(panel,wxID_ANY,wxT(" wxOwnerDrawnComboBox ")),
|
|
||||||
wxVERTICAL);
|
|
||||||
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Writable, sorted:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT|wxEXPAND, border );
|
|
||||||
|
|
||||||
odc = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
odc->Append(wxT("H - Appended Item")); // test sorting in append
|
|
||||||
|
|
||||||
odc->SetValue(wxT("Dot Dash"));
|
|
||||||
|
|
||||||
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
//
|
|
||||||
// Readonly ODComboBox
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Read-only:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
|
||||||
|
|
||||||
odc = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
odc->SetValue(wxT("Dot Dash"));
|
|
||||||
odc->SetText(wxT("Dot Dash (Testing SetText)"));
|
|
||||||
|
|
||||||
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
//
|
|
||||||
// Disabled ODComboBox
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Disabled:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
|
||||||
|
|
||||||
odc = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
odc->SetValue(wxT("Dot Dash"));
|
|
||||||
odc->Enable(false);
|
|
||||||
|
|
||||||
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
rowSizer->Add( groupSizer, 1, wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
|
|
||||||
groupSizer = new wxStaticBoxSizer(new wxStaticBox(panel,wxID_ANY,wxT(" wxComboBox ")),
|
|
||||||
wxVERTICAL);
|
|
||||||
|
|
||||||
//
|
|
||||||
// wxComboBox
|
|
||||||
//
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Writable, sorted:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT|wxEXPAND, border );
|
|
||||||
|
|
||||||
cb = new wxComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
cb->Append(wxT("H - Appended Item")); // test sorting in append
|
|
||||||
|
|
||||||
cb->SetValue(wxT("Dot Dash"));
|
|
||||||
|
|
||||||
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
//
|
|
||||||
// Readonly wxComboBox
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Read-only:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
|
||||||
|
|
||||||
cb = new wxComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
cb->SetValue(wxT("Dot Dash"));
|
|
||||||
|
|
||||||
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
//
|
|
||||||
// Disabled wxComboBox
|
|
||||||
groupSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Disabled:")), 0,
|
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
|
||||||
|
|
||||||
cb = new wxComboBox(panel,wxID_ANY,wxEmptyString,
|
|
||||||
wxDefaultPosition, wxDefaultSize,
|
|
||||||
arrItems,
|
|
||||||
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
|
||||||
);
|
|
||||||
|
|
||||||
cb->SetValue(wxT("Dot Dash"));
|
|
||||||
cb->Enable(false);
|
|
||||||
|
|
||||||
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
rowSizer->Add( groupSizer, 1, wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
|
|
||||||
colSizer->Add( rowSizer, 1, wxEXPAND|wxALL, border );
|
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Pen selector ODComboBox with application painted items
|
// Create pen selector ODComboBox with owner-drawn items
|
||||||
//
|
//
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
||||||
wxT("OwnerDrawnComboBox with Custom Paint Items and Button Placing:")), 1,
|
wxT("OwnerDrawnComboBox with owner-drawn items:")), 1,
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
|
|
||||||
// When defining derivative class for callbacks, we need
|
// When defining derivative class for callbacks, we need
|
||||||
// to use two-stage creation (or redefine the common wx
|
// to use two-stage creation (or redefine the common wx
|
||||||
@@ -762,10 +657,42 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
odc = new wxPenStyleComboBox();
|
odc = new wxPenStyleComboBox();
|
||||||
odc->Create(panel,wxID_ANY,wxEmptyString,
|
odc->Create(panel,wxID_ANY,wxEmptyString,
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
arrItems,
|
m_arrItems,
|
||||||
wxCB_READONLY //wxNO_BORDER | wxCB_READONLY
|
wxCB_READONLY //wxNO_BORDER | wxCB_READONLY
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
odc->SetSelection(0);
|
||||||
|
|
||||||
|
rowSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxALL, 4 );
|
||||||
|
rowSizer->AddStretchSpacer(1);
|
||||||
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Same but with changed button position
|
||||||
|
//
|
||||||
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
||||||
|
wxT("OwnerDrawnComboBox with owner-drawn items and button on the left:")), 1,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
|
|
||||||
|
// When defining derivative class for callbacks, we need
|
||||||
|
// to use two-stage creation (or redefine the common wx
|
||||||
|
// constructor).
|
||||||
|
odc = new wxPenStyleComboBox();
|
||||||
|
odc->Create(panel,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_READONLY //wxNO_BORDER | wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
odc->SetSelection(0);
|
odc->SetSelection(0);
|
||||||
odc->SetButtonPosition(-2, // width adjustment
|
odc->SetButtonPosition(-2, // width adjustment
|
||||||
-6, // height adjustment
|
-6, // height adjustment
|
||||||
@@ -782,40 +709,25 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
// List View wxComboCtrl
|
// List View wxComboCtrl
|
||||||
//
|
//
|
||||||
|
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
rowSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("List View wxComboCtrl:")), 1,
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("List View wxComboCtrl:")), 1,
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
rowSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Tree Ctrl wxGenericComboControl:")), 1,
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,wxT("Tree Ctrl wxComboControl:")), 1,
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
cc = new wxComboCtrl(panel,2,wxEmptyString,
|
cc = new wxComboCtrl(panel,2,wxEmptyString,
|
||||||
wxDefaultPosition, wxDefaultSize);
|
wxDefaultPosition, wxDefaultSize);
|
||||||
|
|
||||||
cc->SetPopupMinWidth(300);
|
cc->SetPopupMinWidth(300);
|
||||||
|
|
||||||
ListViewComboPopup* iface = new ListViewComboPopup();
|
ListViewComboPopup* iface = new ListViewComboPopup();
|
||||||
cc->SetPopupControl(iface);
|
cc->SetPopupControl(iface);
|
||||||
|
|
||||||
iface->AddSelection( wxT("Cabbage") );
|
int i;
|
||||||
iface->AddSelection( wxT("Potato") );
|
for ( i=0; i<100; i++ )
|
||||||
iface->AddSelection( wxT("Onion") );
|
iface->AddSelection( wxString::Format(wxT("Item %02i"),i));
|
||||||
iface->AddSelection( wxT("Carrot") );
|
|
||||||
iface->AddSelection( wxT("Cauliflower") );
|
|
||||||
iface->AddSelection( wxT("Bean") );
|
|
||||||
iface->AddSelection( wxT("Raddish") );
|
|
||||||
iface->AddSelection( wxT("Banana") );
|
|
||||||
iface->AddSelection( wxT("Apple") );
|
|
||||||
iface->AddSelection( wxT("Orange") );
|
|
||||||
iface->AddSelection( wxT("Kiwi") );
|
|
||||||
iface->AddSelection( wxT("Strawberry") );
|
|
||||||
iface->AddSelection( wxT("Cucumber") );
|
|
||||||
iface->AddSelection( wxT("Blackberry") );
|
|
||||||
iface->AddSelection( wxT("Melon") );
|
|
||||||
iface->AddSelection( wxT("Cherry") );
|
|
||||||
iface->AddSelection( wxT("Pea") );
|
|
||||||
iface->AddSelection( wxT("Pear") );
|
|
||||||
|
|
||||||
rowSizer->Add( cc, 1, wxALIGN_CENTER_VERTICAL|wxALL, 5 );
|
rowSizer->Add( cc, 1, wxALIGN_CENTER_VERTICAL|wxALL, 5 );
|
||||||
|
|
||||||
@@ -838,20 +750,18 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
|
|
||||||
wxTreeItemId groupId;
|
wxTreeItemId groupId;
|
||||||
|
|
||||||
groupId = tcPopup->AppendItem(rootId,wxT("Controls"));
|
for ( i=0; i<4; i++ )
|
||||||
tcPopup->AppendItem(groupId,wxT("wxButton"));
|
{
|
||||||
tcPopup->AppendItem(groupId,wxT("wxCheckBox"));
|
groupId = tcPopup->AppendItem(rootId,
|
||||||
tcPopup->AppendItem(groupId,wxT("wxListCtrl"));
|
wxString::Format(wxT("Branch %02i"),i));
|
||||||
tcPopup->AppendItem(groupId,wxT("wxStaticBox"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxStaticText"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxTextCtrl"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxTreeCtrl"));
|
|
||||||
groupId = tcPopup->AppendItem(rootId,wxT("Dialogs"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxDirDialog"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxFileDialog"));
|
|
||||||
tcPopup->AppendItem(groupId,wxT("wxWizard"));
|
|
||||||
|
|
||||||
gcc->SetValue(wxT("wxStaticBox"));
|
int n;
|
||||||
|
for ( n=0; n<25; n++ )
|
||||||
|
tcPopup->AppendItem(groupId,
|
||||||
|
wxString::Format(wxT("Subitem %02i"),(i*25)+n));
|
||||||
|
}
|
||||||
|
|
||||||
|
gcc->SetValue(wxT("Subitem 05"));
|
||||||
|
|
||||||
// Move button to left - it makes more sense for a tree ctrl
|
// Move button to left - it makes more sense for a tree ctrl
|
||||||
gcc->SetButtonPosition(0, // width adjustment
|
gcc->SetButtonPosition(0, // width adjustment
|
||||||
@@ -871,25 +781,25 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
// Custom Dropbutton Bitmaps
|
// Custom Dropbutton Bitmaps
|
||||||
// (second one uses blank button background)
|
// (second one uses blank button background)
|
||||||
//
|
//
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
||||||
wxT("OwnerDrawnComboBox with simple dropbutton graphics:")), 1,
|
wxT("OwnerDrawnComboBox with simple dropbutton graphics:")), 1,
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
|
|
||||||
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
odc = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
odc = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
arrItems,
|
m_arrItems,
|
||||||
(long)0 // wxCB_SORT // wxNO_BORDER | wxCB_READONLY
|
(long)0 // wxCB_SORT // wxNO_BORDER | wxCB_READONLY
|
||||||
);
|
);
|
||||||
|
|
||||||
wxOwnerDrawnComboBox* odc2;
|
wxOwnerDrawnComboBox* odc2;
|
||||||
odc2 = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
odc2 = new wxOwnerDrawnComboBox(panel,wxID_ANY,wxEmptyString,
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
arrItems,
|
m_arrItems,
|
||||||
(long)0 // wxCB_SORT // wxNO_BORDER | wxCB_READONLY
|
(long)0 // wxCB_SORT // wxNO_BORDER | wxCB_READONLY
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -924,7 +834,7 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
//
|
//
|
||||||
// wxComboCtrl with totally custom button action (open file dialog)
|
// wxComboCtrl with totally custom button action (open file dialog)
|
||||||
//
|
//
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
rowSizer->Add( new wxStaticText(panel,wxID_ANY,
|
||||||
wxT("wxComboCtrl with custom button action:")), 1,
|
wxT("wxComboCtrl with custom button action:")), 1,
|
||||||
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, 4 );
|
||||||
@@ -932,7 +842,7 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
|
|
||||||
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
rowSizer = new wxBoxSizer ( wxHORIZONTAL );
|
rowSizer = new wxBoxSizer( wxHORIZONTAL );
|
||||||
wxFileSelectorCombo* fsc;
|
wxFileSelectorCombo* fsc;
|
||||||
|
|
||||||
fsc = new wxFileSelectorCombo(panel,wxID_ANY,wxEmptyString,
|
fsc = new wxFileSelectorCombo(panel,wxID_ANY,wxEmptyString,
|
||||||
@@ -944,6 +854,10 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, 5 );
|
||||||
|
|
||||||
|
|
||||||
|
// Make sure GetFeatures is implemented
|
||||||
|
wxComboCtrl::GetFeatures();
|
||||||
|
|
||||||
|
|
||||||
topRowSizer->Add( colSizer, 1, wxALL, 2 );
|
topRowSizer->Add( colSizer, 1, wxALL, 2 );
|
||||||
|
|
||||||
topRowSizer->Add( m_logWin, 1, wxEXPAND|wxALL, 5 );
|
topRowSizer->Add( m_logWin, 1, wxEXPAND|wxALL, 5 );
|
||||||
@@ -952,21 +866,16 @@ MyFrame::MyFrame(const wxString& title)
|
|||||||
panel->SetSizer( topSizer );
|
panel->SetSizer( topSizer );
|
||||||
topSizer->SetSizeHints( panel );
|
topSizer->SetSizeHints( panel );
|
||||||
|
|
||||||
SetSize(740,480);
|
SetSize(740,400);
|
||||||
Centre();
|
Centre();
|
||||||
}
|
}
|
||||||
|
|
||||||
MyFrame::~MyFrame()
|
|
||||||
{
|
|
||||||
delete wxLog::SetActiveTarget(m_logOld);
|
|
||||||
}
|
|
||||||
|
|
||||||
// event handlers
|
// event handlers
|
||||||
|
|
||||||
void MyFrame::OnComboBoxUpdate( wxCommandEvent& event )
|
void MyFrame::OnComboBoxUpdate( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
// Don't show messages for the log output window (it'll crash)
|
// Don't show messages for the log output window (it'll crash)
|
||||||
if ( event.GetId() == 105 )
|
if ( !event.GetEventObject()->IsKindOf(CLASSINFO(wxComboCtrl)) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ( event.GetEventType() == wxEVT_COMMAND_COMBOBOX_SELECTED )
|
if ( event.GetEventType() == wxEVT_COMMAND_COMBOBOX_SELECTED )
|
||||||
@@ -975,6 +884,152 @@ void MyFrame::OnComboBoxUpdate( wxCommandEvent& event )
|
|||||||
wxLogDebug(wxT("EVT_TEXT(id=%i,string=\"%s\")"),event.GetId(),event.GetString().c_str());
|
wxLogDebug(wxT("EVT_TEXT(id=%i,string=\"%s\")"),event.GetId(),event.GetString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnShowComparison( wxCommandEvent& WXUNUSED(event) )
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Show some wxOwnerDrawComboBoxes for comparison
|
||||||
|
//
|
||||||
|
|
||||||
|
wxBoxSizer* colSizer;
|
||||||
|
wxBoxSizer* rowSizer;
|
||||||
|
wxStaticBoxSizer* groupSizer;
|
||||||
|
|
||||||
|
wxComboBox* cb;
|
||||||
|
wxOwnerDrawnComboBox* odc;
|
||||||
|
|
||||||
|
const int border = 4;
|
||||||
|
|
||||||
|
wxDialog* dlg = new wxDialog(this,wxID_ANY,
|
||||||
|
wxT("Compare against wxComboBox"),
|
||||||
|
wxDefaultPosition,wxDefaultSize,
|
||||||
|
wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER);
|
||||||
|
|
||||||
|
colSizer = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
|
rowSizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
|
groupSizer = new wxStaticBoxSizer(new wxStaticBox(dlg,wxID_ANY,wxT(" wxOwnerDrawnComboBox ")),
|
||||||
|
wxVERTICAL);
|
||||||
|
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Writable, sorted:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT|wxEXPAND, border );
|
||||||
|
|
||||||
|
odc = new wxOwnerDrawnComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
odc->Append(wxT("H - Appended Item")); // test sorting in append
|
||||||
|
|
||||||
|
odc->SetValue(wxT("Dot Dash"));
|
||||||
|
|
||||||
|
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
//
|
||||||
|
// Readonly ODComboBox
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Read-only:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
||||||
|
|
||||||
|
odc = new wxOwnerDrawnComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
odc->SetValue(wxT("Dot Dash"));
|
||||||
|
odc->SetText(wxT("Dot Dash (Testing SetText)"));
|
||||||
|
|
||||||
|
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
//
|
||||||
|
// Disabled ODComboBox
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Disabled:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
||||||
|
|
||||||
|
odc = new wxOwnerDrawnComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
odc->SetValue(wxT("Dot Dash"));
|
||||||
|
odc->Enable(false);
|
||||||
|
|
||||||
|
groupSizer->Add( odc, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
rowSizer->Add( groupSizer, 1, wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
|
||||||
|
groupSizer = new wxStaticBoxSizer(new wxStaticBox(dlg,wxID_ANY,wxT(" wxComboBox ")),
|
||||||
|
wxVERTICAL);
|
||||||
|
|
||||||
|
//
|
||||||
|
// wxComboBox
|
||||||
|
//
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Writable, sorted:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT|wxEXPAND, border );
|
||||||
|
|
||||||
|
cb = new wxComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
cb->Append(wxT("H - Appended Item")); // test sorting in append
|
||||||
|
|
||||||
|
cb->SetValue(wxT("Dot Dash"));
|
||||||
|
|
||||||
|
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
//
|
||||||
|
// Readonly wxComboBox
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Read-only:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
||||||
|
|
||||||
|
cb = new wxComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
cb->SetValue(wxT("Dot Dash"));
|
||||||
|
|
||||||
|
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
//
|
||||||
|
// Disabled wxComboBox
|
||||||
|
groupSizer->Add( new wxStaticText(dlg,wxID_ANY,wxT("Disabled:")), 0,
|
||||||
|
wxALIGN_CENTER_VERTICAL|wxRIGHT, border );
|
||||||
|
|
||||||
|
cb = new wxComboBox(dlg,wxID_ANY,wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
m_arrItems,
|
||||||
|
wxCB_SORT|wxCB_READONLY // wxNO_BORDER|wxCB_READONLY
|
||||||
|
);
|
||||||
|
|
||||||
|
cb->SetValue(wxT("Dot Dash"));
|
||||||
|
cb->Enable(false);
|
||||||
|
|
||||||
|
groupSizer->Add( cb, 1, wxALIGN_CENTER_VERTICAL|wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
rowSizer->Add( groupSizer, 1, wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
colSizer->Add( rowSizer, 0, wxEXPAND|wxALL, border );
|
||||||
|
|
||||||
|
dlg->SetSizer( colSizer );
|
||||||
|
colSizer->SetSizeHints( dlg );
|
||||||
|
|
||||||
|
dlg->SetSize(60,240);
|
||||||
|
dlg->Centre();
|
||||||
|
dlg->ShowModal();
|
||||||
|
}
|
||||||
|
|
||||||
|
MyFrame::~MyFrame()
|
||||||
|
{
|
||||||
|
delete wxLog::SetActiveTarget(m_logOld);
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
// true is to force the frame to close
|
// true is to force the frame to close
|
||||||
@@ -986,7 +1041,7 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
|||||||
wxMessageBox(wxString::Format(
|
wxMessageBox(wxString::Format(
|
||||||
_T("Welcome to %s!\n")
|
_T("Welcome to %s!\n")
|
||||||
_T("\n")
|
_T("\n")
|
||||||
_T("This is the wxWidgets wxComboCtrl sample\n")
|
_T("This is the wxWidgets wxComboCtrl and wxOwnerDrawnComboBox sample\n")
|
||||||
_T("running under %s."),
|
_T("running under %s."),
|
||||||
wxVERSION_STRING,
|
wxVERSION_STRING,
|
||||||
wxGetOsDescription().c_str()
|
wxGetOsDescription().c_str()
|
||||||
|
Reference in New Issue
Block a user