VC多功能标签CLabelEx

2016-02-19 21:42 11 1 收藏

下面是个超简单的VC多功能标签CLabelEx教程,图老师小编精心挑选推荐,大家行行好,多给几个赞吧,小编吐血跪求~

【 tulaoshi.com - 编程语言 】

  引言

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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

  一、功能简介

  新增的功能主要有:

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

  二、实现原理

  1、其实就是在OnPaint()里画出各种效果:本文发表于http://bianceng.cn(编程入门网)

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);
     pOldPen=dc.SelectObject(&UnderLinePen);
     dc.MoveTo(nTextLeft,nTextTop);
     dc.LineTo(nTextLeft+tm.tmAveCharWidth*strText.GetLength(),nTextTop);
   }
}   
  注:对字体加下划线我没有使用直接设置字体下划线的方法,因为我觉得那样不好看,呵呵

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  2、感应鼠标用的方法如下所示:

  在MouseMove里SetCapture()和ReleaseCapture();

void CLabelEx::OnMouseMove(UINT nFlags, CPoint point)
{
   // TODO: Add your message handler code here and/or call default
   if (m_bOver)    // Cursor is currently over control
   {
     CRect rect;
     GetClientRect(rect);
    
     if (!rect.PtInRect(point))
     {
       m_bOver = FALSE;
       if(m_bAutoUnderLine) ///自动下划线
       {
         this-SetUnderLine(FALSE,RGB(0,0,0));
       }
       if(m_bHighLight)  //自动高亮
       {
         ///恢复原来的字体颜色
         this-SetTextColor(m_crBackText);
       }
       RedrawWindow();
       ReleaseCapture();
       return;
     }
   }
   else           // Cursor has just moved over control
   {
     m_bOver = TRUE;
     if(m_bAutoUnderLine)
     {
       this-SetUnderLine(TRUE,RGB(0,0,255));
     }
     if(m_bHighLight)
     {
       m_crBackText=m_crText;
       this-SetTextColor(RGB(0,0,255));
     }
     RedrawWindow();
     SetCapture();
     ::SetCursor(m_hHandCur);
   }
   CStatic::OnMouseMove(nFlags, point);
}   
  注:这种方法简单方便,但是有一个问题,看附带的工程,单击Label1弹出一个对话框后Label1无法恢复原状。我一直没解决这个问题.若谁知道请告知我 querw@sina.com

来源:http://www.tulaoshi.com/n/20160219/1626889.html

延伸阅读
标签: 电脑入门
Uninstall Tool是一款国际知名的专业卸载工具,支持显示隐藏的安装程序,按名称过滤已安装程序的列表,强行卸载程序,浏览注册表项目,保存安装程序列表,是一款足以代替系统添加/删除程序的绝佳工具。下面8844就来给大家介绍Uninstall Tool的功能吧! 启动Uninstall Tool的主程序,可以看到默认显示的是软件标签页,上面自动显示了当前系统...
标签: 生活常识
岁末除尘之发掘柜橱的多功能 1、橱侧挂耳:壁橱的侧面可以安装挂耳来悬挂一些经常穿戴的衣物。如果需要放置的数量比较多的话,你可以选择内外环设置的挂耳。 2、储纳盒:可以充当凳子用的储纳盒最适合用来存放一些季节性很强的衣物和那些比较少会用到的装饰品。 3、格架:觉得柜子不够用几乎是每个家庭都会遇到的困扰。帆布质...
搁架是唯一可以与墙融为一体的收纳家具。精心地挑选搁架的材质和造型,规划墙面的布置和风格;让空白的墙壁即时改观,令房间里的层次更加丰富,生活更加便利。下面推荐30款时尚搁架,让你的小户型空间也变得更宽敞,更有序。 1 柱形支撑搁架空间一分为二 纤细的柱形支撑隔断,把餐厅和客厅两个区域完全分隔开,同时又不失通透的效果,搁架...
教程开始前,先看张效果图,很温馨吧!   步骤1:准备好所需材料。   步骤2:用夹子围着易拉罐夹一圈即可。   一个既能当烛台又能当花盆的小物品就完成了! 

经验教程

699

收藏

39
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部