可以通过WM_CTLCOLORDLG消息来设置对话框的背景,MSDN上对这个消息的说明如下:
The WM_CTLCOLORDLG message is sent to a dialog box before the system draws the dialog box. By responding to this message, the dialog box can set its text and background colors using the specified display device context handle.
当窗口消息响应函数接收这个消息时,wParam表示对 话框的设备上下方即HDC,lParam表示对话框的句柄。如果程序处理了这个消息,应返回一个画刷。系统将会 用这个画刷来重绘对话框背景。
因此我们在这个WM_CTLCOLORDLG消息中得到对话框的大小,并通过 StretchBlt函数将位图缩放后贴到对话框的HDC中就完成了对话框背景的设置,然后返回一个空画刷给系统, 这样系统就不会将位图背景给覆盖了。
代码非常简单,要注意的是在使用StretchBlt函数缩放位图时 ,最好先使用
SetStretchBltMode函数来设置下位图内容伸展模式,这样可以避免缩放后位图失真严 重。SetStretchBltMode函数原型如下:
int SetStretchBltMode(
HDChdc, // handle to DC
int iStretchMode // bitmap stretching mode
);
第一个参数就是设备上下方即HDC。
第二个参数有四种设置:
1. BLACKONWHITE or STRETCH_ANDSCANS
如果两个或多个像素得合并成一个像素,那么StretchBlt会对 像素执行一个逻辑AND运算。这样的结果是只有全部的原始像素是白色时该像素才为白色,其实际意义是黑色 像素控制了白色像素。这适用于白色背景中主要是黑色的单色点阵图。
2. WHITEONBLACK or STRETCH_ORSCANS
如果两个或多个像素得合并成一个像素,那么StretchBlt会对像素执行逻辑OR运算 。这样的结果是只有全部的原始像素都是黑色时该像素才为黑色,也就是说由白色像素决定颜色。这适用于 黑色背景中主要是白色的单色点阵图。
3. COLORONCOLOR or STRETCH_DELETESCANS
简单地消 除图素行或列,而没有任何逻辑组合。这是通常是处理彩色点阵图的最佳方法。
4. HALFTONE or STRETCH_HALFTONE
根据组合起来的来源颜色来计算目的的平均颜色。
其它技术细节可以见代 码中的注释,完整代码如下(也可以下载,下载地址为: http://download.csdn.net/download/morewindows/4947377):
// 对话框位图背景 - WM_CTLCOLORDLG中使用StretchBlt贴图 //By MoreWindows-(http://blog.csdn.net/MoreWindows) #include <windows.h> #include "resource.h" const char szDlgTitle[] = "位图背景 使用StretchBlt贴图 MoreWindows- (http://blog.csdn.net/MoreWindows)"; // 对话框消息处理函数 BOOL CALLBACK DlgProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam); int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { DialogBox(hInstance, MAKEINTRESOURCE(IDD_DIALOG1), NULL, DlgProc); return 0; } BOOL CALLBACK DlgProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) { RECT rcDialog; HBITMAP hBitmap; static BITMAP s_bm; static HDC s_hdcMem; switch (message) { case WM_INITDIALOG: // 设置对话框标题 SetWindowText(hDlg, szDlgTitle); // 设置对话框大小可调节 SetWindowLong(hDlg, GWL_STYLE, GetWindowLong(hDlg, GWL_STYLE) | WS_SIZEBOX); // 加载背影图片 hBitmap = (HBITMAP)LoadImage(NULL, "005.bmp", IMAGE_BITMAP, 0, 0, LR_LOADFROMFILE | LR_CREATEDIBSECTION); if (hBitmap == NULL) { MessageBox(hDlg, "LoadImage failed", "Error", MB_ICONERROR); exit(0); } else { // 将背影图片放入HDC - s_hdcMem HDC hdc; hdc = GetDC(hDlg); s_hdcMem = CreateCompatibleDC(hdc); SelectObject(s_hdcMem, hBitmap); ReleaseDC(hDlg, hdc); // 得到位图信息 GetObject(hBitmap, sizeof(s_bm), &s_bm); } return 0; case WM_COMMAND: switch (LOWORD(wParam)) { case IDCANCEL: DeleteDC(s_hdcMem); EndDialog(hDlg, LOWORD(wParam)); return TRUE; } break; case WM_SIZE: InvalidateRect(hDlg, NULL, TRUE); return TRUE; case WM_CTLCOLORDLG: GetClientRect(hDlg, &rcDialog); //通过SetStretchBltMode的设置能使StretchBlt在缩放图像更加清晰 SetStretchBltMode((HDC)wParam, COLORONCOLOR); StretchBlt((HDC)wParam, 0, 0, rcDialog.right, rcDialog.bottom, s_hdcMem, 0, 0, s_bm.bmWidth, s_bm.bmHeight, SRCCOPY); return (BOOL)((HBRUSH)GetStockObject(NULL_BRUSH)); } return FALSE; }
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索对话框
, 函数
, 位图
, 像素
, 消息
, 背景
NULL位图
位图画刷、windows界面编程、windows图形界面编程、windows 界面编程 qt、windows位图,以便于您获取更多的相关知识。