首先感谢李素颙同学的热心和耐心指导。
做游戏或者计算机图形程序,GUI是重要的一个环节,假如你的时间足够多的话,或许你可以自己写一个符合自己的GUI系统,但是假如你想要使用现成的GUI系统并且还要有很多不错的功能的话,CEGUI是个不错的选择的。
尽管CEGUI有着各种各样的让人无法忽视的弊病,但是最重要的是:这是免费的,而且有一个不错的编辑器CElayoutEdtior,尽管这个编辑器时常崩溃和各种各样的错误让人挠头.
免费的GUI系统或许还有其他选择,比如MyGUI,BetaGUI等等,但是CEGUI却是相对比较出色的一个.
如何得到CEGUI?请前来这里下载:
你可以在这里下载SDK和原始码,同时还有CEGUI的各种各样的皮肤,以及那个著名的编辑器CELayoutEdtior.
不幸的是,似乎身处中国大陆我并不能打开CEGUI的Skin皮肤页面,当我FQ之后却打开一切正常,难道是被GFW屏蔽了么?对此感到无语。
假如现在你仍然不知道GFW是什么,那么或许有两种可能:一,你没有生活在中国大陆。二,你还没具有一个大陆网民的基本素质。
本文档的目的:在于让你快速的熟悉CEGUI的基本使用,同时可以让一个对CEGUI完全不熟悉的人在很短的时间内就能自行的创建一个简单的内容,假如你已经对CEGUI有着基本的熟悉,那么本文档已经不再适合你了。
本文档采用CEGUI SDK 0.7.1,里面的部分内容已经不再和老版本的CEGUI SDK0.6.2相兼容,请升级SDK到最新版本.
下面让我们进入正题。
二、环境配置你使用什么开发环境,就得下载符合这个开发环境的SDK,我下载的是CEGUI 0.7.1 Binary Downloads for Microsoft Visual C++ 2008。
注意,这份文档教授的是快速上手CEGUI,因此已经略去了如何教你下载SDK的原始码自行编译的部分,直接下载以及编译好的SDK,这样会省事很多,当然,假如你想要更多了解,你可以尝试下载原始码,自行编译一下.
下载完成解压到任何目录,将CEGUI-SDK-0.7.1-vc9目录,CEGUI-SDK-0.7.1-vc9\RendererModules和CEGUI-SDK-0.7.1-vc9\dependencies\include还有CEGUI-SDK-0.7.1-vc9\cegui\include目录一起加入VisualStudio 的Include包含路径。
同时还要把CEGUI-SDK-0.7.1-vc9\dependencies\lib\dynamic,CEGUI-SDK-0.7.1-vc9\dependencies\lib\static和CEGUI-SDK-0.7.1-vc9\lib加入VisualStudio 的Lib包含目录,这样就完成了CEGUI开发环境的配置.
三、 开始前的一点准备渲染环境是基于OpenGL制作的GLUT,GLUT 也是一个非常快速的搭建OpenGL环境的东西,能够让你避免还得自己去处理Windows消息循环,等等一大堆烦人的东西,并且,GLUT是开源而且跨平台的。
当然,CEGUI是支持DirectX和OGRE引擎渲染模式的,这里我们采用了OpenGL渲染模式.
下面让我们开始最快速的部分,当然首先你得包含头档和Lib档。
请为了避免缺少头档包含而出的错误,建议直接把这些全部写上去吧:
#include <dependencies\include\GL\freeglut.h>
#include <CEGUI.h>
#include <CEGUIWindowRenderer.h>
#include <CEGUIResourceProvider.h>
#include <CEGUIDefaultResourceProvider.h>
#include <RendererModules\OpenGL\CEGUIOpenGL.h>
#include <RendererModules\OpenGL\CEGUIOpenGLRenderer.h>
#include <XMLParserModules\XercesParser\CEGUIXercesParser.h>
#include <CEGUIXMLParser.h>
#include <CEGUISystem.h>
#include <CEGUIInputEvent.h>
#include <CEGUIWindow.h>
#include <CEGUIWindowManager.h>
#include <CEGUISchemeManager.h>
#include <CEGUIFontManager.h>
#include <elements/CEGUIFrameWindow.h>
同时你得包含Lib文件:
#pragma comment(lib, "CEGUIBase_d.lib")
#pragma comment(lib, "CEGUIOpenGLRenderer_d.lib")
#pragma comment(lib, "CEGUIXercesParser_d.lib")
“_d”表示这是Debug模式,假如你想Release了,那么就包含没有”_d”的.
同时可以这样:using namespaceCEGUI;
四、 开始动手吧,不过之前得有一点小准备
下面我们开始实际的编码了,首先得初始化CEGUI,创建一个渲染对象。
CEGUI::OpenGLRenderer *myRenderer;
这句话是声明一个OpenGL的渲染对象,也只能有这一个对象。
接着你得创建OpenGL渲染环境:
myRenderer = &CEGUI::OpenGLRenderer::create();
CEGUI::System::create(*myRenderer);
OK,现在我们创建好了基本的渲染环境,注意,创建的这部分代码仅仅适用于CEGUI SDK 0.7.1版本,并不适用于CEGUI SDK 0.6.2.
一个GUI系统,得需要有资源,比如脚本,用编辑器做好的菜单文件,图片以及字体什么的,所以下一步你得设置这些GUI资源的目录。
所以接着你得写如下代码用来设置资源:目录
CEGUI::DefaultResourceProvider*rp = static_cast<CEGUI::DefaultResourceProvider*>(CEGUI::System::getSingleton().getResourceProvider());rp->setResourceGroupDirectory("schemes", "datafiles/schemes/"); rp->setResourceGroupDirectory("imagesets","datafiles/imagesets/"); rp->setResourceGroupDirectory("fonts", "datafiles/fonts/"); rp->setResourceGroupDirectory("layouts", "datafiles/layouts/"); rp->setResourceGroupDirectory("looknfeels","datafiles/looknfeel/"); rp->setResourceGroupDirectory("lua_scripts","datafiles/lua_scripts/");
// 使用Xerces作为XML解析器 rp->setResourceGroupDirectory("schemas","http://www.cnblogs.com/XMLRefSchema/");
CEGUI基于强大的设计思想,只要少量的修改或扩充,几乎可以实现现存国内外任何一款3D网游的界面。
这是一张大图:主要实现的功能有:
1基础控件2具有wow外观的的Frame窗口3拖曳控件4拖曳控件的buffer显示,其实是饼图的pregress,及buffer完成后的高亮闪烁5血量不足时的心跳效果6根据不同网速显示的设置按钮7wow效果的拖曳控件8吟唱技能条9高光效果9聊天向下指示箭头的闪烁11小地图12任务面板13目标的目标14wow效果的聊天界面15快键栏wow的技能吟唱条实现技能条上的亮条通过高光贴图实现,加载完成后的高亮贴图也是高光贴图,最后通过改变alpha值实现淡入淡出。=================本地化支持:OGRE+CEGUI中文输入:OGRE方面的问题
本文原文发表在,
代码还没有上传上去,全文也没有写完,先转载过来一章,供大家拍砖。本地化支持:OGRE+CEGUI中文输入:OGRE方面的问题From OGRE 3D 中文网Jump to: navigation, search其实从许久以前的版本开始,CEGUI基本上已经成为官方制定的GUI系统,并在OGRE的演示程序中使用(能得到同等待遇的似乎只有ODE物理引擎)。 而中文输入这种关联与GUI的事件,已经基本上和OGRE引擎没有多少关系了。但是这里仍然有几件事情需要我们注意。 从CEGUI版本0.4.x 迁移到版本0.5.x OGRE 引擎对CEGUI的支持是通过一个叫做OgreGUIRenderer.dll的插件来完成的,你可以在OGRE提供的SDK中找到这个文件。不过到目前为止,官方之提供了对0.4.0版本CEGUI的支持。似乎为了保持版本的稳定性,目前还看不出来OGRE官方对这个插件的升级计划。 0.4.0也是一个不错的CEGUI版本(我没有用过,纯属瞎说),但是对于中文支持有一个致命的弱点,那就是不支持分页对文字的读取。中文常用汉字就有上千个,再分为不同的字体,对内存的占用量是无法接受的。CEGUI版本0.5.0已经解决了这个问题。 这时候就需要我们继承革命前辈“自己动手丰衣足食”的优良传统了。根据OGRE官方论坛提供的方法,我们对OgreGUIRenderer.dll插件进行一次手术。让其适配CEGUI版本0.5.x。 首先需要下载OGRE引擎的源代码和相应的依赖包,我这里使用的平台是WindowsXP+Visual Studio2005(VC8.0)。 解压完源代码并配置好依赖项目,你会看到OgreCEGUIRenderer项目(ogrenew\Samples\Common\CEGUIRenderer),然后进行如下修改: 文件OgreCEGUITexture.h,第109行, virtual void loadFromMemory(const void* buffPtr, uint buffWidth, uint buffHeight);改为 virtual void loadFromMemory(const void* buffPtr, uint buffWidth, uint buffHeight, PixelFormat pixelFormat = CEGUI::Texture::PF_RGBA);文件OgreCEGUITexture.cpp,第144行, void OgreCEGUITexture::loadFromMemory(const void* buffPtr, uint buffWidth, uint buffHeight)改为 void OgreCEGUITexture::loadFromMemory(const void* buffPtr, uint buffWidth, uint buffHeight, PixelFormat pixelFormat)相同文件,第167行 d_ogre_texture = TextureManager::getSingleton().loadRawData(getUniqueName(), "General", odc, buffWidth, buffHeight, PF_A8R8G8B8, TEX_TYPE_2D, 0, 1.0f);改为 d_ogre_texture = TextureManager::getSingleton().loadRawData(getUniqueName(), "General", odc, buffWidth, buffHeight, pixelFormat == CEGUI::Texture::PF_RGB ? PF_R8G8B8:PF_A8R8G8B8, TEX_TYPE_2D, 0, 1.0f);然后去CEGUI网站上下载最新0.5.x版本的CEGUI库,覆盖OGRE相应的CEGUI依赖文件(包括头文件以及lib、dll文件)。编译生成新的OgreGUIRenderer.dll,如果你觉得这个过程很麻烦,那么可以到这里下载。 后遗症是因为CEGUI版本接口的变动,之前OGRE所提供的Demo中使用CEGUI部分会无法编译通过。 得到Win32系统消息 我们这里有两种得到Win32系统消息的办法,一种是好的,一种是简单的。请根据实际情况选择相应的方法: 好的方法 OGRE 3D是一个跨平台的引擎,所以平台相关的操作自然要封装在具体的实现里面。这样就等于说,用户在使用中无法了解具体的平台相关信息。对于跨平台的设计来说这样做是合理的,但是对于一些需要得到系统消息的项目来说,就有一些特殊需要了。 OGRE 项目并不是没有顾全到这种情况,因此提供了两种不同的创建窗口办法,简单的方法是Demo中所使用的,委托OGRE创建并维护窗口。另外一种方法是手动创建窗口,之后交给OGRE引擎用来渲染,并手动维护。手动维护窗口虽然比较麻烦,但是这样可以更自由的控制窗口,换句话说可以简单得得到任何窗口信息,包括消息。 创建窗口不是一个困难的过程,但是却是麻烦。在这里交给读者作为作业来做吧(我还没抽出时间来实现呢)。然后通过下面的方法来初始化渲染窗口: //假设之前已经执行完创建窗口以及Ogre::Root对象的过程//hWnd为窗口句柄,root为Ogre::Root类型实例Ogre::NamevaluePairList params;//构造参数std::stringstream ss;ss<<hWnd;//窗口句柄params["externalWindowHandle"] = ss.str();//把窗口句柄做为字符串形势设置到参数中root->initialise(false);//Ogre::Root对象初始化参数为false,表示手动创建渲染窗口//下面创建渲染窗口Ogre::RenderWindow * window = _root->createRenderWindow("name", //名称 width,//宽度 height, //高度 false, //是否全屏显示 ¶ms);这样就能把手动创建的窗口交给Ogre进行渲染操作,代价是你作为窗口的拥有者应该管理窗口的一切行为。这是一个正规的方法,任何真正的项目都应该遵守尽量不要破坏库的封装。 简单的方法 也可以称作懒人的方法,或者免费打工仔偷懒的方法。极力不推荐,但这里的演示却是用它。我知道这有一些矛盾,但作为只是想要测试中文输入功能的工作来说,还勉强算说得过去。 这种方法就是破坏OGRE引擎的封装,通过直接修改OGRE源代码来得到已经被封装好的Win32窗口消息。我不会在这做太多地介绍,因为你马上会看到相应的源代码,没有什么难度,只要覆盖OGRE工程中相应的文件就可以了。