MFC bmp彩色工具栏

来源:互联网 发布:巨人网络新出的游戏 编辑:程序博客网 时间:2024/05/02 02:55

------------------------------------------------------------------------------------------------------------------------------------

本文转自:http://www.cnblogs.com/shiney/archive/2012/01/03/2311137.html

------------------------------------------------------------------------------------------------------------------------------------

 

1.bmp基本概念

 (1)色位

  色位即色彩位数,指每个像素点上颜色的数据位数(bit),有色彩深度、色彩精度等等多种称法,以24位为例,表示R.G.B每原色用8位二进制数据表示,最多可表达256级浓淡,从而可以再现256x256x256=16777216种颜色。色彩数越多,图像就越生动艳丽。

 (2)图片大小

  位图图片大小和像素有关。像素:图片上的1个点就是1个像素。

 (3)分辨率

  分辨率通常是指1英寸长度上的像素(点)数,表示一张图片上像素之间排列的疏密程度。

2.MFC工具栏控件

 创建工具栏步骤:

 (1)在Resource View中插入新toolbar

 (2)在toolbar上双击增加按钮,更改ID为ID_BUTTON,编译后在resource.h中即可看到

          #define    ID_BUTTON1   32771

 (3)在框架类中添加保护的成员变量 CToolBar    m_MyToolBar;

 (4)在框架类的OnCreate中用CreateEx创建工具栏控件(设置属性),加载工具栏资源

   代码如下:

复制代码
  if (!m_MyToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_LEFT        | CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||        !m_MyToolBar.LoadToolBar(IDR_TOOLBAR1))    {        TRACE0("Failed to create toolbar\n");        return -1;      // fail to create    }    m_MyToolBar.EnableDocking(CBRS_ALIGN_ANY);    EnableDocking(CBRS_ALIGN_ANY);    DockControlBar(&m_MyToolBar);
复制代码

 (5)为工具栏按钮添加消息响应函数,否则按钮为灰色

  在框架类Add Window Message Handle, 选择ID_BUTTON,添加消息响应。

  具体添加的代码为:1.框架类的声明中afx_msg void OnButton1();

           2.框架类的源文件中ON_COMMAND(ID_BUTTON1, OnButton1)

           3.框架类的源文件中消息响应函数的实现void CMainFrame::OnButton1() {}

    效果图如下:

 

3.bmp工具栏(开始步骤同上略去)

 (1)在Resource View中添加bitmap (在此之前先用画图工具将bitmap调整至合适大小,如48*48),同样编译后可在

    resource.h中观察到#define   IDB_BITMAP1    132

 (2)在框架类中添加成员变量CImageList  m_imagelist;

 (3)初始化imagelist并将它与CImageList对象联系起来

m_imagelist.Create(48,48,ILC_COLOR32|ILC_MASK,0,0);

   ILC_MASK的作用是将背景色透明。

 (4)加载位图资源并且添加进图像列表imagelist(注意要用deleteObject释放之前加载的资源)

复制代码
    CBitmap bmp;    for(int i=0;i<3;++i)    {        bmp.LoadBitmap(IDB_BITMAP1+i);        m_imagelist.Add(&bmp,RGB(255,255,255));        bmp.DeleteObject();    }
复制代码

 (5)构建一个ToolBar 按钮ID的数组

    UINT nArray[3];    for(int k=0;k<3;++i)    {        nArray[k]=ID_BUTTON1+i;    }

 (6)设置工具栏按钮的ID,按钮与位图的大小

    m_MyToolBar.SetButtons(nArray,3);    m_MyToolBar.SetSizes(CSize(55,55),CSize(48,48));

 (7)设置图像

m_MyToolBar.GetToolBarCtrl().SetImageList(&m_imagelist);

  效果图如下:

4.为工具栏按钮添加鼠标停留提示信息

 (1)在创建工具栏加上一句代码:m_MyToolBar.EnableToolTips();

 (2)在框架类增加一个成员变量 CString str;

 (3)在框架类Message Map中加入 ON_NOTIFY_EX(TTN_NEEDTEXT,0,OnToolBarTips)

 (4)在框架类添加函数BOOL OnToolBarTips(UINT id, NMHDR * pTTTStruct, LRESULT * pResult);

   包括头文件中的函数声明和源文件的函数实现。该响应函数的实现如下

复制代码
BOOL CMainFrame::OnToolBarTips( UINT id, NMHDR * pNMHDR, LRESULT * pResult ){    TOOLTIPTEXT *pTTT = (TOOLTIPTEXT *)pNMHDR;    UINT nID =pNMHDR->idFrom;    UINT nIndex=m_MyToolBar.CommandToIndex(nID);    switch(nIndex)    {    case 0:        str.Format("连接仪器");        break;    case 1:        str.Format("新建任务");        break;    default:        break;    }    pTTT->lpszText=str.GetBuffer(str.GetLength());    pTTT->hinst=AfxGetResourceHandle();    return TRUE;}
复制代码

效果图如下:

 5. 单击工具栏按钮后改变图片

  采用了笨办法,设置了两个imagelist.

  效果图如下: