首先,利用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;
}
通过以上程序,我们就可直接调整编辑控件的背景色。
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/