Switch deferred sizing off by default
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@33016 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
0832aaafb8
commit
85d8df29aa
@ -28,6 +28,8 @@ pages).}
|
||||
\twocolitem{msw.staticbitmap.htclient}{If set to 1, allows the static bitmap to respond to mouse
|
||||
events. The default is 0, since a value of 1 can interfere with refresh in static boxes. Note that once set,
|
||||
this option cannot be unset later in the application.}
|
||||
\twocolitem{msw.window.defersize}{If set to 1, optimizes window sizing and positioning when a size event is
|
||||
received. This can occasionally have unwanted side-effects, so is off by default.}
|
||||
\end{twocollist}
|
||||
|
||||
\wxheading{Mac}
|
||||
|
@ -1122,7 +1122,7 @@ void wxWindowMSW::SetWindowStyleFlag(long flags)
|
||||
|
||||
::SetWindowLong(GetHwnd(), GWL_EXSTYLE, exstyleReal);
|
||||
|
||||
// we must call SetWindowPos() to flash the cached extended style and
|
||||
// we must call SetWindowPos() to flush the cached extended style and
|
||||
// also to make the change to wxSTAY_ON_TOP style take effect: just
|
||||
// setting the style simply doesn't work
|
||||
if ( !::SetWindowPos(GetHwnd(),
|
||||
@ -1504,10 +1504,14 @@ void wxWindowMSW::DoMoveWindow(int x, int y, int width, int height)
|
||||
if (height < 0)
|
||||
height = 0;
|
||||
|
||||
HDWP hdwp = 0;
|
||||
|
||||
if ( wxSystemOptions::GetOptionInt(wxT("msw.window.defersize")) == 1 )
|
||||
{
|
||||
// if our parent had prepared a defer window handle for us, use it (unless
|
||||
// we are a top level window)
|
||||
wxWindowMSW *parent = GetParent();
|
||||
HDWP hdwp = (parent && !IsTopLevel()) ? (HDWP)parent->m_hDWP : NULL;
|
||||
hdwp = (parent && !IsTopLevel()) ? (HDWP)parent->m_hDWP : NULL;
|
||||
if ( hdwp )
|
||||
{
|
||||
hdwp = ::DeferWindowPos(hdwp, GetHwnd(), NULL,
|
||||
@ -1521,6 +1525,7 @@ void wxWindowMSW::DoMoveWindow(int x, int y, int width, int height)
|
||||
// hdwp must be updated as it may have been changed
|
||||
parent->m_hDWP = (WXHANDLE)hdwp;
|
||||
}
|
||||
}
|
||||
|
||||
// otherwise (or if deferring failed) move the window in place immediately
|
||||
if ( !hdwp )
|
||||
@ -4104,6 +4109,8 @@ bool wxWindowMSW::HandleSize(int WXUNUSED(w), int WXUNUSED(h), WXUINT wParam)
|
||||
// repositioned as well, prepare to use DeferWindowPos() for them
|
||||
const int numChildren = GetChildren().GetCount();
|
||||
if ( numChildren > 1 )
|
||||
{
|
||||
if ( wxSystemOptions::GetOptionInt(wxT("msw.window.defersize")) == 1 )
|
||||
{
|
||||
m_hDWP = (WXHANDLE)::BeginDeferWindowPos(numChildren);
|
||||
if ( !m_hDWP )
|
||||
@ -4111,6 +4118,7 @@ bool wxWindowMSW::HandleSize(int WXUNUSED(w), int WXUNUSED(h), WXUINT wParam)
|
||||
wxLogLastError(_T("BeginDeferWindowPos"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// update this window size
|
||||
bool processed = false;
|
||||
|
Loading…
Reference in New Issue
Block a user