]>
git.saurik.com Git - wxWidgets.git/blob - interface/menuitem.h
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: interface of wxMenuItem
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
13 A menu item represents an item in a menu. Note that you usually don't have to
14 deal with it directly as wxMenu methods usually construct an
15 object of this class for you.
17 Also please note that the methods related to fonts and bitmaps are currently
18 only implemented for Windows and GTK+.
23 @see wxMenuBar, wxMenu
25 class wxMenuItem
: public wxObject
29 Constructs a wxMenuItem object.
30 Menu items can be standard, or "stock menu items'', or custom. For the
31 standard menu items (such as commands to open a file, exit the program and so
32 on, see @ref overview_stockitems "stock items" for the full list) it is enough
34 specify just the stock ID and leave @a text and @a helpString empty. In
35 fact, leaving at least @a text empty for the stock menu items is strongly
36 recommended as they will have appearance and keyboard interface (including
37 standard accelerators) familiar to the user.
38 For the custom (non-stock) menu items, @a text must be specified and while
39 @a helpString may be left empty, it's recommended to pass the item
40 description (which is automatically shown by the library in the status bar when
41 the menu item is selected) in this parameter.
42 Finally note that you can e.g. use a stock menu label without using its stock
45 that is, stock properties are set independently one from the other.
48 Menu that the menu item belongs to.
50 Identifier for this menu item, or wxID_SEPARATOR to indicate a separator.
52 Text for the menu item, as shown on the menu. An accelerator
53 key can be specified using the ampersand '' character. In order to embed an
54 ampersand character in the menu item text, the ampersand must be doubled.
56 Optional help string that will be shown on the status bar.
58 May be wxITEM_SEPARATOR, wxITEM_NORMAL,
59 wxITEM_CHECK or wxITEM_RADIO
61 If non-@NULL, indicates that the menu item is a submenu.
63 wxMenuItem(wxMenu
* parentMenu
= NULL
, int id
= wxID_SEPARATOR
,
64 const wxString
& text
= "",
65 const wxString
& helpString
= "",
66 wxItemKind kind
= wxITEM_NORMAL
,
67 wxMenu
* subMenu
= NULL
);
75 Checks or unchecks the menu item.
76 Note that this only works when the item is already appended to a menu.
78 void Check(bool check
= true);
81 Enables or disables the menu item.
83 void Enable(bool enable
= true);
86 Returns the background colour associated with the menu item (Windows only).
88 wxColour
GetBackgroundColour() const;
91 Returns the checked or unchecked bitmap (Windows only).
93 wxBitmap
GetBitmap(bool checked
= true) const;
96 Returns the font associated with the menu item (Windows only).
98 wxFont
GetFont() const;
101 Returns the help string associated with the menu item.
103 wxString
GetHelp() const;
106 Returns the menu item identifier.
111 Returns the text associated with the menu item including any accelerator
112 characters that were passed to the constructor or SetItemLabel.
114 @see GetItemLabelText(), GetLabelText()
116 wxString
GetItemLabel() const;
119 Returns the text associated with the menu item, without any accelerator
122 @see GetItemLabel(), GetLabelText()
124 wxString
GetItemLabelText() const;
127 Returns the item kind, one of @c wxITEM_SEPARATOR, @c wxITEM_NORMAL,
128 @c wxITEM_CHECK or @c wxITEM_RADIO.
130 wxItemKind
GetKind() const;
133 Returns the text associated with the menu item without any accelerator
134 characters it might contain.
135 This function is deprecated in favour of GetItemLabelText().
137 @see GetText(), GetLabelFromText()
139 wxString
GetLabel() const;
142 Strips all accelerator characters and mnemonics from the given @e text.
145 will return just @c "Hello".
146 This function is deprecated; please use GetLabelText() instead.
148 @see GetText(), GetLabel()
150 static wxString
GetLabelFromText(const wxString
& text
);
153 Strips all accelerator characters and mnemonics from the given @e text.
156 will return just @c "Hello".
158 @see GetItemLabelText(), GetItemLabel()
160 static wxString
GetLabelText(const wxString
& text
);
163 Gets the width of the menu item checkmark bitmap (Windows only).
165 int GetMarginWidth() const;
168 Returns the menu this menu item is in, or @NULL if this menu item is not
171 wxMenu
* GetMenu() const;
174 Returns the text associated with the menu item.
175 @b NB: this function is deprecated, please use
176 GetItemLabel() or GetItemLabelText()
179 wxString
GetName() const;
182 Returns the submenu associated with the menu item, or @NULL if there isn't one.
184 wxMenu
* GetSubMenu() const;
187 Returns the text associated with the menu item, such as it was passed to the
188 wxMenuItem constructor, i.e. with any accelerator characters it may contain.
189 This function is deprecated in favour of GetItemLabel().
191 @see GetLabel(), GetLabelFromText()
193 wxString
GetText() const;
196 Returns the text colour associated with the menu item (Windows only).
198 wxColour
GetTextColour() const;
201 Returns @true if the item is checkable.
203 bool IsCheckable() const;
206 Returns @true if the item is checked.
208 bool IsChecked() const;
211 Returns @true if the item is enabled.
213 bool IsEnabled() const;
216 Returns @true if the item is a separator.
218 bool IsSeparator() const;
221 Returns @true if the item is a submenu.
223 bool IsSubMenu() const;
226 Sets the background colour associated with the menu item (Windows only).
228 void SetBackgroundColour(const wxColour
& colour
) const;
231 Sets the bitmap for the menu item (Windows and GTK+ only). It is
232 equivalent to wxMenuItem::SetBitmaps(bmp, wxNullBitmap).
234 void SetBitmap(const wxBitmap
& bmp
);
237 Sets the checked/unchecked bitmaps for the menu item (Windows only). The first
239 is also used as the single bitmap for uncheckable menu items.
241 void SetBitmaps(const wxBitmap
& checked
,
242 const wxBitmap
& unchecked
= wxNullBitmap
);
245 Sets the font associated with the menu item (Windows only).
247 void SetFont(const wxFont
& font
);
250 Sets the help string.
252 void SetHelp(const wxString
& helpString
);
255 Sets the label associated with the menu item.
257 void SetItemLabel(const wxString
& label
);
260 Sets the width of the menu item checkmark bitmap (Windows only).
262 void SetMarginWidth(int width
) const;
265 Sets the parent menu which will contain this menu item.
267 void SetMenu(const wxMenu
* menu
);
270 Sets the submenu of this menu item.
272 void SetSubMenu(const wxMenu
* menu
);
275 Sets the text associated with the menu item.
276 This function is deprecated in favour of SetItemLabel().
278 void SetText(const wxString
& text
);
281 Sets the text colour associated with the menu item (Windows only).
283 void SetTextColour(const wxColour
& colour
);