MFC设置文本字体大小颜色

本文介绍如何使用MFC框架自定义控件的字体、大小、颜色及背景等属性,包括通过CFont设置静态文本的字体大小,以及利用OnCtlColor函数调整多种控件如编辑框、按钮等的颜色和背景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以静态文本为例,分享一下怎么修改文本字体、大小、颜色、背景等参数。其他文本、控件等可参照修改。 

1.修改字体、大小

这个很简单,首先在Dlg类中声明一个CFont类型的成员变量:

 

然后在类的初始化函数OnInitDialog()中添加以下两行代码:

1     //设置静态文本字体大小
2     m_editFont.CreatePointFont(180, _T("宋体"));
3     m_Static.SetFont(&m_editFont);

2.改变编辑框文本颜色、背景颜色

右键点击该对话框-> 类导向 -> 消息 ->双击添加WM_CTLCOLOR,就可以在Dlg类中看到3所示函数OnCtlColor了。

 

复制代码
 1 HBRUSH CTimerDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
 2 
 3 {
 4 
 5     HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
 6 
 7  
 8 
 9     // TODO:  在此更改 DC 的任何特性
10 
11     if (pWnd->GetDlgCtrlID() == IDC_Display)// IDC_Display为所选文本框ID
12 
13     {
14 
15         pDC->SetTextColor(RGB(255, 0, 0));//设置字体颜色
16 
17         pDC->SetBkColor(RGB(0, 255, 0));//设置背景颜色
18 
19         //pDC->SetBkMode(TRANSPARENT);//设置背景透明
20 
21     }
22 
23     // TODO:  如果默认的不是所需画笔,则返回另一个画笔
24 
25     return hbr;
26 
27 }
复制代码

OnCtlColor函数除了用来设置静态控件的颜色、背景外,还适用于以下几种类型:

CTLCOLOR_BTN                            按钮控件

CTLCOLOR_DLG                            对话框

CTLCOLOR_EDIT                            编辑框

CTLCOLOR_LISTBOX                            列表控件

CTLCOLOR_MSGBOX                        消息控件

CTLCOLOR_SCROLLBAR                                                         滚动条控件

CTLCOLOR_STATIC                           静态控件

 

除了用上面指定ID设置属性,还可以指定控件类型来设置属性

复制代码
 1 HBRUSH CTimerDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
 2 
 3 {
 4 
 5     HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
 6 
 7  
 8 
 9     // TODO:  在此更改 DC 的任何特性
10 
11     if (nCtlColor == CTLCOLOR_STATIC)
12 
13     {
14 
15         pDC->SetTextColor(RGB(0, 255, 0));//设置字体颜色
16 
17         pDC->SetBkColor(RGB(255, 0, 0));//设置背景颜色
18 
19     }
20 
21     // TODO:  如果默认的不是所需画笔,则返回另一个画笔
22 
23     return hbr;
24 
25 }
复制代码
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值