2004-03-23 17:35:05 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: mdi.h
|
|
|
|
// Purpose: MDI (Multiple Document Interface) classes.
|
|
|
|
// This doesn't have to be implemented just like Windows,
|
|
|
|
// it could be a tabbed design as in wxGTK.
|
|
|
|
// Author: Stefan Csomor
|
|
|
|
// Modified by:
|
|
|
|
// Created: 1998-01-01
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) Stefan Csomor
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2004-03-23 17:35:05 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_MDI_H_
|
|
|
|
#define _WX_MDI_H_
|
|
|
|
|
|
|
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
|
|
|
#pragma interface "mdi.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "wx/frame.h"
|
|
|
|
|
|
|
|
WXDLLEXPORT_DATA(extern const wxChar*) wxFrameNameStr;
|
|
|
|
WXDLLEXPORT_DATA(extern const wxChar*) wxStatusLineNameStr;
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxMDIClientWindow;
|
|
|
|
class WXDLLEXPORT wxMDIChildFrame;
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxMDIParentFrame: public wxFrame
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxMDIParentFrame)
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2005-09-01 01:26:49 +00:00
|
|
|
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, // Scrolling refers to client window
|
|
|
|
const wxString& name = wxFrameNameStr)
|
2004-03-23 17:35:05 +00:00
|
|
|
{
|
2005-09-01 01:26:49 +00:00
|
|
|
Init();
|
2004-03-23 17:35:05 +00:00
|
|
|
Create(parent, id, title, pos, size, style, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
~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);
|
|
|
|
|
|
|
|
// Mac OS activate event
|
|
|
|
virtual void MacActivate(long timestamp, bool activating);
|
|
|
|
|
2004-05-23 14:56:36 +00:00
|
|
|
// wxWidgets activate event
|
2004-03-23 17:35:05 +00:00
|
|
|
void OnActivate(wxActivateEvent& event);
|
|
|
|
void OnSysColourChanged(wxSysColourChangedEvent& event);
|
|
|
|
|
|
|
|
void SetMenuBar(wxMenuBar *menu_bar);
|
|
|
|
|
|
|
|
// Get the active MDI child window (Windows only)
|
|
|
|
wxMDIChildFrame *GetActiveChild() const ;
|
|
|
|
|
|
|
|
// Get the client window
|
|
|
|
inline wxMDIClientWindow *GetClientWindow() const { return m_clientWindow; };
|
2004-11-22 20:10:53 +00:00
|
|
|
// Get rect to be used to center top-level children
|
|
|
|
virtual void GetRectForTopLevelChildren(int *x, int *y, int *w, int *h);
|
2004-03-23 17:35:05 +00:00
|
|
|
|
|
|
|
// Create the client window class (don't Create the window,
|
|
|
|
// just return a new class)
|
|
|
|
virtual wxMDIClientWindow *OnCreateClient() ;
|
|
|
|
|
|
|
|
// MDI operations
|
|
|
|
virtual void Cascade();
|
2005-03-21 12:27:49 +00:00
|
|
|
virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL);
|
2004-03-23 17:35:05 +00:00
|
|
|
virtual void ArrangeIcons();
|
|
|
|
virtual void ActivateNext();
|
|
|
|
virtual void ActivatePrevious();
|
|
|
|
|
2004-10-01 01:51:29 +00:00
|
|
|
virtual bool Show( bool show = true );
|
|
|
|
|
2005-09-01 01:26:49 +00:00
|
|
|
// overridden base clas virtuals
|
|
|
|
virtual void AddChild(wxWindowBase *child);
|
|
|
|
virtual void RemoveChild(wxWindowBase *child);
|
|
|
|
|
2004-03-23 17:35:05 +00:00
|
|
|
protected:
|
2005-09-01 01:26:49 +00:00
|
|
|
// common part of all ctors
|
|
|
|
void Init();
|
|
|
|
|
|
|
|
// returns true if this frame has some contents and so should be visible,
|
|
|
|
// false if it's used solely as container for its children
|
|
|
|
bool ShouldBeVisible() const;
|
2004-03-23 17:35:05 +00:00
|
|
|
|
|
|
|
|
2005-09-01 01:26:49 +00:00
|
|
|
// TODO maybe have this member
|
|
|
|
wxMDIClientWindow *m_clientWindow;
|
|
|
|
wxMDIChildFrame *m_currentChild;
|
|
|
|
wxMenu *m_windowMenu;
|
|
|
|
|
|
|
|
// true if MDI Frame is intercepting commands, not child
|
2004-03-23 17:35:05 +00:00
|
|
|
bool m_parentFrameActive;
|
|
|
|
|
2005-09-01 01:26:49 +00:00
|
|
|
// true if the frame should be shown but is not because it is empty and
|
|
|
|
// useless otherwise than a container for its children
|
|
|
|
bool m_shouldBeShown;
|
|
|
|
|
2004-03-23 17:35:05 +00:00
|
|
|
private:
|
|
|
|
friend class WXDLLEXPORT wxMDIChildFrame;
|
2005-09-01 01:26:49 +00:00
|
|
|
DECLARE_EVENT_TABLE()
|
2004-03-23 17:35:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxMDIChildFrame: public wxFrame
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxMDIChildFrame)
|
|
|
|
public:
|
|
|
|
|
|
|
|
wxMDIChildFrame();
|
|
|
|
inline 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);
|
|
|
|
}
|
|
|
|
|
|
|
|
~wxMDIChildFrame();
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
// Mac OS activate event
|
|
|
|
virtual void MacActivate(long timestamp, bool activating);
|
|
|
|
|
|
|
|
// Set menu bar
|
|
|
|
void SetMenuBar(wxMenuBar *menu_bar);
|
|
|
|
|
|
|
|
// MDI operations
|
|
|
|
virtual void Maximize();
|
|
|
|
virtual void Maximize( bool ){ Maximize() ; } // this one is inherited from wxFrame
|
|
|
|
virtual void Restore();
|
|
|
|
virtual void Activate();
|
|
|
|
protected:
|
|
|
|
|
|
|
|
// common part of all ctors
|
|
|
|
void Init();
|
|
|
|
};
|
|
|
|
|
|
|
|
/* The client window is a child of the parent MDI frame, and itself
|
|
|
|
* contains the child MDI frames.
|
|
|
|
* However, you create the MDI children as children of the MDI parent:
|
|
|
|
* only in the implementation does the client window become the parent
|
|
|
|
* of the children. Phew! So the children are sort of 'adopted'...
|
|
|
|
*/
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxMDIClientWindow: public wxWindow
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxMDIClientWindow)
|
|
|
|
public:
|
|
|
|
|
|
|
|
wxMDIClientWindow() ;
|
|
|
|
inline wxMDIClientWindow(wxMDIParentFrame *parent, long style = 0)
|
|
|
|
{
|
|
|
|
CreateClient(parent, style);
|
|
|
|
}
|
|
|
|
|
|
|
|
~wxMDIClientWindow();
|
|
|
|
|
|
|
|
// Note: this is virtual, to allow overridden behaviour.
|
|
|
|
virtual bool CreateClient(wxMDIParentFrame *parent, long style = wxVSCROLL | wxHSCROLL);
|
|
|
|
|
|
|
|
// Gets the size available for subwindows after menu size, toolbar size
|
|
|
|
// and status bar size have been subtracted. If you want to manage your own
|
|
|
|
// toolbar(s), don't call SetToolBar.
|
|
|
|
void DoGetClientSize(int *width, int *height) const;
|
|
|
|
|
|
|
|
// Explicitly call default scroll behaviour
|
|
|
|
void OnScroll(wxScrollEvent& event);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
DECLARE_EVENT_TABLE()
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|
|
|
|
// _WX_MDI_H_
|