VC如何改变编辑框的背景色

这里介绍的改变文本编辑框的背景颜色的方法不需要对CEdit生成新的类,步骤如下:

(1) 新建一个基于对话框的MFC应用程序,程序名称为Test;
(2) 在对话框上添加两个文本框,ID分别为IDC_EDIT1和IDC_EDIT2;
(3) 在CTestDlg的头文件中添加几个成员变量,如下所示;
class CTestDlg : public CDialog
{
protected:
CBrush m_redbrush,m_bluebrush;
COLORREF m_redcolor,m_bluecolor,m_textcolor;
};
(4) 在CTestDlg.cpp文件的BOOL CTestDlg::OnInitDialog()中添加以下代码:
BOOL CTestDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE);    // Set big icon
SetIcon(m_hIcon, FALSE);   // Set small icon

m_redcolor=RGB(255,0,0);                      // 红色
m_bluecolor=RGB(0,0,255);                     // 蓝色
m_textcolor=RGB(255,255,255);                 // 文本颜色设置为白色
m_redbrush.CreateSolidBrush(m_redcolor);      // 红色背景色
m_bluebrush.CreateSolidBrush(m_bluecolor);    // 蓝色背景色 
return TRUE; // return TRUE unless you set the focus to a control
}
(5) 右击对话框空白面,选择Event,为WM_CTLCOLOR添加消息响应函数,编辑代码如下:
HBRUSH CTestDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);

// TODO: Change any attributes of the DC here
switch (nCtlColor) //对所有同一类型的控件进行判断

   // process my edit controls by ID.
case CTLCOLOR_EDIT:
case CTLCOLOR_MSGBOX://假设控件是文本框或者消息框,则进入下一个switch
   switch (pWnd->GetDlgCtrlID())//对某一个特定控件进行判断
   {     
    // first CEdit control ID
   case IDC_EDIT1:         // 第一个文本框
    // here
    pDC->SetBkColor(m_bluecolor);    // change the background
    // color [background colour
    // of the text ONLY]
    pDC->SetTextColor(m_textcolor); // change the text color
    hbr = (HBRUSH) m_bluebrush;    // apply the blue brush
    // [this fills the control                   //在进行这一段设置后的效果是只有文本行的背景色被修改,编辑框其他地方颜色还是为对话框颜色,解决方法是将编辑框属性里的TRANSPARENT设为TRUE就OK
    // rectangle]
    break;   
    // second CEdit control ID
   case IDC_EDIT2:         // 第二个文本框
    // but control is still
    // filled with the brush
    // color!
    pDC->SetBkMode(TRANSPARENT);   // make background
    // transparent [only affects
    // the TEXT itself]
    pDC->SetTextColor(m_textcolor); // change the text color
    hbr = (HBRUSH) m_redbrush;     // apply the red brush
    // [this fills the control
    // rectangle]
    break;
   default: 
    hbr=CDialog::OnCtlColor(pDC,pWnd,nCtlColor); 
    break;
   } 
   break;
}
// TODO: Return a different brush if the default is not desired
return hbr;
}
注:case的类别有以下几种:
CTLCOLOR_BTN 按钮控件
CTLCOLOR_DLG 对话框
CTLCOLOR_EDIT 编辑框
CTLCOLOR_LISTBOX 列表框
CTLCOLOR_MSGBOX 消息框
CTLCOLOR_SCROLLBAR 滚动条
CTLCOLOR_STATIC 静态文本         

    以上方法,对只读的编辑框无效!

 

 

 

 

 

 

 

 

 

 

VC/MFC如何设置对话框背景颜色

 

方法一:调用CWinApp类的成员函数SetDialogBkColor来实现。  (这个函数已经废弃)

?
1
void SetDialogBkColor( COLORREF clrCtlBk = RGB(192, 192, 192), COLORREF clrCtlText = RGB(0, 0, 0));

其中函数的第一个参数指定了背景颜色,第二个参数指定了文本颜色。

在InitInstance()中添加如下代码:  

?
1
SetDialogBkColor(RGB(0,0,255),RGB(255,0,0));

值得注意的是:在调用DoModal()之前必须先调用SetDialogBkColor。

这种方法经过笔者验证,并不能改变对话框背景

方法二:重载OnPaint(),即WM_PAINT消息

