1.右键需要设置颜色的static控件,并选择类向导:
2.在“类向导”的“消息”中找到WM_CTLCOLOR并双击:
这么做的作用是为了重写颜色控制函数。
此时它会出现一段代码:
HBRUSH CRadaDataDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
TODO: 在此更改 DC 的任何特性
TODO: 如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}
在代码中间添加所需的功能即可:
HBRUSH CRadaDataDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
// TODO: 在此更改 DC 的任何特性
if (pWnd->GetDlgCtrlID() == IDC_STATIC)//注意此处的(pWnd->),否则没效果/*nCtlColor == CTLCOLOR_EDIT &&*/
{
pDC->SetTextColor(RGB(255, 255, 255));
pDC->SetBkColor(RGB(79, 79, 79));
//pDC->SetBkColor(RGB(255, 255, 255));//设置文本背景色
pDC->SetBkMode(OPAQUE);//设置背景透明
return(HBRUSH)GetStockObject(NULL_BRUSH);
/*hbr = (HBRUSH)m_brush;*/
}
// TODO: 如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}
3.结果:第一幅图为没改变颜色时的字体,第二幅图为必变颜色后的字体: