don't use WS_POPUP under CE for normal windows
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26746 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -157,21 +157,14 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
// creates a window with both caption and border, hence we also test it
|
// creates a window with both caption and border, hence we also test it
|
||||||
// below in some other cases
|
// below in some other cases
|
||||||
if ( style & wxFRAME_TOOL_WINDOW )
|
if ( style & wxFRAME_TOOL_WINDOW )
|
||||||
msflags |= WS_POPUP;
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
if (msflags & WS_BORDER)
|
msflags |= WS_POPUP;
|
||||||
msflags |= WS_OVERLAPPED;
|
|
||||||
}
|
}
|
||||||
|
//else: WS_OVERLAPPED is 0 anyhow, so it is on by default
|
||||||
|
|
||||||
// border and caption styles
|
// border and caption styles
|
||||||
if ( style & wxRESIZE_BORDER )
|
if ( style & wxRESIZE_BORDER )
|
||||||
#ifndef WS_THICKFRAME
|
|
||||||
msflags = msflags;
|
|
||||||
#else
|
|
||||||
msflags |= WS_THICKFRAME;
|
msflags |= WS_THICKFRAME;
|
||||||
#endif
|
|
||||||
else if ( exflags && ((style & wxBORDER_DOUBLE) || (style & wxBORDER_RAISED)) )
|
else if ( exflags && ((style & wxBORDER_DOUBLE) || (style & wxBORDER_RAISED)) )
|
||||||
*exflags |= WS_EX_DLGMODALFRAME;
|
*exflags |= WS_EX_DLGMODALFRAME;
|
||||||
else if ( !(style & wxBORDER_NONE) )
|
else if ( !(style & wxBORDER_NONE) )
|
||||||
@@ -179,16 +172,16 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
else
|
else
|
||||||
msflags |= WS_POPUP;
|
msflags |= WS_POPUP;
|
||||||
|
|
||||||
|
// normally we consider that all windows without caption must be popups,
|
||||||
|
// but CE is an exception: there windows normally do not have the caption
|
||||||
|
// but shouldn't be made popups as popups can't have menus and don't look
|
||||||
|
// like normal windows anyhow
|
||||||
if ( style & wxCAPTION )
|
if ( style & wxCAPTION )
|
||||||
#ifdef __WXWINCE__
|
|
||||||
msflags = msflags;
|
|
||||||
#else
|
|
||||||
msflags |= WS_CAPTION;
|
msflags |= WS_CAPTION;
|
||||||
#endif
|
#ifndef __WXWINCE__
|
||||||
else
|
else
|
||||||
msflags |= WS_POPUP;
|
msflags |= WS_POPUP;
|
||||||
|
#endif // !__WXWINCE__
|
||||||
return msflags;
|
|
||||||
|
|
||||||
// next translate the individual flags
|
// next translate the individual flags
|
||||||
if ( style & wxMINIMIZE_BOX )
|
if ( style & wxMINIMIZE_BOX )
|
||||||
@@ -198,15 +191,12 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
if ( style & wxSYSTEM_MENU )
|
if ( style & wxSYSTEM_MENU )
|
||||||
msflags |= WS_SYSMENU;
|
msflags |= WS_SYSMENU;
|
||||||
|
|
||||||
// under CE these 2 styles are not defined currently
|
// NB: under CE these 2 styles are not supported currently, we should
|
||||||
#ifdef WS_MINIMIZE
|
// call Minimize()/Maximize() "manually" if we want to support them
|
||||||
if ( style & wxMINIMIZE )
|
if ( style & wxMINIMIZE )
|
||||||
msflags |= WS_MINIMIZE;
|
msflags |= WS_MINIMIZE;
|
||||||
#endif // WS_MINIMIZE
|
|
||||||
#ifdef WS_MAXIMIZE
|
|
||||||
if ( style & wxMAXIMIZE )
|
if ( style & wxMAXIMIZE )
|
||||||
msflags |= WS_MAXIMIZE;
|
msflags |= WS_MAXIMIZE;
|
||||||
#endif // WS_MAXIMIZE
|
|
||||||
|
|
||||||
// Keep this here because it saves recoding this function in wxTinyFrame
|
// Keep this here because it saves recoding this function in wxTinyFrame
|
||||||
if ( style & (wxTINY_CAPTION_VERT | wxTINY_CAPTION_HORIZ) )
|
if ( style & (wxTINY_CAPTION_VERT | wxTINY_CAPTION_HORIZ) )
|
||||||
@@ -214,6 +204,8 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
|
|
||||||
if ( exflags )
|
if ( exflags )
|
||||||
{
|
{
|
||||||
|
// there is no taskbar under CE, so omit all this
|
||||||
|
#ifndef __WXWINCE__
|
||||||
if ( !(GetExtraStyle() & wxTOPLEVEL_EX_DIALOG) )
|
if ( !(GetExtraStyle() & wxTOPLEVEL_EX_DIALOG) )
|
||||||
{
|
{
|
||||||
if ( style & wxFRAME_TOOL_WINDOW )
|
if ( style & wxFRAME_TOOL_WINDOW )
|
||||||
@@ -225,8 +217,6 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
style |= wxFRAME_NO_TASKBAR;
|
style |= wxFRAME_NO_TASKBAR;
|
||||||
}
|
}
|
||||||
|
|
||||||
// again, support for this is missing under CE
|
|
||||||
#ifdef WS_EX_APPWINDOW
|
|
||||||
// We have to solve 2 different problems here:
|
// We have to solve 2 different problems here:
|
||||||
//
|
//
|
||||||
// 1. frames with wxFRAME_NO_TASKBAR flag shouldn't appear in the
|
// 1. frames with wxFRAME_NO_TASKBAR flag shouldn't appear in the
|
||||||
@@ -245,8 +235,8 @@ WXDWORD wxTopLevelWindowMSW::MSWGetStyle(long style, WXDWORD *exflags) const
|
|||||||
*exflags |= WS_EX_APPWINDOW;
|
*exflags |= WS_EX_APPWINDOW;
|
||||||
}
|
}
|
||||||
//else: nothing to do [here]
|
//else: nothing to do [here]
|
||||||
#endif // WS_EX_APPWINDOW
|
|
||||||
}
|
}
|
||||||
|
#endif // !__WXWINCE__
|
||||||
|
|
||||||
if ( style & wxSTAY_ON_TOP )
|
if ( style & wxSTAY_ON_TOP )
|
||||||
*exflags |= WS_EX_TOPMOST;
|
*exflags |= WS_EX_TOPMOST;
|
||||||
|
Reference in New Issue
Block a user