?
1
2
3
4
CRect   rect;  
  CPaintDC   dc( this );  
  GetClientRect(rect);  
  dc.FillSolidRect(rect,RGB(0,255,0));   //设置为绿色背景

方法三:重载OnCtlColor   (CDC*   pDC,   CWnd*   pWnd,   UINT   nCtlColor),即WM_CTLCOLOR消息

.h头文件添加 CBrush  m_brush;

.cpp源文件添加 m_brush.CreateSolidBrush(RGB(255,0,0));

?
1
2
3
4
5
6
7
OnCtlColor(CDC*   pDC,   CWnd*   pWnd,   UINT   nCtlColor)    
{  
/*  下行代码要注释掉  
      HBRUSH   hbr   =   CDialog::OnCtlColor(pDC,   pWnd,   nCtlColor);  
*/  
return   m_brush;   //返加红色刷子  
}

方法四:还是重载OnCtlColor   (CDC*   pDC,   CWnd*   pWnd,   UINT   nCtlColor), 即WM_CTLCOLOR消息

.h头文件添加 CBrush m_brush;

.cpp源文件添加 m_brush.CreateSolidBrush(RGB(255,0,0));

?
1
2
3
4
5
6
7
8
OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 
   {  
   HBRUSH   hbr   =   CDialog::OnCtlColor(pDC,   pWnd,   nCtlColor);  
   //在这加一条是否为对话框的判断语句  
      if (nCtlColor   ==CTLCOLOR_DLG)  
         return   m_brush;   //返加红色刷子  
   return   hbr;  
   }

可以根据不同的控件类型返回不同的画刷,来实现不同控件颜色的设置  

?
1
2
3
4
5
6
7
CTLCOLOR_BTN                按钮控件
  CTLCOLOR_DLG                对话框
  CTLCOLOR_EDIT               编辑框
  CTLCOLOR_LISTBOX            列表控件
  CTLCOLOR_MSGBOX             消息控件
  CTLCOLOR_SCROLLBAR          滚动条控件
  CTLCOLOR_STATIC             静态控件
?
1
这里大家要注意,OnCtlColor能改变Static等子控件的颜色,对于Button必须设置其属性Owner Draw为True,才能改变Button按钮背景色(CButton 文本的字体颜色并不能通过SetBkColor来改变,需要自己重绘CButton,在DrawItem中进行实现。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
HBRUSH CXXXDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
  HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
  // TODO:  在此更改 DC 的任何属性
  if (nCtlColor==CTLCOLOR_BTN)          //更改按钮颜色
  {
   //pDC->SetBkMode(TRANSPARENT);
   pDC->SetTextColor(RGB(0,0,0));
   pDC->SetBkColor(RGB(121,121,255));   
   HBRUSH b=CreateSolidBrush(RGB(121,121,255));
   return b;
  }
  else if (nCtlColor==CTLCOLOR_SCROLLBAR)  //
  {
   //pDC->SetBkMode(TRANSPARENT);
   pDC->SetTextColor(RGB(0,0,0));
   pDC->SetBkColor(RGB(233,233,220));
   HBRUSH b=CreateSolidBrush(RGB(233,233,220));
   return b;
  }
  else if (nCtlColor==CTLCOLOR_EDIT)   //更改编辑框
  {
   //pDC->SetBkMode(TRANSPARENT);
   pDC->SetTextColor(RGB(0,0,0));
   pDC->SetBkColor(RGB(165,254,236));
   HBRUSH b=CreateSolidBrush(RGB(165,254,236));
   return b;
  }
  else if (nCtlColor==CTLCOLOR_STATIC)  //更改静态文本
  {
   pDC->SetTextColor(RGB(0,0,0));
   pDC->SetBkColor(RGB(166,254,1));
   HBRUSH b=CreateSolidBrush(RGB(166,254,1));
   return b;
  }
  else if (nCtlColor==CTLCOLOR_DLG)   //更改对话框背景色
  {
   pDC->SetTextColor(RGB(0,0,0));
   pDC->SetBkColor(RGB(166,254,1));
   HBRUSH b=CreateSolidBrush(RGB(166,254,1));
   return b;
  }
  // TODO:  如果默认的不是所需画笔,则返回另一个画笔
  return hbr;

 

转载于:https://www.cnblogs.com/yangxx-1990/p/4819563.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值