From: Robert Roebling Date: Wed, 19 May 1999 13:41:55 +0000 (+0000) Subject: YOu can now activate the menu pressing F10 anywhere. X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/801aa1782caa8f612fec05278d6c63a1aa6a9e6a?ds=inline YOu can now activate the menu pressing F10 anywhere. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2511 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/include/wx/gtk/menu.h b/include/wx/gtk/menu.h index 1e1d52349a..f571fe084e 100644 --- a/include/wx/gtk/menu.h +++ b/include/wx/gtk/menu.h @@ -95,8 +95,6 @@ public: GtkAccelGroup *m_accel; GtkItemFactory *m_factory; - -private: wxList m_menus; GtkWidget *m_menubar; }; diff --git a/include/wx/gtk1/menu.h b/include/wx/gtk1/menu.h index 1e1d52349a..f571fe084e 100644 --- a/include/wx/gtk1/menu.h +++ b/include/wx/gtk1/menu.h @@ -95,8 +95,6 @@ public: GtkAccelGroup *m_accel; GtkItemFactory *m_factory; - -private: wxList m_menus; GtkWidget *m_menubar; }; diff --git a/src/gtk/frame.cpp b/src/gtk/frame.cpp index 365f857639..e0b475caae 100644 --- a/src/gtk/frame.cpp +++ b/src/gtk/frame.cpp @@ -24,6 +24,7 @@ #include "gdk/gdk.h" #include "gtk/gtk.h" #include "wx/gtk/win_gtk.h" +#include "gdk/gdkkeysyms.h" //----------------------------------------------------------------------------- // constants @@ -132,7 +133,8 @@ static void gtk_toolbar_attached_callback( GtkWidget *WXUNUSED(widget), GtkWidge static void gtk_toolbar_detached_callback( GtkWidget *widget, GtkWidget *WXUNUSED(child), wxFrame *win ) { - if (g_isIdle) wxapp_install_idle_handler(); + if (g_isIdle) + wxapp_install_idle_handler(); if (!win->m_hasVMT) return; diff --git a/src/gtk/window.cpp b/src/gtk/window.cpp index 7326273401..691f76d0c9 100644 --- a/src/gtk/window.cpp +++ b/src/gtk/window.cpp @@ -630,6 +630,7 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e ret = win->GetEventHandler()->ProcessEvent( new_event ); } + /* generate wxID_CANCEL if has been pressed (typically in dialogs) */ if ( (!ret) && (gdk_event->keyval == GDK_Escape) ) { @@ -637,6 +638,36 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e new_event.SetEventObject( win ); ret = win->GetEventHandler()->ProcessEvent( new_event ); } + + /* pressing F10 will activate the menu bar of the top frame */ + if ( (!ret) && + (gdk_event->keyval == GDK_F10) ) + { + wxWindow *ancestor = win; + while (ancestor) + { + if (wxIsKindOf(ancestor,wxFrame)) + { + wxFrame *frame = (wxFrame*) ancestor; + wxMenuBar *menubar = frame->GetMenuBar(); + if (menubar) + { + wxNode *node = menubar->GetMenus().First(); + if (node) + { + wxMenu *firstMenu = (wxMenu*) node->Data(); + gtk_menu_shell_select_item( + GTK_MENU_SHELL(menubar->m_menubar), + firstMenu->m_owner ); + + ret = TRUE; + break; + } + } + } + ancestor = ancestor->GetParent(); + } + } /* Damn, I forgot why this didn't work, but it didn't work. diff --git a/src/gtk1/frame.cpp b/src/gtk1/frame.cpp index 365f857639..e0b475caae 100644 --- a/src/gtk1/frame.cpp +++ b/src/gtk1/frame.cpp @@ -24,6 +24,7 @@ #include "gdk/gdk.h" #include "gtk/gtk.h" #include "wx/gtk/win_gtk.h" +#include "gdk/gdkkeysyms.h" //----------------------------------------------------------------------------- // constants @@ -132,7 +133,8 @@ static void gtk_toolbar_attached_callback( GtkWidget *WXUNUSED(widget), GtkWidge static void gtk_toolbar_detached_callback( GtkWidget *widget, GtkWidget *WXUNUSED(child), wxFrame *win ) { - if (g_isIdle) wxapp_install_idle_handler(); + if (g_isIdle) + wxapp_install_idle_handler(); if (!win->m_hasVMT) return; diff --git a/src/gtk1/window.cpp b/src/gtk1/window.cpp index 7326273401..691f76d0c9 100644 --- a/src/gtk1/window.cpp +++ b/src/gtk1/window.cpp @@ -630,6 +630,7 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e ret = win->GetEventHandler()->ProcessEvent( new_event ); } + /* generate wxID_CANCEL if has been pressed (typically in dialogs) */ if ( (!ret) && (gdk_event->keyval == GDK_Escape) ) { @@ -637,6 +638,36 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e new_event.SetEventObject( win ); ret = win->GetEventHandler()->ProcessEvent( new_event ); } + + /* pressing F10 will activate the menu bar of the top frame */ + if ( (!ret) && + (gdk_event->keyval == GDK_F10) ) + { + wxWindow *ancestor = win; + while (ancestor) + { + if (wxIsKindOf(ancestor,wxFrame)) + { + wxFrame *frame = (wxFrame*) ancestor; + wxMenuBar *menubar = frame->GetMenuBar(); + if (menubar) + { + wxNode *node = menubar->GetMenus().First(); + if (node) + { + wxMenu *firstMenu = (wxMenu*) node->Data(); + gtk_menu_shell_select_item( + GTK_MENU_SHELL(menubar->m_menubar), + firstMenu->m_owner ); + + ret = TRUE; + break; + } + } + } + ancestor = ancestor->GetParent(); + } + } /* Damn, I forgot why this didn't work, but it didn't work.