SetClassLong 设置窗口背景色的问题!
注册完 他为什么颜色不变啊????
SetClassLong一直返回错的
//*******************************************************标签
BQ_hwnd = CreateWindow (TEXT("STATIC"),TEXT("状态标签"),WS_VISIBLE | WS_CHILDWINDOW | WS_CLIPSIBLINGS | WS_BORDER,0,0,100,100,CK_hwnd,NULL,hInstance, NULL);
if (!BQ_hwnd)
{
return FALSE;
}
//更改列表框的默认的字体,
SendMessage(BQ_hwnd, WM_SETFONT, (WPARAM)hDefaultFont, MAKELPARAM(FALSE, 0)); //更改列表字体
//更改 标签背景颜色
SetClassLong(BQ_hwnd,GCL_HBRBACKGROUND,(long)CreateSolidBrush(COLOR_BACKGROUND));
[解决办法]
SetWindowLong ?
[解决办法]
请帖主移驾VC/MFC论坛。
[解决办法]
InvalidateRect
The InvalidateRect function adds a rectangle to the specified window's update region. The update region represents the portion of the window's client area that must be redrawn.
BOOL InvalidateRect(
HWND hWnd, // handle of window with changed update region
CONST RECT *lpRect,
// address of rectangle coordinates
BOOL bErase // erase-background flag
);
Parameters
hWnd
Handle to the window whose update region has changed. If this parameter is NULL, the system invalidates and redraws all windows, and sends theWM_ERASEBKGND and WM_NCPAINT messages to the window procedure before the function returns.
lpRect
Pointer to a RECT structure that contains the client coordinates of the rectangle to be added to the update region. If this parameter is NULL, the entire client area is added to the update region.
bErase
Specifies whether the background within the update region is to be erased when the update region is processed. If this parameter is TRUE, the background is erased when the BeginPaint function is called. If this parameter is FALSE, the background remains unchanged.
Return Values
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Windows NT: To get extended error information, callGetLastError.
Remarks
The invalidated areas accumulate in the update region until the region is processed when the next WM_PAINT message occurs or until the region is validated by using the ValidateRect or ValidateRgn function.
The system sends a WM_PAINT message to a window whenever its update region is not empty and there are no other messages in the application queue for that window.
If the bErase parameter is TRUE for any part of the update region, the background is erased in the entire region, not just in the given part.
Windows CE: The hWnd parameter cannot be NULL.
QuickInfo
Windows NT: Requires version 3.1 or later.
Windows: Requires Windows 95 or later.
Windows CE: Requires version 1.0 or later.
Header: Declared in winuser.h.
Import Library: Use user32.lib.
See Also
Painting and Drawing Overview, Painting and Drawing Functions, BeginPaint, InvalidateRgn, RECT, ValidateRect, ValidateRgn,WM_ERASEBKGND, WM_NCPAINT, WM_PAINT