X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4a0b46a7622f28f8365e56b90d62209c63b4ba93..4c15b7aff2f65bbb2b63e7f4004bfe97e7cbd0e5:/samples/splitter/splitter.cpp?ds=inline diff --git a/samples/splitter/splitter.cpp b/samples/splitter/splitter.cpp index 89a7b7c829..a7ecbfd0e8 100644 --- a/samples/splitter/splitter.cpp +++ b/samples/splitter/splitter.cpp @@ -5,267 +5,387 @@ // Modified by: // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem +// Copyright: (c) Julian Smart // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// +// ============================================================================ +// declarations +// ============================================================================ + +// ---------------------------------------------------------------------------- +// headers +// ---------------------------------------------------------------------------- + // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ -#pragma hdrstop + #pragma hdrstop #endif #ifndef WX_PRECOMP -#include "wx/wx.h" + #include "wx/log.h" + + #include "wx/app.h" + #include "wx/frame.h" + + #include "wx/scrolwin.h" + #include "wx/menu.h" + + #include "wx/textdlg.h" // for wxGetTextFromUser #endif #include "wx/splitter.h" +#include "wx/dc.h" + +// ---------------------------------------------------------------------------- +// constants +// ---------------------------------------------------------------------------- + +// ID for the menu commands +enum +{ + SPLIT_QUIT, + SPLIT_HORIZONTAL, + SPLIT_VERTICAL, + SPLIT_UNSPLIT, + SPLIT_LIVE, + SPLIT_SETPOSITION, + SPLIT_SETMINSIZE +}; -class MyApp; -class MyFrame; -class MyCanvas; +// ---------------------------------------------------------------------------- +// our classes +// ---------------------------------------------------------------------------- class MyApp: public wxApp { public: - bool OnInit(); + bool OnInit(); }; -class MySplitterWindow : public wxSplitterWindow +class MyFrame: public wxFrame { public: - MySplitterWindow(wxFrame *parent, wxWindowID id) - : wxSplitterWindow(parent, id, wxDefaultPosition, wxDefaultSize, wxSP_3D | wxSP_LIVE_UPDATE) - { - m_frame = parent; - } + MyFrame(); + virtual ~MyFrame(); - virtual bool OnSashPositionChange(int newSashPosition) - { - if ( !wxSplitterWindow::OnSashPositionChange(newSashPosition) ) - return FALSE; + // 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); - wxString str; - str.Printf( _T("Sash position = %d"), newSashPosition); - m_frame->SetStatusText(str); + void Quit(wxCommandEvent& event); - return TRUE; - } + // Menu command update functions + void UpdateUIHorizontal(wxUpdateUIEvent& event); + void UpdateUIVertical(wxUpdateUIEvent& event); + void UpdateUIUnsplit(wxUpdateUIEvent& event); private: - wxFrame *m_frame; + wxScrolledWindow *m_left, *m_right; + + wxSplitterWindow* m_splitter; + + DECLARE_EVENT_TABLE() }; -class MyFrame: public wxFrame +class MySplitterWindow : public wxSplitterWindow { public: - MyFrame(wxFrame* frame, const wxString& title, const wxPoint& pos, const wxSize& size); - virtual ~MyFrame(); - - // Menu commands - void SplitHorizontal(wxCommandEvent& event); - void SplitVertical(wxCommandEvent& event); - void Unsplit(wxCommandEvent& event); - void SetMinSize(wxCommandEvent& event); - void Quit(wxCommandEvent& event); + MySplitterWindow(wxFrame *parent); - // Menu command update functions - void UpdateUIHorizontal(wxUpdateUIEvent& event); - void UpdateUIVertical(wxUpdateUIEvent& event); - void UpdateUIUnsplit(wxUpdateUIEvent& event); + // event handlers + void OnPositionChanged(wxSplitterEvent& event); + void OnPositionChanging(wxSplitterEvent& event); + void OnDClick(wxSplitterEvent& event); + void OnUnsplit(wxSplitterEvent& event); private: - void UpdatePosition(); + wxFrame *m_frame; - wxMenu* fileMenu; - wxMenuBar* menuBar; - MyCanvas* m_leftCanvas; - MyCanvas* m_rightCanvas; - MySplitterWindow* m_splitter; - -DECLARE_EVENT_TABLE() + DECLARE_EVENT_TABLE() }; class MyCanvas: public wxScrolledWindow { public: - MyCanvas(wxWindow* parent, wxWindowID id = -1, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, const wxString& name = ""); + MyCanvas(wxWindow* parent); virtual ~MyCanvas(); - virtual void OnDraw(wxDC& dc); - -DECLARE_EVENT_TABLE() + virtual void OnDraw(wxDC& dc); }; -BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow) -END_EVENT_TABLE() - -// ID for the menu commands -enum -{ - SPLIT_QUIT, - SPLIT_HORIZONTAL, - SPLIT_VERTICAL, - SPLIT_UNSPLIT, - SPLIT_SETMINSIZE -}; +// ============================================================================ +// implementation +// ============================================================================ -// Window ids -#define SPLITTER_WINDOW 100 -#define SPLITTER_FRAME 101 -#define CANVAS1 102 -#define CANVAS2 103 +// ---------------------------------------------------------------------------- +// MyApp +// ---------------------------------------------------------------------------- IMPLEMENT_APP(MyApp) -bool MyApp::OnInit(void) +bool MyApp::OnInit() { - MyFrame* frame = new MyFrame((wxFrame *) NULL, "wxSplitterWindow Example", - wxPoint(50, 50), wxSize(420, 300)); + // create and show the main frame + MyFrame* frame = new MyFrame; - // Show the frame - frame->Show(TRUE); + frame->Show(TRUE); - SetTopWindow(frame); - - return TRUE; + return TRUE; } +// ---------------------------------------------------------------------------- +// MyFrame +// ---------------------------------------------------------------------------- + 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_QUIT, MyFrame::Quit) - EVT_MENU(SPLIT_SETMINSIZE, MyFrame::SetMinSize) - - 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::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_QUIT, MyFrame::Quit) + + EVT_UPDATE_UI(SPLIT_VERTICAL, MyFrame::UpdateUIVertical) + EVT_UPDATE_UI(SPLIT_HORIZONTAL, MyFrame::UpdateUIHorizontal) + EVT_UPDATE_UI(SPLIT_UNSPLIT, MyFrame::UpdateUIUnsplit) END_EVENT_TABLE() // My frame constructor -MyFrame::MyFrame(wxFrame* frame, const wxString& title, const wxPoint& pos, const wxSize& size): - wxFrame(frame, SPLITTER_FRAME, title, pos, size) +MyFrame::MyFrame() + : wxFrame(NULL, -1, _T("wxSplitterWindow sample"), + wxDefaultPosition, wxSize(420, 300), + wxDEFAULT_FRAME_STYLE | wxNO_FULL_REPAINT_ON_RESIZE) { - CreateStatusBar(2); - - // Make a menubar - fileMenu = new wxMenu; - fileMenu->Append(SPLIT_VERTICAL, "Split &Vertically\tCtrl-V", "Split vertically"); - fileMenu->Append(SPLIT_HORIZONTAL, "Split &Horizontally\tCtrl-H", "Split horizontally"); - fileMenu->Append(SPLIT_UNSPLIT, "&Unsplit\tCtrl-U", "Unsplit"); - fileMenu->AppendSeparator(); - fileMenu->Append(SPLIT_SETMINSIZE, "Set &min size", "Set minimum pane size"); - fileMenu->AppendSeparator(); - fileMenu->Append(SPLIT_QUIT, "E&xit\tAlt-X", "Exit"); - - menuBar = new wxMenuBar; - menuBar->Append(fileMenu, "&File"); - - SetMenuBar(menuBar); - - m_splitter = new MySplitterWindow(this, SPLITTER_WINDOW); - -#if 0 - wxSize sz( m_splitter->GetSize() ); - wxLogMessage( "Initial splitter size: %d %d\n", (int)sz.x, (int)sz.y ); -#endif // 0 - - m_leftCanvas = new MyCanvas(m_splitter, CANVAS1, wxPoint(0, 0), wxSize(400, 400), "Test1" ); - m_leftCanvas->SetBackgroundColour(*wxRED); - m_leftCanvas->SetScrollbars(20, 20, 50, 50); - m_leftCanvas->SetCursor(wxCursor(wxCURSOR_MAGNIFIER)); - - m_rightCanvas = new MyCanvas(m_splitter, CANVAS2, wxPoint(0, 0), wxSize(400, 400), "Test2" ); - m_rightCanvas->SetBackgroundColour(*wxCYAN); - m_rightCanvas->SetScrollbars(20, 20, 50, 50); + CreateStatusBar(2); + + // Make a menubar + wxMenu *splitMenu = new wxMenu; + splitMenu->Append(SPLIT_VERTICAL, + _T("Split &Vertically\tCtrl-V"), + _T("Split vertically")); + splitMenu->Append(SPLIT_HORIZONTAL, + _T("Split &Horizontally\tCtrl-H"), + _T("Split horizontally")); + splitMenu->Append(SPLIT_UNSPLIT, + _T("&Unsplit\tCtrl-U"), + _T("Unsplit")); + splitMenu->AppendSeparator(); + + splitMenu->AppendCheckItem(SPLIT_LIVE, + _T("&Live update\tCtrl-L"), + _T("Toggle live update mode")); + splitMenu->Append(SPLIT_SETPOSITION, + _T("Set splitter &position\tCtrl-P"), + _T("Set the splitter position")); + splitMenu->Append(SPLIT_SETMINSIZE, + _T("Set &min size\tCtrl-M"), + _T("Set minimum pane size")); + splitMenu->AppendSeparator(); + + splitMenu->Append(SPLIT_QUIT, _T("E&xit\tAlt-X"), _T("Exit")); + + wxMenuBar *menuBar = new wxMenuBar; + menuBar->Append(splitMenu, _T("&Splitter")); + + SetMenuBar(menuBar); + + menuBar->Check(SPLIT_LIVE, TRUE); + m_splitter = new MySplitterWindow(this); + +#if 1 + m_left = new MyCanvas(m_splitter); + m_left->SetBackgroundColour(*wxRED); + m_left->SetScrollbars(20, 20, 50, 50); + m_left->SetCursor(wxCursor(wxCURSOR_MAGNIFIER)); + + m_right = new MyCanvas(m_splitter); + m_right->SetBackgroundColour(*wxCYAN); + m_right->SetScrollbars(20, 20, 50, 50); +#else // for testing kbd navigation inside the splitter + m_left = new wxTextCtrl(m_splitter, -1, _T("first text")); + m_right = new wxTextCtrl(m_splitter, -1, _T("second text")); +#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 - m_rightCanvas->Show(FALSE); - m_splitter->Initialize(m_leftCanvas); + m_right->Show(FALSE); + m_splitter->Initialize(m_left); #else - m_splitter->SplitVertically(m_leftCanvas, m_rightCanvas, 100); + // you can also try -100 + m_splitter->SplitVertically(m_left, m_right, 100); #endif - SetStatusText("Min pane size = 0", 1); + SetStatusText(_T("Min pane size = 0"), 1); } MyFrame::~MyFrame() { } +// menu command handlers + void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) ) { - Close(TRUE); + Close(TRUE); } void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) ) { - if ( m_splitter->IsSplit() ) - m_splitter->Unsplit(); - m_leftCanvas->Show(TRUE); - m_rightCanvas->Show(TRUE); - m_splitter->SplitHorizontally( m_leftCanvas, m_rightCanvas ); - UpdatePosition(); + if ( m_splitter->IsSplit() ) + m_splitter->Unsplit(); + m_left->Show(TRUE); + m_right->Show(TRUE); + m_splitter->SplitHorizontally( m_left, m_right ); + + SetStatusText(_T("Splitter split horizontally"), 1); } void MyFrame::SplitVertical(wxCommandEvent& WXUNUSED(event) ) { - if ( m_splitter->IsSplit() ) - m_splitter->Unsplit(); - m_leftCanvas->Show(TRUE); - m_rightCanvas->Show(TRUE); - m_splitter->SplitVertically( m_leftCanvas, m_rightCanvas ); - UpdatePosition(); + if ( m_splitter->IsSplit() ) + m_splitter->Unsplit(); + m_left->Show(TRUE); + m_right->Show(TRUE); + m_splitter->SplitVertically( m_left, m_right ); + + SetStatusText(_T("Splitter split vertically"), 1); } void MyFrame::Unsplit(wxCommandEvent& WXUNUSED(event) ) { - if ( m_splitter->IsSplit() ) - m_splitter->Unsplit(); - SetStatusText("No splitter"); + if ( m_splitter->IsSplit() ) + m_splitter->Unsplit(); + SetStatusText(_T("No splitter")); +} + +void MyFrame::ToggleLive(wxCommandEvent& event ) +{ + long style = m_splitter->GetWindowStyleFlag(); + if ( event.IsChecked() ) + style |= wxSP_LIVE_UPDATE; + else + style &= ~wxSP_LIVE_UPDATE; + + m_splitter->SetWindowStyleFlag(style); +} + +void MyFrame::SetPosition(wxCommandEvent& WXUNUSED(event) ) +{ + wxString str; + str.Printf( wxT("%d"), m_splitter->GetSashPosition()); + str = wxGetTextFromUser(_T("Enter splitter position:"), _T(""), str, this); + if ( str.empty() ) + return; + + long pos; + if ( !str.ToLong(&pos) ) + { + wxLogError(_T("The splitter position should be an integer.")); + return; + } + + m_splitter->SetSashPosition(pos); + + wxLogStatus(this, _T("Splitter position set to %ld"), pos); } void MyFrame::SetMinSize(wxCommandEvent& WXUNUSED(event) ) { - wxString str; - str.Printf( _T("%d"), m_splitter->GetMinimumPaneSize()); - str = wxGetTextFromUser("Enter minimal size for panes:", "", str, this); - if ( str.IsEmpty() ) - return; - - int minsize = wxStrtol( str, (wxChar**)NULL, 10 ); - m_splitter->SetMinimumPaneSize(minsize); - str.Printf( _T("Min pane size = %d"), minsize); - SetStatusText(str, 1); + wxString str; + str.Printf( wxT("%d"), m_splitter->GetMinimumPaneSize()); + str = wxGetTextFromUser(_T("Enter minimal size for panes:"), _T(""), str, this); + if ( str.empty() ) + return; + + int minsize = wxStrtol( str, (wxChar**)NULL, 10 ); + m_splitter->SetMinimumPaneSize(minsize); + str.Printf( wxT("Min pane size = %d"), minsize); + SetStatusText(str, 1); } +// Update UI handlers + void MyFrame::UpdateUIHorizontal(wxUpdateUIEvent& event) { - event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_HORIZONTAL) ) ); + event.Enable( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_HORIZONTAL) ); } void MyFrame::UpdateUIVertical(wxUpdateUIEvent& event) { - event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_VERTICAL) ) ); + event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_VERTICAL) ) ); } void MyFrame::UpdateUIUnsplit(wxUpdateUIEvent& event) { - event.Enable( m_splitter->IsSplit() ); + event.Enable( m_splitter->IsSplit() ); +} + +// ---------------------------------------------------------------------------- +// MySplitterWindow +// ---------------------------------------------------------------------------- + +BEGIN_EVENT_TABLE(MySplitterWindow, wxSplitterWindow) + EVT_SPLITTER_SASH_POS_CHANGED(-1, MySplitterWindow::OnPositionChanged) + EVT_SPLITTER_SASH_POS_CHANGING(-1, MySplitterWindow::OnPositionChanging) + + EVT_SPLITTER_DCLICK(-1, MySplitterWindow::OnDClick) + + EVT_SPLITTER_UNSPLIT(-1, MySplitterWindow::OnUnsplit) +END_EVENT_TABLE() + +MySplitterWindow::MySplitterWindow(wxFrame *parent) + : wxSplitterWindow(parent, -1, + wxDefaultPosition, wxDefaultSize, + wxSP_3D | wxSP_LIVE_UPDATE | wxCLIP_CHILDREN) +{ + m_frame = parent; +} + +void MySplitterWindow::OnPositionChanged(wxSplitterEvent& event) +{ + wxLogStatus(m_frame, _T("Position has changed, now = %d (or %d)"), + event.GetSashPosition(), GetSashPosition()); + + event.Skip(); +} + +void MySplitterWindow::OnPositionChanging(wxSplitterEvent& event) +{ + wxLogStatus(m_frame, _T("Position is changing, now = %d (or %d)"), + event.GetSashPosition(), GetSashPosition()); + + event.Skip(); +} + +void MySplitterWindow::OnDClick(wxSplitterEvent& event) +{ + m_frame->SetStatusText(_T("Splitter double clicked"), 1); + + event.Skip(); } -void MyFrame::UpdatePosition() +void MySplitterWindow::OnUnsplit(wxSplitterEvent& event) { - wxString str; - str.Printf( _("Sash position = %d"), m_splitter->GetSashPosition()); - SetStatusText(str); + m_frame->SetStatusText(_T("Splitter unsplit"), 1); + + event.Skip(); } -MyCanvas::MyCanvas(wxWindow* parent, wxWindowID id, const wxPoint& point, const wxSize& size, const wxString &name ) : - wxScrolledWindow(parent, id, point, size, 0, name ) +// ---------------------------------------------------------------------------- +// MyCanvas +// ---------------------------------------------------------------------------- + +MyCanvas::MyCanvas(wxWindow* parent) + : wxScrolledWindow(parent, -1) { } @@ -275,13 +395,14 @@ MyCanvas::~MyCanvas() void MyCanvas::OnDraw(wxDC& dc) { - dc.SetPen(*wxBLACK_PEN); - dc.DrawLine(0, 0, 100, 100); + dc.SetPen(*wxBLACK_PEN); + dc.DrawLine(0, 0, 100, 100); - dc.SetBackgroundMode(wxTRANSPARENT); - dc.DrawText("Testing", 50, 50); + dc.SetBackgroundMode(wxTRANSPARENT); + dc.DrawText(_T("Testing"), 50, 50); - dc.SetPen(*wxRED_PEN); - dc.SetBrush(*wxGREEN_BRUSH); - dc.DrawRectangle(120, 120, 100, 80); + dc.SetPen(*wxRED_PEN); + dc.SetBrush(*wxGREEN_BRUSH); + dc.DrawRectangle(120, 120, 100, 80); } +