#pragma hdrstop
#endif
+#include "wx/toplevel.h"
+
#ifndef WX_PRECOMP
#include "wx/app.h"
- #include "wx/toplevel.h"
#include "wx/dialog.h"
#include "wx/string.h"
#include "wx/log.h"
// WS_POPUP in a few cases just to avoid having caption/border which we
// don't want
-#if !(defined(__SMARTPHONE__) && defined(__WXWINCE__))
// border and caption styles
- if ( style & wxRESIZE_BORDER )
+ if ( ( style & wxRESIZE_BORDER ) && !IsAlwaysMaximized())
msflags |= WS_THICKFRAME;
else if ( exflags && ((style & wxBORDER_DOUBLE) || (style & wxBORDER_RAISED)) )
*exflags |= WS_EX_DLGMODALFRAME;
#ifndef __POCKETPC__
else
msflags |= WS_POPUP;
-#endif
#endif
// normally we consider that all windows without a caption must be popups,
#endif
// next translate the individual flags
- if ( style & wxMINIMIZE_BOX )
- msflags |= WS_MINIMIZEBOX;
- if ( style & wxMAXIMIZE_BOX )
- msflags |= WS_MAXIMIZEBOX;
+
+ // WS_EX_CONTEXTHELP is incompatible with WS_MINIMIZEBOX and WS_MAXIMIZEBOX
+ // and is ignored if we specify both of them, but chances are that if we
+ // use wxFRAME_EX_CONTEXTHELP, we really do want to have the context help
+ // button while wxMINIMIZE/wxMAXIMIZE are included by default, so the help
+ // takes precedence
+ if ( !(GetExtraStyle() & wxFRAME_EX_CONTEXTHELP) )
+ {
+ if ( style & wxMINIMIZE_BOX )
+ msflags |= WS_MINIMIZEBOX;
+ if ( style & wxMAXIMIZE_BOX )
+ msflags |= WS_MAXIMIZEBOX;
+ }
#ifndef __WXWINCE__
if ( style & wxSYSTEM_MENU )
if ( style & wxMINIMIZE )
msflags |= WS_MINIMIZE;
-#if !defined(__POCKETPC__)
if ( style & wxMAXIMIZE )
msflags |= WS_MAXIMIZE;
-#endif
// Keep this here because it saves recoding this function in wxTinyFrame
if ( style & (wxTINY_CAPTION_VERT | wxTINY_CAPTION_HORIZ) )
SHACTIVATEINFO *info = (SHACTIVATEINFO*) m_activateInfo;
if ( info )
{
- return SHHandleWMSettingChange(GetHwnd(), wParam, lParam, info) == TRUE;
+ SHHandleWMSettingChange(GetHwnd(), wParam, lParam, info);
}
- return false;
+ return wxWindowMSW::HandleSettingChange(wParam, lParam);
}
#endif
break;
}
- case WM_SETTINGCHANGE:
- {
- processed = HandleSettingChange(wParam, lParam);
-
- // if it was processed will still need to allow the base class to
- // forward this message to child windows
- if ( processed )
- {
- wxTopLevelWindowBase::MSWWindowProc(message, wParam, lParam);
- }
- break;
- }
case WM_HIBERNATE:
{
if (wxTheApp)
WXDWORD exflags;
WXDWORD flags = MSWGetCreateWindowFlags(&exflags);
-#if !defined(__HANDHELDPC__) && ((defined(_WIN32_WCE) && _WIN32_WCE < 400) || \
- defined(__POCKETPC__) || \
- defined(__SMARTPHONE__))
- // Always expand to fit the screen in PocketPC or SmartPhone
- wxSize sz(wxDefaultSize);
- wxUnusedVar(size);
-#else // other (including normal desktop) Windows
- wxSize sz(size);
-#endif
+ const wxSize sz = IsAlwaysMaximized() ? wxDefaultSize : size;
- bool result = MSWCreate(wxCanvasClassName, title, pos, sz, flags, exflags);
-
- return result;
+ return MSWCreate(wxCanvasClassName, title, pos, sz, flags, exflags);
}
bool wxTopLevelWindowMSW::Create(wxWindow *parent,
// Note: if we include PocketPC in this test, dialogs can fail to show up,
// for example the text entry dialog in the dialogs sample. Problem with Maximise()?
#if defined(__WXWINCE__) && (defined(__SMARTPHONE__) || defined(__WINCE_STANDARDSDK__))
- if ( style & wxMAXIMIZE )
+ if ( ( style & wxMAXIMIZE ) || IsAlwaysMaximized() )
{
this->Maximize();
}
frame->GetMenuBar()->AddAdornments(GetWindowStyleFlag());
#endif
+ // we only set pending size if we're maximized before being shown, now that
+ // we're shown we don't need it any more (it is reset in size event handler
+ // for child windows but we have to do it ourselves for this parent window)
+ m_pendingSize = wxDefaultSize;
+
return true;
}
// it's shown, so return our size as it will be then in this case
if ( maximize )
{
- // unfortunately we don't know which display we're on yet so we
- // have to use the default one
- SetSize(wxGetClientDisplayRect().GetSize());
+ // we must only change pending size here, and not call SetSize()
+ // because otherwise Windows would think that this (full screen)
+ // size is the natural size for the frame and so would use it when
+ // the user clicks on "restore" title bar button instead of the
+ // correct initial frame size
+ //
+ // NB: unfortunately we don't know which display we're on yet so we
+ // have to use the default one
+ m_pendingSize = wxGetClientDisplayRect().GetSize();
}
//else: can't do anything in this case, we don't have the old size
}
bool wxTopLevelWindowMSW::IsMaximized() const
{
-#ifdef __WXWINCE__
- return false;
-#else
- return m_maximizeOnShow || ::IsZoomed(GetHwnd()) != 0;
+ return IsAlwaysMaximized() ||
+#if !defined(__SMARTPHONE__) && !defined(__POCKETPC__)
+ (::IsZoomed(GetHwnd()) != 0) ||
#endif
+ m_maximizeOnShow;
}
void wxTopLevelWindowMSW::Iconize(bool iconize)