X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/83885a398be7f011ae6e5aa030dca2b2a1e281d5..75ce0581545a6c151484e488596ed200c2ffd93e:/include/wx/gtk/menu.h?ds=sidebyside diff --git a/include/wx/gtk/menu.h b/include/wx/gtk/menu.h index 38da6ec98f..860e0b8d14 100644 --- a/include/wx/gtk/menu.h +++ b/include/wx/gtk/menu.h @@ -2,9 +2,8 @@ // Name: menu.h // Purpose: // Author: Robert Roebling -// Created: 01/02/97 -// Id: -// Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem +// Id: $Id$ +// Copyright: (c) 1998 Robert Roebling, Julian Smart // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -20,6 +19,7 @@ #include "wx/object.h" #include "wx/list.h" #include "wx/window.h" +#include "wx/menuitem.h" //----------------------------------------------------------------------------- // classes @@ -49,13 +49,26 @@ public: int FindMenuItem( const wxString &menuString, const wxString &itemString ) const; wxMenuItem* FindMenuItemById( int id ) const; + inline wxMenuItem* FindItemForId( int id ) const + { return FindMenuItemById( id ); } + + void Check( int id, bool check ); + bool Checked( int id ) const; + void Enable( int id, bool enable ); + bool Enabled( int id ) const; + inline bool IsEnabled(int Id) const { return Enabled(Id); } + inline bool IsChecked(int Id) const { return Checked(Id); } + + wxString GetLabel( int id ) const; + void SetLabel( int id, const wxString &label ); + + void EnableTop( int pos, bool flag ); + void SetLabelTop( int pos, const wxString& label ); + wxString GetLabelTop( int pos ) const; int GetMenuCount() const { return m_menus.Number(); } wxMenu *GetMenu(int n) const { return (wxMenu *)m_menus.Nth(n)->Data(); } - bool IsChecked( int id ) const; - bool IsEnabled( int id ) const; - wxList m_menus; GtkWidget *m_menubar; }; @@ -64,64 +77,18 @@ public: // wxMenu //----------------------------------------------------------------------------- -class wxMenuItem: public wxObject -{ -DECLARE_DYNAMIC_CLASS(wxMenuItem) - -public: - wxMenuItem(); - - // accessors - // id - void SetId(int id) { m_id = id; } - int GetId() const { return m_id; } - bool IsSeparator() const { return m_id == ID_SEPARATOR; } - - // the item's text - void SetText(const wxString& str); - const wxString& GetText() const { return m_text; } - - // what kind of menu item we are - void SetCheckable(bool checkable) { m_isCheckMenu = checkable; } - bool IsCheckable() const { return m_isCheckMenu; } - void SetSubMenu(wxMenu *menu) { m_subMenu = menu; } - wxMenu *GetSubMenu() const { return m_subMenu; } - bool IsSubMenu() const { return m_subMenu != NULL; } - - // state - void Enable(bool enable = TRUE) { m_isEnabled = enable; } - bool IsEnabled() const { return m_isEnabled; } - void Check(bool check = TRUE); - bool IsChecked() const; - - // help string (displayed in the status bar by default) - void SetHelpString(const wxString& str) { m_helpStr = str; } - - // implementation - void SetMenuItem(GtkWidget *menuItem) { m_menuItem = menuItem; } - GtkWidget *GetMenuItem() const { return m_menuItem; } - -private: - int m_id; - wxString m_text; - bool m_isCheckMenu; - bool m_isChecked; - bool m_isEnabled; - wxMenu *m_subMenu; - wxString m_helpStr; - - GtkWidget *m_menuItem; // GtkMenuItem -}; - class wxMenu: public wxEvtHandler { DECLARE_DYNAMIC_CLASS(wxMenu) public: // construction - wxMenu( const wxString &title = "" ); + wxMenu( const wxString& title = wxEmptyString, const wxFunction func = (wxFunction) NULL ); // operations + // title + void SetTitle(const wxString& label); + const wxString GetTitle() const; // menu creation void AppendSeparator(); void Append(int id, const wxString &item, @@ -132,7 +99,8 @@ public: // find item by name/id int FindItem( const wxString itemString ) const; - wxMenuItem *FindItem(int id) const; + wxMenuItem *FindItem( int id ) const; + wxMenuItem *FindItemForId( int id ) const { return FindItem( id ); } // get/set item's state void Enable( int id, bool enable ); @@ -141,20 +109,38 @@ public: bool IsChecked( int id ) const; void SetLabel( int id, const wxString &label ); + wxString GetLabel( int id ) const; + // helpstring + virtual void SetHelpString(int id, const wxString& helpString); + virtual wxString GetHelpString(int id) const ; + // accessors wxList& GetItems() { return m_items; } -public: + inline void Callback(const wxFunction func) { m_callback = func; } + + inline void SetEventHandler(wxEvtHandler *handler) { m_eventHandler = handler; } + inline wxEvtHandler *GetEventHandler() { return m_eventHandler; } + + inline void SetClientData( void* clientData ) { m_clientData = clientData; } + inline void* GetClientData() const { return m_clientData; } + +// implementation + int FindMenuIdByMenuItem( GtkWidget *menuItem ) const; void SetInvokingWindow( wxWindow *win ); wxWindow *GetInvokingWindow(); - wxString m_title; - wxList m_items; - wxWindow *m_invokingWindow; + wxString m_title; + wxList m_items; + wxWindow *m_invokingWindow; + wxFunction m_callback; + wxEvtHandler *m_eventHandler; + void *m_clientData; - GtkWidget *m_menu; // GtkMenu + GtkWidget *m_menu; // GtkMenu + GtkWidget *m_owner; }; #endif // __GTKMENUH__