3f66f6a5b3
This keyword is not expanded by Git which means it's not replaced with the correct revision value in the releases made using git-based scripts and it's confusing to have lines with unexpanded "$Id$" in the released files. As expanding them with Git is not that simple (it could be done with git archive and export-subst attribute) and there are not many benefits in having them in the first place, just remove all these lines. If nothing else, this will make an eventual transition to Git simpler. Closes #14487. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@74602 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
266 lines
8.1 KiB
C++
266 lines
8.1 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: wx/msw/mdi.h
|
|
// Purpose: MDI (Multiple Document Interface) classes
|
|
// Author: Julian Smart
|
|
// Modified by: 2008-10-31 Vadim Zeitlin: derive from the base classes
|
|
// Created: 01/02/97
|
|
// Copyright: (c) 1997 Julian Smart
|
|
// (c) 2008 Vadim Zeitlin
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef _WX_MSW_MDI_H_
|
|
#define _WX_MSW_MDI_H_
|
|
|
|
#include "wx/frame.h"
|
|
|
|
class WXDLLIMPEXP_FWD_CORE wxAcceleratorTable;
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// wxMDIParentFrame
|
|
// ---------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIParentFrame : public wxMDIParentFrameBase
|
|
{
|
|
public:
|
|
wxMDIParentFrame() { Init(); }
|
|
wxMDIParentFrame(wxWindow *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
|
|
const wxString& name = wxFrameNameStr)
|
|
{
|
|
Init();
|
|
|
|
Create(parent, id, title, pos, size, style, name);
|
|
}
|
|
|
|
virtual ~wxMDIParentFrame();
|
|
|
|
bool Create(wxWindow *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
|
|
const wxString& name = wxFrameNameStr);
|
|
|
|
// override/implement base class [pure] virtual methods
|
|
// ----------------------------------------------------
|
|
|
|
static bool IsTDI() { return false; }
|
|
|
|
// we don't store the active child in m_currentChild so override this
|
|
// function to find it dynamically
|
|
virtual wxMDIChildFrame *GetActiveChild() const;
|
|
|
|
virtual void Cascade();
|
|
virtual void Tile(wxOrientation orient = wxHORIZONTAL);
|
|
virtual void ArrangeIcons();
|
|
virtual void ActivateNext();
|
|
virtual void ActivatePrevious();
|
|
|
|
#if wxUSE_MENUS
|
|
virtual void SetWindowMenu(wxMenu* menu);
|
|
|
|
virtual void DoMenuUpdates(wxMenu* menu = NULL);
|
|
|
|
// return the active child menu, if any
|
|
virtual WXHMENU MSWGetActiveMenu() const;
|
|
#endif // wxUSE_MENUS
|
|
|
|
|
|
// implementation only from now on
|
|
|
|
// MDI helpers
|
|
// -----------
|
|
|
|
#if wxUSE_MENUS
|
|
// called by wxMDIChildFrame after it was successfully created
|
|
virtual void AddMDIChild(wxMDIChildFrame *child);
|
|
|
|
// called by wxMDIChildFrame just before it is destroyed
|
|
virtual void RemoveMDIChild(wxMDIChildFrame *child);
|
|
#endif // wxUSE_MENUS
|
|
|
|
// handlers
|
|
// --------
|
|
|
|
// Responds to colour changes
|
|
void OnSysColourChanged(wxSysColourChangedEvent& event);
|
|
|
|
void OnSize(wxSizeEvent& event);
|
|
void OnIconized(wxIconizeEvent& event);
|
|
|
|
bool HandleActivate(int state, bool minimized, WXHWND activate);
|
|
|
|
// override window proc for MDI-specific message processing
|
|
virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
|
|
|
|
virtual WXLRESULT MSWDefWindowProc(WXUINT, WXWPARAM, WXLPARAM);
|
|
virtual bool MSWTranslateMessage(WXMSG* msg);
|
|
|
|
#if wxUSE_MENUS
|
|
// override wxFrameBase function to also look in the active child menu bar
|
|
// and the "Window" menu
|
|
virtual wxMenuItem *FindItemInMenuBar(int menuId) const;
|
|
#endif // wxUSE_MENUS
|
|
|
|
protected:
|
|
#if wxUSE_MENUS_NATIVE
|
|
virtual void InternalSetMenuBar();
|
|
#endif // wxUSE_MENUS_NATIVE
|
|
|
|
virtual WXHICON GetDefaultIcon() const;
|
|
|
|
// set the size of the MDI client window to match the frame size
|
|
void UpdateClientSize();
|
|
|
|
private:
|
|
// common part of all ctors
|
|
void Init();
|
|
|
|
#if wxUSE_MENUS
|
|
// "Window" menu commands event handlers
|
|
void OnMDICommand(wxCommandEvent& event);
|
|
void OnMDIChild(wxCommandEvent& event);
|
|
|
|
|
|
// add/remove window menu if we have it (i.e. m_windowMenu != NULL)
|
|
void AddWindowMenu();
|
|
void RemoveWindowMenu();
|
|
|
|
// update the window menu (if we have it) to enable or disable the commands
|
|
// which only make sense when we have more than one child
|
|
void UpdateWindowMenu(bool enable);
|
|
|
|
#if wxUSE_ACCEL
|
|
wxAcceleratorTable *m_accelWindowMenu;
|
|
#endif // wxUSE_ACCEL
|
|
#endif // wxUSE_MENUS
|
|
|
|
// return the number of child frames we currently have (maybe 0)
|
|
int GetChildFramesCount() const;
|
|
|
|
|
|
friend class WXDLLIMPEXP_FWD_CORE wxMDIChildFrame;
|
|
|
|
DECLARE_EVENT_TABLE()
|
|
DECLARE_DYNAMIC_CLASS(wxMDIParentFrame)
|
|
wxDECLARE_NO_COPY_CLASS(wxMDIParentFrame);
|
|
};
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// wxMDIChildFrame
|
|
// ---------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIChildFrame : public wxMDIChildFrameBase
|
|
{
|
|
public:
|
|
wxMDIChildFrame() { Init(); }
|
|
wxMDIChildFrame(wxMDIParentFrame *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
const wxString& name = wxFrameNameStr)
|
|
{
|
|
Init();
|
|
|
|
Create(parent, id, title, pos, size, style, name);
|
|
}
|
|
|
|
bool Create(wxMDIParentFrame *parent,
|
|
wxWindowID id,
|
|
const wxString& title,
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
const wxSize& size = wxDefaultSize,
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
const wxString& name = wxFrameNameStr);
|
|
|
|
virtual ~wxMDIChildFrame();
|
|
|
|
// implement MDI operations
|
|
virtual void Activate();
|
|
|
|
// Override some frame operations too
|
|
virtual void Maximize(bool maximize = true);
|
|
virtual void Restore();
|
|
|
|
virtual bool Show(bool show = true);
|
|
|
|
// Implementation only from now on
|
|
// -------------------------------
|
|
|
|
// Handlers
|
|
bool HandleMDIActivate(long bActivate, WXHWND, WXHWND);
|
|
bool HandleWindowPosChanging(void *lpPos);
|
|
bool HandleGetMinMaxInfo(void *mmInfo);
|
|
|
|
virtual WXLRESULT MSWWindowProc(WXUINT message, WXWPARAM wParam, WXLPARAM lParam);
|
|
virtual WXLRESULT MSWDefWindowProc(WXUINT message, WXWPARAM wParam, WXLPARAM lParam);
|
|
virtual bool MSWTranslateMessage(WXMSG *msg);
|
|
|
|
virtual void MSWDestroyWindow();
|
|
|
|
bool ResetWindowStyle(void *vrect);
|
|
|
|
void OnIdle(wxIdleEvent& event);
|
|
|
|
protected:
|
|
virtual void DoGetScreenPosition(int *x, int *y) const;
|
|
virtual void DoGetPosition(int *x, int *y) const;
|
|
virtual void DoSetSize(int x, int y, int width, int height, int sizeFlags);
|
|
virtual void DoSetClientSize(int width, int height);
|
|
virtual void InternalSetMenuBar();
|
|
virtual bool IsMDIChild() const { return true; }
|
|
virtual void DetachMenuBar();
|
|
|
|
virtual WXHICON GetDefaultIcon() const;
|
|
|
|
// common part of all ctors
|
|
void Init();
|
|
|
|
private:
|
|
bool m_needsInitialShow; // Show must be called in idle time after Creation
|
|
bool m_needsResize; // flag which tells us to artificially resize the frame
|
|
|
|
DECLARE_EVENT_TABLE()
|
|
DECLARE_DYNAMIC_CLASS_NO_COPY(wxMDIChildFrame)
|
|
};
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// wxMDIClientWindow
|
|
// ---------------------------------------------------------------------------
|
|
|
|
class WXDLLIMPEXP_CORE wxMDIClientWindow : public wxMDIClientWindowBase
|
|
{
|
|
public:
|
|
wxMDIClientWindow() { Init(); }
|
|
|
|
// Note: this is virtual, to allow overridden behaviour.
|
|
virtual bool CreateClient(wxMDIParentFrame *parent,
|
|
long style = wxVSCROLL | wxHSCROLL);
|
|
|
|
// Explicitly call default scroll behaviour
|
|
void OnScroll(wxScrollEvent& event);
|
|
|
|
protected:
|
|
virtual void DoSetSize(int x, int y,
|
|
int width, int height,
|
|
int sizeFlags = wxSIZE_AUTO);
|
|
|
|
void Init() { m_scrollX = m_scrollY = 0; }
|
|
|
|
int m_scrollX, m_scrollY;
|
|
|
|
private:
|
|
DECLARE_EVENT_TABLE()
|
|
DECLARE_DYNAMIC_CLASS_NO_COPY(wxMDIClientWindow)
|
|
};
|
|
|
|
#endif // _WX_MSW_MDI_H_
|