X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/77e0a6d8c3507b27661417b43fd1c8e616ba6367..8aa40b04f87deb33b41efab7a6a28fc9fc053d8d:/samples/splitter/splitter.cpp diff --git a/samples/splitter/splitter.cpp b/samples/splitter/splitter.cpp index f927de8ca0..a25419d30e 100644 --- a/samples/splitter/splitter.cpp +++ b/samples/splitter/splitter.cpp @@ -39,6 +39,10 @@ #include "wx/splitter.h" #include "wx/dcmirror.h" +#ifndef __WXMSW__ + #include "../sample.xpm" +#endif + // ---------------------------------------------------------------------------- // constants // ---------------------------------------------------------------------------- @@ -51,9 +55,12 @@ enum SPLIT_VERTICAL, SPLIT_UNSPLIT, SPLIT_LIVE, + SPLIT_BORDER, + SPLIT_3DSASH, SPLIT_SETPOSITION, SPLIT_SETMINSIZE, - SPLIT_SETGRAVITY + SPLIT_SETGRAVITY, + SPLIT_REPLACE }; // ---------------------------------------------------------------------------- @@ -67,38 +74,47 @@ public: virtual bool OnInit(); - DECLARE_NO_COPY_CLASS(MyApp) + wxDECLARE_NO_COPY_CLASS(MyApp); }; class MyFrame: public wxFrame { public: MyFrame(); - virtual ~MyFrame(){}; + virtual ~MyFrame(); - // Menu commands - void SplitHorizontal(wxCommandEvent& event); - void SplitVertical(wxCommandEvent& event); - void Unsplit(wxCommandEvent& event); - void ToggleLive(wxCommandEvent& event); - void SetPosition(wxCommandEvent& event); - void SetMinSize(wxCommandEvent& event); - void SetGravity(wxCommandEvent& event); + void ToggleFlag(int flag, bool enable); - void Quit(wxCommandEvent& event); + // Menu commands + void OnSplitHorizontal(wxCommandEvent& event); + void OnSplitVertical(wxCommandEvent& event); + void OnUnsplit(wxCommandEvent& event); + void OnToggleLive(wxCommandEvent& event) + { ToggleFlag(wxSP_LIVE_UPDATE, event.IsChecked()); } + void OnToggleBorder(wxCommandEvent& event) + { ToggleFlag(wxSP_BORDER, event.IsChecked()); } + void OnToggle3DSash(wxCommandEvent& event) + { ToggleFlag(wxSP_3DSASH, event.IsChecked()); } + void OnSetPosition(wxCommandEvent& event); + void OnSetMinSize(wxCommandEvent& event); + void OnSetGravity(wxCommandEvent& event); + void OnReplace(wxCommandEvent &event); + + void OnQuit(wxCommandEvent& event); // Menu command update functions - void UpdateUIHorizontal(wxUpdateUIEvent& event); - void UpdateUIVertical(wxUpdateUIEvent& event); - void UpdateUIUnsplit(wxUpdateUIEvent& event); + void OnUpdateUIHorizontal(wxUpdateUIEvent& event); + void OnUpdateUIVertical(wxUpdateUIEvent& event); + void OnUpdateUIUnsplit(wxUpdateUIEvent& event); private: wxScrolledWindow *m_left, *m_right; wxSplitterWindow* m_splitter; + wxWindow *m_replacewindow; DECLARE_EVENT_TABLE() - DECLARE_NO_COPY_CLASS(MyFrame) + wxDECLARE_NO_COPY_CLASS(MyFrame); }; class MySplitterWindow : public wxSplitterWindow @@ -116,7 +132,7 @@ private: wxFrame *m_frame; DECLARE_EVENT_TABLE() - DECLARE_NO_COPY_CLASS(MySplitterWindow) + wxDECLARE_NO_COPY_CLASS(MySplitterWindow); }; class MyCanvas: public wxScrolledWindow @@ -130,7 +146,7 @@ public: private: bool m_mirror; - DECLARE_NO_COPY_CLASS(MyCanvas) + wxDECLARE_NO_COPY_CLASS(MyCanvas); }; // ============================================================================ @@ -145,6 +161,9 @@ IMPLEMENT_APP(MyApp) bool MyApp::OnInit() { + if ( !wxApp::OnInit() ) + return false; + // create and show the main frame MyFrame* frame = new MyFrame; @@ -158,19 +177,22 @@ bool MyApp::OnInit() // ---------------------------------------------------------------------------- BEGIN_EVENT_TABLE(MyFrame, wxFrame) - EVT_MENU(SPLIT_VERTICAL, MyFrame::SplitVertical) - EVT_MENU(SPLIT_HORIZONTAL, MyFrame::SplitHorizontal) - EVT_MENU(SPLIT_UNSPLIT, MyFrame::Unsplit) - EVT_MENU(SPLIT_LIVE, MyFrame::ToggleLive) - EVT_MENU(SPLIT_SETPOSITION, MyFrame::SetPosition) - EVT_MENU(SPLIT_SETMINSIZE, MyFrame::SetMinSize) - EVT_MENU(SPLIT_SETGRAVITY, MyFrame::SetGravity) - - EVT_MENU(SPLIT_QUIT, MyFrame::Quit) - - EVT_UPDATE_UI(SPLIT_VERTICAL, MyFrame::UpdateUIVertical) - EVT_UPDATE_UI(SPLIT_HORIZONTAL, MyFrame::UpdateUIHorizontal) - EVT_UPDATE_UI(SPLIT_UNSPLIT, MyFrame::UpdateUIUnsplit) + EVT_MENU(SPLIT_VERTICAL, MyFrame::OnSplitVertical) + EVT_MENU(SPLIT_HORIZONTAL, MyFrame::OnSplitHorizontal) + EVT_MENU(SPLIT_UNSPLIT, MyFrame::OnUnsplit) + EVT_MENU(SPLIT_LIVE, MyFrame::OnToggleLive) + EVT_MENU(SPLIT_BORDER, MyFrame::OnToggleBorder) + EVT_MENU(SPLIT_3DSASH, MyFrame::OnToggle3DSash) + EVT_MENU(SPLIT_SETPOSITION, MyFrame::OnSetPosition) + EVT_MENU(SPLIT_SETMINSIZE, MyFrame::OnSetMinSize) + EVT_MENU(SPLIT_SETGRAVITY, MyFrame::OnSetGravity) + EVT_MENU(SPLIT_REPLACE, MyFrame::OnReplace) + + EVT_MENU(SPLIT_QUIT, MyFrame::OnQuit) + + EVT_UPDATE_UI(SPLIT_VERTICAL, MyFrame::OnUpdateUIVertical) + EVT_UPDATE_UI(SPLIT_HORIZONTAL, MyFrame::OnUpdateUIHorizontal) + EVT_UPDATE_UI(SPLIT_UNSPLIT, MyFrame::OnUpdateUIUnsplit) END_EVENT_TABLE() // My frame constructor @@ -179,6 +201,8 @@ MyFrame::MyFrame() wxDefaultPosition, wxSize(420, 300), wxDEFAULT_FRAME_STYLE | wxNO_FULL_REPAINT_ON_RESIZE) { + SetIcon(wxICON(sample)); + #if wxUSE_STATUSBAR CreateStatusBar(2); #endif // wxUSE_STATUSBAR @@ -199,6 +223,14 @@ MyFrame::MyFrame() splitMenu->AppendCheckItem(SPLIT_LIVE, _T("&Live update\tCtrl-L"), _T("Toggle live update mode")); + splitMenu->AppendCheckItem(SPLIT_BORDER, + _T("3D &Border"), + _T("Toggle wxSP_BORDER flag")); + splitMenu->Check(SPLIT_BORDER, true); + splitMenu->AppendCheckItem(SPLIT_3DSASH, + _T("&3D Sash"), + _T("Toggle wxSP_3DSASH flag")); + splitMenu->Check(SPLIT_3DSASH, true); splitMenu->Append(SPLIT_SETPOSITION, _T("Set splitter &position\tCtrl-P"), _T("Set the splitter position")); @@ -210,6 +242,11 @@ MyFrame::MyFrame() _T("Set gravity of sash")); splitMenu->AppendSeparator(); + splitMenu->Append(SPLIT_REPLACE, + _T("&Replace right window"), + _T("Replace right window")); + splitMenu->AppendSeparator(); + splitMenu->Append(SPLIT_QUIT, _T("E&xit\tAlt-X"), _T("Exit")); wxMenuBar *menuBar = new wxMenuBar; @@ -219,7 +256,7 @@ MyFrame::MyFrame() menuBar->Check(SPLIT_LIVE, true); m_splitter = new MySplitterWindow(this); - + m_splitter->SetSashGravity(1.0); #if 1 @@ -248,16 +285,26 @@ MyFrame::MyFrame() #if wxUSE_STATUSBAR SetStatusText(_T("Min pane size = 0"), 1); #endif // wxUSE_STATUSBAR + + m_replacewindow = (wxWindow *)0; +} + +MyFrame::~MyFrame() +{ + if (m_replacewindow) { + m_replacewindow->Destroy(); + m_replacewindow = (wxWindow *)0; + } } // menu command handlers -void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event) ) { Close(true); } -void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnSplitHorizontal(wxCommandEvent& WXUNUSED(event) ) { if ( m_splitter->IsSplit() ) m_splitter->Unsplit(); @@ -270,7 +317,7 @@ void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) ) #endif // wxUSE_STATUSBAR } -void MyFrame::SplitVertical(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnSplitVertical(wxCommandEvent& WXUNUSED(event) ) { if ( m_splitter->IsSplit() ) m_splitter->Unsplit(); @@ -283,7 +330,7 @@ void MyFrame::SplitVertical(wxCommandEvent& WXUNUSED(event) ) #endif // wxUSE_STATUSBAR } -void MyFrame::Unsplit(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnUnsplit(wxCommandEvent& WXUNUSED(event) ) { if ( m_splitter->IsSplit() ) m_splitter->Unsplit(); @@ -292,22 +339,29 @@ void MyFrame::Unsplit(wxCommandEvent& WXUNUSED(event) ) #endif // wxUSE_STATUSBAR } -void MyFrame::ToggleLive(wxCommandEvent& event ) +void MyFrame::ToggleFlag(int flag, bool enable) { long style = m_splitter->GetWindowStyleFlag(); - if ( event.IsChecked() ) - style |= wxSP_LIVE_UPDATE; + if ( enable ) + style |= flag; else - style &= ~wxSP_LIVE_UPDATE; + style &= ~flag; m_splitter->SetWindowStyleFlag(style); + + // we need to move sash to redraw it + int pos = m_splitter->GetSashPosition(); + m_splitter->SetSashPosition(pos + 1); + m_splitter->SetSashPosition(pos); } -void MyFrame::SetPosition(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnSetPosition(wxCommandEvent& WXUNUSED(event) ) { wxString str; str.Printf( wxT("%d"), m_splitter->GetSashPosition()); +#if wxUSE_TEXTDLG str = wxGetTextFromUser(_T("Enter splitter position:"), _T(""), str, this); +#endif if ( str.empty() ) return; @@ -323,11 +377,13 @@ void MyFrame::SetPosition(wxCommandEvent& WXUNUSED(event) ) wxLogStatus(this, _T("Splitter position set to %ld"), pos); } -void MyFrame::SetMinSize(wxCommandEvent& WXUNUSED(event) ) +void MyFrame::OnSetMinSize(wxCommandEvent& WXUNUSED(event) ) { wxString str; str.Printf( wxT("%d"), m_splitter->GetMinimumPaneSize()); +#if wxUSE_TEXTDLG str = wxGetTextFromUser(_T("Enter minimal size for panes:"), _T(""), str, this); +#endif if ( str.empty() ) return; @@ -338,11 +394,14 @@ void MyFrame::SetMinSize(wxCommandEvent& WXUNUSED(event) ) SetStatusText(str, 1); #endif // wxUSE_STATUSBAR } -void MyFrame::SetGravity(wxCommandEvent& WXUNUSED(event) ) + +void MyFrame::OnSetGravity(wxCommandEvent& WXUNUSED(event) ) { wxString str; str.Printf( wxT("%g"), m_splitter->GetSashGravity()); +#if wxUSE_TEXTDLG str = wxGetTextFromUser(_T("Enter sash gravity (0,1):"), _T(""), str, this); +#endif if ( str.empty() ) return; @@ -354,19 +413,34 @@ void MyFrame::SetGravity(wxCommandEvent& WXUNUSED(event) ) #endif // wxUSE_STATUSBAR } +void MyFrame::OnReplace(wxCommandEvent& WXUNUSED(event) ) +{ + if (m_replacewindow == 0) { + m_replacewindow = m_splitter->GetWindow2(); + m_splitter->ReplaceWindow(m_replacewindow, new wxPanel(m_splitter, wxID_ANY)); + m_replacewindow->Hide(); + } else { + wxWindow *empty = m_splitter->GetWindow2(); + m_splitter->ReplaceWindow(empty, m_replacewindow); + m_replacewindow->Show(); + m_replacewindow = 0; + empty->Destroy(); + } +} + // Update UI handlers -void MyFrame::UpdateUIHorizontal(wxUpdateUIEvent& event) +void MyFrame::OnUpdateUIHorizontal(wxUpdateUIEvent& event) { event.Enable( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_HORIZONTAL) ); } -void MyFrame::UpdateUIVertical(wxUpdateUIEvent& event) +void MyFrame::OnUpdateUIVertical(wxUpdateUIEvent& event) { event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_VERTICAL) ) ); } -void MyFrame::UpdateUIUnsplit(wxUpdateUIEvent& event) +void MyFrame::OnUpdateUIUnsplit(wxUpdateUIEvent& event) { event.Enable( m_splitter->IsSplit() ); } @@ -445,7 +519,7 @@ void MyCanvas::OnDraw(wxDC& dcOrig) dc.SetPen(*wxBLACK_PEN); dc.DrawLine(0, 0, 100, 200); - dc.SetBackgroundMode(wxTRANSPARENT); + dc.SetBackgroundMode(wxBRUSHSTYLE_TRANSPARENT); dc.DrawText(_T("Testing"), 50, 50); dc.SetPen(*wxRED_PEN);