SDI默认定义的背景颜色是白色,请问如何改变它的颜色?
解决方案 »
- VC问题
- 用TrackPopupMenu显示菜单时如何让菜单的第一项处于选中状态?
- VC++初学者的求救
- VC6.0 开发的软件在WindowXp Sp2上安装出现问题?
- 一个线程函数调用全局变量的问题《--问题解决就结贴
- 关于access数据库的排序问题
- [请教]问三个关于VC中CButton类的问题
- 我想做一个可以拖动的Button,我重载了CButton,可是。。。。。。。。
- 作了一个查杀以把可执行文件以资源形式包装的病毒或木马的程序,大家试试看,说不定从你机上就能找出一大堆来.
- win32sdk 中非模态对话框弹出一个messgebox,但messagebox无法关闭
- Recordset删除指定列的问题
- 数组访问越界问题!在线等
详见msdn
void CMyView::OnDraw(CDC* pDC)
{
CSsDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
///////////////////////////////////////////////////////////
CRect rect;
this->GetClientRect(rect);
pDC->FillSolidRect(&rect,RGB(255,0,0));//设置你需要的颜色
////////////////////////////////////////////////////////////
// TODO: add draw code for native data here
}
一个是在响应WM_ERASEBKGND消息(OnErasebkgnd)的时候绘制背景,可以贴图。
方法 一:Windows 向窗口发送一个WM_ERASEBKGND 消息通知该窗口擦除背景,可以使用
ClassWizard 重载该消息的缺省处理程序来擦除背景(实际是画),并返回TRUE 以防止
Windows擦除窗口。
//Paint area that needs to be erased.
BOOL CSampleView : : OnEraseBkgnd (CDC* pDC)
{
// Create a pruple brush.
CBrush Brush (RGB (128 , 0 , 128) );
// Select the brush into the device context .
CBrush* pOldBrush = pDC―>SelcetObject (&brush);
// Get the area that needs to be erased .
CRect reClip ;
pDC―>GetCilpBox (&rcClip);
//Paint the area.
pDC―> PatBlt (rcClip.left , rcClip.top ,
rcClip.Width ( ) , rcClip.Height ( ) , PATCOPY );
//Unselect brush out of device context .
pDC―>SelectObject (pOldBrush );
// Return nonzero to half fruther processing .
return TRUE;
}
方法二:调用CWinApp : : SetDialogBkColor 可以改变所有应用程序的背景颜色。第一个参数
指定了背景颜色,第二个参数指定了文本颜色。下例将应用程序对话设置为蓝色背景和
黄色文本。
BOOL CSampleApp : : InitInstance ( )
{
…
//use blue dialog with yellow text .
SetDialogBkColor (RGB (0, 0, 255 ), RGB ( 255 , 255 , 0 ) ) ;
…
}
需要重画对话(或对话的子控件)时,Windows 向对话发送消息WM_CTLCOLOR,通常用
户可以让Windows 选择绘画背景的刷子,也可重置该消息指定刷子。下例说明了创建一
个红色背景对话的步骤。
首先,给对话基类增加一人成员变量CBursh :
class CMyFormView : public CFormView
{
…
private :
CBrush m_ brush ; // background brush
…
} ;
其次, 在类的构造函数中将刷子初始化为所需要的背景颜色。
CMyFormView : : CMyFormView ( )
{
// Initialize background brush .
m_brush .CreateSolidBrush (RGB ( 0, 0, 255 ) )
}
最后,使用ClassWizard处理WM_CTLCOLOR消息并返回一个用来绘画对话背景的刷子句
柄。注意:由于当重画对话控件时也要调用该函数,所以要检测nCtlColor参量。
HBRUSH CMyFormView : : OnCtlColor (CDC* pDC , CWnd*pWnd , UINT nCtlColor )
{
// Determine if drawing a dialog box . If we are , return +handle to
//our own background brush . Otherwise let windows handle it .
if (nCtlColor = = CTLCOLOR _ DLG )
return (HBRUSH) m_brush .GetSafeHandle ( ) ;
return CFormView : : OnCtlColor (pDC, pWnd , nCtlColor );
}
最好的方法是在onprecreatewindow中改变注册的窗口类,也就是采用自己定义的窗口类的类名。
我是这样实现的:
cs.lpszClass=AfxRegisterWndClass(CS_HREDRAW|CS_VREDRAW,0,(HBRUSH)GetStockObject(LTGRAY_BRUSH),0);
采用背景画刷为LTGRAY_BRUSH的窗口类注册。