关闭

VC : 改变控件颜色

标签: attributesdialogmfclistclass图形
695人阅读 评论(0) 收藏 举报
分类:
如何改变控件的颜色
 
有两种方法。其一,可以在父类中指定控件的颜色,或者利用MFC4.0新的消息反射在控件类中指定颜色。 当控件需要重新着色时,工作框调用父窗口(通常是对话框)的CWnd: : OnCrtlColor,可以在父窗口类中重置该函数并指定控件的新的绘画属性。例如,下述代码将对话中的所有编辑控件文本颜色改为红色:
HBRUSH CAboutDig : : OnCtlColor (CDC * pDCM , CWnd * pWnd , UINT nCtlColor)
{
 HBRUSH hbr = CDialog : : OnCtlColor (pDC, pWnd , nCtlColor )
 //Draw red text for all edit controls .
 if (nCtlColor= = CTLCOLOR_EDIT )
 pDC —> SetTextColor (RGB (255, 0 , 0 , ) )
 return hbr
}
然而,由于每个父窗口必须处理通知消息并指定每个控件的绘画属性,所以,这种方法不完全的面向对象的方法。控件处理该消息并指定绘画属性更合情合理。消息反射允许用户这样做。通知消息首先发送给父窗口,如果父窗口没有处理则发送给控件。创建一个定制彩色列表框控件必须遵循下述步骤。
首先,使用ClassWizard 创建一个CListBox 的派生类并为该类添加下述
数据成员。
class CMyListBox publilc CListBox
{
private
 COLORREF m_clrFor // foreground color
 COLORREF m_clrBack //background color
 Cbrush m_brush //background brush
}
其次,在类的构造函数中,初始化数据中。
CMyListBox : : CMyListBox ()
{
 //Initialize data members .
 m_clrFore =RGB (255 , 255 , 0) //yellow text
 m_clrBack=RGB (0 , 0 , 255) // blue background
 m_brush . CreateSolidBrush (m _clrBack )
}
 
最后,使用ClassWizard处理反射的WM_CTLCOLOR(=WM_CTLCOLOR)消息并指定
新的绘画属性。
HBRUSH CMyListBox : : CtlColor (CDC* pDC, UINT nCtlColor )
{
 pDC—>SetTextColor (m_clrFore)
 pDC—>SetBkColor (m_clrBack)
 
 return (HBRUSH) m_brush.GetSafeHandle ()
}
现在,控件可以自己决定如何绘画,与父窗口无关。
  
对话框与其控件的颜色,字体的设置
 
要改变对话框的一般颜色,可以在C***App的InitInstance函数里加入如下代码:SetDialogBkColor(RGB(0,255,255),RGB(255,0,0));//背景青蓝、文字红色
但是这样不能改变对话框中的图形控件的颜色;
 
每个控件在dialog中都是一个窗口,当要绘制控件时,会发出一个WM_CTLCOLOR消息给它的父窗口(对话框本身).消息映射及响应函数如下:
ON_WM_CRLCOLOR() //反映WM_CTLCOLOR消息
afx_msg HBRUSH CWnd::OnCrlColor(CDC* pDC,CWnd* pWnd,UINT nCtlColor);
 
nCtlColor类型,即它的取值:
CTLCOLOR_DLG对话框本身,不含有所有的控件
CTLCOLOR_STATIC 所有包含static text控件的设置(也包括无效的edit box、combo box的eidt box)
CTLCOLOR_EDIT     edit box与combo box的eidt box部分
CTLCOLOR_LIST     list box与combo box的edit box部分
CTLCOLOR_SCROLLBAR Scroll bar的空白区
 
