改变MFC对话框背景色、控件…

来源:互联网 发布:魔法王座骑兵升级数据 编辑:程序博客网 时间:2024/05/16 09:32
原文地址:改变MFC对话框背景色、控件内的字体颜色和背景色作者:中天数字
C 设置 Dialog, Group Box, Static Text, CheckBox, Edit Ctrl(disabled), Combo Box(disabled), RadioButton等背景色
编写WM_CTLCOLOR消息的映射函数OnCtlColor(CDC *pDC, CWnd pWnd, UINTnCtlColor)
加入如下代码:
COLORREF backColor = RGB(216, 231, 252) //office 2003背景色
pDC->SetBkMode(TRANSPARENT);                //设置控件背景透明
returnCreateSolidBrush(backColor);            //创建背景刷子

一个基于对话框的MFCAppWizard应用程序中,如何改变对话框的背景颜色呢?对于这个问题,其实可以由几种不同的方法来实现,具体如下(粗斜体代码为增添的):

----方法一:调用CWinApp类的成员函数SetDialogBkColor来实现。
‍‍---- 其中函数的第一个参数指定了背景颜色,第二个参数指定了文本颜色。下面的例子是将应用程序对话框设置为蓝色背景和红色文本,步骤如下:
---- ① 新建一个基于Dialog的MFC AppWizard应用程序ExampleDlg。
---- ② 在CExampleDlgApp ::InitInstance()中添加如下代码:
‍BOOL CExampleDlgApp: : InitInstance ( )
{
CExampleDlgDlg dlg;
m_pMainWnd = &dlg;
‍//先于DoModal()调用,将对话框设置为蓝色背景、红色文本
‍SetDialogBkColor(RGB(0,0,255),RGB(255,0,0));
‍int nResponse = dlg.DoModal();
}
编译并运行,此时对话框的背景色和文本色已发生了改变。值得注意的是:在调用DoModal()之前必须先调用SetDialogBkColor,且此方法是将改变应用程序中所有的对话框颜色,并不能针对某一个指定的对话框。

 

----方法二:重载OnPaint(),即WM_PAINT消息。有关代码如下(以上例工程为准):
void CExampleDlgDlg::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, UINTnCtlColor),即WM_CTLCOLOR消息。具体 步骤如下(以上例工程为准):
---- ①在CExampleDlgDlg的头文件中,添加一CBrush的成员变量:
class CExampleDlgDlg : public CDialog
{
...
protected:
CBrush m_brush;
...
};
---- ②在OnInitDialog()函数中添加如下代码:
BOOL CExampleDlgDlg::OnInitDialog()
{
...
// TODO: Add extra initialization here
m_brush.CreateSolidBrush(RGB(0, 255, 0)); // 生成一绿色刷子
...
}
---- ③利用ClassWizard重载OnCtlColor(…),即WM_CTLCOLOR消息:
HBRUSH CExampleDlgDlg::OnCtlColor
(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{

return m_brush;   //返加绿色刷子
}
---- 方法四:还是重载OnCtlColor (CDC* pDC, CWnd* pWnd, UINTnCtlColor),即WM_CTLCOLOR消息。 具体步骤如下(以上例工程为准):
---- 步骤①、②同上方法三中的步骤①、②。
---- 步骤③利用ClassWizard重载OnCtlColor(…)(即WM_CTLCOLOR消息)时则有些不同:
HBRUSH CExampleDlgDlg::OnCtlColor
(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
//在这加一条是否为对话框的判断语句
if(nCtlColor ==CTLCOLOR_DLG)
return m_brush;   //返加绿色刷子
return hbr;
}
---- 编译并运行即可。
---- 关于如何改变对话框背景颜色的问题,可能还有很多种不同方法可以实现,笔者在这仅举出四种常见的方法。其中方法三的编程似乎有点不太规范,方法四则要比方法三正统些,笔者这样的对比举例是为了拓宽VC编程爱好者特别是初学者的编程思路,读者可以根据实际情况选用其中的一种。如果再结合《软件报》2000年第5期中改变对话框上的控件颜色,相信会使您的MFC应用程序"增色"不少。

另外一种就是用

BOOL CBPCALLView::OnEraseBkgnd(CDC*pDC)
{
//可以背景图,画刷等
//return CScrollView::OnEraseBkgnd(pDC);
}

BOOLCHardwaremessage::OnEraseBkgnd(CDC* pDC)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
   CBrush   brush;
   CRect   rect;
   COLORREF  rgbBackGnd    RGB(210,210,210);
   GetClientRect(&rect);
   brush.CreateSolidBrush(rgbBackGnd);
   pDC-> FillRect(rect,&brush);
   return   TRUE;
return CDialog::OnEraseBkgnd(pDC);
}

MFC改变控件内的字体颜色和背景色
2010-11-26 13:25

 

在MFC类库提供了CWnd::OnCtlColor函数,在工作框架的子窗口被重画时将调用该成员函数.因此可以重载WM_CTLCOLOR消息的响应函数.此函数的原型:
  afx_msg HBRUSHOnCtlColor(CDC *pDC,CWnd *pWnd,UINTnCtlColor);
          参数nCtlColor用于指定控件的类型,可以是:
          .CTLCOLOR_BTN               按钮控件
          .CTLCOLOR_DLG               对话框
          .CTLCOLOR_EDIT              编辑框
          .CTLCOLOR_LISTBOX           列表控件
          .CTLCOLOR_MSGBOX            消息控件
          .CTLCOLOR_SCROLLBAR滚动条控件
          .CTLCOLOR_STATIC            静态控件
[程序实现]
          假设你已有了名为My的对话框工程.你有了一个STATIC的控件,ID为IDC_STATIC1.
  HBRUSH CMyDlg::OnCtlColor(CDC* pDC,CWnd* pWnd, UINT nCtlColor)
          {
        HBRUSHhbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
  
       // TODO: Change any attributes of the DChere
           if(nCtlColor==CTLCOLOR_STATIC)

             {
                   pDC->SetTextColor(RGB(255,0,0));
  //字体颜色
                   pDC->SetBkColor(RGB(0, 0,255));   //字体背景色  

               }
       
// TODO: Return a different brush ifthe default is notdesired
        returnhbr;
          }


如果要指定某个特定控件可以这样写:ID为IDC_STATIC1

if(pWnd->GetDlgCtrlID()==IDC_STATIC1)
{
      pDC->SetTextColor
(
RGB(255,0,0));  //设置字体颜色
      pDC->SetBkMode(TRANSPARENT); //设置字体背景为透明
// TODO: Return a different brush if the defaultis notdesired
  return(HBRUSH)::GetStockObject(BLACK_BRUSH);  //设置背景色
}
else
return hbr;

【注】

BLACK_BRUSH:黑色

WHITE_BRUSH:白色

GRAY_BRUSH:灰色

NULL_BRUSH:透明

HOLLOW_BRUSH :透明


 

0 0
原创粉丝点击