当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 动态真彩工具栏

VC++
如何实现24位色工具条
如何定制浮动工具条
如何实现工具栏的下拉箭头按钮
Outlook式样界面菜单和页面控制
如何在状态栏中实现进度指示器控制
Outlook风格的单列使用不同的颜色显示新邮件数
为CListBox加上智能水平滚动条
如何实现类似VC属性表中的钉子按钮
在窗体中加入3D Bar
通过程序向RichEditView写文本
如何在工具栏上添加平面下拉控件
按数据库记录构建树控件
树控件的双击响应
VC++中轻松实现滑动控件
深入浅出 CPropertySheet
如何在ListBox中选择背景位图
在对话框中加入属性页
如何在EDITBOX控件中使用背景位图
如何在树型控件中使用背景位图
树型控件拖动的完美实现

VC++ 中的 动态真彩工具栏


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

动态真彩工具栏
作者:王健

下载本文配套源代码

源代码执行效果图如下:


与VCKBASE接触良久,从来都是贪婪的从中掘取好用的东东,却没想过把自己的东西拿出来与人共享,很不好意思。
自从我的RangerChat点对点聊天工具在VCKBASE上发表以来收到众多朋友的来信。他们很多人都说一次性看这么多代码,还真不知如何从中提取自己想要的东西。现在奉上我做项目过程中的一些好的资源片段供大家评判。以后我会不间断的提供一些好的代码和大家分享。谢谢大家。
第一个:一个拥有动态真彩图标的工具栏,相信可以为大家的应用程序增色不少。

Step1:建一个单文档/多文档框架
Step2:在框架类CMainFrame中添加如下变量

CReBar m_wndReBar

Step3:添加BOOL型成员函数CreateExToolBar()
BOOL CMainFrame::CreateExToolBar(){	CImageList img;	CString str;	if(!m_wndReBar.Create(this))	{	return -1;	}	if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP	| CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC))	{	return -1;	}	//下面的代码是设置按钮的宽度和长度	m_wndToolBar.GetToolBarCtrl().SetButtonWidth(40, 80);	//下面的代码是设置"热"的位图	img.Create(22, 22, ILC_COLOR8|ILC_MASK,2,2);	img.SetBkColor(::GetSysColor(COLOR_BTNFACE));	img.Add(AfxGetApp()->LoadIcon(IDI_ICON_MSG_GETBUTTON));//0收信	.............	//省略其它按钮设置的代码,详见本文提供的源代码	m_wndToolBar.GetToolBarCtrl().SetHotImageList(&img);	img.Detach();	//下面的代码是设置"冷"的位图	img.Create(19, 19, ILC_COLOR8|ILC_MASK, 2,2);	img.SetBkColor(::GetSysColor(COLOR_BTNFACE));	img.Add(AfxGetApp()->LoadIcon(IDI_ICON_MSG_GETBUTTON));//0收信	img.Add(AfxGetApp()->LoadIcon(IDI_ICON_MSG_WRITEMSGBTN));//1写信	.............	//省略其它按钮设置的代码,详见本文提供的源代码	m_wndToolBar.GetToolBarCtrl().SetImageList(&img);	img.Detach();	//改变属性	m_wndToolBar.ModifyStyle(0, TBSTYLE_FLAT |CBRS_TOOLTIPS | TBSTYLE_TRANSPARENT|TBBS_CHECKBOX );	m_wndToolBar.SetButtons(NULL,21);	// set up each toolbar button设置文字	m_wndToolBar.SetButtonInfo(0, IDC_WRITEMSG, TBSTYLE_BUTTON, 1);	m_wndToolBar.SetButtonText(0, "写信");	............ //省略其它按钮设置的代码,详见本文提供的源代码	CRect rectToolBar;	//得到按钮的大小	m_wndToolBar.GetItemRect(0, &rectToolBar);	//设置按钮的大小	m_wndToolBar.SetSizes(rectToolBar.Size(), CSize(20,20));	//在Rebar中加入ToolBar	m_wndReBar.AddBar(&m_wndToolBar);	//改变一些属性	REBARBANDINFO rbbi;	rbbi.cbSize = sizeof(rbbi);	//这个是必须填	rbbi.fMask = RBBIM_CHILDSIZE | RBBIM_IDEALSIZE | RBBIM_SIZE|RBBIM_BACKGROUND;	//工具条的宽度	rbbi.cxMinChild = rectToolBar.Width();	//高度	rbbi.cyMinChild = rectToolBar.Height();	//下面这行代码是为工具条加入背景位图,请注意上rbbi.fMask中RBBIM_BACKGROUND标志	rbbi.hbmBack = LoadBitmap(::AfxGetInstanceHandle(), MAKEINTRESOURCE(IDB_TOOLBARBKMAP));	rbbi.cx = rbbi.cxIdeal = rectToolBar.Width() * 10;	m_wndReBar.GetReBarCtrl().SetBandInfo(0, &rbbi);	return TRUE;}
Step4:打开OnCreate()成员函数添加如下代码
//创建扩展工具栏
If (!this->CreateExToolBar()) return -1;

并把原先关于ToolBar的一切操作(创建、浮动)删除。
至此真彩动态工具栏已创建成功!

下面做一些说明:
No1: 工具栏中的每个按钮都要自已手动创建(见源码)
No2: 每个按钮的ID和消息处理要手动添加(在此不详述过程)
OK了,大家还不快试试。