我说的是多行的CEdit
好像和单行的CEdit不一样

解决方案 »

  1.   

    自己写一个CEDIT的派生类,自己想怎么变就怎么变
      

  2.   

    如何改变控件的颜色
     
    有两种方法。其一,可以在父类中指定控件的颜色,或者利用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 ()
    }
    现在,控件可以自己决定如何绘画,与父窗口无关。 
      

  3.   

    这个方法对多行的CEdit好像不行.
    有字的地方背景颜色变了,没字的地方还是白色
      

  4.   

    自己继承来做.BOOL OnEraseBkgnd( CDC* pDC );
    擦掉它, 涂上你要的颜色.
      

  5.   

    不好意思是CWinApp::SetDialogBkColor 写的太快那
      

  6.   

    虽有源代码的话,发我一份(两个信箱,双保险)
    [email protected]
    [email protected]
    收到立刻给分
    谢谢
      

  7.   

    不是在Dlg里好象有麻烦啊,我重载的OnEraseBkgnd(),OnPaint()在Edit滚动文本时根本就没有调用!
      

  8.   

    VC技术内部上只能用于单行的CEdit,好像?
    谁有多行的例子?
      

  9.   

    CWnd* pWnd1=GetDlgItem(IDC_EDIT1);
    if(nCtlColor==CTLCOLOR_EDIT)
    {
    HBRUSH m_hbrDlg;
    m_hbrDlg=CreateSolidBrush(RGB(0,0,0));
    pDC->SetBkMode(TRANSPARENT);
    pDC->SetTextColor(RGB(6,150,255));
    return m_hbrDlg;
    }
    else
    {
    HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    return hbr;
    }