当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 让工具条显示256色图像

VC++
面试题目:猫吃老鼠问题的求解
一个最基本的有限元计算程序
简单的表达式求值
C程序移植到VC开发环境下
一个小语言的词法分析程序
A/B 向上取整的方法
马走日棋盘算法
一种随机抽题的简单算法
clone模式在平衡排序二叉树实现中的应用
递归的应用 -- 最简单分形图形实现
比较数据排序前后的查找次数
根据前序和中序序列生成二叉树
如何用CZip/CUnzip类压缩/解压缩文件
使用 random_shuffle() 算法随机化序列元素
Ceb解除打印屏蔽实战
基于SHA-256的HMAC文件校验器
模拟信息加密流程图简介
关于数据校验
浅谈利用RSA算法防止非法注册机的制作
加密它:用新的高级加密标准(AES)保持你的数据安全

VC++ 中的 让工具条显示256色图像


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


如何让工具条显示256色图像
编译:hangwire

下载范例源代码

问题:
   论坛中有很多人提出:基于Windows的程序如资源管理器(Explorer.exe),IE等都能显示出漂亮的工具栏图像和图标。但是,用MFC开发的应用程序一般都只能显示16色的工具栏图像和列表视图(如CListView)图像,而无法显示在资源中创建的256色图标和位图。这是为什么?
解答:
   工具栏和列表视图都是把自己的图像存储在图像列表中。这个图像列表实际上就是一个图像清单。它是一个由许多小图像组成的长条型位图图像。如图一所示:
      图一
假设你有7个20x20的图标,则在图像清单中会将它们保存为一个140x20的位图(7x20=140)。你可以根据需要来调整这个位图的颜色特性;但是必须在创建图像清单时指出要使用多少种颜色。在缺省情况下是16色。另外,当MFC加载工具栏位图时使用的一个内部函数,AfxLoadSysColorBitmap,也假设颜色为16色。所以用MFC编程时,为了显示256色图像,你必须要对图像清单进行处理。
我编写了DEMO程序TBColor来说明如何在工具栏中显示256色图像,这个程序是一个极其典型的MFC程序——它有一个漂亮的工具栏。如图二所示:
图二
按下工具栏的每一个按钮都弹出“关于”对话框。具体处理细节全都在CMainFrame::OnCreate函数中实现:
MainFrm.cpp ////////////////////////////////////////////////////////////////// Set tabsize = 3 in your editor.//#include "StdAfx.h"#include "MainFrm.h"#include "Resource.h"BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd) ON_WM_CREATE()END_MESSAGE_MAP()static UINT indicators[] = { ID_SEPARATOR, // status line indicator ID_INDICATOR_CAPS, ID_INDICATOR_NUM, ID_INDICATOR_SCRL,};CMainFrame::CMainFrame(){}CMainFrame::~CMainFrame(){}BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs){ cs.style |= WS_CLIPCHILDREN; return CFrameWnd::PreCreateWindow(cs);}int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct){ VERIFY(CFrameWnd::OnCreate(lpCreateStruct)==0); //创建并加载工具栏 // VERIFY(m_wndToolBar.Create(this)); VERIFY(m_wndToolBar.LoadToolBar(IDR_MAINFRAME)); // 加载工具栏位图 - 必须使用::LoadImage映射颜色 // 将(192,192,192) 映射到 COLOR_3DFACE. // HBITMAP hbm = (HBITMAP)::LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAINFRAME), IMAGE_BITMAP, 0,0, // cx,cy LR_CREATEDIBSECTION | LR_LOADMAP3DCOLORS ); CBitmap bm; bm.Attach