1999-11-16 16:31:40 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/frame.h
|
|
|
|
// Purpose: wxFrame class interface
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 15.11.99
|
2004-05-23 10:56:36 -04:00
|
|
|
// Copyright: (c) wxWidgets team
|
2004-05-23 16:53:33 -04:00
|
|
|
// Licence: wxWindows licence
|
1999-11-16 16:31:40 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-08-14 20:23:28 -04:00
|
|
|
#ifndef _WX_FRAME_H_BASE_
|
|
|
|
#define _WX_FRAME_H_BASE_
|
1998-05-20 10:01:55 -04:00
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// headers
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2001-09-15 18:13:08 -04:00
|
|
|
#include "wx/toplevel.h" // the base class
|
2009-04-21 07:10:44 -04:00
|
|
|
#include "wx/statusbr.h"
|
1999-11-16 16:31:40 -05:00
|
|
|
|
|
|
|
// the default names for various classs
|
2008-03-26 11:06:00 -04:00
|
|
|
extern WXDLLIMPEXP_DATA_CORE(const char) wxStatusLineNameStr[];
|
|
|
|
extern WXDLLIMPEXP_DATA_CORE(const char) wxToolBarNameStr[];
|
1999-11-16 16:31:40 -05:00
|
|
|
|
2007-07-09 06:09:52 -04:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxFrame;
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxMenuBar;
|
2007-11-11 19:23:15 -05:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxMenuItem;
|
2007-07-09 06:09:52 -04:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxStatusBar;
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxToolBar;
|
1999-11-16 16:31:40 -05:00
|
|
|
|
2004-04-13 08:22:34 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// constants
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// wxFrame-specific (i.e. not for wxDialog) styles
|
2010-05-10 17:09:50 -04:00
|
|
|
//
|
|
|
|
// Also see the bit summary table in wx/toplevel.h.
|
2004-04-13 08:22:34 -04:00
|
|
|
#define wxFRAME_NO_TASKBAR 0x0002 // No taskbar button (MSW only)
|
|
|
|
#define wxFRAME_TOOL_WINDOW 0x0004 // No taskbar button, no system menu
|
|
|
|
#define wxFRAME_FLOAT_ON_PARENT 0x0008 // Always above its parent
|
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxFrame is a top-level window with optional menubar, statusbar and toolbar
|
|
|
|
//
|
|
|
|
// For each of *bars, a frame may have several of them, but only one is
|
|
|
|
// managed by the frame, i.e. resized/moved when the frame is and whose size
|
|
|
|
// is accounted for in client size calculations - all others should be taken
|
|
|
|
// care of manually. The CreateXXXBar() functions create this, main, XXXBar,
|
|
|
|
// but the actual creation is done in OnCreateXXXBar() functions which may be
|
|
|
|
// overridden to create custom objects instead of standard ones when
|
|
|
|
// CreateXXXBar() is called.
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2008-03-26 11:06:00 -04:00
|
|
|
class WXDLLIMPEXP_CORE wxFrameBase : public wxTopLevelWindow
|
1999-11-16 16:31:40 -05:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// construction
|
|
|
|
wxFrameBase();
|
2002-01-07 16:52:28 -05:00
|
|
|
virtual ~wxFrameBase();
|
1999-11-16 16:31:40 -05:00
|
|
|
|
|
|
|
wxFrame *New(wxWindow *parent,
|
2003-03-20 21:58:55 -05:00
|
|
|
wxWindowID winid,
|
1999-11-16 16:31:40 -05:00
|
|
|
const wxString& title,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
|
|
const wxString& name = wxFrameNameStr);
|
|
|
|
|
|
|
|
// frame state
|
|
|
|
// -----------
|
|
|
|
|
1999-12-01 10:23:56 -05:00
|
|
|
// get the origin of the client area (which may be different from (0, 0)
|
|
|
|
// if the frame has a toolbar) in client coordinates
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual wxPoint GetClientAreaOrigin() const wxOVERRIDE;
|
1999-12-01 10:23:56 -05:00
|
|
|
|
2002-08-22 13:03:38 -04:00
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
// menu bar functions
|
|
|
|
// ------------------
|
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
#if wxUSE_MENUS
|
2001-07-10 08:25:46 -04:00
|
|
|
virtual void SetMenuBar(wxMenuBar *menubar);
|
1999-11-16 16:31:40 -05:00
|
|
|
virtual wxMenuBar *GetMenuBar() const { return m_frameMenuBar; }
|
2007-05-18 13:03:38 -04:00
|
|
|
|
|
|
|
// find the item by id in the frame menu bar: this is an internal function
|
|
|
|
// and exists mainly in order to be overridden in the MDI parent frame
|
|
|
|
// which also looks at its active child menu bar
|
2009-01-28 04:14:07 -05:00
|
|
|
virtual wxMenuItem *FindItemInMenuBar(int menuId) const;
|
1999-11-16 16:31:40 -05:00
|
|
|
|
2008-07-05 16:51:16 -04:00
|
|
|
// generate menu command corresponding to the given menu item
|
|
|
|
//
|
|
|
|
// returns true if processed
|
|
|
|
bool ProcessCommand(wxMenuItem *item);
|
|
|
|
|
|
|
|
// generate menu command corresponding to the given menu command id
|
|
|
|
//
|
|
|
|
// returns true if processed
|
2003-03-20 21:58:55 -05:00
|
|
|
bool ProcessCommand(int winid);
|
2008-07-05 16:51:16 -04:00
|
|
|
#else
|
|
|
|
bool ProcessCommand(int WXUNUSED(winid)) { return false; }
|
|
|
|
#endif // wxUSE_MENUS
|
1999-11-16 16:31:40 -05:00
|
|
|
|
|
|
|
// status bar functions
|
|
|
|
// --------------------
|
|
|
|
#if wxUSE_STATUSBAR
|
|
|
|
// create the main status bar by calling OnCreateStatusBar()
|
|
|
|
virtual wxStatusBar* CreateStatusBar(int number = 1,
|
2009-04-25 08:59:09 -04:00
|
|
|
long style = wxSTB_DEFAULT_STYLE,
|
2003-03-20 21:58:55 -05:00
|
|
|
wxWindowID winid = 0,
|
2009-04-21 07:10:44 -04:00
|
|
|
const wxString& name = wxStatusLineNameStr);
|
1999-11-16 16:31:40 -05:00
|
|
|
// return a new status bar
|
|
|
|
virtual wxStatusBar *OnCreateStatusBar(int number,
|
|
|
|
long style,
|
2003-03-20 21:58:55 -05:00
|
|
|
wxWindowID winid,
|
1999-11-16 16:31:40 -05:00
|
|
|
const wxString& name);
|
|
|
|
// get the main status bar
|
|
|
|
virtual wxStatusBar *GetStatusBar() const { return m_frameStatusBar; }
|
|
|
|
|
|
|
|
// sets the main status bar
|
2004-09-30 21:49:45 -04:00
|
|
|
virtual void SetStatusBar(wxStatusBar *statBar);
|
1999-11-16 16:31:40 -05:00
|
|
|
|
|
|
|
// forward these to status bar
|
|
|
|
virtual void SetStatusText(const wxString &text, int number = 0);
|
|
|
|
virtual void SetStatusWidths(int n, const int widths_field[]);
|
2002-05-02 16:07:10 -04:00
|
|
|
void PushStatusText(const wxString &text, int number = 0);
|
|
|
|
void PopStatusText(int number = 0);
|
2002-05-02 19:56:00 -04:00
|
|
|
|
|
|
|
// set the status bar pane the help will be shown in
|
|
|
|
void SetStatusBarPane(int n) { m_statusBarPane = n; }
|
|
|
|
int GetStatusBarPane() const { return m_statusBarPane; }
|
1999-11-16 16:31:40 -05:00
|
|
|
#endif // wxUSE_STATUSBAR
|
|
|
|
|
|
|
|
// toolbar functions
|
|
|
|
// -----------------
|
2003-07-10 06:53:00 -04:00
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
#if wxUSE_TOOLBAR
|
|
|
|
// create main toolbar bycalling OnCreateToolBar()
|
2003-07-10 06:53:00 -04:00
|
|
|
virtual wxToolBar* CreateToolBar(long style = -1,
|
2004-09-14 08:08:28 -04:00
|
|
|
wxWindowID winid = wxID_ANY,
|
1999-11-16 16:31:40 -05:00
|
|
|
const wxString& name = wxToolBarNameStr);
|
|
|
|
// return a new toolbar
|
|
|
|
virtual wxToolBar *OnCreateToolBar(long style,
|
2003-03-20 21:58:55 -05:00
|
|
|
wxWindowID winid,
|
1999-11-16 16:31:40 -05:00
|
|
|
const wxString& name );
|
|
|
|
|
|
|
|
// get/set the main toolbar
|
|
|
|
virtual wxToolBar *GetToolBar() const { return m_frameToolBar; }
|
2004-09-30 21:49:45 -04:00
|
|
|
virtual void SetToolBar(wxToolBar *toolbar);
|
1999-11-16 16:31:40 -05:00
|
|
|
#endif // wxUSE_TOOLBAR
|
|
|
|
|
|
|
|
// implementation only from now on
|
|
|
|
// -------------------------------
|
|
|
|
|
|
|
|
// event handlers
|
2003-10-07 18:55:06 -04:00
|
|
|
#if wxUSE_MENUS
|
|
|
|
#if wxUSE_STATUSBAR
|
2003-07-07 12:21:44 -04:00
|
|
|
void OnMenuOpen(wxMenuEvent& event);
|
2003-10-07 18:55:06 -04:00
|
|
|
void OnMenuClose(wxMenuEvent& event);
|
1999-11-16 16:31:40 -05:00
|
|
|
void OnMenuHighlight(wxMenuEvent& event);
|
2003-10-07 18:55:06 -04:00
|
|
|
#endif // wxUSE_STATUSBAR
|
1999-11-16 16:31:40 -05:00
|
|
|
|
2003-07-12 19:09:04 -04:00
|
|
|
// send wxUpdateUIEvents for all menu items in the menubar,
|
|
|
|
// or just for menu if non-NULL
|
2004-09-01 05:16:21 -04:00
|
|
|
virtual void DoMenuUpdates(wxMenu* menu = NULL);
|
2001-06-26 16:59:19 -04:00
|
|
|
#endif // wxUSE_MENUS
|
1999-11-16 16:31:40 -05:00
|
|
|
|
2003-07-09 06:15:21 -04:00
|
|
|
// do the UI update processing for this window
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual void UpdateWindowUI(long flags = wxUPDATE_UI_NONE) wxOVERRIDE;
|
2003-07-09 06:15:21 -04:00
|
|
|
|
|
|
|
// Implement internal behaviour (menu updating on some platforms)
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual void OnInternalIdle() wxOVERRIDE;
|
2003-07-09 06:15:21 -04:00
|
|
|
|
2006-08-01 08:01:24 -04:00
|
|
|
#if wxUSE_MENUS || wxUSE_TOOLBAR
|
2007-04-02 18:00:52 -04:00
|
|
|
// show help text for the currently selected menu or toolbar item
|
2007-04-03 14:04:44 -04:00
|
|
|
// (typically in the status bar) or hide it and restore the status bar text
|
|
|
|
// originally shown before the menu was opened if show == false
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual void DoGiveHelp(const wxString& text, bool show) wxOVERRIDE;
|
2006-08-01 08:01:24 -04:00
|
|
|
#endif
|
2002-05-02 16:07:10 -04:00
|
|
|
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual bool IsClientAreaChild(const wxWindow *child) const wxOVERRIDE
|
2007-10-26 02:20:23 -04:00
|
|
|
{
|
|
|
|
return !IsOneOfBars(child) && wxTopLevelWindow::IsClientAreaChild(child);
|
|
|
|
}
|
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
protected:
|
|
|
|
// the frame main menu/status/tool bars
|
|
|
|
// ------------------------------------
|
|
|
|
|
|
|
|
// this (non virtual!) function should be called from dtor to delete the
|
|
|
|
// main menubar, statusbar and toolbar (if any)
|
|
|
|
void DeleteAllBars();
|
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
// test whether this window makes part of the frame
|
2014-03-29 20:02:23 -04:00
|
|
|
virtual bool IsOneOfBars(const wxWindow *win) const wxOVERRIDE;
|
2001-06-26 16:59:19 -04:00
|
|
|
|
|
|
|
#if wxUSE_MENUS
|
|
|
|
// override to update menu bar position when the frame size changes
|
|
|
|
virtual void PositionMenuBar() { }
|
|
|
|
|
2001-07-10 08:25:46 -04:00
|
|
|
// override to do something special when the menu bar is being removed
|
|
|
|
// from the frame
|
|
|
|
virtual void DetachMenuBar();
|
|
|
|
|
|
|
|
// override to do something special when the menu bar is attached to the
|
|
|
|
// frame
|
|
|
|
virtual void AttachMenuBar(wxMenuBar *menubar);
|
|
|
|
|
2012-11-24 19:15:49 -05:00
|
|
|
// Return true if we should update the menu item state from idle event
|
|
|
|
// handler or false if we should delay it until the menu is opened.
|
|
|
|
static bool ShouldUpdateMenuFromIdle();
|
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
wxMenuBar *m_frameMenuBar;
|
2006-08-01 08:01:24 -04:00
|
|
|
#endif // wxUSE_MENUS
|
2003-10-07 18:55:06 -04:00
|
|
|
|
2006-08-01 08:01:24 -04:00
|
|
|
#if wxUSE_STATUSBAR && (wxUSE_MENUS || wxUSE_TOOLBAR)
|
2003-10-07 18:55:06 -04:00
|
|
|
// the saved status bar text overwritten by DoGiveHelp()
|
|
|
|
wxString m_oldStatusText;
|
2009-08-05 20:21:16 -04:00
|
|
|
|
|
|
|
// the last help string we have shown in the status bar
|
|
|
|
wxString m_lastHelpShown;
|
2006-08-01 08:01:24 -04:00
|
|
|
#endif
|
1999-11-16 16:31:40 -05:00
|
|
|
|
|
|
|
#if wxUSE_STATUSBAR
|
|
|
|
// override to update status bar position (or anything else) when
|
|
|
|
// something changes
|
|
|
|
virtual void PositionStatusBar() { }
|
|
|
|
|
2007-05-18 12:44:31 -04:00
|
|
|
// show the help string for the given menu item using DoGiveHelp() if the
|
2007-05-18 13:03:38 -04:00
|
|
|
// given item does have a help string (as determined by FindInMenuBar()),
|
|
|
|
// return false if there is no help for such item
|
2007-05-18 12:44:31 -04:00
|
|
|
bool ShowMenuHelp(int helpid);
|
2000-07-15 15:51:35 -04:00
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
wxStatusBar *m_frameStatusBar;
|
|
|
|
#endif // wxUSE_STATUSBAR
|
|
|
|
|
2002-05-02 16:07:10 -04:00
|
|
|
|
|
|
|
int m_statusBarPane;
|
|
|
|
|
1999-11-16 16:31:40 -05:00
|
|
|
#if wxUSE_TOOLBAR
|
|
|
|
// override to update status bar position (or anything else) when
|
|
|
|
// something changes
|
|
|
|
virtual void PositionToolBar() { }
|
|
|
|
|
|
|
|
wxToolBar *m_frameToolBar;
|
|
|
|
#endif // wxUSE_TOOLBAR
|
|
|
|
|
2003-10-07 18:55:06 -04:00
|
|
|
#if wxUSE_MENUS && wxUSE_STATUSBAR
|
1999-11-16 16:31:40 -05:00
|
|
|
DECLARE_EVENT_TABLE()
|
2003-10-07 18:55:06 -04:00
|
|
|
#endif // wxUSE_MENUS && wxUSE_STATUSBAR
|
|
|
|
|
2009-02-08 06:45:59 -05:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxFrameBase);
|
1999-11-16 16:31:40 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
// include the real class declaration
|
2001-11-28 13:22:16 -05:00
|
|
|
#if defined(__WXUNIVERSAL__) // && !defined(__WXMICROWIN__)
|
2001-06-26 16:59:19 -04:00
|
|
|
#include "wx/univ/frame.h"
|
2001-07-09 17:41:19 -04:00
|
|
|
#else // !__WXUNIVERSAL__
|
2012-01-14 20:05:28 -05:00
|
|
|
#if defined(__WXMSW__)
|
2001-10-19 16:35:05 -04:00
|
|
|
#include "wx/msw/frame.h"
|
2006-01-22 22:27:34 -05:00
|
|
|
#elif defined(__WXGTK20__)
|
2001-10-19 16:35:05 -04:00
|
|
|
#include "wx/gtk/frame.h"
|
2006-01-22 22:27:34 -05:00
|
|
|
#elif defined(__WXGTK__)
|
|
|
|
#include "wx/gtk1/frame.h"
|
2001-10-19 16:35:05 -04:00
|
|
|
#elif defined(__WXMOTIF__)
|
|
|
|
#include "wx/motif/frame.h"
|
|
|
|
#elif defined(__WXMAC__)
|
2008-06-11 15:17:41 -04:00
|
|
|
#include "wx/osx/frame.h"
|
2003-03-22 01:18:36 -05:00
|
|
|
#elif defined(__WXCOCOA__)
|
|
|
|
#include "wx/cocoa/frame.h"
|
2001-10-19 16:35:05 -04:00
|
|
|
#endif
|
|
|
|
#endif
|
2001-06-26 16:59:19 -04:00
|
|
|
|
1998-05-20 10:01:55 -04:00
|
|
|
#endif
|
1998-08-14 20:23:28 -04:00
|
|
|
// _WX_FRAME_H_BASE_
|