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

VC++
面试题目:猫吃老鼠问题的求解
一个最基本的有限元计算程序
简单的表达式求值
C程序移植到VC开发环境下
一个小语言的词法分析程序
A/B 向上取整的方法
马走日棋盘算法
一种随机抽题的简单算法
clone模式在平衡排序二叉树实现中的应用
递归的应用 -- 最简单分形图形实现
比较数据排序前后的查找次数
根据前序和中序序列生成二叉树
如何用CZip/CUnzip类压缩/解压缩文件
使用 random_shuffle() 算法随机化序列元素
Ceb解除打印屏蔽实战
基于SHA-256的HMAC文件校验器
模拟信息加密流程图简介
关于数据校验
浅谈利用RSA算法防止非法注册机的制作
加密它:用新的高级加密标准(AES)保持你的数据安全

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 113 ::
收藏到网摘: 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]一起探讨。