MFC对话框添加了背景图后,会导致控件周围有阴影,很不美观,因此,我们需要将阴影进行透明化处理。此时需要使用到MFC中的消息函数OnCtlColor()。
一、添加OnCtlColor()函数
1、对话框,右键选择类向导
2、进入类向导,依次选择“消息”、“WM_CTLCOLOR”、“添加处理程序”、“应用”、“确定”。
3、添加完了消息函数之后,主对话框cpp中会出现OnCtlColor()函数,当你打开对话框时,这个函数就会自动被调用,一般静态控件的背景就会被透明。
HBRUSH CCPP2018Dlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
//< TODO: 在此更改 DC 的任何特性
//< TODO: 如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}
或者添加以下代码:
HBRUSH CCPP2018Dlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
//< TODO: 在此更改 DC 的任何特性
if(nCtlColor == CTLCOLOR_STATIC )
{
pDC->SetBkMode(TRANSPARENT);//<设置背景透明
return (HBRUSH)::GetStockObject(NULL_BRUSH);
}
//< TODO: 如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}
二、以上都不能处理单选按钮和复选框的背景,需要添加以下代码
HBRUSH CCPP2018Dlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
//< TODO: 在此更改 DC 的任何特性
UINT id = pWnd->GetDlgCtrlID();
if(id == IDC_RADIO_EXPMODE||IDC_RADIO_TRAINMODE||IDC_CHECK_TRACK||IDC_CHECK_SCENE||IDC_EXIT_BUTTON||IDC_MIN_BUTTON)
{
pDC->SetBkMode(TRANSPARENT);
CRect rc;
pWnd->GetWindowRect(&rc);
ScreenToClient(&rc);
CDC* dc = GetDC();
pDC->BitBlt(0,0,rc.Width(),rc.Height(),dc,rc.left,rc.top,SRCCOPY); //<把父窗口背景图片先画到按钮上
ReleaseDC(dc);
hbr = (HBRUSH) ::GetStockObject(NULL_BRUSH);
}
//< TODO: 如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}