改变对话框的背景色有很多种方法,例如:
方法一:调用CWinApp类的成员函数SetDialogBkColor来实现。
BOOL CXXXX: : InitInstance ( )
{
… CXXXX dlg;
m_pMainWnd = &dlg;
//先于DoModal()调用,将对话框设置为蓝色背景、红色文本
SetDialogBkColor(RGB(0,0,255),RGB(255,0,0));
int nResponse = dlg.DoModal();
…}
---- 编译并运行,此时对话框的背景色和文本色已发生了改变。值得注意的是:在调用DoModal()之前必
须先调用SetDialogBkColor,且此方法是将改变应用程序中所有的对话框颜色,并不能针对某一个指定的
方法二::重载OnPaint(),即WM_PAINT消息。有关代码如下(以上例工程为准):
void CXXXX::OnPaint()
{
if (IsIconic())
… else
{
CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0)); //设置为绿色背景
CDialog::OnPaint();
}
方法三:重载OnCtlColor (CDC* pDC, CWnd* pWnd, UINT nCtlColor),即WM_CTLCOLOR消息。具体
步骤如下(以上例工程为准):
---- ①在CXXXX的头文件中,添加一CBrush的成员变量:
class CXXXX : public CDialog
{...
protected:
CBrush m_brush;
...
};
---- ②在OnInitDialog()函数中添加如下代码:
BOOL CXXXX::OnInitDialog()
{
...
// TODO: Add extra initialization here
m_brush.CreateSolidBrush(RGB(0, 255, 0)); // 生成一绿色刷子
...
}
---- ③利用ClassWizard重载OnCtlColor(…),即WM_CTLCOLOR消息:
HBRUSH CXXXX::OnCtlColor
(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
/*
** 这里不必编写任何代码!
**下行代码要注释掉
** HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
*/
return m_brush; //返加绿色刷子
}
方法四:在OnEraseBkgnd(CDC* pDC)函数
在.h文件中添加 afx_msg BOOL OnEraseBkgnd(CDC* pDC);
.cpp文件中ON_WM_ERASEBKGND()
再在OnEraseBkgnd(CDC* pDC)实现,示例代码:
BOOL CXXXX::OnEraseBkgnd(CDC* pDC)
{
CRect rectdlg;
GetClientRect(&rectdlg);
CDC mdc;
mdc.CreateCompatibleDC(pDC);
CBitmap bitmap;
bitmap.LoadBitmap(IDB_BITMAP_DLG_BMP);//位图。。。可以用一种颜色的位图
BITMAP bmp;
bitmap.GetBitmap(&bmp);
mdc.SelectObject(&bitmap);
pDC->StretchBlt(rectdlg.left,rectdlg.top,rectdlg.Width(),rectdlg.Height(),&mdc,0,0,bmp.bmWidth,bmp.bmHeight,SRCCOPY);
return TRUE;
}