我们也可以单独改变某一个控件的颜色.OnCtrlColor函数的pWnd成员变量是各控件的窗口指针,以pWnd->GetDlgCtrlID()可以获得调用此函数的控件ID,将它与已知ID比较,就可以改变这个控件的颜色。
if(pWnd->GetDlgCtrlID() ==IDC_CONTROL)//为控件的ID
{
//pDC->SetBkColor(RGB(255, 0, 0)); -----------在这里也用上了这种写法。不行的,
 
 
}
 
 
另外一个作法是比较pWnd;例如:如果一个edit box控件的成员变量m_edit1被声明为CEdit类,那么把m_edit1.m_hWnd与pWnd->m_hWnd比较,也可以知道是哪个控件.
 
 
下面是一个例子:
HBRUSH CDIALOGDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
    HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    // TODO: Change any attributes of the DC here
    if(nCtlColor==CTLCOLOR_EDIT)
        pDC->SetTextColor(RGB(0,0,255));    
    if(nCtlColor== CTLCOLOR_LISTBOX)
    {
        HBRUSH m_hbrush;
        m_hbrush=CreateSolidBrush(RGB(0,0,0));
        pDC->SetBkMode(TRANSPARENT);
                //设置字体颜色
        pDC->SetTextColor(RGB(255,255,255));
        return m_hbrush;
    }
    CBrush m_cBrush;
    m_cBrush.CreateSolidBrush(RGB(0,255,255));
    switch(nCtlColor)
    {
    case CTLCOLOR_DLG:
        pDC->SetBkMode(TRANSPARENT);
        break;
    case CTLCOLOR_STATIC:
        pDC->SetTextColor(RGB(255,0,0));
        pDC->SetBkColor(RGB(0,255,255));      
        break;
    }
    DeleteObject(m_cBrush);
    // TODO: Return a different brush if the default is not desired
    return hbr;
}
 
字体设置:
 
   VC的对话框字体设置对所有控件都有效,你不能单独地改变某个静态文本的字体。对于你的问题,需要首先用CreateFont来建立一个字体对象,然后调用控件的SetFont,就可以了。
 
 
    例子:
    1、改静态文体的ID,如:IDC_STATIC1
    2、添加一个Edit控件,建立一个关联的控件m_editControl。
    3、在OnInitDialog中添加如下代码:
     CFont * f;
     f = new CFont;
     f->CreateFont(16, // nHeight
     0, // nWidth
     0, // nEscapement
     0, // nOrientation
     FW_BOLD, // nWeight
     TRUE, // bItalic
     FALSE, // bUnderline
     0, // cStrikeOut
     ANSI_CHARSET, // nCharSet
     OUT_DEFAULT_PRECIS, // nOutPrecision
     CLIP_DEFAULT_PRECIS, // nClipPrecision
     DEFAULT_QUALITY, // nQuality
     DEFAULT_PITCH | FF_SWISS, // nPitchAndFamily
     _T("Arial")); // lpszFac
 
     m_editControl.SetFont(f);
     m_editControl.SetWindowText("问专家");
     GetDlgItem(IDC_STATIC1)->SetFont(f);
    
       需要注意的是,这里我们使用的是CFont指针,而不是普通的CFont局部变量。非MFC程序,首先用CreateFont来建立一个字体句柄,然后再用SendMessage发给控件WM_SETFONT消息,将建立的字体句柄赋值过去,就可以了。

重载DialogON_WM_CTLCOLOR 
HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 

HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor); 
// TODO: Change any attributes of the DC here 
//change the color of dialog 
if(nCtlColor==CTLCOLOR_DLG) 

pDC->SetBkColor(RGB(100,150,200)); 
return m_hDlgFace; 

//change the color of static 
if(nCtlColor==CTLCOLOR_STATIC) 

pDC->SetBkColor(RGB(100,150,200)); 
pDC->SetTextColor(RGB(0,0,255)); 
return m_hDlgFace; 

//EDIT
控件只能用这种方法,我也不知道为什么 
if(pWnd->GetDlgCtrlID()==IDC_EDIT1) 

pDC->SetBkColor(RGB(100,180,200)); 
return m_hPage2Face; 

return hbr; 
}

 
 
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:205635次
    • 积分:2339
    • 等级:
    • 排名:第16980名
    • 原创:38篇
    • 转载:31篇
    • 译文:0篇
    • 评论:11条
    文章分类
    最新评论