handle wxNO_FULL_REPAINT_ON_RESIZE for MDI children
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_2_BRANCH@7847 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -63,8 +63,10 @@
|
|||||||
extern wxWindowList wxModelessWindows; // from dialog.cpp
|
extern wxWindowList wxModelessWindows; // from dialog.cpp
|
||||||
extern wxMenu *wxCurrentPopupMenu;
|
extern wxMenu *wxCurrentPopupMenu;
|
||||||
|
|
||||||
extern const wxChar *wxMDIFrameClassName;
|
extern const wxChar *wxMDIFrameClassName; // from app.cpp
|
||||||
extern const wxChar *wxMDIChildFrameClassName;
|
extern const wxChar *wxMDIChildFrameClassName;
|
||||||
|
extern const wxChar *wxMDIChildFrameClassNameNoRedraw;
|
||||||
|
|
||||||
extern wxWindow *wxWndHook; // from window.cpp
|
extern wxWindow *wxWndHook; // from window.cpp
|
||||||
|
|
||||||
extern void wxAssociateWinWithHandle(HWND hWnd, wxWindow *win);
|
extern void wxAssociateWinWithHandle(HWND hWnd, wxWindow *win);
|
||||||
@@ -221,8 +223,16 @@ bool wxMDIParentFrame::Create(wxWindow *parent,
|
|||||||
if (style & wxCLIP_CHILDREN)
|
if (style & wxCLIP_CHILDREN)
|
||||||
msflags |= WS_CLIPCHILDREN;
|
msflags |= WS_CLIPCHILDREN;
|
||||||
|
|
||||||
wxWindow::MSWCreate(m_windowId, parent, wxMDIFrameClassName, this, title, x, y, width, height,
|
if ( !wxWindow::MSWCreate(m_windowId,
|
||||||
msflags);
|
parent,
|
||||||
|
wxMDIFrameClassName,
|
||||||
|
this,
|
||||||
|
title,
|
||||||
|
x, y, width, height,
|
||||||
|
msflags) )
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
wxModelessWindows.Append(this);
|
wxModelessWindows.Append(this);
|
||||||
|
|
||||||
@@ -653,7 +663,9 @@ bool wxMDIChildFrame::Create(wxMDIParentFrame *parent,
|
|||||||
|
|
||||||
MDICREATESTRUCT mcs;
|
MDICREATESTRUCT mcs;
|
||||||
|
|
||||||
mcs.szClass = wxMDIChildFrameClassName;
|
mcs.szClass = style & wxNO_FULL_REPAINT_ON_RESIZE
|
||||||
|
? wxMDIChildFrameClassNameNoRedraw
|
||||||
|
: wxMDIChildFrameClassName;
|
||||||
mcs.szTitle = title;
|
mcs.szTitle = title;
|
||||||
mcs.hOwner = wxGetInstance();
|
mcs.hOwner = wxGetInstance();
|
||||||
if (x > -1)
|
if (x > -1)
|
||||||
@@ -696,12 +708,8 @@ bool wxMDIChildFrame::Create(wxMDIParentFrame *parent,
|
|||||||
|
|
||||||
mcs.lParam = 0;
|
mcs.lParam = 0;
|
||||||
|
|
||||||
DWORD Return = SendMessage(GetWinHwnd(parent->GetClientWindow()),
|
m_hWnd = (WXHWND)::SendMessage(GetWinHwnd(parent->GetClientWindow()),
|
||||||
WM_MDICREATE, 0, (LONG)(LPSTR)&mcs);
|
WM_MDICREATE, 0, (LONG)(LPSTR)&mcs);
|
||||||
|
|
||||||
//handle = (HWND)LOWORD(Return);
|
|
||||||
// Must be the DWORRD for WIN32. And in 16 bits, HIWORD=0 (says Microsoft)
|
|
||||||
m_hWnd = (WXHWND)Return;
|
|
||||||
|
|
||||||
wxWndHook = NULL;
|
wxWndHook = NULL;
|
||||||
wxAssociateWinWithHandle((HWND) GetHWND(), this);
|
wxAssociateWinWithHandle((HWND) GetHWND(), this);
|
||||||
|
Reference in New Issue
Block a user