added orient parameter to wxMDIParentFrame::Tile()

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32951 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2005-03-21 12:27:49 +00:00
parent 3b880f293e
commit 0d97c09023
14 changed files with 70 additions and 59 deletions

View File

@@ -30,6 +30,10 @@ Unix:
- Fixed build on Linux/AMD64 - Fixed build on Linux/AMD64
wxMSW:
- Added "orient" parameter to wxMDIParentFrame::Tile()
wxGTK: wxGTK:
- Improved wxSystemSettings::GetMetric() to work better with X11. (Mart Raudsepp) - Improved wxSystemSettings::GetMetric() to work better with X11. (Mart Raudsepp)

View File

@@ -545,9 +545,12 @@ To remove the window completely, use the wxFRAME\_NO\_WINDOW\_MENU window style.
\membersection{wxMDIParentFrame::Tile}\label{wxmdiparentframetile} \membersection{wxMDIParentFrame::Tile}\label{wxmdiparentframetile}
\func{void}{Tile}{\void} \func{void}{Tile}{\param{wxOrientation}{ orient = wxHORIZONTAL}}
Tiles the MDI child windows. Tiles the MDI child windows either horizontally or vertically depending on
whether \arg{orient} is wxHORIZONTAL or wxVERTICAL.
Currently only implemented for MSW, does nothing under the other platforms.
\wxheading{See also} \wxheading{See also}

View File

