当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 如何在ListBox中选择背景位图

VC++
如何实现24位色工具条
如何定制浮动工具条
如何实现工具栏的下拉箭头按钮
Outlook式样界面菜单和页面控制
如何在状态栏中实现进度指示器控制
Outlook风格的单列使用不同的颜色显示新邮件数
为CListBox加上智能水平滚动条
如何实现类似VC属性表中的钉子按钮
在窗体中加入3D Bar
通过程序向RichEditView写文本
如何在工具栏上添加平面下拉控件
按数据库记录构建树控件
树控件的双击响应
VC++中轻松实现滑动控件
深入浅出 CPropertySheet
如何在ListBox中选择背景位图
在对话框中加入属性页
如何在EDITBOX控件中使用背景位图
如何在树型控件中使用背景位图
树型控件拖动的完美实现

VC++ 中的 如何在ListBox中选择背景位图


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 99 ::
收藏到网摘: n/a

如何在ListBox中选择背景位图
作者:zhoudb

下载本文源代码

本文介绍如何在ListBox中添加更换背景位图,并提供源代码供参考。本文源代码运行效果图如下:


一、基本原理

构造一个LISTBOX的子类CMYLISTBOX,在刷新背底的时候,选择背景位图。此时需要设置背景模式为透明,当你在其上写入文字的时候,文字背底就不会变白色,而是背景色;刷子也必须是空的,这样每次刷新的后,背景就不会改变。
其中特别需要注意的是,当你的LISTBOX出现了滚动条的时候需要重新设置背底位图的尺寸的大小,减去相应的滚动条区域,否则,底图会把滚动条覆盖。

二、实现代码

下面把CMYLISTBOX类几个重载函数再说明一下:
//当你选择的ITEM变化时刷新;

void CMyListBox::OnSelchange() {	iSelectChange = TRUE;}void CMyListBox::OnLButtonDown(UINT nFlags, CPoint point) {	if(iSelectChange)	{	iSelectChange= FALSE;	Invalidate();	}	CListBox::OnLButtonDown(nFlags, point);}
//设置画刷,背景模式,文字颜色
HBRUSH CMyListBox::CtlColor(CDC* pDC, UINT nCtlColor) {	pDC->SetBkMode(TRANSPARENT); //设置背景模式透明	pDC->SetTextColor(RGB(64,32,0));//设置文字颜色;	return m_brHollow;	//设置空心画刷;}
//在垂直滚动时刷新;
void CMyListBox::OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar) {	Invalidate();	CListBox::OnVScroll(nSBCode, nPos, pScrollBar);}
//在水平滚动时刷新;
void CMyListBox::OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar) {	Invalidate();	CListBox::OnHScroll(nSBCode, nPos, pScrollBar);}
//将背景位图画出来;
BOOL CMyListBox::OnEraseBkgnd(CDC* pDC) {	BITMAP bm;	m_bmp.GetBitmap(&bm);	m_pbmCurrent = &m_bmp;	CDC dcMem;	dcMem.CreateCompatibleDC(pDC);	CBitmap* pOldBitmap = dcMem.SelectObject(m_pbmCurrent);	pDC->BitBlt(0,0,bm.bmWidth,bm.bmHeight,&dcMem,0,0,SRCCOPY);	dcMem.SelectObject(pOldBitmap);	return CListBox::OnEraseBkgnd(pDC);}
对于背景位图的大小,我们事先先判断一下区域大小;
m_listbox.GetClientRect(LPRECT);
然后判断如果需要更改背景位图大小的话,可以调用HBITMAP CMylistboxDlg::GetSizeBITMAP(HBITMAP hBitmap, int w, int h)函数,这个函数可以根据把你的HBITMAP减切至适当大小(w,h)。具体一些其它函数就不一一介绍。
说明,可能有人通过对LISTBOX的DRAWITEM函数进行重载,实现的方法与此方法原理不同,每个ITEM都是画出来的,不是作为一个整体,所以其在刷新的时候可能会慢一点,但或许程序界面的抖动会少些。
代码我已经整理了一遍,可能还可以部分优化,如果有兴趣可以发信至[email protected]一起探讨。