X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a80c322c0ddbc9f7846d7d3565090a7f5cc1920e..3da93aae505563c359f58b357e6c79cd117c5320:/samples/menu/menu.cpp diff --git a/samples/menu/menu.cpp b/samples/menu/menu.cpp index bcbc815d70..1b098b2f39 100644 --- a/samples/menu/menu.cpp +++ b/samples/menu/menu.cpp @@ -65,6 +65,7 @@ public: void OnGetMenuItemInfo(wxCommandEvent& event); void OnAppendMenu(wxCommandEvent& event); + void OnInsertMenu(wxCommandEvent& event); void OnDeleteMenu(wxCommandEvent& event); void OnToggleMenu(wxCommandEvent& event); void OnEnableMenu(wxCommandEvent& event); @@ -76,12 +77,14 @@ public: void OnUpdateCheckMenuItemUI(wxUpdateUIEvent& event); private: - wxMenu *CreateDummyMenu(); + wxMenu *CreateDummyMenu(wxString *title); wxMenuItem *GetLastMenuItem() const; wxMenu *m_menu; + size_t m_countDummy; + DECLARE_EVENT_TABLE() }; @@ -95,6 +98,7 @@ enum Menu_MenuBar_Toggle = 200, Menu_MenuBar_Append, + Menu_MenuBar_Insert, Menu_MenuBar_Delete, Menu_MenuBar_Enable, Menu_MenuBar_GetLabel, @@ -137,6 +141,7 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_MENU(Menu_MenuBar_Toggle, MyFrame::OnToggleMenu) EVT_MENU(Menu_MenuBar_Append, MyFrame::OnAppendMenu) + EVT_MENU(Menu_MenuBar_Insert, MyFrame::OnInsertMenu) EVT_MENU(Menu_MenuBar_Delete, MyFrame::OnDeleteMenu) EVT_MENU(Menu_MenuBar_Enable, MyFrame::OnEnableMenu) EVT_MENU(Menu_MenuBar_GetLabel, MyFrame::OnGetLabelMenu) @@ -195,6 +200,7 @@ MyFrame::MyFrame() wxDefaultPosition, wxSize(300, 200)) { m_menu = NULL; + m_countDummy = 0; CreateStatusBar(); @@ -205,6 +211,8 @@ MyFrame::MyFrame() wxMenu *menubarMenu = new wxMenu; menubarMenu->Append(Menu_MenuBar_Append, "&Append menu\tCtrl-A", "Append a menu to the menubar"); + menubarMenu->Append(Menu_MenuBar_Insert, "&Insert menu\tCtrl-I", + "Insert a menu into the menubar"); menubarMenu->Append(Menu_MenuBar_Delete, "&Delete menu\tCtrl-D", "Delete the last menu from the menubar"); menubarMenu->Append(Menu_MenuBar_Toggle, "&Toggle menu\tCtrl-T", @@ -261,13 +269,18 @@ MyFrame::MyFrame() SetMenuBar(menuBar); } -wxMenu *MyFrame::CreateDummyMenu() +wxMenu *MyFrame::CreateDummyMenu(wxString *title) { wxMenu *menu = new wxMenu; menu->Append(Menu_Dummy_First, "First item\tCtrl-F1"); menu->AppendSeparator(); menu->Append(Menu_Dummy_Second, "Second item\tCtrl-F2", "", TRUE); + if ( title ) + { + title->Printf("Dummy menu &%d", ++m_countDummy); + } + return menu; } @@ -317,14 +330,18 @@ void MyFrame::OnDeleteMenu(wxCommandEvent& WXUNUSED(event)) } } -void MyFrame::OnAppendMenu(wxCommandEvent& WXUNUSED(event)) +void MyFrame::OnInsertMenu(wxCommandEvent& WXUNUSED(event)) { - static int s_count = 0; - wxString title; - title.Printf("Dummy menu &%d", ++s_count); + wxMenu *menu = CreateDummyMenu(&title); + GetMenuBar()->Insert(0, menu, title); +} - GetMenuBar()->Append(CreateDummyMenu(), title); +void MyFrame::OnAppendMenu(wxCommandEvent& WXUNUSED(event)) +{ + wxString title; + wxMenu *menu = CreateDummyMenu(&title); + GetMenuBar()->Append(menu, title); } void MyFrame::OnToggleMenu(wxCommandEvent& WXUNUSED(event)) @@ -391,10 +408,11 @@ void MyFrame::OnAppendMenuItem(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnAppendSubMenu(wxCommandEvent& WXUNUSED(event)) { wxMenuBar *menubar = GetMenuBar(); + wxMenu *menu = menubar->GetMenu(menubar->GetMenuCount() - 1); - - menu->Append(Menu_Dummy_Last, "Dummy sub menu\tCtrl-F12", - CreateDummyMenu()); + + menu->Append(Menu_Dummy_Last, "Dummy sub menu\tCtrl-F2", + CreateDummyMenu(NULL)); } void MyFrame::OnDeleteMenuItem(wxCommandEvent& WXUNUSED(event)) @@ -442,6 +460,8 @@ void MyFrame::OnCheckMenuItem(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnUpdateCheckMenuItemUI(wxUpdateUIEvent& event) { + wxLogNull nolog; + wxMenuItem *item = GetLastMenuItem(); event.Enable(item && item->IsCheckable()); @@ -548,14 +568,14 @@ void MyFrame::OnRightDown(wxMouseEvent &event ) wxMenu menu("Test popup"); menu.Append(Menu_Help_About, "&About"); - menu.Append(Menu_Popup_Submenu, "Submenu", CreateDummyMenu()); + 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"); - menu.Delete(Menu_Popup_ToBeDeleted); + //menu.Delete(Menu_Popup_ToBeDeleted); menu.Check(Menu_Popup_ToBeChecked, TRUE); menu.Enable(Menu_Popup_ToBeGreyed, FALSE);