首页 > 代码库 > 对话框背景颜色、控件颜色
对话框背景颜色、控件颜色
系统环境:Windows 7
软件环境:Visual C++ 2008 SP1
本次目的:为对话框设置背景颜色、控件颜色
既然MFC对话框不好开发,那么现在我们来开始美化我们的对话框。为对话框设置背景颜色、控件颜色等等。
对话框背景颜色:
网上流传有四种方法(可能还不止),在VC++2008SP1测试后,发现只有三种可以使用了,其中第一种被废弃了。以下是四种方法:
方法一 (失效):调用CWinApp类的成员函数SetDialogBkColor来实现。
其中函数的第一个参数指定了背景颜色,第二个参数指定了文本颜色。下面的例子是将应用程序对 话框设置为蓝色背景和红色文本,步骤如下:
① 新建一个基于Dialog的MFC AppWizard应用程序ExampleDlg。
② 在CExampleDlgApp ::InitInstance()中添加如下代码:
1 BOOL CExampleDlgApp: : InitInstance ( ) 2 { 3 … CExampleDlgDlg dlg; 4 m_pMainWnd = &dlg; 5 //先于DoModal()调用,将对话框设置为蓝色背景、红色文本 6 SetDialogBkColor(RGB(0,0,255),RGB(255,0,0)); 7 int nResponse = dlg.DoModal(); 8 …}
编译并运行,此时对话框的背景色和文本色已发生了改变。值得注意的是:在调用DoModal()之前必须先调用SetDialogBkColor,且此方法是将改变应用程序中所有的对话框颜色,并不能针对某一个指定的对话框。
方法二 :重载OnPaint(),即WM_PAINT消息。有关代码如下(以上例工程为准):
1 void CExampleDlgDlg::OnPaint() 2 { 3 if (IsIconic()) 4 … 5 else 6 { 7 CRect rect; 8 CPaintDC dc(this); 9 GetClientRect(rect); 10 dc.FillSolidRect(rect,RGB(0,255,0)); //设置为绿色背景 11 CDialog::OnPaint(); 12 } 13 }
方法三 :重载OnCtlColor (CDC* pDC, CWnd* pWnd, UINT nCtlColor),即WM_CTLCOLOR消息。具体步骤如下(以上例工程为准):
①在CExampleDlgDlg的头文件中,添加一个CBrush的成员变量:
1 class CExampleDlgDlg : public CDialog 2 {... 3 protected: 4 CBrush m_brush; 5 ... 6 };
②在OnInitDialog()函数中添加如下代码:
1 BOOL CExampleDlgDlg::OnInitDialog() 2 { 3 ... 4 // TODO: Add extra initialization here 5 m_brush.CreateSolidBrush(RGB(0, 255, 0)); // 生成一绿色刷子 6 ... 7 }
③利用ClassWizard重载OnCtlColor(…),即WM_CTLCOLOR消息:
1 HBRUSH CExampleDlgDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 2 { 3 /* 4 ** 这里不必编写任何代码! 5 **下行代码要注释掉 6 ** HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor); 7 */ 8 return m_brush; //返加绿色刷子 9 }
方法四 :还是重载OnCtlColor (CDC* pDC, CWnd* pWnd, UINT nCtlColor),即WM_CTLCOLOR消息。具体步骤如下(以上例工程为准):
步骤①、②同上方法三中的步骤①、②。
步骤③利用ClassWizard重载OnCtlColor(…)(即WM_CTLCOLOR消息)时则有些不同:
1 HBRUSH CExampleDlgDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 2 { 3 HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor); 4 //在这加一条是否为对话框的判断语句 5 if(nCtlColor ==CTLCOLOR_DLG) 6 return m_brush; //返加绿色刷子 7 return hbr; 8 } 9
效果图,在基于上一篇的位图按钮 ,看看是否与背景蛮和谐的:
控件颜色:
对于分布在对话框上的控件,我们可以修改其颜色、其背景颜色,比如对静态文本、文本编辑框、列表框等等。
步骤①、②同上方法三中的步骤①、②。
步骤③:利用ClassWizard重载OnCtlColor(…)(即WM_CTLCOLOR消息)时则有些不同:
1 HBRUSH CTestDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 2 { 3 HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor); 4 if(nCtlColor ==CTLCOLOR_DLG) //对话框颜色 5 return m_brush; //返加绿色刷子 6 if(nCtlColor==CTLCOLOR_STATIC && pWnd->GetDlgCtrlID()==IDC_STATIC) //静态文本颜色,并且指定控件ID号 7 { 8 pDC->SetTextColor(RGB(255,0,0)); 9 pDC->SetBkColor(RGB(191,219,255)); //静态控件的背景颜色设置,这里设置于背景颜色一致,则可以免设置透明 10 //pDC->SetBkMode(TRANSPARENT); //模式设置透明的话,则忽略静态控件的背景颜色设置,与对话框颜色融合 11 hbr=(HBRUSH)m_brush; 12 } 13 if(nCtlColor==CTLCOLOR_EDIT) //文本编辑框颜色 14 { 15 pDC->SetTextColor(RGB(0,0,255)); 16 //pDC->SetBkColor(RGB(191,219,255)); //静态控件的背景颜色设置 17 pDC->SetBkMode(TRANSPARENT); 18 hbr=(HBRUSH)m_brush; 19 } 20 return hbr; 21 }
效果如下:
对于其中nCtlColor类型,即它的取值:
1 CTLCOLOR_DLG 对话框 2 CTLCOLOR_EDIT 编辑框 3 CTLCOLOR_LISTBOX 列表框 4 CTLCOLOR_MSGBOX 消息框 5 CTLCOLOR_SCROLLBAR 滑动条 6 CTLCOLOR_STATIC 静态文本框、矩形等。
转自:http://blog.csdn.net/akof1314/article/details/4952372
对话框背景颜色、控件颜色