added owner drawn checkbox to listbox page and the possibility to test changing the controls font (part of patch 1181057)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@33573 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2005-04-13 15:03:50 +00:00
parent 0f6858b69e
commit 822b9009d7
2 changed files with 58 additions and 11 deletions

View File

@@ -134,10 +134,11 @@ protected:
wxRadioBox *m_radioSelMode; wxRadioBox *m_radioSelMode;
// the checkboxes // the checkboxes
wxCheckBox *m_chkSort, wxCheckBox *m_chkVScroll,
*m_chkCheck,
*m_chkHScroll, *m_chkHScroll,
*m_chkVScroll; *m_chkCheck,
*m_chkSort,
*m_chkOwnerDraw;
// the listbox itself and the sizer it is in // the listbox itself and the sizer it is in
wxListBox *m_lbox; wxListBox *m_lbox;
@@ -205,7 +206,8 @@ ListboxWidgetsPage::ListboxWidgetsPage(wxBookCtrl *book,
m_chkVScroll = m_chkVScroll =
m_chkHScroll = m_chkHScroll =
m_chkCheck = m_chkCheck =
m_chkSort = (wxCheckBox *)NULL; m_chkSort =
m_chkOwnerDraw = (wxCheckBox *)NULL;
m_lbox = (wxListBox *)NULL; m_lbox = (wxListBox *)NULL;
m_sizerLbox = (wxSizer *)NULL; m_sizerLbox = (wxSizer *)NULL;
@@ -247,6 +249,7 @@ ListboxWidgetsPage::ListboxWidgetsPage(wxBookCtrl *book,
); );
m_chkCheck = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Check list box")); m_chkCheck = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Check list box"));
m_chkSort = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Sort items")); m_chkSort = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Sort items"));
m_chkOwnerDraw = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Owner drawn"));
sizerLeft->Add(5, 5, 0, wxGROW | wxALL, 5); // spacer sizerLeft->Add(5, 5, 0, wxGROW | wxALL, 5); // spacer
sizerLeft->Add(m_radioSelMode, 0, wxGROW | wxALL, 5); sizerLeft->Add(m_radioSelMode, 0, wxGROW | wxALL, 5);
@@ -322,10 +325,11 @@ ListboxWidgetsPage::ListboxWidgetsPage(wxBookCtrl *book,
void ListboxWidgetsPage::Reset() void ListboxWidgetsPage::Reset()
{ {
m_radioSelMode->SetSelection(LboxSel_Single); m_radioSelMode->SetSelection(LboxSel_Single);
m_chkSort->SetValue(false);
m_chkCheck->SetValue(false);
m_chkHScroll->SetValue(true);
m_chkVScroll->SetValue(false); m_chkVScroll->SetValue(false);
m_chkHScroll->SetValue(true);
m_chkCheck->SetValue(false);
m_chkSort->SetValue(false);
m_chkOwnerDraw->SetValue(false);
} }
void ListboxWidgetsPage::CreateLbox() void ListboxWidgetsPage::CreateLbox()
@@ -347,6 +351,8 @@ void ListboxWidgetsPage::CreateLbox()
flags |= wxLB_HSCROLL; flags |= wxLB_HSCROLL;
if ( m_chkSort->GetValue() ) if ( m_chkSort->GetValue() )
flags |= wxLB_SORT; flags |= wxLB_SORT;
if ( m_chkOwnerDraw->GetValue() )
flags |= wxLB_OWNERDRAW;
wxArrayString items; wxArrayString items;
if ( m_lbox ) if ( m_lbox )
@@ -468,6 +474,7 @@ void ListboxWidgetsPage::OnUpdateUIResetButton(wxUpdateUIEvent& event)
{ {
event.Enable( (m_radioSelMode->GetSelection() != LboxSel_Single) || event.Enable( (m_radioSelMode->GetSelection() != LboxSel_Single) ||
m_chkSort->GetValue() || m_chkSort->GetValue() ||
m_chkOwnerDraw->GetValue() ||
!m_chkHScroll->GetValue() || !m_chkHScroll->GetValue() ||
m_chkVScroll->GetValue() ); m_chkVScroll->GetValue() );
} }

View File

@@ -43,6 +43,7 @@
#include "wx/bookctrl.h" #include "wx/bookctrl.h"
#include "wx/sizer.h" #include "wx/sizer.h"
#include "wx/colordlg.h" #include "wx/colordlg.h"
#include "wx/fontdlg.h"
#include "wx/textdlg.h" #include "wx/textdlg.h"
#include "widgets.h" #include "widgets.h"
@@ -60,7 +61,8 @@ enum
Widgets_SetTooltip, Widgets_SetTooltip,
#endif // wxUSE_TOOLTIPS #endif // wxUSE_TOOLTIPS
Widgets_SetFgColour, Widgets_SetFgColour,
Widgets_SetBgColour Widgets_SetBgColour,
Widgets_SetFont
}; };
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -100,6 +102,7 @@ protected:
#endif // wxUSE_TOOLTIPS #endif // wxUSE_TOOLTIPS
void OnSetFgCol(wxCommandEvent& event); void OnSetFgCol(wxCommandEvent& event);
void OnSetBgCol(wxCommandEvent& event); void OnSetBgCol(wxCommandEvent& event);
void OnSetFont(wxCommandEvent& event);
#endif // wxUSE_MENUS #endif // wxUSE_MENUS
// initialize the book: add all pages to it // initialize the book: add all pages to it
@@ -124,9 +127,10 @@ private:
wxImageList *m_imaglist; wxImageList *m_imaglist;
#if wxUSE_MENUS #if wxUSE_MENUS
// last chosen fg/bg colours // last chosen fg/bg colours and font
wxColour m_colFg, wxColour m_colFg,
m_colBg; m_colBg;
wxFont m_font;
#endif // wxUSE_MENUS #endif // wxUSE_MENUS
// any class wishing to process wxWidgets events must use this macro // any class wishing to process wxWidgets events must use this macro
@@ -217,6 +221,7 @@ BEGIN_EVENT_TABLE(WidgetsFrame, wxFrame)
EVT_MENU(Widgets_SetFgColour, WidgetsFrame::OnSetFgCol) EVT_MENU(Widgets_SetFgColour, WidgetsFrame::OnSetFgCol)
EVT_MENU(Widgets_SetBgColour, WidgetsFrame::OnSetBgCol) EVT_MENU(Widgets_SetBgColour, WidgetsFrame::OnSetBgCol)
EVT_MENU(Widgets_SetFont, WidgetsFrame::OnSetFont)
EVT_MENU(wxID_EXIT, WidgetsFrame::OnExit) EVT_MENU(wxID_EXIT, WidgetsFrame::OnExit)
END_EVENT_TABLE() END_EVENT_TABLE()
@@ -293,6 +298,7 @@ WidgetsFrame::WidgetsFrame(const wxString& title)
#endif // wxUSE_TOOLTIPS #endif // wxUSE_TOOLTIPS
menuWidget->Append(Widgets_SetFgColour, _T("Set &foreground...\tCtrl-F")); menuWidget->Append(Widgets_SetFgColour, _T("Set &foreground...\tCtrl-F"));
menuWidget->Append(Widgets_SetBgColour, _T("Set &background...\tCtrl-B")); menuWidget->Append(Widgets_SetBgColour, _T("Set &background...\tCtrl-B"));
menuWidget->Append(Widgets_SetFont, _T("Set f&ont...\tCtrl-O"));
menuWidget->AppendSeparator(); menuWidget->AppendSeparator();
menuWidget->Append(wxID_EXIT, _T("&Quit\tCtrl-Q")); menuWidget->Append(wxID_EXIT, _T("&Quit\tCtrl-Q"));
mbar->Append(menuWidget, _T("&Widget")); mbar->Append(menuWidget, _T("&Widget"));
@@ -462,13 +468,17 @@ void WidgetsFrame::OnSetTooltip(wxCommandEvent& WXUNUSED(event))
void WidgetsFrame::OnSetFgCol(wxCommandEvent& WXUNUSED(event)) void WidgetsFrame::OnSetFgCol(wxCommandEvent& WXUNUSED(event))
{ {
#if wxUSE_COLOURDLG #if wxUSE_COLOURDLG
// allow for debugging the default colour the first time this is called
WidgetsPage *page = wxStaticCast(m_book->GetCurrentPage(), WidgetsPage);
if (!m_colFg.Ok())
m_colFg = page->GetForegroundColour();
wxColour col = wxGetColourFromUser(this, m_colFg); wxColour col = wxGetColourFromUser(this, m_colFg);
if ( !col.Ok() ) if ( !col.Ok() )
return; return;
m_colFg = col; m_colFg = col;
WidgetsPage *page = wxStaticCast(m_book->GetCurrentPage(), WidgetsPage);
page->GetWidget()->SetForegroundColour(m_colFg); page->GetWidget()->SetForegroundColour(m_colFg);
page->GetWidget()->Refresh(); page->GetWidget()->Refresh();
@@ -486,13 +496,16 @@ void WidgetsFrame::OnSetFgCol(wxCommandEvent& WXUNUSED(event))
void WidgetsFrame::OnSetBgCol(wxCommandEvent& WXUNUSED(event)) void WidgetsFrame::OnSetBgCol(wxCommandEvent& WXUNUSED(event))
{ {
#if wxUSE_COLOURDLG #if wxUSE_COLOURDLG
WidgetsPage *page = wxStaticCast(m_book->GetCurrentPage(), WidgetsPage);
if ( !m_colBg.Ok() )
m_colBg = page->GetBackgroundColour();
wxColour col = wxGetColourFromUser(this, m_colBg); wxColour col = wxGetColourFromUser(this, m_colBg);
if ( !col.Ok() ) if ( !col.Ok() )
return; return;
m_colBg = col; m_colBg = col;
WidgetsPage *page = wxStaticCast(m_book->GetCurrentPage(), WidgetsPage);
page->GetWidget()->SetBackgroundColour(m_colBg); page->GetWidget()->SetBackgroundColour(m_colBg);
page->GetWidget()->Refresh(); page->GetWidget()->Refresh();
@@ -507,6 +520,33 @@ void WidgetsFrame::OnSetBgCol(wxCommandEvent& WXUNUSED(event))
#endif #endif
} }
void WidgetsFrame::OnSetFont(wxCommandEvent& WXUNUSED(event))
{
#if wxUSE_FONTDLG
WidgetsPage *page = wxStaticCast(m_book->GetCurrentPage(), WidgetsPage);
if (!m_font.Ok())
m_font = page->GetFont();
wxFont font = wxGetFontFromUser(this, m_font);
if ( !font.Ok() )
return;
m_font = font;
page->GetWidget()->SetFont(m_font);
page->GetWidget()->Refresh();
wxControl *ctrl2 = page->GetWidget2();
if ( ctrl2 )
{
ctrl2->SetFont(m_font);
ctrl2->Refresh();
}
#else
wxLogMessage(_T("Font selection dialog not available in current build."));
#endif
}
#endif // wxUSE_MENUS #endif // wxUSE_MENUS
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------