@@ -83,7 +83,7 @@ public:
virtual wxMDIClientWindow *OnCreateClient(); virtual wxMDIClientWindow *OnCreateClient();
virtual void Cascade() {} virtual void Cascade() {}
virtual void Tile() {} virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL) {}
virtual void ArrangeIcons() {} virtual void ArrangeIcons() {}
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -79,7 +79,7 @@ public:
virtual wxGenericMDIClientWindow *OnCreateClient(); virtual wxGenericMDIClientWindow *OnCreateClient();
virtual void Cascade() { /* Has no effect */ } virtual void Cascade() { /* Has no effect */ }
virtual void Tile() { /* Has no effect */ } virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL) { }
virtual void ArrangeIcons() { /* Has no effect */ } virtual void ArrangeIcons() { /* Has no effect */ }
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -74,7 +74,7 @@ public:
virtual wxMDIClientWindow *OnCreateClient(); virtual wxMDIClientWindow *OnCreateClient();
virtual void Cascade() {} virtual void Cascade() {}
virtual void Tile() {} virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL) {}
virtual void ArrangeIcons() {} virtual void ArrangeIcons() {}
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -74,7 +74,7 @@ public:
virtual wxMDIClientWindow *OnCreateClient(); virtual wxMDIClientWindow *OnCreateClient();
virtual void Cascade() {} virtual void Cascade() {}
virtual void Tile() {} virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL) {}
virtual void ArrangeIcons() {} virtual void ArrangeIcons() {}
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -77,7 +77,7 @@ public:
// MDI operations // MDI operations
virtual void Cascade(); virtual void Cascade();
virtual void Tile(); virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL);
virtual void ArrangeIcons(); virtual void ArrangeIcons();
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -75,7 +75,7 @@ public:
// MDI operations // MDI operations
virtual void Cascade(); virtual void Cascade();
virtual void Tile(); virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL);
virtual void ArrangeIcons(); virtual void ArrangeIcons();
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -33,10 +33,10 @@ class WXDLLEXPORT wxMDIChildFrame;
class WXDLLEXPORT wxMDIParentFrame: public wxFrame class WXDLLEXPORT wxMDIParentFrame: public wxFrame
{ {
DECLARE_DYNAMIC_CLASS(wxMDIParentFrame) DECLARE_DYNAMIC_CLASS(wxMDIParentFrame)
friend class WXDLLEXPORT wxMDIChildFrame; friend class WXDLLEXPORT wxMDIChildFrame;
public: public:
wxMDIParentFrame(); wxMDIParentFrame();
inline wxMDIParentFrame(wxWindow *parent, inline wxMDIParentFrame(wxWindow *parent,
wxWindowID id, wxWindowID id,
@@ -48,9 +48,9 @@ public:
{ {
Create(parent, id, title, pos, size, style, name); Create(parent, id, title, pos, size, style, name);
} }
~wxMDIParentFrame(); ~wxMDIParentFrame();
bool Create(wxWindow *parent, bool Create(wxWindow *parent,
wxWindowID id, wxWindowID id,
const wxString& title, const wxString& title,
@@ -58,68 +58,68 @@ public:
const wxSize& size = wxDefaultSize, const wxSize& size = wxDefaultSize,
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL, long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
const wxString& name = wxFrameNameStr); const wxString& name = wxFrameNameStr);
void OnSize(wxSizeEvent& event); void OnSize(wxSizeEvent& event);
void OnActivate(wxActivateEvent& event); void OnActivate(wxActivateEvent& event);
void OnSysColourChanged(wxSysColourChangedEvent& event); void OnSysColourChanged(wxSysColourChangedEvent& event);
void OnMenuHighlight(wxMenuEvent& event); void OnMenuHighlight(wxMenuEvent& event);
void SetMenuBar(wxMenuBar *menu_bar); void SetMenuBar(wxMenuBar *menu_bar);
// Get the active MDI child window // Get the active MDI child window
wxMDIChildFrame *GetActiveChild() const ; wxMDIChildFrame *GetActiveChild() const ;
// Get the client window // Get the client window
wxMDIClientWindow *GetClientWindow() const { return m_clientWindow; }; wxMDIClientWindow *GetClientWindow() const { return m_clientWindow; };
// Create the client window class (don't Create the window, // Create the client window class (don't Create the window,
// just return a new class) // just return a new class)
virtual wxMDIClientWindow *OnCreateClient() ; virtual wxMDIClientWindow *OnCreateClient() ;
// MDI operations // MDI operations
virtual void Cascade(); virtual void Cascade();
virtual void Tile(); virtual void Tile(wxOrientation WXUNUSED(orient) = wxHORIZONTAL);
virtual void ArrangeIcons(); virtual void ArrangeIcons();
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();
// Implementation // Implementation
// Set the active child // Set the active child
inline void SetActiveChild(wxMDIChildFrame* child) { m_activeChild = child; } inline void SetActiveChild(wxMDIChildFrame* child) { m_activeChild = child; }
// Set the child's menubar into the parent frame // Set the child's menubar into the parent frame
void SetChildMenuBar(wxMDIChildFrame* frame); void SetChildMenuBar(wxMDIChildFrame* frame);
inline wxMenuBar* GetActiveMenuBar() const { return m_activeMenuBar; } inline wxMenuBar* GetActiveMenuBar() const { return m_activeMenuBar; }
// Redirect events to active child first // Redirect events to active child first
virtual bool ProcessEvent(wxEvent& event); virtual bool ProcessEvent(wxEvent& event);
protected: protected:
virtual void DoSetSize(int x, int y, virtual void DoSetSize(int x, int y,
int width, int height, int width, int height,
int sizeFlags = wxSIZE_AUTO); int sizeFlags = wxSIZE_AUTO);
virtual void DoSetClientSize(int width, int height); virtual void DoSetClientSize(int width, int height);
// Gets the size available for subwindows after menu size, toolbar size // 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 // and status bar size have been subtracted. If you want to manage your own
// toolbar(s), don't call SetToolBar. // toolbar(s), don't call SetToolBar.
void DoGetClientSize(int *width, int *height) const; void DoGetClientSize(int *width, int *height) const;
protected: protected:
wxMDIClientWindow* m_clientWindow; wxMDIClientWindow* m_clientWindow;
wxMDIChildFrame* m_activeChild; wxMDIChildFrame* m_activeChild;
wxMenuBar* m_activeMenuBar; wxMenuBar* m_activeMenuBar;
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
}; };
class WXDLLEXPORT wxMDIChildFrame: public wxFrame class WXDLLEXPORT wxMDIChildFrame: public wxFrame
{ {
DECLARE_DYNAMIC_CLASS(wxMDIChildFrame) DECLARE_DYNAMIC_CLASS(wxMDIChildFrame)
public: public:
wxMDIChildFrame(); wxMDIChildFrame();
wxMDIChildFrame(wxMDIParentFrame *parent, wxMDIChildFrame(wxMDIParentFrame *parent,
@@ -132,9 +132,9 @@ public:
{ {
Create(parent, id, title, pos, size, style, name); Create(parent, id, title, pos, size, style, name);
} }
~wxMDIChildFrame(); ~wxMDIChildFrame();
bool Create(wxMDIParentFrame *parent, bool Create(wxMDIParentFrame *parent,
wxWindowID id, wxWindowID id,
const wxString& title, const wxString& title,
@@ -142,11 +142,11 @@ public:
const wxSize& size = wxDefaultSize, const wxSize& size = wxDefaultSize,
long style = wxDEFAULT_FRAME_STYLE, long style = wxDEFAULT_FRAME_STYLE,
const wxString& name = wxFrameNameStr); const wxString& name = wxFrameNameStr);
// Set menu bar // Set menu bar
void SetMenuBar(wxMenuBar *menu_bar); void SetMenuBar(wxMenuBar *menu_bar);
void SetTitle(const wxString& title); void SetTitle(const wxString& title);
// Set icon // Set icon
virtual void SetIcon(const wxIcon& icon); virtual void SetIcon(const wxIcon& icon);
virtual void SetIcons(const wxIconBundle& icons ); virtual void SetIcons(const wxIconBundle& icons );
@@ -157,7 +157,7 @@ public:
void Raise(); void Raise();
void Lower(void); void Lower(void);
void DoSetSizeHints(int minW = -1, int minH = -1, int maxW = -1, int maxH = -1, int incW = -1, int incH = -1); void DoSetSizeHints(int minW = -1, int minH = -1, int maxW = -1, int maxH = -1, int incW = -1, int incH = -1);
// MDI operations // MDI operations
virtual void Maximize(); virtual void Maximize();
virtual void Maximize(bool WXUNUSED(maximize)) { }; virtual void Maximize(bool WXUNUSED(maximize)) { };
@@ -166,35 +166,35 @@ public:
virtual void Restore(); virtual void Restore();
virtual void Activate(); virtual void Activate();
virtual bool IsIconized() const ; virtual bool IsIconized() const ;
virtual bool IsTopLevel() const { return false; } virtual bool IsTopLevel() const { return false; }
// Is the frame maximized? Returns true for // Is the frame maximized? Returns true for
// wxMDIChildFrame due to the tabbed implementation. // wxMDIChildFrame due to the tabbed implementation.
virtual bool IsMaximized(void) const ; virtual bool IsMaximized(void) const ;
bool Show(bool show); bool Show(bool show);
WXWidget GetMainWidget() const { return m_mainWidget; }; WXWidget GetMainWidget() const { return m_mainWidget; };
WXWidget GetTopWidget() const { return m_mainWidget; }; WXWidget GetTopWidget() const { return m_mainWidget; };
WXWidget GetClientWidget() const { return m_mainWidget; }; WXWidget GetClientWidget() const { return m_mainWidget; };
/* /*
virtual void OnRaise(); virtual void OnRaise();
virtual void OnLower(); virtual void OnLower();
*/ */
void SetMDIParentFrame(wxMDIParentFrame* parentFrame) { m_mdiParentFrame = parentFrame; } void SetMDIParentFrame(wxMDIParentFrame* parentFrame) { m_mdiParentFrame = parentFrame; }
wxMDIParentFrame* GetMDIParentFrame() const { return m_mdiParentFrame; } wxMDIParentFrame* GetMDIParentFrame() const { return m_mdiParentFrame; }
protected: protected:
wxMDIParentFrame* m_mdiParentFrame; wxMDIParentFrame* m_mdiParentFrame;
virtual void DoSetSize(int x, int y, virtual void DoSetSize(int x, int y,
int width, int height, int width, int height,
int sizeFlags = wxSIZE_AUTO); int sizeFlags = wxSIZE_AUTO);
virtual void DoSetClientSize(int width, int height); virtual void DoSetClientSize(int width, int height);
void DoGetClientSize(int *width, int *height) const; void DoGetClientSize(int *width, int *height) const;
void DoGetSize(int *width, int *height) const; void DoGetSize(int *width, int *height) const;
void DoGetPosition(int *x, int *y) const ; void DoGetPosition(int *x, int *y) const ;
@@ -210,37 +210,37 @@ protected:
class WXDLLEXPORT wxMDIClientWindow: public wxNotebook class WXDLLEXPORT wxMDIClientWindow: public wxNotebook
{ {
DECLARE_DYNAMIC_CLASS(wxMDIClientWindow) DECLARE_DYNAMIC_CLASS(wxMDIClientWindow)
public: public:
wxMDIClientWindow() ; wxMDIClientWindow() ;
wxMDIClientWindow(wxMDIParentFrame *parent, long style = 0) wxMDIClientWindow(wxMDIParentFrame *parent, long style = 0)
{ {
CreateClient(parent, style); CreateClient(parent, style);
} }
~wxMDIClientWindow(); ~wxMDIClientWindow();
// Note: this is virtual, to allow overridden behaviour. // Note: this is virtual, to allow overridden behaviour.
virtual bool CreateClient(wxMDIParentFrame *parent, long style = wxVSCROLL | wxHSCROLL); virtual bool CreateClient(wxMDIParentFrame *parent, long style = wxVSCROLL | wxHSCROLL);
// Explicitly call default scroll behaviour // Explicitly call default scroll behaviour
void OnScroll(wxScrollEvent& event); void OnScroll(wxScrollEvent& event);
// Implementation // Implementation
void OnPageChanged(wxNotebookEvent& event); void OnPageChanged(wxNotebookEvent& event);
int FindPage(const wxNotebookPage* page); int FindPage(const wxNotebookPage* page);
protected: protected:
virtual void DoSetSize(int x, int y, virtual void DoSetSize(int x, int y,
int width, int height, int width, int height,
int sizeFlags = wxSIZE_AUTO); int sizeFlags = wxSIZE_AUTO);
virtual void DoSetClientSize(int width, int height); virtual void DoSetClientSize(int width, int height);
void DoGetClientSize(int *width, int *height) const; void DoGetClientSize(int *width, int *height) const;
void DoGetSize(int *width, int *height) const ; void DoGetSize(int *width, int *height) const ;
void DoGetPosition(int *x, int *y) const ; void DoGetPosition(int *x, int *y) const ;
private: private:
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
}; };

View File

@@ -74,7 +74,7 @@ public:
// MDI operations // MDI operations
// -------------- // --------------
virtual void Cascade(); virtual void Cascade();
virtual void Tile(); virtual void Tile(wxOrientation orient = wxHORIZONTAL);
virtual void ArrangeIcons(); virtual void ArrangeIcons();
virtual void ActivateNext(); virtual void ActivateNext();
virtual void ActivatePrevious(); virtual void ActivatePrevious();

View File

@@ -212,7 +212,7 @@ void wxMDIParentFrame::Cascade()
// TODO // TODO
} }
void wxMDIParentFrame::Tile() void wxMDIParentFrame::Tile(wxOrientation WXUNUSED(orient))
{ {
// TODO // TODO
} }

View File

@@ -213,7 +213,7 @@ void wxMDIParentFrame::Cascade()
// TODO // TODO
} }
void wxMDIParentFrame::Tile() void wxMDIParentFrame::Tile(wxOrientation WXUNUSED(orient))
{ {
// TODO // TODO
} }

View File

@@ -277,7 +277,7 @@ void wxMDIParentFrame::Cascade()
// TODO // TODO
} }
void wxMDIParentFrame::Tile() void wxMDIParentFrame::Tile(wxOrientation WXUNUSED(orient))
{ {
// TODO // TODO
} }

View File

@@ -384,10 +384,14 @@ void wxMDIParentFrame::Cascade()
::SendMessage(GetWinHwnd(GetClientWindow()), WM_MDICASCADE, 0, 0); ::SendMessage(GetWinHwnd(GetClientWindow()), WM_MDICASCADE, 0, 0);
} }
// TODO: add a direction argument (hor/vert) void wxMDIParentFrame::Tile(wxOrientation orient)
void wxMDIParentFrame::Tile()
{ {
::SendMessage(GetWinHwnd(GetClientWindow()), WM_MDITILE, MDITILE_HORIZONTAL, 0); wxASSERT_MSG( orient == wxHORIZONTAL || orient == wxVERTICAL,
_T("invalid orientation value") );
::SendMessage(GetWinHwnd(GetClientWindow()), WM_MDITILE,
orient == wxHORIZONTAL ? MDITILE_HORIZONTAL
: MDITILE_VERTICAL, 0);
} }
void wxMDIParentFrame::ArrangeIcons() void wxMDIParentFrame::ArrangeIcons()