编程调整控件背景色

发表于:2007-07-04来源:作者:点击数: 标签:
苏金国 VC中由于没有直接的属性设置可以调整编辑控件的背景色,因此我们需要利用图形设备接口的有关操作来实现这一目标。 首先,利用Class Wizard为WM_CTLCOLOR 消息构造相应的消息映射,将得到以下的消息处理函数: HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWn
苏金国

  VC中由于没有直接的属性设置可以调整编辑控件的背景色,因此我们需要利用图形设备接口的有关操作来实现这一目标。

  首先,利用Class Wizard为WM_CTLCOLOR 消息构造相应的消息映射,将得到以下的消息处理函数:

  HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)

  {

   HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);

   return hbr;

   // TODO: Return a different brush if the default is not desired

   // return hbr;

  }

  接着检查CTLCOLOR_EDIT 控件的nCtlColor 属性值,与我们希望控件的背景色是否存在差异。最好的方法是使用窗口句柄的比较,而不要比较两个指针。因此需要在消息处理函数中增加以下代码:

  HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)

  {

  //获得控件

   CEdit * pEdit = (CEdit *)GetDlgItem(IDC_REDEDIT);

   if(nCtlColor == CTLCOLOR_EDIT &&&& pEdit->GetSafeHwnd() == pWnd->GetSafeHwnd())

  {

  // 设置背景模式

  pDC->SetBkMode(TRANSPARENT);

  // 调整文本颜色,以便更好地在新的背景色上显示

  pDC->SetTextColor(RGB(255,255,255));

  // 返回红色的刷子

  return m_Brush;

   }

   HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);

   return hbr;

  }

  如果控件置为只读即READONLY ,则最好将nCtlColor与CTLCOLOR_STATIC进行比较,代码如下:

  HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)

  {

  // 取得具有只读性质的控件

  CEdit * pEditReadOnly = (CEdit *)GetDlgItem(IDC_READONLYEDIT);

  //取得控件对应的窗口

  HWND hWndReadOnly = pEditReadOnly->GetSafeHwnd();

  if(nCtlColor == CTLCOLOR_STATIC &&&& hWndReadOnly == pWnd->GetSafeHwnd()) {

  // 设置背景色为刷子颜色(当前为红色)

  pDC->SetBkColor(RGB(255,0,0));

  // 调整文本色

  pDC->SetTextColor(RGB(255,255,255));

  // 返回红色的刷子

  return m_Brush;

   }

  HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);

   return hbr;

   }

  通过以上程序,我们就可直接调整编辑控件的背景色。   

原文转自:http://www.ltesting.net