转载: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);