改变控件颜色问题
我是这么操作的:
1.新建一个类class CMyStatic : public CStatic
2.添加afx_msg HBRUSH CtlColor(CDC* pDC, UINT nCtlColor);函数 在这个函数中添加代码
pDC->SetTextColor(RGB(0,255,0));
3.修改静态文本控件的ID为IDC_STATIC1;在CXDLG类中添加成员变量m_clrStatic,并与IDC_STATIC1关联
为什么这么操作了,静态文本控件中的文本没有改变颜色呢?
代码我上传到网盘了,下载地址是http://xz.qjwm.com/down_890022.html
1.新建一个类class CMyStatic : public CStatic
2.添加afx_msg HBRUSH CtlColor(CDC* pDC, UINT nCtlColor);函数 在这个函数中添加代码
pDC->SetTextColor(RGB(0,255,0));
3.修改静态文本控件的ID为IDC_STATIC1;在CXDLG类中添加成员变量m_clrStatic,并与IDC_STATIC1关联
为什么这么操作了,静态文本控件中的文本没有改变颜色呢?
代码我上传到网盘了,下载地址是http://xz.qjwm.com/down_890022.html
作者: xinMFC 发布时间: 2011-06-14
你重载的类错了。
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTLCOLOR_STATIC && pWnd->GetDlgCtrlID() = IDC_STATIC1)
pDC->SetTextColor(RGB(0,255,0));
return hbr;
}
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTLCOLOR_STATIC && pWnd->GetDlgCtrlID() = IDC_STATIC1)
pDC->SetTextColor(RGB(0,255,0));
return hbr;
}
作者: Sandrer 发布时间: 2011-06-14
引用 1 楼 sandrer 的回复:
你重载的类错了。
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTL……
你重载的类错了。
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTL……
我重载的是 CtlColor函数,而不是OnCtlColor。
作者: xinMFC 发布时间: 2011-06-14
首先 定义一个全局变量, COLORREF statusColor;
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
// TODO:
if(pWnd->GetDlgCtrlID() == IDC_STATUS) //////你的控件ID.
{
pDC->SetTextColor(statusColor); /////////////////////////////
pDC->SetBkMode(TRANSPARENT);
}
// TODO:
return hbr;
}
然后当你需要更改时, 这样做.
statusColor =RGB(0,0,255); //Blue
UpdateData(FALSE);
OK, 解决.
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
// TODO:
if(pWnd->GetDlgCtrlID() == IDC_STATUS) //////你的控件ID.
{
pDC->SetTextColor(statusColor); /////////////////////////////
pDC->SetBkMode(TRANSPARENT);
}
// TODO:
return hbr;
}
然后当你需要更改时, 这样做.
statusColor =RGB(0,0,255); //Blue
UpdateData(FALSE);
OK, 解决.
作者: King_hhuang 发布时间: 2011-06-14
引用 3 楼 king_hhuang 的回复:
首先 定义一个全局变量, COLORREF statusColor;
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, ……
首先 定义一个全局变量, COLORREF statusColor;
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, ……
你说的这个方法确实可以。修改控件颜色也可以由控件自己负责,用的是消息反射
作者: xinMFC 发布时间: 2011-06-14
引用 4 楼 xinmfc 的回复:
引用 3 楼 king_hhuang 的回复:
首先 定义一个全局变量, COLORREF statusColor;
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialo……
引用 3 楼 king_hhuang 的回复:
首先 定义一个全局变量, COLORREF statusColor;
然后重载Dialog的ON_WM_CTLCOLOR, 在里面指定你的控件ID.
HBRUSH CRMAToolDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialo……
为什么我这样做不行呢?
我是继承Cdialog类,然后重载OnCtlColor,在里面直接返回一个画刷;
结果这个继承类对话框背景没有颜色变化?
作者: wesleyluo 发布时间: 2011-06-14
UP
引用 2 楼 xinmfc 的回复:
引用 1 楼 sandrer 的回复:
你重载的类错了。
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
……
引用 1 楼 sandrer 的回复:
你重载的类错了。
不应该在静态文本类中重载,而应该在对话框中重载OnCtlColor
HBRUSH CYourDialog::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
……
作者: yjueqtd 发布时间: 2011-06-14