動態改變Dialog中IDC_STATIC的文字:
SetDlgItemText(IDC_STATIC,"ABC");
動態改變Dialog中IDC_STATIC文字的顏色:
重載OnCtlColor函數,在要更改顏色的時候向對話框發送WM_CTLCOLOR就行了。
1.在對話框的類中加入成員:
CBrush m_brush;
COLORREF m_color;
2.在OnInitDialog()中,加入
m_brush.CreateSolidBrush(RGB(255,255,255));
//此處設置的RGB值可以改變控件的背景色。
m_color=RGB(0,0,0)
//此處設置控件的文字初始顏色。
3.響應WM_ONCTLCOLOR消息,重載OnCtlColor()函數,加入:
if(nCtlColor== CTLCOLOR_STATIC){
pDC->SetBkMode(TRANSPARENT);
pDC->SetTextColor(m_color);
return (HBRUSH)m_brush.GetSafeHandle();
}
4.需要改變顏色時
m_color=RGB(128,0,255);//此處改變字體的顏色
CStatic* m_pStatic1=(CStatic*)GetDlgItem(IDC_STATIC1);
m_pStatic1->RedrawWindow();
關于控件背景和字體顏色設置的疑惑,只要70分,一問題35分
qiangv (說完就走) 2005-03-05 20:15:15 在 VC/MFC / 界面 提問如一個dialog中有一button,一edit控件
1。把dialog畫出來是發生在initinstance之后么,每個控件都是一個窗口
他們的回調函數都是AfxWinPro()
有一個函數OnCtlColor是響應畫出來這個消息的么?能不能把發生的流程說出來。
2。還有改變button按鈕的背景色和前景色為什么要新建一個類,而不能在onctlcolor中改變呢
ownerdraw是什么意思,什么時候發生呢?
問題點數:70、回復次數:3
1、OnCtlColor是響應WM_CTLCOLOR消息的函數。當子控件將要被繪制的時候,就會發送一個WM_CTLCOLOR消息給它的父窗口(通常是對話框),父窗口準備正確的顏色來繪制子窗口。在一個對話框中,每一個控件的繪制都會發送這個消息,也就是說這個OnCtlColor函數會被調用多次。OnCtlColor是一個虛函數,在沒有被覆蓋之前,直接調用父類的OnCtlColor函數,返回一個畫刷句柄,并用這個返回的畫刷句柄去繪制這個控件。因此,我們可以在這個函數中來設置控件的背景和控件上文字的顏色、文字字體及文字的背景色,但是對于Button控件,卻不能直接來改變背景顏色。
2、Button是一種自繪制控件,在自繪制之前就會調用一個虛函數CButton;;DrawItem(),因此,要想改變Button的背景及字體,就要定義一個Button類從CButton派生出來,并且覆蓋DrawItem(),則當要繪制這個按鈕的時候,框架就會調用這個函數。來改變Button的背景顏色和字體,此外,還要設置控件的ownerdraw屬性.
MSDN上有查過...有一點不明白
所謂自繪是不是它有自己的ondraw函數?
它的WM_CTLCOLOR消息不是一樣送到和別的控件一樣的回調函數里去么?
它也繼承了CWND
應該也有OnCtlColor函數的呀
1.還有改變button按鈕的背景色和前景色為什么要新建一個類,而不能在onctlcolor中改變呢
ownerdraw是什么意思,什么時候發生呢?
因為在他上面貼了一層用于顯示標題或貼圖.
要改變對話框的一般顏色,可以在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;