当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 多功能标签CLabelEx

VC++
透明窗体的又一实现
橡皮区矩形 CRectTracker C# 实现
Visual Basic .NET 中多 Windows 窗体的同步
轻松实现类 MSDN 2002 界面(二)
轻松实现类 MSDN 2002 界面
数据库开发之窗体编程
一个打印报表的简单的类
SDK 程序使用SkinMagic工具包换皮肤
Windows SDK笔记(七):创建MDI窗口
Windows SDK笔记(六):使用对话框资源建立窗口
Windows SDK笔记(五):非模式对话框
Windows SDK笔记(四):模式对话框
也谈如何隐藏显示在任务栏中的对话框程序
一个托盘程序演示 -闹钟 Alert
think window procedure
再谈 CFileDialog 对话框的定制
获得 Win32 窗口句柄的更好的方法
个人考勤软件开发实例配套代码 2.1版(Update)
介绍一个操作DHTML表格的C++对象
Windows资源管理器Web视图界面

VC++ 中的 多功能标签CLabelEx


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

多功能标签CLabelEx


作者:北方工业大学 阙荣文(querw)

下载源代码

引言
  做用户界面的时候经常要用到一些静态文本控件,显示一些文字信息,但是 MFC 提供的 CStatic类的功能过于简单,无法满足高级需求。为此我从 CStatic 派生了一个类 CLabelEx,扩展了CStatic。第一次投稿,水平不足请大家见谅。我从 vckbase.com 学到了很多很多东西 ,该是我回报的时候了。

一、功能简介

新增的功能主要有:

  • 1、设置背景图片SetBGBitmap();设置鼠标经过时的背景图片SetMouseOverBGBitmap();设置鼠标单击后的背景图片SetClickedBGBitmap();
  • 2、设置标签图片,SetLabelBitmap();设置鼠标经过时的标签图片SetMouseOverLabelBitmap();设置鼠标单击时的标签图片
  • 3、文字功能
    • (1)设置字体颜色,下划线等就不说了.
    • (2)感应鼠标经过时自动加上下划线,自动把文字变蓝(就像一个超链接一样)
  • 4、边框和背景
    可以设置/取消边框,指定边框颜色;设置背景色,并填充整个标签
二、实现原理

1、其实就是在OnPaint()里画出各种效果:
void CLabelEx::OnPaint() {	CPaintDC dc(this); // device context for painting	dc.SetTextColor(m_crText);	dc.SetBkMode(TRANSPARENT);	dc.SelectObject(this->GetFont());	///准备工作	CRect rect;	CDC MemDC;	CPen BorderPen,*pOldPen,UnderLinePen;	CBrush BGBrush,*pOldBrush;	BITMAP bm;	int nTextLeft=0,nTextTop=0; //文字输出的位置	this->GetClientRect(&rect);	MemDC.CreateCompatibleDC(&dc);	MemDC.SetMapMode(dc.GetMapMode());	///画边框	if(m_bBorder)	{	BorderPen.CreatePen(PS_SOLID,1,m_crBorder);	BGBrush.CreateSolidBrush(m_crBG);	pOldPen=dc.SelectObject(&BorderPen);	pOldBrush=dc.SelectObject(&BGBrush);	dc.Rectangle(&rect);	dc.SelectObject(pOldPen);	dc.SelectObject(pOldBrush);	rect.DeflateRect(1,1);	}	///贴背景图	if(m_bClicked && m_ClickedBGBm.GetSafeHandle()!=NULL)	{	MemDC.SelectObject(m_ClickedBGBm);	dc.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),	&MemDC,0,0,SRCCOPY);	}	else if(m_bOver && m_MouseOverBGBm.GetSafeHandle()!=NULL)//鼠标经过的时候	{	MemDC.SelectObject(m_MouseOverBGBm);	dc.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),	&MemDC,0,0,SRCCOPY);	}	else if(m_BGBm.GetSafeHandle()!=NULL)	{	MemDC.SelectObject(m_BGBm);	dc.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),	&MemDC,0,0,SRCCOPY);	}	///贴标签图片	if(m_bClicked && m_ClickedLabelBm.GetSafeHandle()!=NULL)	{	m_ClickedLabelBm.GetBitmap(&bm);	double fScal=bm.bmWidth*1.0/bm.bmHeight;	nTextLeft=int(rect.Height()*fScal)+4;	MemDC.SelectObject(m_ClickedLabelBm);	dc.StretchBlt(rect.left,rect.top,int(rect.Height()*fScal),rect.Height(),	&MemDC,0,0,bm.bmWidth,bm.bmHeight,SRCCOPY);	}	else if(m_bOver && m_MouseOverLabelBm.GetSafeHandle()!=NULL)	{	m_MouseOverLabelBm.GetBitmap(&bm);	double fScal=bm.bmWidth*1.0/bm.bmHeight;	nTextLeft=int(rect.Height()*fScal)+4;	MemDC.SelectObject(m_MouseOverLabelBm);	dc.StretchBlt(rect.left,rect.top,int(rect.Height()*fScal),rect.Height(),	&MemDC,0,0,bm.bmWidth,bm.bmHeight,SRCCOPY);	}	else if(m_LabelBm.GetSafeHandle()!=NULL)	{	m_LabelBm.GetBitmap(&bm);	double fScal=bm.bmWidth*1.0/bm.bmHeight;	nTextLeft=int(rect.Height()*fScal)+4;	MemDC.SelectObject(m_LabelBm);	dc.StretchBlt(rect.left,rect.top,int(rect.Height()*fScal),rect.Height(),	&MemDC,0,0,bm.bmWidth,bm.bmHeight,SRCCOPY);	}	else	{	nTextLeft=4;	}	///输出文字	TEXTMETRIC tm;	dc.GetTextMetrics(&tm);	CString strText;	this->GetWindowText(strText);	nTextTop=rect.top+(rect.Height()-tm.tmHeight)/2;	if(strText.GetLength()>0)	{	dc.TextOut(nTextLeft,nTextTop,strText);	}	///画下划线	if(m_bUnderLine)	{	nTextLeft-=2;	nTextTop=nTextTop+tm.tmHeight+1;	UnderLinePen.CreatePen(PS_SOLID,1,m_crUnderLine)