Applied [ 899616 ] Fixes to the checklst and splitter samples
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26312 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
46a3848921
commit
8ad18dc32c
@ -129,14 +129,14 @@ bool CheckListBoxApp::OnInit(void)
|
|||||||
);
|
);
|
||||||
SetTopWindow(pFrame);
|
SetTopWindow(pFrame);
|
||||||
|
|
||||||
return TRUE;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// main frame constructor
|
// main frame constructor
|
||||||
CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame,
|
CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame,
|
||||||
const wxChar *title,
|
const wxChar *title,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h)
|
||||||
: wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
|
: wxFrame(frame, wxID_ANY, title, wxPoint(x, y), wxSize(w, h))
|
||||||
{
|
{
|
||||||
// create the status line
|
// create the status line
|
||||||
const int widths[] = { -1, 60 };
|
const int widths[] = { -1, 60 };
|
||||||
@ -170,7 +170,7 @@ CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame,
|
|||||||
SetMenuBar(menu_bar);
|
SetMenuBar(menu_bar);
|
||||||
|
|
||||||
// make a panel with some controls
|
// make a panel with some controls
|
||||||
m_panel = new wxPanel(this, -1, wxPoint(0, 0),
|
m_panel = new wxPanel(this, wxID_ANY, wxPoint(0, 0),
|
||||||
wxSize(400, 200), wxTAB_TRAVERSAL);
|
wxSize(400, 200), wxTAB_TRAVERSAL);
|
||||||
|
|
||||||
CreateCheckListbox();
|
CreateCheckListbox();
|
||||||
@ -192,13 +192,13 @@ CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame,
|
|||||||
mainsizer->Add( bottomsizer, 0, wxCENTER );
|
mainsizer->Add( bottomsizer, 0, wxCENTER );
|
||||||
|
|
||||||
// tell frame to make use of sizer (or constraints, if any)
|
// tell frame to make use of sizer (or constraints, if any)
|
||||||
m_panel->SetAutoLayout( TRUE );
|
m_panel->SetAutoLayout( true );
|
||||||
m_panel->SetSizer( mainsizer );
|
m_panel->SetSizer( mainsizer );
|
||||||
|
|
||||||
// don't allow frame to get smaller than what the sizers tell ye
|
// don't allow frame to get smaller than what the sizers tell ye
|
||||||
mainsizer->SetSizeHints( this );
|
mainsizer->SetSizeHints( this );
|
||||||
|
|
||||||
Show(TRUE);
|
Show(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::CreateCheckListbox(long flags)
|
void CheckListBoxFrame::CreateCheckListbox(long flags)
|
||||||
@ -247,7 +247,7 @@ CheckListBoxFrame::~CheckListBoxFrame()
|
|||||||
|
|
||||||
void CheckListBoxFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
Close(TRUE);
|
Close(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
||||||
@ -266,7 +266,7 @@ void CheckListBoxFrame::OnCheckFirstItem(wxCommandEvent& WXUNUSED(event))
|
|||||||
void CheckListBoxFrame::OnUncheckFirstItem(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnUncheckFirstItem(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
if ( !m_pListBox->IsEmpty() )
|
if ( !m_pListBox->IsEmpty() )
|
||||||
m_pListBox->Check(0, FALSE);
|
m_pListBox->Check(0, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::OnToggleFirstItem(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnToggleFirstItem(wxCommandEvent& WXUNUSED(event))
|
||||||
@ -304,13 +304,35 @@ void CheckListBoxFrame::OnListboxSelect(wxCommandEvent& event)
|
|||||||
{
|
{
|
||||||
int nSel = event.GetSelection();
|
int nSel = event.GetSelection();
|
||||||
wxLogStatus(this, wxT("Item %d selected (%schecked)"), nSel,
|
wxLogStatus(this, wxT("Item %d selected (%schecked)"), nSel,
|
||||||
m_pListBox->IsChecked(nSel) ? _T("") : wxT("not "));
|
m_pListBox->IsChecked(nSel) ? wxT("") : wxT("not "));
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::OnListboxDblClick(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnListboxDblClick(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
|
int selection = -1;
|
||||||
|
if(m_pListBox->GetWindowStyle() & wxLB_EXTENDED)
|
||||||
|
{
|
||||||
|
wxArrayInt list;
|
||||||
|
m_pListBox->GetSelections(list);
|
||||||
|
if(list.Count()==1)
|
||||||
|
{
|
||||||
|
selection = list.Item(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
selection = m_pListBox->GetSelection();
|
||||||
|
}
|
||||||
|
|
||||||
wxString strSelection;
|
wxString strSelection;
|
||||||
strSelection.Printf(wxT("Item %d double clicked"), m_pListBox->GetSelection());
|
if ( selection != -1 )
|
||||||
|
{
|
||||||
|
strSelection.Printf(wxT("Item %d double clicked"), selection);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
strSelection = wxT("List double clicked in multiple selection mode");
|
||||||
|
}
|
||||||
wxMessageDialog dialog(this, strSelection, wxT("wxCheckListBox message"), wxICON_INFORMATION);
|
wxMessageDialog dialog(this, strSelection, wxT("wxCheckListBox message"), wxICON_INFORMATION);
|
||||||
dialog.ShowModal();
|
dialog.ShowModal();
|
||||||
}
|
}
|
||||||
@ -325,17 +347,30 @@ void CheckListBoxFrame::OnCheckboxToggle(wxCommandEvent& event)
|
|||||||
|
|
||||||
void CheckListBoxFrame::OnButtonUp(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnButtonUp(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
OnButtonMove(TRUE);
|
OnButtonMove(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::OnButtonDown(wxCommandEvent& WXUNUSED(event))
|
void CheckListBoxFrame::OnButtonDown(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
OnButtonMove(FALSE);
|
OnButtonMove(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckListBoxFrame::OnButtonMove(bool up)
|
void CheckListBoxFrame::OnButtonMove(bool up)
|
||||||
{
|
{
|
||||||
int selection = m_pListBox->GetSelection();
|
int selection = -1;
|
||||||
|
if(m_pListBox->GetWindowStyle() & wxLB_EXTENDED)
|
||||||
|
{
|
||||||
|
wxArrayInt list;
|
||||||
|
m_pListBox->GetSelections(list);
|
||||||
|
if(list.Count()==1)
|
||||||
|
{
|
||||||
|
selection = list.Item(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
selection = m_pListBox->GetSelection();
|
||||||
|
}
|
||||||
if ( selection != -1 )
|
if ( selection != -1 )
|
||||||
{
|
{
|
||||||
wxString label = m_pListBox->GetString(selection);
|
wxString label = m_pListBox->GetString(selection);
|
||||||
@ -369,16 +404,20 @@ void CheckListBoxFrame::OnButtonMove(bool up)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxLogStatus(this, wxT("Please select an item"));
|
wxLogStatus(this, wxT("Please select single item"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// not implemented in ports other than (native) MSW yet
|
||||||
|
#if defined(__WXMSW__) && !defined(__WXUNIVERSAL__)
|
||||||
void CheckListBoxFrame::AdjustColour(size_t index)
|
void CheckListBoxFrame::AdjustColour(size_t index)
|
||||||
{
|
{
|
||||||
// not implemented in ports other than (native) MSW yet
|
|
||||||
#if defined(__WXMSW__) && !defined(__WXUNIVERSAL__)
|
|
||||||
// even items have grey backround, odd ones - white
|
// even items have grey backround, odd ones - white
|
||||||
unsigned char c = index % 2 ? 255 : 200;
|
unsigned char c = index % 2 ? 255 : 200;
|
||||||
m_pListBox->GetItem(index)->SetBackgroundColour(wxColor(c, c, c));
|
m_pListBox->GetItem(index)->SetBackgroundColour(wxColor(c, c, c));
|
||||||
#endif // wxMSW
|
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
void CheckListBoxFrame::AdjustColour(size_t WXUNUSED(index))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
#endif // wxMSW
|
||||||
|
@ -108,7 +108,7 @@ public:
|
|||||||
void OnPositionChanged(wxSplitterEvent& event);
|
void OnPositionChanged(wxSplitterEvent& event);
|
||||||
void OnPositionChanging(wxSplitterEvent& event);
|
void OnPositionChanging(wxSplitterEvent& event);
|
||||||
void OnDClick(wxSplitterEvent& event);
|
void OnDClick(wxSplitterEvent& event);
|
||||||
void OnUnsplit(wxSplitterEvent& event);
|
void OnUnsplitEvent(wxSplitterEvent& event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
wxFrame *m_frame;
|
wxFrame *m_frame;
|
||||||
@ -146,9 +146,9 @@ bool MyApp::OnInit()
|
|||||||
// create and show the main frame
|
// create and show the main frame
|
||||||
MyFrame* frame = new MyFrame;
|
MyFrame* frame = new MyFrame;
|
||||||
|
|
||||||
frame->Show(TRUE);
|
frame->Show(true);
|
||||||
|
|
||||||
return TRUE;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@ -172,7 +172,7 @@ END_EVENT_TABLE()
|
|||||||
|
|
||||||
// My frame constructor
|
// My frame constructor
|
||||||
MyFrame::MyFrame()
|
MyFrame::MyFrame()
|
||||||
: wxFrame(NULL, -1, _T("wxSplitterWindow sample"),
|
: wxFrame(NULL, wxID_ANY, _T("wxSplitterWindow sample"),
|
||||||
wxDefaultPosition, wxSize(420, 300),
|
wxDefaultPosition, wxSize(420, 300),
|
||||||
wxDEFAULT_FRAME_STYLE | wxNO_FULL_REPAINT_ON_RESIZE)
|
wxDEFAULT_FRAME_STYLE | wxNO_FULL_REPAINT_ON_RESIZE)
|
||||||
{
|
{
|
||||||
@ -209,7 +209,7 @@ MyFrame::MyFrame()
|
|||||||
|
|
||||||
SetMenuBar(menuBar);
|
SetMenuBar(menuBar);
|
||||||
|
|
||||||
menuBar->Check(SPLIT_LIVE, TRUE);
|
menuBar->Check(SPLIT_LIVE, true);
|
||||||
m_splitter = new MySplitterWindow(this);
|
m_splitter = new MySplitterWindow(this);
|
||||||
|
|
||||||
#if 1
|
#if 1
|
||||||
@ -222,13 +222,13 @@ MyFrame::MyFrame()
|
|||||||
m_right->SetBackgroundColour(*wxCYAN);
|
m_right->SetBackgroundColour(*wxCYAN);
|
||||||
m_right->SetScrollbars(20, 20, 5, 5);
|
m_right->SetScrollbars(20, 20, 5, 5);
|
||||||
#else // for testing kbd navigation inside the splitter
|
#else // for testing kbd navigation inside the splitter
|
||||||
m_left = new wxTextCtrl(m_splitter, -1, _T("first text"));
|
m_left = new wxTextCtrl(m_splitter, wxID_ANY, _T("first text"));
|
||||||
m_right = new wxTextCtrl(m_splitter, -1, _T("second text"));
|
m_right = new wxTextCtrl(m_splitter, wxID_ANY, _T("second text"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// you can also do this to start with a single window
|
// you can also do this to start with a single window
|
||||||
#if 0
|
#if 0
|
||||||
m_right->Show(FALSE);
|
m_right->Show(false);
|
||||||
m_splitter->Initialize(m_left);
|
m_splitter->Initialize(m_left);
|
||||||
#else
|
#else
|
||||||
// you can also try -100
|
// you can also try -100
|
||||||
@ -246,15 +246,15 @@ MyFrame::~MyFrame()
|
|||||||
|
|
||||||
void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) )
|
void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
Close(TRUE);
|
Close(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) )
|
void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
if ( m_splitter->IsSplit() )
|
if ( m_splitter->IsSplit() )
|
||||||
m_splitter->Unsplit();
|
m_splitter->Unsplit();
|
||||||
m_left->Show(TRUE);
|
m_left->Show(true);
|
||||||
m_right->Show(TRUE);
|
m_right->Show(true);
|
||||||
m_splitter->SplitHorizontally( m_left, m_right );
|
m_splitter->SplitHorizontally( m_left, m_right );
|
||||||
|
|
||||||
SetStatusText(_T("Splitter split horizontally"), 1);
|
SetStatusText(_T("Splitter split horizontally"), 1);
|
||||||
@ -264,8 +264,8 @@ void MyFrame::SplitVertical(wxCommandEvent& WXUNUSED(event) )
|
|||||||
{
|
{
|
||||||
if ( m_splitter->IsSplit() )
|
if ( m_splitter->IsSplit() )
|
||||||
m_splitter->Unsplit();
|
m_splitter->Unsplit();
|
||||||
m_left->Show(TRUE);
|
m_left->Show(true);
|
||||||
m_right->Show(TRUE);
|
m_right->Show(true);
|
||||||
m_splitter->SplitVertically( m_left, m_right );
|
m_splitter->SplitVertically( m_left, m_right );
|
||||||
|
|
||||||
SetStatusText(_T("Splitter split vertically"), 1);
|
SetStatusText(_T("Splitter split vertically"), 1);
|
||||||
@ -345,16 +345,16 @@ void MyFrame::UpdateUIUnsplit(wxUpdateUIEvent& event)
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(MySplitterWindow, wxSplitterWindow)
|
BEGIN_EVENT_TABLE(MySplitterWindow, wxSplitterWindow)
|
||||||
EVT_SPLITTER_SASH_POS_CHANGED(-1, MySplitterWindow::OnPositionChanged)
|
EVT_SPLITTER_SASH_POS_CHANGED(wxID_ANY, MySplitterWindow::OnPositionChanged)
|
||||||
EVT_SPLITTER_SASH_POS_CHANGING(-1, MySplitterWindow::OnPositionChanging)
|
EVT_SPLITTER_SASH_POS_CHANGING(wxID_ANY, MySplitterWindow::OnPositionChanging)
|
||||||
|
|
||||||
EVT_SPLITTER_DCLICK(-1, MySplitterWindow::OnDClick)
|
EVT_SPLITTER_DCLICK(wxID_ANY, MySplitterWindow::OnDClick)
|
||||||
|
|
||||||
EVT_SPLITTER_UNSPLIT(-1, MySplitterWindow::OnUnsplit)
|
EVT_SPLITTER_UNSPLIT(wxID_ANY, MySplitterWindow::OnUnsplitEvent)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
MySplitterWindow::MySplitterWindow(wxFrame *parent)
|
MySplitterWindow::MySplitterWindow(wxFrame *parent)
|
||||||
: wxSplitterWindow(parent, -1,
|
: wxSplitterWindow(parent, wxID_ANY,
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
wxSP_3D | wxSP_LIVE_UPDATE |
|
wxSP_3D | wxSP_LIVE_UPDATE |
|
||||||
wxCLIP_CHILDREN /* | wxSP_NO_XP_THEME */ )
|
wxCLIP_CHILDREN /* | wxSP_NO_XP_THEME */ )
|
||||||
@ -385,7 +385,7 @@ void MySplitterWindow::OnDClick(wxSplitterEvent& event)
|
|||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MySplitterWindow::OnUnsplit(wxSplitterEvent& event)
|
void MySplitterWindow::OnUnsplitEvent(wxSplitterEvent& event)
|
||||||
{
|
{
|
||||||
m_frame->SetStatusText(_T("Splitter unsplit"), 1);
|
m_frame->SetStatusText(_T("Splitter unsplit"), 1);
|
||||||
|
|
||||||
@ -397,7 +397,7 @@ void MySplitterWindow::OnUnsplit(wxSplitterEvent& event)
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
MyCanvas::MyCanvas(wxWindow* parent, bool mirror)
|
MyCanvas::MyCanvas(wxWindow* parent, bool mirror)
|
||||||
: wxScrolledWindow(parent, -1, wxDefaultPosition, wxDefaultSize,
|
: wxScrolledWindow(parent, wxID_ANY, wxDefaultPosition, wxDefaultSize,
|
||||||
wxHSCROLL | wxVSCROLL | wxNO_FULL_REPAINT_ON_RESIZE)
|
wxHSCROLL | wxVSCROLL | wxNO_FULL_REPAINT_ON_RESIZE)
|
||||||
{
|
{
|
||||||
m_mirror = mirror;
|
m_mirror = mirror;
|
||||||
|
Loading…
Reference in New Issue
Block a user