X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3ca6a5f04692678cd2d9f3ea0843fc3f5a0b254f..2b96d0fb4be7d684c17987d74f8f92d0cfe345b5:/samples/menu/menu.cpp diff --git a/samples/menu/menu.cpp b/samples/menu/menu.cpp index cee944b197..0751bad75d 100644 --- a/samples/menu/menu.cpp +++ b/samples/menu/menu.cpp @@ -25,11 +25,21 @@ #endif #ifndef WX_PRECOMP - #include - + #include + #include + #include + #include #include + #include #endif +#if !wxUSE_MENUS + // nice try... + #error "menu sample requires wxUSE_MENUS=1" +#endif // wxUSE_MENUS + +#include "copy.xpm" + // ---------------------------------------------------------------------------- // classes // ---------------------------------------------------------------------------- @@ -51,7 +61,10 @@ public: void LogMenuEvent(const wxCommandEvent& event); +protected: void OnQuit(wxCommandEvent& event); + void OnClearLog(wxCommandEvent& event); + void OnAbout(wxCommandEvent& event); void OnDummy(wxCommandEvent& event); @@ -74,19 +87,29 @@ public: void OnGetLabelMenu(wxCommandEvent& event); void OnSetLabelMenu(wxCommandEvent& event); - void OnRightDown(wxMouseEvent& event); + void OnRightUp(wxMouseEvent& event); void OnUpdateCheckMenuItemUI(wxUpdateUIEvent& event); + void OnSize(wxSizeEvent& event); + private: wxMenu *CreateDummyMenu(wxString *title); wxMenuItem *GetLastMenuItem() const; - wxMenu *m_menu; + // the menu previously detached from the menubar (may be NULL) + wxMenu *m_menu; + // the count of dummy menus already created size_t m_countDummy; + // the control used for logging + wxTextCtrl *m_textctrl; + + // the previous log target + wxLog *m_logOld; + DECLARE_EVENT_TABLE() }; @@ -116,6 +139,7 @@ private: enum { Menu_File_Quit = 100, + Menu_File_ClearLog, Menu_MenuBar_Toggle = 200, Menu_MenuBar_Append, @@ -156,7 +180,8 @@ enum // ---------------------------------------------------------------------------- BEGIN_EVENT_TABLE(MyFrame, wxFrame) - EVT_MENU(Menu_File_Quit, MyFrame::OnQuit) + EVT_MENU(Menu_File_Quit, MyFrame::OnQuit) + EVT_MENU(Menu_File_ClearLog, MyFrame::OnClearLog) EVT_MENU(Menu_Help_About, MyFrame::OnAbout) @@ -182,7 +207,9 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_UPDATE_UI(Menu_Menu_Check, MyFrame::OnUpdateCheckMenuItemUI) - EVT_RIGHT_DOWN(MyFrame::OnRightDown) + EVT_RIGHT_UP(MyFrame::OnRightUp) + + EVT_SIZE(MyFrame::OnSize) END_EVENT_TABLE() BEGIN_EVENT_TABLE(MyEvtHandler, wxEvtHandler) @@ -208,7 +235,9 @@ bool MyApp::OnInit() frame->Show(TRUE); - frame->SetStatusText("Hello, wxWindows"); +#if wxUSE_STATUSBAR + frame->SetStatusText("Welcome to wxWindows menu sample"); +#endif // wxUSE_STATUSBAR SetTopWindow(frame); @@ -226,12 +255,21 @@ MyFrame::MyFrame() { m_menu = NULL; m_countDummy = 0; + m_logOld = NULL; - CreateStatusBar(2); +#if wxUSE_STATUSBAR + CreateStatusBar(); +#endif // wxUSE_STATUSBAR // create the menubar wxMenu *fileMenu = new wxMenu; - fileMenu->Append(Menu_File_Quit, "E&xit\tAlt-X", "Quit toolbar sample" ); + + wxMenuItem *item = new wxMenuItem(fileMenu, Menu_File_ClearLog, + "Clear &log\tCtrl-L"); + item->SetBitmap(copy_xpm); + fileMenu->Append(item); + fileMenu->AppendSeparator(); + fileMenu->Append(Menu_File_Quit, "E&xit\tAlt-X", "Quit menu sample"); wxMenu *menubarMenu = new wxMenu; menubarMenu->Append(Menu_MenuBar_Append, "&Append menu\tCtrl-A", @@ -295,6 +333,19 @@ MyFrame::MyFrame() // intercept all menu events and log them in this custom event handler PushEventHandler(new MyEvtHandler(this)); + + // create the log text window + m_textctrl = new wxTextCtrl(this, -1, _T(""), + wxDefaultPosition, wxDefaultSize, + wxTE_MULTILINE); + m_textctrl->SetEditable(FALSE); + m_logOld = wxLog::SetActiveTarget(new wxLogTextCtrl(m_textctrl)); + + wxLogMessage(_T("Brief explanations: the commands or the \"Menu\" menu\n") + _T("append/insert/delete items to/from the last menu.\n") + _T("The commands from \"Menubar\" menu work with the\n") + _T("menubar itself.\n") + _T("Right click the band below to test popup menus.\n")); } MyFrame::~MyFrame() @@ -303,14 +354,17 @@ MyFrame::~MyFrame() // delete the event handler installed in ctor PopEventHandler(TRUE); + + // restore old logger + delete wxLog::SetActiveTarget(m_logOld); } wxMenu *MyFrame::CreateDummyMenu(wxString *title) { wxMenu *menu = new wxMenu; - menu->Append(Menu_Dummy_First, "First item\tCtrl-F1"); + menu->Append(Menu_Dummy_First, "&First item\tCtrl-F1"); menu->AppendSeparator(); - menu->Append(Menu_Dummy_Second, "Second item\tCtrl-F2", "", TRUE); + menu->Append(Menu_Dummy_Second, "&Second item\tCtrl-F2", "", TRUE); if ( title ) { @@ -341,6 +395,9 @@ wxMenuItem *MyFrame::GetLastMenuItem() const void MyFrame::LogMenuEvent(const wxCommandEvent& event) { int id = event.GetId(); + if ( !GetMenuBar()->FindItem(id) ) + return; + wxString msg = wxString::Format("Menu command %d", id); if ( GetMenuBar()->FindItem(id)->IsCheckable() ) { @@ -348,7 +405,7 @@ void MyFrame::LogMenuEvent(const wxCommandEvent& event) event.IsChecked() ? "" : "not "); } - SetStatusText(msg, 1); + wxLogMessage(msg); } // ---------------------------------------------------------------------------- @@ -360,9 +417,14 @@ void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event)) Close(TRUE); } +void MyFrame::OnClearLog(wxCommandEvent& WXUNUSED(event)) +{ + m_textctrl->Clear(); +} + void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) { - (void)wxMessageBox("wxWindows toolbar sample", + (void)wxMessageBox("wxWindows menu sample\n© 1999-2001 Vadim Zeitlin", "About wxWindows menu sample", wxICON_INFORMATION); } @@ -413,15 +475,12 @@ void MyFrame::OnToggleMenu(wxCommandEvent& WXUNUSED(event)) } } -void MyFrame::OnEnableMenu(wxCommandEvent& WXUNUSED(event)) +void MyFrame::OnEnableMenu(wxCommandEvent& event) { wxMenuBar *mbar = GetMenuBar(); size_t count = mbar->GetMenuCount(); - static bool s_enabled = TRUE; - - s_enabled = !s_enabled; - mbar->EnableTop(count - 1, s_enabled); + mbar->EnableTop(count - 1, event.IsChecked()); } void MyFrame::OnGetLabelMenu(wxCommandEvent& WXUNUSED(event)) @@ -443,9 +502,7 @@ void MyFrame::OnSetLabelMenu(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnDummy(wxCommandEvent& event) { - wxString s; - s.Printf("Dummy item #%d", event.GetId() - Menu_Dummy_First + 1); - wxMessageBox(s, "Menu sample", wxICON_INFORMATION); + wxLogMessage("Dummy item #%d", event.GetId() - Menu_Dummy_First + 1); } void MyFrame::OnAppendMenuItem(wxCommandEvent& WXUNUSED(event)) @@ -454,7 +511,7 @@ void MyFrame::OnAppendMenuItem(wxCommandEvent& WXUNUSED(event)) wxMenu *menu = menubar->GetMenu(menubar->GetMenuCount() - 1); menu->AppendSeparator(); - menu->Append(Menu_Dummy_Third, "Third dummy item\tCtrl-F3", + menu->Append(Menu_Dummy_Third, "&Third dummy item\tCtrl-F3", "Checkable item", TRUE); } @@ -464,7 +521,7 @@ void MyFrame::OnAppendSubMenu(wxCommandEvent& WXUNUSED(event)) wxMenu *menu = menubar->GetMenu(menubar->GetMenuCount() - 1); - menu->Append(Menu_Dummy_Last, "Dummy sub menu", + menu->Append(Menu_Dummy_Last, "&Dummy sub menu", CreateDummyMenu(NULL), "Dummy sub menu help"); } @@ -616,15 +673,15 @@ void MyFrame::OnGetMenuItemInfo(wxCommandEvent& WXUNUSED(event)) } } -void MyFrame::OnRightDown(wxMouseEvent &event ) +void MyFrame::OnRightUp(wxMouseEvent &event) { wxMenu menu("Test popup"); menu.Append(Menu_Help_About, "&About"); - menu.Append(Menu_Popup_Submenu, "Submenu", CreateDummyMenu(NULL)); - menu.Append(Menu_Popup_ToBeDeleted, "To be deleted"); - menu.Append(Menu_Popup_ToBeChecked, "To be checked", "", TRUE); - menu.Append(Menu_Popup_ToBeGreyed, "To be greyed"); + menu.Append(Menu_Popup_Submenu, "&Submenu", CreateDummyMenu(NULL)); + menu.Append(Menu_Popup_ToBeDeleted, "To be &deleted"); + menu.Append(Menu_Popup_ToBeChecked, "To be &checked", "", TRUE); + menu.Append(Menu_Popup_ToBeGreyed, "To be &greyed"); menu.AppendSeparator(); menu.Append(Menu_File_Quit, "E&xit"); @@ -632,12 +689,27 @@ void MyFrame::OnRightDown(wxMouseEvent &event ) menu.Check(Menu_Popup_ToBeChecked, TRUE); menu.Enable(Menu_Popup_ToBeGreyed, FALSE); - PopupMenu( &menu, event.GetX(), event.GetY() ); + PopupMenu(&menu, event.GetX(), event.GetY()); // test for destroying items in popup menus -#if 0 +#if 0 // doesn't work in wxGTK! menu.Destroy(Menu_Popup_Submenu); PopupMenu( &menu, event.GetX(), event.GetY() ); #endif // 0 } + +void MyFrame::OnSize(wxSizeEvent& event) +{ + // leave a band below for popup menu testing + wxSize size = GetClientSize(); + m_textctrl->SetSize(0, 0, size.x, (3*size.y)/4); + + // this is really ugly but we have to do it as we can't just call + // event.Skip() because wxFrameBase would make the text control fill the + // entire frame then +#ifdef __WXUNIVERSAL__ + PositionMenuBar(); +#endif // __WXUNIVERSAL__ +} +