git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26746
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// creates a window with both caption and border, hence we also test it
// below in some other cases
if ( style & wxFRAME_TOOL_WINDOW )
// creates a window with both caption and border, hence we also test it
// below in some other cases
if ( style & wxFRAME_TOOL_WINDOW )
- msflags |= WS_POPUP;
- else
- if (msflags & WS_BORDER)
- msflags |= WS_OVERLAPPED;
+ //else: WS_OVERLAPPED is 0 anyhow, so it is on by default
// border and caption styles
if ( style & wxRESIZE_BORDER )
// border and caption styles
if ( style & wxRESIZE_BORDER )
-#ifndef WS_THICKFRAME
- msflags = msflags;
-#else
msflags |= WS_THICKFRAME;
msflags |= WS_THICKFRAME;
else if ( exflags && ((style & wxBORDER_DOUBLE) || (style & wxBORDER_RAISED)) )
*exflags |= WS_EX_DLGMODALFRAME;
else if ( !(style & wxBORDER_NONE) )
else if ( exflags && ((style & wxBORDER_DOUBLE) || (style & wxBORDER_RAISED)) )
*exflags |= WS_EX_DLGMODALFRAME;
else if ( !(style & wxBORDER_NONE) )
else
msflags |= WS_POPUP;
else
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
-#ifdef __WXWINCE__
- msflags = msflags;
-#else
else
msflags |= WS_POPUP;
else
msflags |= WS_POPUP;
// next translate the individual flags
if ( style & wxMINIMIZE_BOX )
// next translate the individual flags
if ( style & wxMINIMIZE_BOX )
if ( style & wxSYSTEM_MENU )
msflags |= WS_SYSMENU;
if ( style & wxSYSTEM_MENU )
msflags |= WS_SYSMENU;
- // under CE these 2 styles are not defined currently
-#ifdef WS_MINIMIZE
+ // NB: under CE these 2 styles are not supported currently, we should
+ // call Minimize()/Maximize() "manually" if we want to support them
if ( style & wxMINIMIZE )
msflags |= WS_MINIMIZE;
if ( style & wxMINIMIZE )
msflags |= WS_MINIMIZE;
-#endif // WS_MINIMIZE
-#ifdef WS_MAXIMIZE
if ( style & wxMAXIMIZE )
msflags |= WS_MAXIMIZE;
if ( style & wxMAXIMIZE )
msflags |= WS_MAXIMIZE;
// Keep this here because it saves recoding this function in wxTinyFrame
if ( style & (wxTINY_CAPTION_VERT | wxTINY_CAPTION_HORIZ) )
// Keep this here because it saves recoding this function in wxTinyFrame
if ( style & (wxTINY_CAPTION_VERT | wxTINY_CAPTION_HORIZ) )
+ // there is no taskbar under CE, so omit all this
+#ifndef __WXWINCE__
if ( !(GetExtraStyle() & wxTOPLEVEL_EX_DIALOG) )
{
if ( style & wxFRAME_TOOL_WINDOW )
if ( !(GetExtraStyle() & wxTOPLEVEL_EX_DIALOG) )
{
if ( style & wxFRAME_TOOL_WINDOW )
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:
//
// 1. frames with wxFRAME_NO_TASKBAR flag shouldn't appear in the
// We have to solve 2 different problems here:
//
// 1. frames with wxFRAME_NO_TASKBAR flag shouldn't appear in the
*exflags |= WS_EX_APPWINDOW;
}
//else: nothing to do [here]
*exflags |= WS_EX_APPWINDOW;
}
//else: nothing to do [here]
-#endif // WS_EX_APPWINDOW
if ( style & wxSTAY_ON_TOP )
*exflags |= WS_EX_TOPMOST;
if ( style & wxSTAY_ON_TOP )
*exflags |= WS_EX_TOPMOST;