1998-05-20 14:12:05 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
2002-03-21 02:35:08 +00:00
|
|
|
// Name: wx/msw/menu.h
|
1998-05-20 14:12:05 +00:00
|
|
|
// Purpose: wxMenu, wxMenuBar classes
|
|
|
|
// Author: Julian Smart
|
|
|
|
// Modified by: Vadim Zeitlin (wxMenuItem is now in separate file)
|
|
|
|
// Created: 01/02/97
|
2003-03-17 10:34:04 +00:00
|
|
|
// Copyright: (c) Julian Smart
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
1998-05-20 14:12:05 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-08-07 23:52:45 +00:00
|
|
|
#ifndef _WX_MENU_H_
|
|
|
|
#define _WX_MENU_H_
|
1998-05-20 14:12:05 +00:00
|
|
|
|
1999-08-23 15:23:29 +00:00
|
|
|
#if wxUSE_ACCEL
|
1999-10-25 15:51:37 +00:00
|
|
|
#include "wx/accel.h"
|
1999-11-02 01:25:43 +00:00
|
|
|
#include "wx/dynarray.h"
|
|
|
|
|
2003-10-08 22:13:14 +00:00
|
|
|
WX_DEFINE_EXPORTED_ARRAY_PTR(wxAcceleratorEntry *, wxAcceleratorArray);
|
1999-08-23 15:23:29 +00:00
|
|
|
#endif // wxUSE_ACCEL
|
1998-05-20 14:12:05 +00:00
|
|
|
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxFrame;
|
1998-05-20 14:12:05 +00:00
|
|
|
|
2011-05-10 08:50:38 +00:00
|
|
|
class wxMenuRadioItemsData;
|
2004-06-12 22:58:28 +00:00
|
|
|
|
|
|
|
|
2003-07-21 19:55:46 +00:00
|
|
|
#include "wx/arrstr.h"
|
|
|
|
|
1998-05-20 14:12:05 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Menu
|
|
|
|
// ----------------------------------------------------------------------------
|
1999-03-24 19:05:19 +00:00
|
|
|
|
2008-03-26 15:06:00 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxMenu : public wxMenuBase
|
1998-05-20 14:12:05 +00:00
|
|
|
{
|
|
|
|
public:
|
1999-07-19 22:17:40 +00:00
|
|
|
// ctors & dtor
|
1999-11-02 01:25:43 +00:00
|
|
|
wxMenu(const wxString& title, long style = 0)
|
|
|
|
: wxMenuBase(title, style) { Init(); }
|
1999-08-04 13:01:20 +00:00
|
|
|
|
1999-11-02 01:25:43 +00:00
|
|
|
wxMenu(long style = 0) : wxMenuBase(style) { Init(); }
|
1999-07-19 22:17:40 +00:00
|
|
|
|
1999-03-24 19:05:19 +00:00
|
|
|
virtual ~wxMenu();
|
|
|
|
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual void Break() wxOVERRIDE;
|
1999-11-02 01:25:43 +00:00
|
|
|
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual void SetTitle(const wxString& title) wxOVERRIDE;
|
1999-03-24 19:05:19 +00:00
|
|
|
|
2011-08-08 09:32:39 +00:00
|
|
|
// MSW-only methods
|
|
|
|
// ----------------
|
|
|
|
|
|
|
|
// Create a new menu from the given native HMENU. Takes ownership of the
|
|
|
|
// menu handle and will delete it when this object is destroyed.
|
|
|
|
static wxMenu *MSWNewFromHMENU(WXHMENU hMenu) { return new wxMenu(hMenu); }
|
|
|
|
|
2014-06-18 12:51:45 +00:00
|
|
|
// Detaches HMENU so that it isn't deleted when this object is destroyed.
|
|
|
|
// Don't use this object after calling this method.
|
|
|
|
WXHMENU MSWDetachHMENU() { WXHMENU m = m_hMenu; m_hMenu = NULL; return m; }
|
2011-08-08 09:32:39 +00:00
|
|
|
|
1999-11-02 01:25:43 +00:00
|
|
|
// implementation only from now on
|
|
|
|
// -------------------------------
|
1999-03-24 19:05:19 +00:00
|
|
|
|
1999-11-02 01:25:43 +00:00
|
|
|
bool MSWCommand(WXUINT param, WXWORD id);
|
1999-03-24 19:05:19 +00:00
|
|
|
|
2010-04-24 15:07:39 +00:00
|
|
|
// get the native menu handle
|
1999-11-02 01:25:43 +00:00
|
|
|
WXHMENU GetHMenu() const { return m_hMenu; }
|
1998-05-20 14:12:05 +00:00
|
|
|
|
2011-05-10 08:50:38 +00:00
|
|
|
// Return the start and end position of the radio group to which the item
|
|
|
|
// at the given position belongs. Returns false if there is no radio group
|
|
|
|
// containing this position.
|
|
|
|
bool MSWGetRadioGroupRange(int pos, int *start, int *end) const;
|
|
|
|
|
1999-06-13 22:54:04 +00:00
|
|
|
#if wxUSE_ACCEL
|
1999-11-02 01:25:43 +00:00
|
|
|
// called by wxMenuBar to build its accel table from the accels of all menus
|
2009-01-27 16:45:24 +00:00
|
|
|
bool HasAccels() const { return !m_accels.empty(); }
|
|
|
|
size_t GetAccelCount() const { return m_accels.size(); }
|
1999-05-19 00:53:27 +00:00
|
|
|
size_t CopyAccels(wxAcceleratorEntry *accels) const;
|
|
|
|
|
1999-11-02 01:25:43 +00:00
|
|
|
// called by wxMenuItem when its accels changes
|
|
|
|
void UpdateAccel(wxMenuItem *item);
|
2016-12-05 16:59:03 +00:00
|
|
|
void RemoveAccel(wxMenuItem *item);
|
1999-05-19 00:53:27 +00:00
|
|
|
|
1999-11-02 01:25:43 +00:00
|
|
|
// helper used by wxMenu itself (returns the index in m_accels)
|
|
|
|
int FindAccel(int id) const;
|
2009-01-27 16:45:24 +00:00
|
|
|
|
|
|
|
// used only by wxMDIParentFrame currently but could be useful elsewhere:
|
|
|
|
// returns a new accelerator table with accelerators for just this menu
|
|
|
|
// (shouldn't be called if we don't have any accelerators)
|
|
|
|
wxAcceleratorTable *CreateAccelTable() const;
|
1999-11-02 01:25:43 +00:00
|
|
|
#endif // wxUSE_ACCEL
|
1999-05-19 00:53:27 +00:00
|
|
|
|
2014-12-05 22:18:07 +00:00
|
|
|
// get the menu with given handle (recursively)
|
|
|
|
wxMenu* MSWGetMenu(WXHMENU hMenu);
|
|
|
|
|
2010-01-23 13:21:46 +00:00
|
|
|
#if wxUSE_OWNER_DRAWN
|
|
|
|
|
|
|
|
int GetMaxAccelWidth()
|
|
|
|
{
|
|
|
|
if (m_maxAccelWidth == -1)
|
|
|
|
CalculateMaxAccelWidth();
|
|
|
|
return m_maxAccelWidth;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ResetMaxAccelWidth()
|
|
|
|
{
|
|
|
|
m_maxAccelWidth = -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
void CalculateMaxAccelWidth();
|
|
|
|
|
|
|
|
#endif // wxUSE_OWNER_DRAWN
|
|
|
|
|
2006-02-08 21:47:09 +00:00
|
|
|
protected:
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual wxMenuItem* DoAppend(wxMenuItem *item) wxOVERRIDE;
|
|
|
|
virtual wxMenuItem* DoInsert(size_t pos, wxMenuItem *item) wxOVERRIDE;
|
|
|
|
virtual wxMenuItem* DoRemove(wxMenuItem *item) wxOVERRIDE;
|
2006-02-08 21:47:09 +00:00
|
|
|
|
1998-05-20 14:12:05 +00:00
|
|
|
private:
|
2011-08-08 09:32:39 +00:00
|
|
|
// This constructor is private, use MSWNewFromHMENU() to use it.
|
|
|
|
wxMenu(WXHMENU hMenu);
|
|
|
|
|
|
|
|
// Common part of all ctors, it doesn't create a new HMENU.
|
|
|
|
void InitNoCreate();
|
|
|
|
|
|
|
|
// Common part of all ctors except of the one above taking a native menu
|
|
|
|
// handler: calls InitNoCreate() and also creates a new menu.
|
1999-11-02 01:25:43 +00:00
|
|
|
void Init();
|
|
|
|
|
|
|
|
// common part of Append/Insert (behaves as Append is pos == (size_t)-1)
|
|
|
|
bool DoInsertOrAppend(wxMenuItem *item, size_t pos = (size_t)-1);
|
|
|
|
|
2011-05-10 08:50:38 +00:00
|
|
|
|
|
|
|
// This variable contains the description of the radio item groups and
|
|
|
|
// allows to find whether an item at the given position is part of the
|
|
|
|
// group and also where its group starts and ends.
|
|
|
|
//
|
|
|
|
// It is initially NULL and only allocated if we have any radio items.
|
|
|
|
wxMenuRadioItemsData *m_radioData;
|
2002-03-21 02:35:08 +00:00
|
|
|
|
2004-08-30 10:18:55 +00:00
|
|
|
// if true, insert a breal before appending the next item
|
1999-11-02 01:25:43 +00:00
|
|
|
bool m_doBreak;
|
|
|
|
|
|
|
|
// the menu handle of this menu
|
|
|
|
WXHMENU m_hMenu;
|
1999-05-19 00:53:27 +00:00
|
|
|
|
1999-06-13 22:54:04 +00:00
|
|
|
#if wxUSE_ACCEL
|
1999-10-25 15:51:37 +00:00
|
|
|
// the accelerators for our menu items
|
|
|
|
wxAcceleratorArray m_accels;
|
1999-06-13 22:54:04 +00:00
|
|
|
#endif // wxUSE_ACCEL
|
1999-11-02 01:25:43 +00:00
|
|
|
|
2010-01-23 13:21:27 +00:00
|
|
|
#if wxUSE_OWNER_DRAWN
|
|
|
|
// true if the menu has any ownerdrawn items
|
|
|
|
bool m_ownerDrawn;
|
|
|
|
|
|
|
|
// the max width of menu items bitmaps
|
|
|
|
int m_maxBitmapWidth;
|
2010-01-23 13:21:46 +00:00
|
|
|
|
|
|
|
// the max width of menu items accels
|
|
|
|
int m_maxAccelWidth;
|
2010-01-23 13:21:27 +00:00
|
|
|
#endif // wxUSE_OWNER_DRAWN
|
|
|
|
|
2015-04-23 11:49:01 +00:00
|
|
|
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxMenu);
|
1998-05-20 14:12:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Menu Bar (a la Windows)
|
|
|
|
// ----------------------------------------------------------------------------
|
1999-03-24 19:05:19 +00:00
|
|
|
|
2008-03-26 15:06:00 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxMenuBar : public wxMenuBarBase
|
1998-05-20 14:12:05 +00:00
|
|
|
{
|
1999-03-24 19:05:19 +00:00
|
|
|
public:
|
2004-08-30 10:18:55 +00:00
|
|
|
// ctors & dtor
|
1999-04-03 22:25:12 +00:00
|
|
|
// default constructor
|
1999-03-24 19:05:19 +00:00
|
|
|
wxMenuBar();
|
1999-04-03 22:25:12 +00:00
|
|
|
// unused under MSW
|
1999-03-24 19:05:19 +00:00
|
|
|
wxMenuBar(long style);
|
1999-04-03 22:25:12 +00:00
|
|
|
// menubar takes ownership of the menus arrays but copies the titles
|
2005-03-17 23:45:24 +00:00
|
|
|
wxMenuBar(size_t n, wxMenu *menus[], const wxString titles[], long style = 0);
|
1999-03-24 19:05:19 +00:00
|
|
|
virtual ~wxMenuBar();
|
|
|
|
|
|
|
|
// menubar construction
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual bool Append( wxMenu *menu, const wxString &title ) wxOVERRIDE;
|
|
|
|
virtual bool Insert(size_t pos, wxMenu *menu, const wxString& title) wxOVERRIDE;
|
|
|
|
virtual wxMenu *Replace(size_t pos, wxMenu *menu, const wxString& title) wxOVERRIDE;
|
|
|
|
virtual wxMenu *Remove(size_t pos) wxOVERRIDE;
|
1999-03-24 19:05:19 +00:00
|
|
|
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual void EnableTop( size_t pos, bool flag ) wxOVERRIDE;
|
|
|
|
virtual bool IsEnabledTop(size_t pos) const wxOVERRIDE;
|
|
|
|
virtual void SetMenuLabel( size_t pos, const wxString& label ) wxOVERRIDE;
|
|
|
|
virtual wxString GetMenuLabel( size_t pos ) const wxOVERRIDE;
|
1999-03-24 19:05:19 +00:00
|
|
|
|
1999-10-26 19:35:25 +00:00
|
|
|
// implementation from now on
|
|
|
|
WXHMENU Create();
|
2016-09-23 14:59:11 +00:00
|
|
|
virtual void Detach() wxOVERRIDE;
|
|
|
|
virtual void Attach(wxFrame *frame) wxOVERRIDE;
|
1999-04-03 22:25:12 +00:00
|
|
|
|
1999-06-13 22:54:04 +00:00
|
|
|
#if wxUSE_ACCEL
|
2005-05-31 09:20:43 +00:00
|
|
|
// update the accel table (must be called after adding/deleting a menu)
|
1999-11-02 01:25:43 +00:00
|
|
|
void RebuildAccelTable();
|
1999-06-13 22:54:04 +00:00
|
|
|
#endif // wxUSE_ACCEL
|
|
|
|
|
1999-04-03 22:25:12 +00:00
|
|
|
// get the menu handle
|
|
|
|
WXHMENU GetHMenu() const { return m_hMenu; }
|
|
|
|
|
|
|
|
// if the menubar is modified, the display is not updated automatically,
|
|
|
|
// call this function to update it (m_menuBarFrame should be !NULL)
|
|
|
|
void Refresh();
|
|
|
|
|
2003-07-02 11:44:24 +00:00
|
|
|
// To avoid compile warning
|
2003-07-02 13:45:49 +00:00
|
|
|
void Refresh( bool eraseBackground,
|
2016-09-23 14:59:11 +00:00
|
|
|
const wxRect *rect = (const wxRect *) NULL ) wxOVERRIDE { wxWindow::Refresh(eraseBackground, rect); }
|
2003-07-02 11:44:24 +00:00
|
|
|
|
2014-12-05 22:19:19 +00:00
|
|
|
// Get a top level menu position or wxNOT_FOUND from its handle.
|
|
|
|
int MSWGetTopMenuPos(WXHMENU hMenu) const;
|
|
|
|
|
2014-12-05 22:19:16 +00:00
|
|
|
// Get a top level or sub menu with given handle (recursively).
|
|
|
|
wxMenu* MSWGetMenu(WXHMENU hMenu) const;
|
2011-03-31 09:28:38 +00:00
|
|
|
|
1999-09-06 12:53:09 +00:00
|
|
|
protected:
|
|
|
|
// common part of all ctors
|
|
|
|
void Init();
|
|
|
|
|
1999-04-03 22:25:12 +00:00
|
|
|
WXHMENU m_hMenu;
|
1999-05-19 00:53:27 +00:00
|
|
|
|
2004-01-14 05:57:09 +00:00
|
|
|
// Return the MSW position for a wxMenu which is sometimes different from
|
2004-05-23 14:56:36 +00:00
|
|
|
// the wxWidgets position.
|
2004-01-14 05:57:09 +00:00
|
|
|
int MSWPositionForWxMenu(wxMenu *menu, int wxpos);
|
1999-10-26 19:35:25 +00:00
|
|
|
|
|
|
|
private:
|
2015-04-23 11:49:01 +00:00
|
|
|
wxDECLARE_DYNAMIC_CLASS_NO_COPY(wxMenuBar);
|
1998-05-20 14:12:05 +00:00
|
|
|
};
|
|
|
|
|
1998-08-07 23:52:45 +00:00
|
|
|
#endif // _WX_MENU_H_
|