关闭

CEDIT 背景色

650人阅读 评论(0) 收藏 举报

总结:

一。首先,利用Class Wizard为WM_CTLCOLOR 消息构造相应的消息映射,将得到以下的消息处理函数:
     //说明,WM_CTLCOLOR 是从CWnd就有的,所以直接从CWnd或是CDialogue类(其实也是从CWnd中继承来的)继承的都可以

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

二。在MyDlg.h头文件中增加如下的函数说明:

    afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor);

     ....

     DECLARE_MESSAGE_MAP()

     protected:

        static HBRUSH  m_BrushBack;

三。在MyDlg.cpp文件中初始化静态变量:

      HBRUSH  CMyDlg::m_BrushBack = HBRUSH(RGB(235,235,235));

 

四。在MyDlg.cpp文件中增加如下的消息映射:

BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
        ON_WM_CTLCOLOR()   //增加此条目

        ....

    再增加如下的消息处理函数:

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

  {

  //获得控件

   CEdit * pEdit = (CEdit *)GetDlgItem(IDC_MYEDIT);  //此处的IDC_MYEDIT即为CMyDlg窗口中要设置的CEdit控件的ID

   if(pEdit->GetSafeHwnd() == pWnd->GetSafeHwnd())

  {
      // 返回设置好的刷子
      return m_BrushgRA;

   }

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

   return hbr;

  }


//////////////////////////////////////////////////////////////////////////////////以下为别人的//////////// 

 

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;

   }

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:366829次
    • 积分:5179
    • 等级:
    • 排名:第5294名
    • 原创:114篇
    • 转载:233篇
    • 译文:1篇
    • 评论:70条
    文章分类
    最新评论