wxWidgets第十五课 wxBitmap图片显示

简介:

说明

    显示一张图片,非常容易


例子

  wxImage image(wxT("C:/timg.bmp"), wxBITMAP_TYPE_BMP);

wxBitmap bitmap(image);

  wxBufferedPaintDC dc(this);

dc.DrawBitmap(bitmap, 0, 0, true);


问题

    尝试调用Create函数指定图片的原始数据,当前使用bmp位图为例子,bmp的偏移54个字节之后是调色板,但是当前使用24色


位图,所以没有调色板,后面直接是图片数据,生辰位图出错,记录如下:

FILE * fileFd;

long fileLen;


fileFd = fopen ("C:/timg.bmp","rb");

if (fileFd==NULL)

{

return ;

}

else

{

fseek (fileFd, 0, SEEK_END);  

fileLen=ftell (fileFd); 

}

char* pRawData = (char*)malloc(fileLen-54);

fseek (fileFd, 54, SEEK_SET);

fputs(pRawData, fileFd);   

fclose(fileFd);

wxBitmap bitmap;

bitmap.Create(pRawData, wxBITMAP_TYPE_BMP, 1024, 626);

wxBufferedPaintDC dc(this);

dc.DrawBitmap(bitmap, 0, 0, true);



说明

使用AGG渲染,存在一块渲染缓存区域,实际上就是一块内存区域保存每一个像素的RGBA数据。在已有的章节中,可以使用Win32 API,但是从整一个过程可以看到,过程比较繁琐,并且会导致已有的wxClientDC等不能使用DrawText函数的问题。如果wxBitmap能够绑定一块渲染缓存,或许能够完美的解决该问题


测试结果

实际上,调用wxBitmap的Create函数返回值永远是false,并且跟踪源代码bitmap.cpp发现,通过调用基类wxBitmapHandler的派生类Create函数来实现,但是派生类的的具体实现只有一句话:return false; 说明实现的并不完整,因此下面的测试代码不能实现基本功能


测试代码

char* pData = (char*)malloc(width*height*4);

memset(pData, 0xff, width*height*4);


wxBitmap bitmap;

bool ret = bitmap.Create(pData, wxBITMAP_TYPE_BMP_RESOURCE, width, height, 1);//wxBITMAP_TYPE_BMP

m_rbuf.attach((unsigned char*)pData, width, height, -width*4); // Use negative stride in order

m_pixf.attach(m_rbuf);

m_renb.attach(m_pixf);

m_ren.attach(m_renb);


m_renb.clear(agg::rgba8(0, 0, 0, 255));


m_ras.move_to_d(100, 34.15);

m_ras.line_to_d(398.23, 123.43);

m_ras.line_to_d(165.45, 401.87);


// Setting the attrribute (color) & Rendering

m_ren.color(agg::rgba8(80, 90, 60));

agg::render_scanlines(m_ras, m_sl, m_ren);


wxMemoryDC memDC;

memDC.SelectObject(bitmap);

memDC.SetPen(*wxRED_PEN);

memDC.DrawRectangle((wxRect(10, 10, 100, 100)));

wxBufferedPaintDC destDC(this);

 destDC.SetBackground(*wxWHITE_BRUSH);

 destDC.Clear();

destDC.Blit(0, 0,

bitmap.GetWidth(), bitmap.GetHeight(),

&memDC,

0, 0,

wxCOPY,

true);

memDC.SelectObject(wxNullBitmap);

return;




     本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/1955426,如需转载请自行联系原作者



相关文章
|
9月前
六、如何优雅地在PPT中使用课本插图?(附源文件) | 微课系列教程
上图,相信大家都不陌生吧!没错,《少年闰土》中的经典插图——看瓜刺猹。但这个图,不但没有高清版,就算有高清版,它的复古画风,不管如何都不好在PPT中排版啊。
362 0
|
5月前
|
图形学
【Unity 3D】3D游戏跑酷小子实战教学(附源码和步骤 超详细)
【Unity 3D】3D游戏跑酷小子实战教学(附源码和步骤 超详细)
187 0
|
5月前
|
C# 图形学
【Unity】2D游戏-愤怒的小鸟教学实战(附源码和实现步骤 超详细)
【Unity】2D游戏-愤怒的小鸟教学实战(附源码和实现步骤 超详细)
181 1
|
5月前
|
C# 图形学
Unity的几个入门小常识
Unity的几个入门小常识
|
10月前
|
前端开发
前端代码分享——霓虹灯图标菜单特效(内含源码)
前端代码分享——霓虹灯图标菜单特效(内含源码)
|
11月前
|
存储 Java API
一个精美的主界面窗口功能的设计和实现原来如此简单,万字肝爆
一个精美的主界面窗口功能的设计和实现原来如此简单,万字肝爆
72 0
|
12月前
游戏开发零基础入门教程(5):不要挡住我,我要去上面
这一节我们学习了层级管理,以及通过使用拖拽的方式来调整层级的顺序。 在真实的游戏中可能会包含很多的层级,在调整层级时,不要忘记口诀:谁挡住了我,我就去谁的上面。 试着在游戏中加入更多的层级,拖拽调整层级的顺序,然后观察编辑区中的图片显示效果。
126 0
|
Java API 图形学
Java实现拼图小游戏(5)—— 美化界面(含源码阅读)
先加载的图片在上方,后加载的图片在下方,所以我们要把创建背景图的代码放在我们之前创建十五个小图片的代码后面,否则会出现背景图片将我们要拼的图片覆盖的情况
345 0
Java实现拼图小游戏(5)—— 美化界面(含源码阅读)
面向小白!在Unity中实现最简单的人物移动脚本
网上关于角色移动的文章太多太多了,就我自己整理的时候都发现写了好多篇(因为有不同的方案),今天就将目前已知的移动角色的方案总结出来,毕竟是一个资源整合的时代,谁也不想找个角色移动的脚本都要找好几篇文章对吧 目前可以划分为三个方面 • 角色移动到鼠标点击的位置 • 键盘控制角色移动(其他的比如游戏手柄也算键盘、HTC手柄 也算键盘) • 手机端转盘控制角色移动 其他的比如摄像机跟随移动这个可以作为拓展
|
C# 图形学
边学边做的第一个Unity小游戏
学Unity开发,肯定先要了解小Unity这个开发工具长什么样。 第一次看到Unity界面的时候,我第一反应是,我靠,这不是犀牛么。学工业设计的人应该接触过犀牛这款3D建模软件,主界面也是一个3D透视界面。
1496 0