X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/83885a398be7f011ae6e5aa030dca2b2a1e281d5..700d08c1092bd08150d47b952c1e0d817a64d75f:/include/wx/gtk/menu.h diff --git a/include/wx/gtk/menu.h b/include/wx/gtk/menu.h index 38da6ec98f..eda3f5a5b1 100644 --- a/include/wx/gtk/menu.h +++ b/include/wx/gtk/menu.h @@ -1,160 +1,114 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: menu.h +// Name: wx/gtk/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 ///////////////////////////////////////////////////////////////////////////// - #ifndef __GTKMENUH__ #define __GTKMENUH__ -#ifdef __GNUG__ -#pragma interface -#endif - -#include "wx/defs.h" -#include "wx/object.h" -#include "wx/list.h" -#include "wx/window.h" - //----------------------------------------------------------------------------- -// classes +// wxMenuBar //----------------------------------------------------------------------------- -class wxMenuBar; -class wxMenuItem; -class wxMenu; +class WXDLLIMPEXP_CORE wxMenuBar : public wxMenuBarBase +{ +public: + // ctors + wxMenuBar(); + wxMenuBar(long style); + wxMenuBar(size_t n, wxMenu *menus[], const wxString titles[], long style = 0); + virtual ~wxMenuBar(); -//----------------------------------------------------------------------------- -// const -//----------------------------------------------------------------------------- + // implement base class (pure) virtuals + virtual bool Append( wxMenu *menu, const wxString &title ); + virtual bool Insert(size_t pos, wxMenu *menu, const wxString& title); + virtual wxMenu *Replace(size_t pos, wxMenu *menu, const wxString& title); + virtual wxMenu *Remove(size_t pos); -#define ID_SEPARATOR (-1) + virtual int FindMenuItem(const wxString& menuString, + const wxString& itemString) const; + virtual wxMenuItem* FindItem( int id, wxMenu **menu = NULL ) const; -//----------------------------------------------------------------------------- -// wxMenuBar -//----------------------------------------------------------------------------- + virtual void EnableTop( size_t pos, bool flag ); + virtual void SetMenuLabel( size_t pos, const wxString& label ); + virtual wxString GetMenuLabel( size_t pos ) const; -class wxMenuBar: public wxWindow -{ -DECLARE_DYNAMIC_CLASS(wxMenuBar) + void SetLayoutDirection(wxLayoutDirection dir); + wxLayoutDirection GetLayoutDirection() const; -public: - wxMenuBar(); - void Append( wxMenu *menu, const wxString &title ); + // wxMenuBar is not a top level window but it still doesn't need a parent + // window + virtual bool GTKNeedsParent() const { return false; } + + void Attach(wxFrame *frame); - int FindMenuItem( const wxString &menuString, const wxString &itemString ) const; - wxMenuItem* FindMenuItemById( int id ) const; + // implementation only from now on + void SetInvokingWindow( wxWindow *win ); + void UnsetInvokingWindow( wxWindow *win ); - int GetMenuCount() const { return m_menus.Number(); } - wxMenu *GetMenu(int n) const { return (wxMenu *)m_menus.Nth(n)->Data(); } + // common part of Append and Insert + bool GtkAppend(wxMenu *menu, const wxString& title, int pos=-1); - bool IsChecked( int id ) const; - bool IsEnabled( int id ) const; + GtkWidget *m_menubar; + long m_style; + wxWindow *m_invokingWindow; + +private: + void Init(size_t n, wxMenu *menus[], const wxString titles[], long style); - wxList m_menus; - GtkWidget *m_menubar; + DECLARE_DYNAMIC_CLASS(wxMenuBar) }; //----------------------------------------------------------------------------- // wxMenu //----------------------------------------------------------------------------- -class wxMenuItem: public wxObject +class WXDLLIMPEXP_CORE wxMenu : public wxMenuBase { -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; } + // ctors & dtor + wxMenu(const wxString& title, long style = 0) + : wxMenuBase(title, style) { Init(); } -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 -}; + wxMenu(long style = 0) : wxMenuBase(style) { Init(); } -class wxMenu: public wxEvtHandler -{ -DECLARE_DYNAMIC_CLASS(wxMenu) + virtual ~wxMenu(); -public: - // construction - wxMenu( const wxString &title = "" ); + void Attach(wxMenuBarBase *menubar); - // operations - // menu creation - void AppendSeparator(); - void Append(int id, const wxString &item, - const wxString &helpStr = "", bool checkable = FALSE); - void Append(int id, const wxString &item, - wxMenu *subMenu, const wxString &helpStr = "" ); - void Break() {}; + void SetLayoutDirection(const wxLayoutDirection dir); + wxLayoutDirection GetLayoutDirection() const; - // find item by name/id - int FindItem( const wxString itemString ) const; - wxMenuItem *FindItem(int id) const; + // TODO: virtual void SetTitle(const wxString& title); - // get/set item's state - void Enable( int id, bool enable ); - bool IsEnabled( int id ) const; - void Check( int id, bool check ); - bool IsChecked( int id ) const; + // implementation + int FindMenuIdByMenuItem( GtkWidget *menuItem ) const; - void SetLabel( int id, const wxString &label ); + // implementation GTK only + GtkWidget *m_menu; // GtkMenu + GtkWidget *m_owner; + GtkAccelGroup *m_accel; - // accessors - wxList& GetItems() { return m_items; } +protected: + virtual wxMenuItem* DoAppend(wxMenuItem *item); + virtual wxMenuItem* DoInsert(size_t pos, wxMenuItem *item); + virtual wxMenuItem* DoRemove(wxMenuItem *item); -public: - int FindMenuIdByMenuItem( GtkWidget *menuItem ) const; - void SetInvokingWindow( wxWindow *win ); - wxWindow *GetInvokingWindow(); +private: + // common code for all constructors: + void Init(); + + // common part of Append (if pos == -1) and Insert + bool GtkAppend(wxMenuItem *item, int pos=-1); - wxString m_title; - wxList m_items; - wxWindow *m_invokingWindow; + GtkWidget *m_prevRadio; - GtkWidget *m_menu; // GtkMenu + DECLARE_DYNAMIC_CLASS(wxMenu) }; -#endif // __GTKMENUH__ +#endif + // __GTKMENUH__