转载:OGRE一起学(十三) 旧版本 addons 的编译小技巧

第十三章 旧版本 addons 的编译小技巧

OGRE 的功能扩展插件拥有两种待遇:

一种是 PlugIns ,放在 cvshome\ogrenew\PlugIns 目录下。只有功能已经比较成熟、性能比较稳定的插件才能被放进这个目录,作为 OGRE 的一部分有 OGRE Team 共同维护、更新和提供支持。 
一种是 AddOns ,放在 cvshome\ogreaddons 目录下。一些尚不成熟、尚不稳定的外部插件都放在这里, 由插件作者本人负责维护更新, OGRE Team 不提供技术支持,可以说 ogreaddons 目录就是一个处于边缘地带的“外城”,这里的很多插件,虽然可能很有用,但是没有可靠保障,有很多已经好久不更新了。

因为好久不更新,在 OGRE 版本升级尤其是升级到现在的 0.15 之后,现在再编译这些插件代码可能会非常吃力,因为版本不兼容会导致出现很多编译错误。但是,解决编译错误也是有一些经验之谈的,下面的几条是在 OGRE 官方论坛翻出来的,用它来编译 0.15 之前的旧版 AddOns 很有用。

(1) 与 Ogre::String 相关的错误的纠正 
如果错误信息是: 
* 不能将参数 2 从“Ogre::String”转换为“const char *” 
* 无法从“const Ogre::String”转换为“CStr” 
* 不能将参数 2 从“Ogre::String”转换为“LPCSTR” 
可以在有问题的 Ogre::String 参数后面加上一个 ".c_str()" 把它转换为 cstring 。 
例如:

SetCurrentDirectory(appPath.c_str()); // OK.

(2) 与 Ogre::Radian 相关的错误的纠正 
如果错误信息是: 
* 不能将参数 1 从“float”转换为“const Ogre::Radian &” 
* 不能将参数 2 从“Ogre::Real”转换为“const Ogre::Radian &” 
可以使用 Ogre::Angle() 对有问题的参数进行强制类型转换。 
例如:

pLight->setSpotlightRange(inner, outer, falloff); 
// OK. 
pLight->setSpotlightRange(Ogre::Angle(inner), Ogre::Angle(outer), falloff);

posted @ 2009-06-08 13:21  回忆1919  阅读(653)  评论(0编辑  收藏  举报