下载本文示例代码
本文介绍如何在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都是画出来的,不是作为一个整体,所以其在刷新的时候可能会慢一点,但或许程序界面的抖动会少些。 代码我已经整理了一遍,可能还可以部分优化,如果有兴趣可以可以在下面留言探讨。 zmbbs=1;
本文介绍如何在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都是画出来的,不是作为一个整体,所以其在刷新的时候可能会慢一点,但或许程序界面的抖动会少些。 代码我已经整理了一遍,可能还可以部分优化,如果有兴趣可以可以在下面留言探讨。 zmbbs=1;
下载本文示例代码
VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图VC实现在ListBox中选择背景位图