git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@55912 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			281 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
			
		
		
	
	
			281 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        menuitem.h
 | |
| // Purpose:     interface of wxMenuItem
 | |
| // Author:      wxWidgets team
 | |
| // RCS-ID:      $Id$
 | |
| // Licence:     wxWindows license
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| /**
 | |
|     @class wxMenuItem
 | |
| 
 | |
|     A menu item represents an item in a menu. Note that you usually don't have to
 | |
|     deal with it directly as wxMenu methods usually construct an
 | |
|     object of this class for you.
 | |
| 
 | |
|     Also please note that the methods related to fonts and bitmaps are currently
 | |
|     only implemented for Windows and GTK+.
 | |
| 
 | |
|     @library{wxcore}
 | |
|     @category{menus}
 | |
| 
 | |
|     @see wxMenuBar, wxMenu
 | |
| */
 | |
| class wxMenuItem : public wxObject
 | |
| {
 | |
| public:
 | |
|     /**
 | |
|         Constructs a wxMenuItem object.
 | |
|         Menu items can be standard, or "stock menu items", or custom. For the
 | |
|         standard menu items (such as commands to open a file, exit the program and so
 | |
|         on, see @ref page_stockitems "Stock Items" for the full list) it is enough
 | |
|         to specify just the stock ID and leave @a text and @a helpString empty. In
 | |
|         fact, leaving at least @a text empty for the stock menu items is strongly
 | |
|         recommended as they will have appearance and keyboard interface (including
 | |
|         standard accelerators) familiar to the user.
 | |
|         For the custom (non-stock) menu items, @a text must be specified and while
 | |
|         @a helpString may be left empty, it's recommended to pass the item
 | |
|         description (which is automatically shown by the library in the status bar when
 | |
|         the menu item is selected) in this parameter.
 | |
|         Finally note that you can e.g. use a stock menu label without using its stock
 | |
|         help string; that is, stock properties are set independently one from the other.
 | |
| 
 | |
|         @param parentMenu
 | |
|             Menu that the menu item belongs to. Can be @NULL if the item is
 | |
|             going to be added to the menu later.
 | |
|         @param id
 | |
|             Identifier for this menu item. May be @c wxID_SEPARATOR, in which
 | |
|             case the given kind is ignored and taken to be @c wxITEM_SEPARATOR
 | |
|             instead.
 | |
|         @param text
 | |
|             Text for the menu item, as shown on the menu. An accelerator
 | |
|             key can be specified using the ampersand " character. In order to embed an
 | |
|             ampersand character in the menu item text, the ampersand must be doubled.
 | |
|         @param helpString
 | |
|             Optional help string that will be shown on the status bar.
 | |
|         @param kind
 | |
|             May be @c wxITEM_SEPARATOR, @c wxITEM_NORMAL, @c wxITEM_CHECK or @c
 | |
|             wxITEM_RADIO
 | |
|         @param subMenu
 | |
|             If non-@NULL, indicates that the menu item is a submenu.
 | |
|     */
 | |
|     wxMenuItem(wxMenu* parentMenu = NULL, int id = wxID_SEPARATOR,
 | |
|                const wxString& text = "",
 | |
|                const wxString& helpString = "",
 | |
|                wxItemKind kind = wxITEM_NORMAL,
 | |
|                wxMenu* subMenu = NULL);
 | |
| 
 | |
|     /**
 | |
|         Destructor.
 | |
|     */
 | |
|     virtual ~wxMenuItem();
 | |
| 
 | |
|     /**
 | |
|         Checks or unchecks the menu item.
 | |
|         Note that this only works when the item is already appended to a menu.
 | |
|     */
 | |
|     virtual void Check(bool check = true);
 | |
| 
 | |
|     /**
 | |
|         Enables or disables the menu item.
 | |
|     */
 | |
|     virtual void Enable(bool enable = true);
 | |
| 
 | |
|     /**
 | |
|         Returns the background colour associated with the menu item (Windows only).
 | |
|     */
 | |
|     wxColour GetBackgroundColour() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the checked or unchecked bitmap (Windows only).
 | |
|     */
 | |
|     wxBitmap GetBitmap(bool checked = true) const;
 | |
| 
 | |
|     /**
 | |
|         Returns the font associated with the menu item (Windows only).
 | |
|     */
 | |
|     wxFont GetFont() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the help string associated with the menu item.
 | |
|     */
 | |
|     wxString GetHelp() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the menu item identifier.
 | |
|     */
 | |
|     int GetId() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text associated with the menu item including any accelerator
 | |
|         characters that were passed to the constructor or SetItemLabel.
 | |
| 
 | |
|         @see GetItemLabelText(), GetLabelText()
 | |
|     */
 | |
|     virtual wxString GetItemLabel() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text associated with the menu item, without any accelerator
 | |
|         characters.
 | |
| 
 | |
|         @see GetItemLabel(), GetLabelText()
 | |
|     */
 | |
|     virtual wxString GetItemLabelText() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the item kind, one of @c wxITEM_SEPARATOR, @c wxITEM_NORMAL,
 | |
|         @c wxITEM_CHECK or @c wxITEM_RADIO.
 | |
|     */
 | |
|     wxItemKind GetKind() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text associated with the menu item without any accelerator
 | |
|         characters it might contain.
 | |
|         @deprecated This function is deprecated in favour of GetItemLabelText().
 | |
|         @see GetText(), GetLabelFromText()
 | |
|     */
 | |
|     wxString GetLabel() const;
 | |
| 
 | |
|     /**
 | |
|         @deprecated This function is deprecated; please use GetLabelText() instead.
 | |
|         @see GetText(), GetLabel()
 | |
|     */
 | |
|     static wxString GetLabelFromText(const wxString& text);
 | |
| 
 | |
|     /**
 | |
|         Strips all accelerator characters and mnemonics from the given @e text.
 | |
|         For example:
 | |
| 
 | |
|         @code
 | |
|           wxMenuItem::GetLabelfromText( "&Hello\tCtrl-h");
 | |
|         @endcode
 | |
| 
 | |
|         will return just @c "Hello".
 | |
| 
 | |
|         @see GetItemLabelText(), GetItemLabel()
 | |
|     */
 | |
|     static wxString GetLabelText(const wxString& text);
 | |
| 
 | |
|     /**
 | |
|         Gets the width of the menu item checkmark bitmap (Windows only).
 | |
|     */
 | |
|     int GetMarginWidth() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the menu this menu item is in, or @NULL if this menu item is not
 | |
|         attached.
 | |
|     */
 | |
|     wxMenu* GetMenu() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text associated with the menu item.
 | |
|         @deprecated This function is deprecated. Please use
 | |
|         GetItemLabel() or GetItemLabelText() instead.
 | |
|     */
 | |
|     wxString GetName() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the submenu associated with the menu item, or @NULL if there isn't one.
 | |
|     */
 | |
|     wxMenu* GetSubMenu() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text associated with the menu item, such as it was passed to the
 | |
|         wxMenuItem constructor, i.e. with any accelerator characters it may contain.
 | |
|         @deprecated This function is deprecated in favour of GetItemLabel().
 | |
|         @see GetLabel(), GetLabelFromText()
 | |
|     */
 | |
|     wxString GetText() const;
 | |
| 
 | |
|     /**
 | |
|         Returns the text colour associated with the menu item (Windows only).
 | |
|     */
 | |
|     wxColour GetTextColour() const;
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the item is checkable.
 | |
|     */
 | |
|     bool IsCheckable() const;
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the item is checked.
 | |
|     */
 | |
|     virtual bool IsChecked() const;
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the item is enabled.
 | |
|     */
 | |
|     virtual bool IsEnabled() const;
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the item is a separator.
 | |
|     */
 | |
|     bool IsSeparator() const;
 | |
| 
 | |
|     /**
 | |
|         Returns @true if the item is a submenu.
 | |
|     */
 | |
|     bool IsSubMenu() const;
 | |
| 
 | |
|     /**
 | |
|         Sets the background colour associated with the menu item (Windows only).
 | |
|     */
 | |
|     void SetBackgroundColour(const wxColour& colour) const;
 | |
| 
 | |
|     /**
 | |
|         Sets the bitmap for the menu item (Windows and GTK+ only). It is
 | |
|         equivalent to wxMenuItem::SetBitmaps(bmp, wxNullBitmap).
 | |
|     */
 | |
|     virtual void SetBitmap(const wxBitmap& bmp);
 | |
| 
 | |
|     /**
 | |
|         Sets the checked/unchecked bitmaps for the menu item (Windows only). The first
 | |
|         bitmap
 | |
|         is also used as the single bitmap for uncheckable menu items.
 | |
|     */
 | |
|     void SetBitmaps(const wxBitmap& checked,
 | |
|                     const wxBitmap& unchecked = wxNullBitmap);
 | |
| 
 | |
|     /**
 | |
|         Sets the font associated with the menu item (Windows only).
 | |
|     */
 | |
|     void SetFont(const wxFont& font);
 | |
| 
 | |
|     /**
 | |
|         Sets the help string.
 | |
|     */
 | |
|     void SetHelp(const wxString& helpString);
 | |
| 
 | |
|     /**
 | |
|         Sets the label associated with the menu item.
 | |
|     */
 | |
|     virtual void SetItemLabel(const wxString& label);
 | |
| 
 | |
|     /**
 | |
|         Sets the width of the menu item checkmark bitmap (Windows only).
 | |
|     */
 | |
|     void SetMarginWidth(int width) const;
 | |
| 
 | |
|     /**
 | |
|         Sets the parent menu which will contain this menu item.
 | |
|     */
 | |
|     void SetMenu(const wxMenu* menu);
 | |
| 
 | |
|     /**
 | |
|         Sets the submenu of this menu item.
 | |
|     */
 | |
|     void SetSubMenu(const wxMenu* menu);
 | |
| 
 | |
|     /**
 | |
|         Sets the text associated with the menu item.
 | |
|         @deprecated This function is deprecated in favour of SetItemLabel().
 | |
|     */
 | |
|     virtual void SetText(const wxString& text);
 | |
| 
 | |
|     /**
 | |
|         Sets the text colour associated with the menu item (Windows only).
 | |
|     */
 | |
|     void SetTextColour(const wxColour& colour);
 | |
| };
 | |
| 
 |