有兩種方法。其一,可以在父類中指定控件的顏色,或者利用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 ()
}
現在,控件可以自己決定如何繪畫,與父窗口無關。