LRESULT DefWndNCPaint(HWND hWnd, HRGN hRgn, BOOL Active);
LRESULT DefWndNCCalcSize(HWND hWnd, BOOL CalcSizeStruct, RECT *Rect);
-LRESULT DefWndNCActivate(HWND hWnd, WPARAM wParam);
+LRESULT DefWndNCActivate(HWND hWnd, WPARAM wParam, LPARAM lParam);
LRESULT DefWndNCHitTest(HWND hWnd, POINT Point);
LRESULT DefWndNCLButtonDown(HWND hWnd, WPARAM wParam, LPARAM lParam);
LRESULT DefWndNCLButtonDblClk(HWND hWnd, WPARAM wParam, LPARAM lParam);
+LRESULT NC_HandleNCRButtonDown( HWND hwnd, WPARAM wParam, LPARAM lParam );
void FASTCALL MenuInitSysMenuPopup(HMENU Menu, DWORD Style, DWORD ClsStyle, LONG HitTest );
void MENU_EndMenu( HWND );
/*
* @implemented
*/
-DWORD WINAPI
+DWORD
+WINAPI
+DECLSPEC_HOTPATCH
GetSysColor(int nIndex)
{
if(nIndex >= 0 && nIndex < NUM_SYSCOLORS)
/*
* @implemented
*/
-HBRUSH WINAPI
+HBRUSH
+WINAPI
+DECLSPEC_HOTPATCH
GetSysColorBrush(int nIndex)
{
if(nIndex >= 0 && nIndex < NUM_SYSCOLORS)
/* Remove frame from rectangle */
if (UserHasThickFrameStyle(Style, ExStyle ))
{
- InflateRect(rect, -GetSystemMetrics(SM_CXFRAME),
- -GetSystemMetrics(SM_CYFRAME));
+ InflateRect(rect, -GetSystemMetrics(SM_CXFRAME), -GetSystemMetrics(SM_CYFRAME));
}
else
{
if (UserHasDlgFrameStyle(Style, ExStyle ))
{
- InflateRect(rect, -GetSystemMetrics(SM_CXDLGFRAME),
- -GetSystemMetrics(SM_CYDLGFRAME));
+ InflateRect(rect, -GetSystemMetrics(SM_CXDLGFRAME), -GetSystemMetrics(SM_CYDLGFRAME));
/* FIXME: this isn't in NC_AdjustRect? why not? */
if (ExStyle & WS_EX_DLGMODALFRAME)
InflateRect( rect, -1, 0 );
{
if (UserHasThinFrameStyle(Style, ExStyle))
{
- InflateRect(rect, -GetSystemMetrics(SM_CXBORDER),
- -GetSystemMetrics(SM_CYBORDER));
+ InflateRect(rect, -GetSystemMetrics(SM_CXBORDER), -GetSystemMetrics(SM_CYBORDER));
}
}
}
-}
-
-
-VOID
-DefWndSetRedraw(HWND hWnd, WPARAM wParam)
-{
- LONG Style = GetWindowLongPtr(hWnd, GWL_STYLE);
- /* Content can be redrawn after a change. */
- if (wParam)
- {
- if (!(Style & WS_VISIBLE)) /* Not Visible */
- {
- SetWindowLongPtr(hWnd, GWL_STYLE, WS_VISIBLE);
- }
- }
- else /* Content cannot be redrawn after a change. */
+ /* We have additional border information if the window
+ * is a child (but not an MDI child) */
+ if ((Style & WS_CHILD) && !(ExStyle & WS_EX_MDICHILD))
{
- if (Style & WS_VISIBLE) /* Visible */
- {
- RedrawWindow( hWnd, NULL, 0, RDW_ALLCHILDREN | RDW_VALIDATE );
- Style &= ~WS_VISIBLE;
- SetWindowLongPtr(hWnd, GWL_STYLE, Style); /* clear bits */
- }
+ if (ExStyle & WS_EX_CLIENTEDGE)
+ InflateRect (rect, -GetSystemMetrics(SM_CXEDGE), -GetSystemMetrics(SM_CYEDGE));
+ if (ExStyle & WS_EX_STATICEDGE)
+ InflateRect (rect, -GetSystemMetrics(SM_CXBORDER), -GetSystemMetrics(SM_CYBORDER));
}
- return;
}
-
LRESULT
DefWndHandleSetCursor(HWND hWnd, WPARAM wParam, LPARAM lParam, ULONG Style)
{
return((LRESULT)SetCursor(LoadCursorW(0, IDC_ARROW)));
}
-static LONG
-DefWndStartSizeMove(HWND hWnd, PWND Wnd, WPARAM wParam, POINT *capturePoint)
-{
- LONG hittest = 0;
- POINT pt;
- MSG msg;
- RECT rectWindow;
- ULONG Style = Wnd->style;
-
- rectWindow = Wnd->rcWindow;
-
- if ((wParam & 0xfff0) == SC_MOVE)
- {
- /* Move pointer at the center of the caption */
- RECT rect;
- UserGetInsideRectNC(Wnd, &rect);
- if (Style & WS_SYSMENU)
- rect.left += GetSystemMetrics(SM_CXSIZE) + 1;
- if (Style & WS_MINIMIZEBOX)
- rect.right -= GetSystemMetrics(SM_CXSIZE) + 1;
- if (Style & WS_MAXIMIZEBOX)
- rect.right -= GetSystemMetrics(SM_CXSIZE) + 1;
- pt.x = rectWindow.left + (rect.right - rect.left) / 2;
- pt.y = rectWindow.top + rect.top + GetSystemMetrics(SM_CYSIZE)/2;
- hittest = HTCAPTION;
- *capturePoint = pt;
- }
- else /* SC_SIZE */
- {
- pt.x = pt.y = 0;
- while(!hittest)
- {
- if (!GetMessageW(&msg, NULL, 0, 0)) break; //return 0;
- if (CallMsgFilterW( &msg, MSGF_SIZE )) continue;
-
- switch(msg.message)
- {
- case WM_MOUSEMOVE:
- hittest = DefWndNCHitTest(hWnd, msg.pt);
- if ((hittest < HTLEFT) || (hittest > HTBOTTOMRIGHT))
- hittest = 0;
- break;
-
- case WM_LBUTTONUP:
- return 0;
-
- case WM_KEYDOWN:
- switch(msg.wParam)
- {
- case VK_UP:
- hittest = HTTOP;
- pt.x =(rectWindow.left+rectWindow.right)/2;
- pt.y = rectWindow.top + GetSystemMetrics(SM_CYFRAME) / 2;
- break;
- case VK_DOWN:
- hittest = HTBOTTOM;
- pt.x =(rectWindow.left+rectWindow.right)/2;
- pt.y = rectWindow.bottom - GetSystemMetrics(SM_CYFRAME) / 2;
- break;
- case VK_LEFT:
- hittest = HTLEFT;
- pt.x = rectWindow.left + GetSystemMetrics(SM_CXFRAME) / 2;
- pt.y =(rectWindow.top+rectWindow.bottom)/2;
- break;
- case VK_RIGHT:
- hittest = HTRIGHT;
- pt.x = rectWindow.right - GetSystemMetrics(SM_CXFRAME) / 2;
- pt.y =(rectWindow.top+rectWindow.bottom)/2;
- break;
- case VK_RETURN:
- case VK_ESCAPE:
- return 0;
- }
- default:
- TranslateMessage( &msg );
- DispatchMessageW( &msg );
- break;
- }
- }
- *capturePoint = pt;
- }
- SetCursorPos( pt.x, pt.y );
- DefWndHandleSetCursor(hWnd, (WPARAM)hWnd, MAKELONG(hittest, WM_MOUSEMOVE), Style);
- return hittest;
-}
-
-#define ON_LEFT_BORDER(hit) \
- (((hit) == HTLEFT) || ((hit) == HTTOPLEFT) || ((hit) == HTBOTTOMLEFT))
-#define ON_RIGHT_BORDER(hit) \
- (((hit) == HTRIGHT) || ((hit) == HTTOPRIGHT) || ((hit) == HTBOTTOMRIGHT))
-#define ON_TOP_BORDER(hit) \
- (((hit) == HTTOP) || ((hit) == HTTOPLEFT) || ((hit) == HTTOPRIGHT))
-#define ON_BOTTOM_BORDER(hit) \
- (((hit) == HTBOTTOM) || ((hit) == HTBOTTOMLEFT) || ((hit) == HTBOTTOMRIGHT))
-
-static VOID
-UserDrawWindowFrame(HDC hdc, const RECT *rect,
- ULONG width, ULONG height)
-{
- static HBRUSH hDraggingRectBrush = NULL;
- HBRUSH hbrush;
-
- if(!hDraggingRectBrush)
- {
- static HBITMAP hDraggingPattern = NULL;
- const DWORD Pattern[4] = {0x5555AAAA, 0x5555AAAA, 0x5555AAAA, 0x5555AAAA};
-
- hDraggingPattern = CreateBitmap(8, 8, 1, 1, Pattern);
- hDraggingRectBrush = CreatePatternBrush(hDraggingPattern);
- }
-
- hbrush = SelectObject( hdc, hDraggingRectBrush );
- PatBlt( hdc, rect->left, rect->top,
- rect->right - rect->left - width, height, PATINVERT );
- PatBlt( hdc, rect->left, rect->top + height, width,
- rect->bottom - rect->top - height, PATINVERT );
- PatBlt( hdc, rect->left + width, rect->bottom - 1,
- rect->right - rect->left - width, -height, PATINVERT );
- PatBlt( hdc, rect->right - 1, rect->top, -width,
- rect->bottom - rect->top - height, PATINVERT );
- SelectObject( hdc, hbrush );
-}
-
-static VOID
-UserDrawMovingFrame(HDC hdc, RECT *rect, BOOL thickframe)
-{
- if(thickframe)
- {
- UserDrawWindowFrame(hdc, rect, GetSystemMetrics(SM_CXFRAME), GetSystemMetrics(SM_CYFRAME));
- }
- else
- {
- UserDrawWindowFrame(hdc, rect, 1, 1);
- }
-}
-
-static VOID
-DefWndDoSizeMove(HWND hwnd, WORD wParam)
-{
- HRGN DesktopRgn;
- MSG msg;
- RECT sizingRect, mouseRect, origRect, clipRect, unmodRect;
- HDC hdc;
- LONG hittest = (LONG)(wParam & 0x0f);
- HCURSOR hDragCursor = 0, hOldCursor = 0;
- POINT minTrack, maxTrack;
- POINT capturePoint, pt;
- ULONG Style, ExStyle;
- BOOL thickframe;
- BOOL iconic;
- BOOL moved = FALSE;
- DWORD dwPoint = GetMessagePos();
- BOOL DragFullWindows = FALSE;
- HWND hWndParent = NULL;
- PWND Wnd;
-
- Wnd = ValidateHwnd(hwnd);
- if (!Wnd)
- return;
-
- Style = Wnd->style;
- ExStyle = Wnd->ExStyle;
- iconic = (Style & WS_MINIMIZE) != 0;
-
- SystemParametersInfoA(SPI_GETDRAGFULLWINDOWS, 0, &DragFullWindows, 0);
-
- pt.x = GET_X_LPARAM(dwPoint);
- pt.y = GET_Y_LPARAM(dwPoint);
- capturePoint = pt;
-
- if ((Style & WS_MAXIMIZE) || !IsWindowVisible(hwnd))
- {
- return;
- }
-
- thickframe = UserHasThickFrameStyle(Style, ExStyle) && !(Style & WS_MINIMIZE);
- if ((wParam & 0xfff0) == SC_MOVE)
- {
- if (!hittest)
- {
- hittest = DefWndStartSizeMove(hwnd, Wnd, wParam, &capturePoint);
- }
- if (!hittest)
- {
- return;
- }
- }
- else /* SC_SIZE */
- {
- if (!thickframe)
- {
- return;
- }
- if (hittest && ((wParam & 0xfff0) != SC_MOUSEMENU))
- {
- hittest += (HTLEFT - WMSZ_LEFT);
- }
- else
- {
- SetCapture(hwnd);
- hittest = DefWndStartSizeMove(hwnd, Wnd, wParam, &capturePoint);
- if (!hittest)
- {
- ReleaseCapture();
- return;
- }
- }
- }
-
- /* Get min/max info */
-
- WinPosGetMinMaxInfo(hwnd, NULL, NULL, &minTrack, &maxTrack);
- sizingRect = Wnd->rcWindow;
- if (Style & WS_CHILD)
- {
- hWndParent = GetParent(hwnd);
- MapWindowPoints( 0, hWndParent, (LPPOINT)&sizingRect, 2 );
- unmodRect = sizingRect;
- GetClientRect(hWndParent, &mouseRect );
- clipRect = mouseRect;
- MapWindowPoints(hWndParent, HWND_DESKTOP, (LPPOINT)&clipRect, 2);
- }
- else
- {
- if(!(ExStyle & WS_EX_TOPMOST))
- {
- SystemParametersInfoW(SPI_GETWORKAREA, 0, &clipRect, 0);
- mouseRect = clipRect;
- }
- else
- {
- SetRect(&mouseRect, 0, 0, GetSystemMetrics(SM_CXSCREEN), GetSystemMetrics(SM_CYSCREEN));
- clipRect = mouseRect;
- }
- unmodRect = sizingRect;
- }
- ClipCursor(&clipRect);
-
- origRect = sizingRect;
- if (ON_LEFT_BORDER(hittest))
- {
- mouseRect.left = max( mouseRect.left, sizingRect.right-maxTrack.x );
- mouseRect.right = min( mouseRect.right, sizingRect.right-minTrack.x );
- }
- else if (ON_RIGHT_BORDER(hittest))
- {
- mouseRect.left = max( mouseRect.left, sizingRect.left+minTrack.x );
- mouseRect.right = min( mouseRect.right, sizingRect.left+maxTrack.x );
- }
- if (ON_TOP_BORDER(hittest))
- {
- mouseRect.top = max( mouseRect.top, sizingRect.bottom-maxTrack.y );
- mouseRect.bottom = min( mouseRect.bottom,sizingRect.bottom-minTrack.y);
- }
- else if (ON_BOTTOM_BORDER(hittest))
- {
- mouseRect.top = max( mouseRect.top, sizingRect.top+minTrack.y );
- mouseRect.bottom = min( mouseRect.bottom, sizingRect.top+maxTrack.y );
- }
- if (Style & WS_CHILD)
- {
- MapWindowPoints( hWndParent, 0, (LPPOINT)&mouseRect, 2 );
- }
-
- SendMessageA( hwnd, WM_ENTERSIZEMOVE, 0, 0 );
- NtUserxSetGUIThreadHandle(MSQ_STATE_MOVESIZE, hwnd);
- if (GetCapture() != hwnd) SetCapture( hwnd );
-
- if (Style & WS_CHILD)
- {
- /* Retrieve a default cache DC (without using the window style) */
- hdc = GetDCEx(hWndParent, 0, DCX_CACHE);
- DesktopRgn = NULL;
- }
- else
- {
- hdc = GetDC( 0 );
- DesktopRgn = CreateRectRgnIndirect(&clipRect);
- }
-
- SelectObject(hdc, DesktopRgn);
-
- if( iconic ) /* create a cursor for dragging */
- {
- HICON hIcon = (HICON)GetClassLongPtrW(hwnd, GCL_HICON);
- if(!hIcon) hIcon = (HICON)SendMessageW( hwnd, WM_QUERYDRAGICON, 0, 0L);
- if( hIcon ) hDragCursor = CursorIconToCursor( hIcon, TRUE );
- if( !hDragCursor ) iconic = FALSE;
- }
-
- /* invert frame if WIN31_LOOK to indicate mouse click on caption */
- if( !iconic && !DragFullWindows)
- {
- UserDrawMovingFrame( hdc, &sizingRect, thickframe);
- }
-
- for(;;)
- {
- int dx = 0, dy = 0;
-
- if (!GetMessageW(&msg, 0, 0, 0)) break;
- if (CallMsgFilterW( &msg, MSGF_SIZE )) continue;
-
- /* Exit on button-up, Return, or Esc */
- if ((msg.message == WM_LBUTTONUP) ||
- ((msg.message == WM_KEYDOWN) &&
- ((msg.wParam == VK_RETURN) || (msg.wParam == VK_ESCAPE)))) break;
-
- if (msg.message == WM_PAINT)
- {
- if(!iconic && !DragFullWindows) UserDrawMovingFrame( hdc, &sizingRect, thickframe );
- UpdateWindow( msg.hwnd );
- if(!iconic && !DragFullWindows) UserDrawMovingFrame( hdc, &sizingRect, thickframe );
- continue;
- }
-
- if ((msg.message != WM_KEYDOWN) && (msg.message != WM_MOUSEMOVE))
- {
- TranslateMessage( &msg );
- DispatchMessageW( &msg );
- continue; /* We are not interested in other messages */
- }
-
- pt = msg.pt;
-
- if (msg.message == WM_KEYDOWN) switch(msg.wParam)
- {
- case VK_UP: pt.y -= 8; break;
- case VK_DOWN: pt.y += 8; break;
- case VK_LEFT: pt.x -= 8; break;
- case VK_RIGHT: pt.x += 8; break;
- }
-
- pt.x = max( pt.x, mouseRect.left );
- pt.x = min( pt.x, mouseRect.right );
- pt.y = max( pt.y, mouseRect.top );
- pt.y = min( pt.y, mouseRect.bottom );
-
- dx = pt.x - capturePoint.x;
- dy = pt.y - capturePoint.y;
-
- if (dx || dy)
- {
- if( !moved )
- {
- moved = TRUE;
-
- if( iconic ) /* ok, no system popup tracking */
- {
- hOldCursor = SetCursor(hDragCursor);
- ShowCursor( TRUE );
- }
- }
-
- if (msg.message == WM_KEYDOWN) SetCursorPos( pt.x, pt.y );
- else
- {
- RECT newRect = unmodRect;
- WPARAM wpSizingHit = 0;
-
- if (hittest == HTCAPTION) OffsetRect( &newRect, dx, dy );
- if (ON_LEFT_BORDER(hittest)) newRect.left += dx;
- else if (ON_RIGHT_BORDER(hittest)) newRect.right += dx;
- if (ON_TOP_BORDER(hittest)) newRect.top += dy;
- else if (ON_BOTTOM_BORDER(hittest)) newRect.bottom += dy;
- if(!iconic && !DragFullWindows) UserDrawMovingFrame( hdc, &sizingRect, thickframe );
- capturePoint = pt;
-
- /* determine the hit location */
- if (hittest >= HTLEFT && hittest <= HTBOTTOMRIGHT)
- wpSizingHit = WMSZ_LEFT + (hittest - HTLEFT);
- unmodRect = newRect;
- SendMessageA( hwnd, WM_SIZING, wpSizingHit, (LPARAM)&newRect );
-
- if (!iconic)
- {
- if(!DragFullWindows)
- UserDrawMovingFrame( hdc, &newRect, thickframe );
- else {
- /* To avoid any deadlocks, all the locks on the windows
- structures must be suspended before the SetWindowPos */
- SetWindowPos( hwnd, 0, newRect.left, newRect.top,
- newRect.right - newRect.left,
- newRect.bottom - newRect.top,
- ( hittest == HTCAPTION ) ? SWP_NOSIZE : 0 );
- }
- }
- sizingRect = newRect;
- }
- }
- }
-
- ReleaseCapture();
- ClipCursor(NULL);
- if( iconic )
- {
- if( moved ) /* restore cursors, show icon title later on */
- {
- ShowCursor( FALSE );
- SetCursor( hOldCursor );
- }
- DestroyCursor( hDragCursor );
- }
- else if(!DragFullWindows)
- UserDrawMovingFrame( hdc, &sizingRect, thickframe );
-
- if (Style & WS_CHILD)
- ReleaseDC( hWndParent, hdc );
- else
- {
- ReleaseDC( 0, hdc );
- if(DesktopRgn)
- {
- DeleteObject(DesktopRgn);
- }
- }
-
- if (ISITHOOKED(WH_CBT))
- {
- LRESULT lResult;
- NtUserMessageCall( hwnd, WM_CBT, HCBT_MOVESIZE, (LPARAM)&sizingRect, (ULONG_PTR)&lResult, FNID_DEFWINDOWPROC, FALSE);
- if (lResult) moved = FALSE;
- }
-
- NtUserxSetGUIThreadHandle(MSQ_STATE_MOVESIZE, NULL);
- SendMessageA( hwnd, WM_EXITSIZEMOVE, 0, 0 );
- SendMessageA( hwnd, WM_SETVISIBLE, !IsIconic(hwnd), 0L);
-
- /* window moved or resized */
- if (moved)
- {
- /* if the moving/resizing isn't canceled call SetWindowPos
- * with the new position or the new size of the window
- */
- if (!((msg.message == WM_KEYDOWN) && (msg.wParam == VK_ESCAPE)) )
- {
- /* NOTE: SWP_NOACTIVATE prevents document window activation in Word 6 */
- if(!DragFullWindows)
- SetWindowPos( hwnd, 0, sizingRect.left, sizingRect.top,
- sizingRect.right - sizingRect.left,
- sizingRect.bottom - sizingRect.top,
- ( hittest == HTCAPTION ) ? SWP_NOSIZE : 0 );
- }
- else { /* restore previous size/position */
- if(DragFullWindows)
- SetWindowPos( hwnd, 0, origRect.left, origRect.top,
- origRect.right - origRect.left,
- origRect.bottom - origRect.top,
- ( hittest == HTCAPTION ) ? SWP_NOSIZE : 0 );
- }
- }
-
- if( IsWindow(hwnd) )
- if( Style & WS_MINIMIZE )
- {
- /* Single click brings up the system menu when iconized */
-
- if( !moved )
- {
- if( Style & WS_SYSMENU )
- SendMessageA( hwnd, WM_SYSCOMMAND,
- SC_MOUSEMENU + HTSYSMENU, MAKELONG(pt.x,pt.y));
- }
- }
-}
-
-
/***********************************************************************
* DefWndTrackScrollBar
*
LRESULT
DefWndHandleSysCommand(HWND hWnd, WPARAM wParam, LPARAM lParam)
{
-// WINDOWPLACEMENT wp;
POINT Pt;
LRESULT lResult;
{
case SC_MOVE:
case SC_SIZE:
- DefWndDoSizeMove(hWnd, wParam);
+ NtUserMessageCall( hWnd, WM_SYSCOMMAND, wParam, lParam, (ULONG_PTR)&lResult, FNID_DEFWINDOWPROC, FALSE);
break;
+
case SC_MINIMIZE:
if (hWnd == GetActiveWindow())
ShowOwnedPopups(hWnd,FALSE);
case SC_CLOSE:
return SendMessageW(hWnd, WM_CLOSE, 0, 0);
+
// case SC_DEFAULT:
case SC_MOUSEMENU:
{
}
break;
+ case SC_TASKLIST:
+ WinExec( "taskman.exe", SW_SHOWNORMAL );
+ break;
+
case SC_SCREENSAVE:
NtUserMessageCall( hWnd, WM_SYSCOMMAND, wParam, lParam, (ULONG_PTR)&lResult, FNID_DEFWINDOWPROC, FALSE);
break;
return(0);
}
-LRESULT
-DefWndHandleWindowPosChanging(HWND hWnd, WINDOWPOS* Pos)
-{
- POINT maxTrack, minTrack;
- LONG style = GetWindowLongPtrA(hWnd, GWL_STYLE);
-
- if (Pos->flags & SWP_NOSIZE) return 0;
- if ((style & WS_THICKFRAME) || ((style & (WS_POPUP | WS_CHILD)) == 0))
- {
- WinPosGetMinMaxInfo(hWnd, NULL, NULL, &minTrack, &maxTrack);
- Pos->cx = min(Pos->cx, maxTrack.x);
- Pos->cy = min(Pos->cy, maxTrack.y);
- if (!(style & WS_MINIMIZE))
- {
- if (Pos->cx < minTrack.x) Pos->cx = minTrack.x;
- if (Pos->cy < minTrack.y) Pos->cy = minTrack.y;
- }
- }
- else
- {
- Pos->cx = max(Pos->cx, 0);
- Pos->cy = max(Pos->cy, 0);
- }
- return 0;
-}
-
-LRESULT
-DefWndHandleWindowPosChanged(HWND hWnd, WINDOWPOS* Pos)
-{
- RECT Rect;
-
- GetClientRect(hWnd, &Rect);
- MapWindowPoints(hWnd, (GetWindowLongPtrW(hWnd, GWL_STYLE) & WS_CHILD ?
- GetParent(hWnd) : NULL), (LPPOINT) &Rect, 2);
-
- if (! (Pos->flags & SWP_NOCLIENTMOVE))
- {
- SendMessageW(hWnd, WM_MOVE, 0, MAKELONG(Rect.left, Rect.top));
- }
-
- if (! (Pos->flags & SWP_NOCLIENTSIZE))
- {
- WPARAM wp = SIZE_RESTORED;
- if (IsZoomed(hWnd))
- {
- wp = SIZE_MAXIMIZED;
- }
- else if (IsIconic(hWnd))
- {
- wp = SIZE_MINIMIZED;
- }
- SendMessageW(hWnd, WM_SIZE, wp,
- MAKELONG(Rect.right - Rect.left, Rect.bottom - Rect.top));
- }
-
- return 0;
-}
-
/***********************************************************************
* DefWndControlColor
*
return TRUE;
}
+// WM_SETICON
+LRESULT FASTCALL
+DefWndSetIcon(PWND pWnd, WPARAM wParam, LPARAM lParam)
+{
+ HICON hIcon, hIconSmall, hIconOld;
+
+ if ( wParam > ICON_SMALL2 )
+ {
+ SetLastError(ERROR_INVALID_PARAMETER);
+ return 0;
+ }
+ hIconSmall = UserGetProp(UserHMGetHandle(pWnd), gpsi->atomIconSmProp);
+ hIcon = UserGetProp(UserHMGetHandle(pWnd), gpsi->atomIconProp);
+
+ hIconOld = wParam == ICON_BIG ? hIcon : hIconSmall;
+
+ switch(wParam)
+ {
+ case ICON_BIG:
+ hIcon = (HICON)lParam;
+ break;
+ case ICON_SMALL:
+ hIconSmall = (HICON)lParam;
+ break;
+ case ICON_SMALL2:
+ ERR("FIXME: Set ICON_SMALL2 support!\n");
+ default:
+ break;
+ }
+
+ NtUserSetProp(UserHMGetHandle(pWnd), gpsi->atomIconProp, hIcon);
+ NtUserSetProp(UserHMGetHandle(pWnd), gpsi->atomIconSmProp, hIconSmall);
+
+ if ((pWnd->style & WS_CAPTION ) == WS_CAPTION)
+ DefWndNCPaint(UserHMGetHandle(pWnd), HRGN_WINDOW, -1); /* Repaint caption */
+
+ return (LRESULT)hIconOld;
+}
+
+LRESULT FASTCALL
+DefWndGetIcon(PWND pWnd, WPARAM wParam, LPARAM lParam)
+{
+ HICON hIconRet;
+ if ( wParam > ICON_SMALL2 )
+ {
+ SetLastError(ERROR_INVALID_PARAMETER);
+ return 0;
+ }
+ switch(wParam)
+ {
+ case ICON_BIG:
+ hIconRet = UserGetProp(UserHMGetHandle(pWnd), gpsi->atomIconProp);
+ break;
+ case ICON_SMALL:
+ case ICON_SMALL2:
+ hIconRet = UserGetProp(UserHMGetHandle(pWnd), gpsi->atomIconSmProp);
+ break;
+ default:
+ break;
+ }
+ return (LRESULT)hIconRet;
+}
VOID FASTCALL
DefWndScreenshot(HWND hWnd)
ReleaseDC(hWnd, hdc2);
CloseClipboard();
-
}
LPARAM lParam,
BOOL bUnicode)
{
+ PWND pWnd = NULL;
+ if (hWnd)
+ {
+ pWnd = ValidateHwnd(hWnd);
+ if (!pWnd) return 0;
+ }
+
switch (Msg)
{
case WM_NCPAINT:
case WM_NCACTIVATE:
{
- return DefWndNCActivate(hWnd, wParam);
+ return DefWndNCActivate(hWnd, wParam, lParam);
}
case WM_NCHITTEST:
return (DefWndNCLButtonDblClk(hWnd, wParam, lParam));
}
- case WM_WINDOWPOSCHANGING:
- {
- return (DefWndHandleWindowPosChanging(hWnd, (WINDOWPOS*)lParam));
- }
-
- case WM_WINDOWPOSCHANGED:
- {
- return (DefWndHandleWindowPosChanged(hWnd, (WINDOWPOS*)lParam));
- }
-
case WM_NCRBUTTONDOWN:
- {
- /* in Windows, capture is taken when right-clicking on the caption bar */
- if (wParam == HTCAPTION)
- {
- SetCapture(hWnd);
- }
- break;
- }
+ return NC_HandleNCRButtonDown( hWnd, wParam, lParam );
case WM_RBUTTONUP:
{
case WM_PAINT:
{
PAINTSTRUCT Ps;
- HDC hDC = BeginPaint(hWnd, &Ps);
+ HDC hDC;
+
+ /* If already in Paint and Client area is not empty just return. */
+ if (pWnd->state2 & WNDS2_STARTPAINT && !IsRectEmpty(&pWnd->rcClient))
+ {
+ ERR("In Paint and Client area is not empty!\n");
+ return 0;
+ }
+
+ hDC = BeginPaint(hWnd, &Ps);
if (hDC)
{
HICON hIcon;
- if (GetWindowLongPtrW(hWnd, GWL_STYLE) & WS_MINIMIZE &&
- (hIcon = (HICON)GetClassLongPtrW(hWnd, GCL_HICON)) != NULL)
+ if (IsIconic(hWnd) && ((hIcon = (HICON)GetClassLongPtrW( hWnd, GCLP_HICON))))
{
RECT ClientRect;
INT x, y;
return (0);
}
- case WM_SYNCPAINT:
- {
- HRGN hRgn;
- hRgn = CreateRectRgn(0, 0, 0, 0);
- if (GetUpdateRgn(hWnd, hRgn, FALSE) != NULLREGION)
- {
- RedrawWindow(hWnd, NULL, hRgn,
- RDW_ERASENOW | RDW_ERASE | RDW_FRAME |
- RDW_ALLCHILDREN);
- }
- DeleteObject(hRgn);
- return (0);
- }
-
- case WM_SETREDRAW:
- {
- LONG_PTR Style = GetWindowLongPtrW(hWnd, GWL_STYLE);
- if (wParam) SetWindowLongPtr(hWnd, GWL_STYLE, Style | WS_VISIBLE);
- else
- {
- RedrawWindow(hWnd, NULL, 0, RDW_ALLCHILDREN | RDW_VALIDATE);
- Style &= ~WS_VISIBLE;
- SetWindowLongPtr(hWnd, GWL_STYLE, Style);
- }
- return (0);
- }
-
case WM_CLOSE:
- {
DestroyWindow(hWnd);
return (0);
- }
case WM_MOUSEACTIVATE:
- {
if (GetWindowLongPtrW(hWnd, GWL_STYLE) & WS_CHILD)
{
- LONG Ret;
- if (bUnicode)
- {
- Ret = SendMessageW(GetParent(hWnd), WM_MOUSEACTIVATE,
- wParam, lParam);
- }
- else
- {
- Ret = SendMessageA(GetParent(hWnd), WM_MOUSEACTIVATE,
- wParam, lParam);
- }
- if (Ret)
- {
- return (Ret);
- }
+ LONG Ret = SendMessageW(GetParent(hWnd), WM_MOUSEACTIVATE, wParam, lParam);
+ if (Ret) return (Ret);
}
- return ((LOWORD(lParam) >= HTCLIENT) ? MA_ACTIVATE : MA_NOACTIVATE);
- }
+ return ( (HIWORD(lParam) == WM_LBUTTONDOWN && LOWORD(lParam) == HTCAPTION) ? MA_NOACTIVATE : MA_ACTIVATE );
case WM_ACTIVATE:
- {
- /* Check if the window is minimized. */
+ /* The default action in Windows is to set the keyboard focus to
+ * the window, if it's being activated and not minimized */
if (LOWORD(wParam) != WA_INACTIVE &&
!(GetWindowLongPtrW(hWnd, GWL_STYLE) & WS_MINIMIZE))
{
+ //ERR("WM_ACTIVATE %p\n",hWnd);
SetFocus(hWnd);
}
break;
- }
case WM_MOUSEWHEEL:
- {
if (GetWindowLongPtrW(hWnd, GWL_STYLE) & WS_CHILD)
- {
- if (bUnicode)
- {
- return (SendMessageW(GetParent(hWnd), WM_MOUSEWHEEL,
- wParam, lParam));
- }
- else
- {
- return (SendMessageA(GetParent(hWnd), WM_MOUSEWHEEL,
- wParam, lParam));
- }
- }
+ return SendMessageW( GetParent(hWnd), WM_MOUSEWHEEL, wParam, lParam);
break;
- }
case WM_ERASEBKGND:
case WM_ICONERASEBKGND:
case WM_ISACTIVEICON:
{
- PWND pWnd;
BOOL isai;
- pWnd = ValidateHwnd(hWnd);
- if (!pWnd) return 0;
isai = (pWnd->state & WNDS_ACTIVEFRAME) != 0;
return isai;
}
case WM_SETICON:
{
- INT Index = (wParam != 0) ? GCL_HICON : GCL_HICONSM;
- HICON hOldIcon = (HICON)GetClassLongPtrW(hWnd, Index);
- SetClassLongPtrW(hWnd, Index, lParam);
- SetWindowPos(hWnd, 0, 0, 0, 0, 0,
- SWP_FRAMECHANGED | SWP_NOSIZE | SWP_NOMOVE |
- SWP_NOACTIVATE | SWP_NOZORDER);
- return ((LRESULT)hOldIcon);
+ return DefWndSetIcon(pWnd, wParam, lParam);
}
case WM_GETICON:
{
- INT Index = (wParam == ICON_BIG) ? GCL_HICON : GCL_HICONSM;
- return (GetClassLongPtrW(hWnd, Index));
+ return DefWndGetIcon(pWnd, wParam, lParam);
}
case WM_HELP:
break;
}
-/* Move to win32k !*/
+/* Move to Win32k !*/
case WM_SHOWWINDOW:
if (!lParam) break; // Call when it is necessary.
+ case WM_SYNCPAINT:
+ case WM_SETREDRAW:
case WM_CLIENTSHUTDOWN:
case WM_GETHOTKEY:
case WM_SETHOTKEY:
+ case WM_WINDOWPOSCHANGING:
+ case WM_WINDOWPOSCHANGED:
+ case WM_APPCOMMAND:
{
LRESULT lResult;
NtUserMessageCall( hWnd, Msg, wParam, lParam, (ULONG_PTR)&lResult, FNID_DEFWINDOWPROC, !bUnicode);
{
case WM_NCCREATE:
{
+ if ( Wnd &&
+ Wnd->style & (WS_HSCROLL | WS_VSCROLL) )
+ {
+ if (!Wnd->pSBInfo)
+ {
+ SCROLLINFO si = {sizeof si, SIF_ALL, 0, 100, 0, 0, 0};
+ SetScrollInfo( hWnd, SB_HORZ, &si, FALSE );
+ SetScrollInfo( hWnd, SB_VERT, &si, FALSE );
+ }
+ }
+
if (lParam)
{
LPCREATESTRUCTA cs = (LPCREATESTRUCTA)lParam;
{
case WM_NCCREATE:
{
+ if ( Wnd &&
+ Wnd->style & (WS_HSCROLL | WS_VSCROLL) )
+ {
+ if (!Wnd->pSBInfo)
+ {
+ SCROLLINFO si = {sizeof si, SIF_ALL, 0, 100, 0, 0, 0};
+ SetScrollInfo( hWnd, SB_HORZ, &si, FALSE );
+ SetScrollInfo( hWnd, SB_VERT, &si, FALSE );
+ }
+ }
+
if (lParam)
{
LPCREATESTRUCTW cs = (LPCREATESTRUCTW)lParam;