1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxMenu, wxMenuBar classes
4 // Author: Stefan Csomor
8 // Copyright: (c) Stefan Csomor
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
15 class WXDLLIMPEXP_FWD_CORE wxFrame
;
17 #include "wx/arrstr.h"
19 // ----------------------------------------------------------------------------
21 // ----------------------------------------------------------------------------
23 class WXDLLIMPEXP_FWD_CORE wxMenuImpl
;
25 class WXDLLIMPEXP_CORE wxMenu
: public wxMenuBase
29 wxMenu(const wxString
& title
, long style
= 0)
30 : wxMenuBase(title
, style
) { Init(); }
32 wxMenu(long style
= 0) : wxMenuBase(style
) { Init(); }
36 virtual void Attach(wxMenuBarBase
*menubar
) ;
40 virtual void SetTitle(const wxString
& title
);
42 bool ProcessCommand(wxCommandEvent
& event
);
44 // get the menu handle
45 WXHMENU
GetHMenu() const ;
47 // implementation only from now on
48 // -------------------------------
50 bool HandleCommandUpdateStatus( wxMenuItem
* menuItem
, wxWindow
* senderWindow
= NULL
);
51 bool HandleCommandProcess( wxMenuItem
* menuItem
, wxWindow
* senderWindow
= NULL
);
52 void HandleMenuItemHighlighted( wxMenuItem
* menuItem
);
53 void HandleMenuOpened();
54 void HandleMenuClosed();
56 wxMenuImpl
* GetPeer() { return m_peer
; }
58 // make sure we can veto
59 void SetAllowRearrange( bool allow
);
60 bool AllowRearrange() const { return m_allowRearrange
; }
62 // if a menu is used purely for internal implementation reasons (eg wxChoice)
63 // we don't want native menu events being triggered
64 void SetNoEventsMode( bool noEvents
);
65 bool GetNoEventsMode() const { return m_noEventsMode
; }
67 // hide special menu items like exit, preferences etc
68 // that are expected in the app menu
71 bool DoHandleMenuEvent( wxEvent
& evt
);
72 virtual wxMenuItem
* DoAppend(wxMenuItem
*item
);
73 virtual wxMenuItem
* DoInsert(size_t pos
, wxMenuItem
*item
);
74 virtual wxMenuItem
* DoRemove(wxMenuItem
*item
);
77 // common part of all ctors
80 // common part of Append/Insert (behaves as Append is pos == (size_t)-1)
81 bool DoInsertOrAppend(wxMenuItem
*item
, size_t pos
= (size_t)-1);
83 // terminate the current radio group, if any
86 // Common part of HandleMenu{Opened,Closed}().
87 void DoHandleMenuOpenedOrClosed(wxEventType evtType
);
90 // if TRUE, insert a breal before appending the next item
93 // in this menu rearranging of menu items (esp hiding) is allowed
94 bool m_allowRearrange
;
96 // don't trigger native events
99 // the position of the first item in the current radio group or -1
100 int m_startRadioGroup
;
104 DECLARE_DYNAMIC_CLASS(wxMenu
)
107 #if wxOSX_USE_COCOA_OR_CARBON
109 // the iphone only has popup-menus
111 // ----------------------------------------------------------------------------
112 // Menu Bar (a la Windows)
113 // ----------------------------------------------------------------------------
115 class WXDLLIMPEXP_CORE wxMenuBar
: public wxMenuBarBase
119 // default constructor
122 wxMenuBar(long style
);
123 // menubar takes ownership of the menus arrays but copies the titles
124 wxMenuBar(size_t n
, wxMenu
*menus
[], const wxString titles
[], long style
= 0);
125 virtual ~wxMenuBar();
127 // menubar construction
128 virtual bool Append( wxMenu
*menu
, const wxString
&title
);
129 virtual bool Insert(size_t pos
, wxMenu
*menu
, const wxString
& title
);
130 virtual wxMenu
*Replace(size_t pos
, wxMenu
*menu
, const wxString
& title
);
131 virtual wxMenu
*Remove(size_t pos
);
133 virtual void EnableTop( size_t pos
, bool flag
);
134 virtual void SetMenuLabel( size_t pos
, const wxString
& label
);
135 virtual wxString
GetMenuLabel( size_t pos
) const;
136 virtual bool Enable( bool enable
= true );
137 // for virtual function hiding
138 virtual void Enable( int itemid
, bool enable
)
140 wxMenuBarBase::Enable( itemid
, enable
);
143 // implementation from now on
146 // returns TRUE if we're attached to a frame
147 bool IsAttached() const { return m_menuBarFrame
!= NULL
; }
148 // get the frame we live in
149 wxFrame
*GetFrame() const { return m_menuBarFrame
; }
151 void Attach(wxFrame
*frame
);
153 // if the menubar is modified, the display is not updated automatically,
154 // call this function to update it (m_menuBarFrame should be !NULL)
155 void Refresh(bool eraseBackground
= true, const wxRect
*rect
= NULL
);
157 static void SetAutoWindowMenu( bool enable
) { s_macAutoWindowMenu
= enable
; }
158 static bool GetAutoWindowMenu() { return s_macAutoWindowMenu
; }
160 void MacInstallMenuBar() ;
161 static wxMenuBar
* MacGetInstalledMenuBar() { return s_macInstalledMenuBar
; }
162 static void MacSetCommonMenuBar(wxMenuBar
* menubar
) { s_macCommonMenuBar
=menubar
; }
163 static wxMenuBar
* MacGetCommonMenuBar() { return s_macCommonMenuBar
; }
166 static WXHMENU
MacGetWindowMenuHMenu() { return s_macWindowMenuHandle
; }
168 // common part of all ctors
171 static bool s_macAutoWindowMenu
;
172 static WXHMENU s_macWindowMenuHandle
;
175 static wxMenuBar
* s_macInstalledMenuBar
;
176 static wxMenuBar
* s_macCommonMenuBar
;
181 DECLARE_DYNAMIC_CLASS(wxMenuBar
)
186 #endif // _WX_MENU_H_