《天龙八部3D》中Unity使用介绍
发表于2015-07-14
摘要:很多端游进入手游市场都在榜单上大获成功,但如果仅仅照搬端游的玩法可能会遇到很多风险。《天龙八部3D》制作人佟庆和主程王华分享了在使用unity引擎制作《天龙八部3D》游戏的过程中遇到的一些经验和教训。
在过去一年里,很多端游进入手游市场在榜单上大获成功,但考虑到性能及用户属性等,如果仅仅照搬端游的玩法,在开发过程中可能会遇到很多风险。《天龙八部3D》是搜狐畅游自主研发的一款游戏,它是3D的MMO系统,在去年10月进行公测及上线之后,得到了很多玩家的认可,取得了不错的成绩。所以,今天我想来分享一下在使用Unity引擎制作《天龙八部3D》游戏的过程中遇到的一些经验和教训。
《天龙八部3D》技术方案揭秘首先,我先简单介绍一下《天龙八部3D》项目的基本情况。《天龙八部3D》在公测之初的24小时便获得了1257万的流水,首日导入大概110万的用户,在内地以及台湾、香港的iOS付费及免费榜均取得过TOP1的成绩,在iPhone畅销榜的最高排名是TOP3。正式上线之后的首月流水是2.3亿,从“凌波微步”、“武林大会”到最近的“丐世英雄”,《天龙八部3D》推出的资料片流水均高于公测时,这个事例可以体现MMOARPG的生命力还是比较顽强的。
在技术层面上,结合服务器端和客户端的整体考量,《天龙八部3D》主要运用了以下几种技术方案:
而在客户端,则有稳定的帧率和顺畅的操作感,里面带有高效的动态资源管理策略,可以保证客户端的内存方面不会出现特别大的问题,导致客户端闪退等。此外,还有成熟的性能优化解决方案,其实在去年刚起步时我们还是一头雾水,但经过一年多的努力和学习,我们基本上已经学会了一套在客户端上性能优化的完整解决方案。
从端游到手游,如何打造惊艳的移动端画面表现?手游和端游不同,做移动端游戏,面数是一个很大的问题,手游上面数较少,而《天龙八部3D》则将游戏资源与美术相结合,从定制化的场景到人物材质都是一种3D的表现,这样可以保证美术资源在面数较少的情况下,也能达到漂亮、惊艳的效果,如图1所示。

项目最初一个月,我们都在探索着尝试各种美术风格定位,后来开始着手研究Unity引擎开发,在2013年12月底,我们使用Unity做了一个Demo,基本上代表了之后的美术方向和整个玩法的基本雏形。
经过从α、β到Golden版本的优化演进,《天龙八部3D》从初具雏形到公测、正式上线,在此过程中真正运用了哪些Unity技术?
《天龙八部3D》中常用的释放点有两个,分别为转场景时释放一些非全局资源、每次打开界面一秒后进行一次主动调用GC的操作。这是我们权衡了很久的做法,但实际效果还很不错。当时我们为了兼容低端机型运用了缓存池的功能,在512MB设备上运行会变卡,而且还无法控制,最终我们在打开操作界面时执行缓存池,尽管实际出现卡顿但玩家却不会有感觉,这属于是一种比较取巧的方式。
值得开发者们注意的是,在将所有东西打包成AssetBundle时,需划分出依赖关系,单个界面的AssetBundle最好不要超过1M,单个模型骨骼数不超过32个,角色和NPC控制在2000面以下。
最后,再来说一下《天龙八部3D》游戏中使用到的优化方案。
按照C++的思想来管理内存,比如使用内存池、对象池、手动卸载、主动GC等,能够在内存和帧率之间做好平衡。另外,规划好美术资源的重复利用也相当重要,它能够减少包的大小,比如NPC变色多场景可共用,制备、水等很多场景的美术资源制作也可重复利用。
佟庆 《天龙八部3D》制作人;王华 《天龙八部3D》主程
在过去一年里,很多端游进入手游市场在榜单上大获成功,但考虑到性能及用户属性等,如果仅仅照搬端游的玩法,在开发过程中可能会遇到很多风险。《天龙八部3D》是搜狐畅游自主研发的一款游戏,它是3D的MMO系统,在去年10月进行公测及上线之后,得到了很多玩家的认可,取得了不错的成绩。所以,今天我想来分享一下在使用Unity引擎制作《天龙八部3D》游戏的过程中遇到的一些经验和教训。
《天龙八部3D》技术方案揭秘首先,我先简单介绍一下《天龙八部3D》项目的基本情况。《天龙八部3D》在公测之初的24小时便获得了1257万的流水,首日导入大概110万的用户,在内地以及台湾、香港的iOS付费及免费榜均取得过TOP1的成绩,在iPhone畅销榜的最高排名是TOP3。正式上线之后的首月流水是2.3亿,从“凌波微步”、“武林大会”到最近的“丐世英雄”,《天龙八部3D》推出的资料片流水均高于公测时,这个事例可以体现MMOARPG的生命力还是比较顽强的。
在技术层面上,结合服务器端和客户端的整体考量,《天龙八部3D》主要运用了以下几种技术方案:
- 完整的动态负载均衡方案。单服务器支持一万人同时在线,在人数上涨时可以调动整个服务器的负载均衡,让一万人都能流畅、稳定地运行。
- 服务器内部通讯机制。
- 充分利用硬件资源。比如在一台物理机上开两个服务器,当一个人多而另一个人少的时候,服务器会自动通过动态负载均衡调用更多的硬件支持人多的服务器。
- 异常处理机制。
- 带有垃圾回收功能的对象池。
而在客户端,则有稳定的帧率和顺畅的操作感,里面带有高效的动态资源管理策略,可以保证客户端的内存方面不会出现特别大的问题,导致客户端闪退等。此外,还有成熟的性能优化解决方案,其实在去年刚起步时我们还是一头雾水,但经过一年多的努力和学习,我们基本上已经学会了一套在客户端上性能优化的完整解决方案。
从端游到手游,如何打造惊艳的移动端画面表现?手游和端游不同,做移动端游戏,面数是一个很大的问题,手游上面数较少,而《天龙八部3D》则将游戏资源与美术相结合,从定制化的场景到人物材质都是一种3D的表现,这样可以保证美术资源在面数较少的情况下,也能达到漂亮、惊艳的效果,如图1所示。

图1 《天龙八部3D》游戏界面截图
《天龙八部3D》项目是从2013年11月开始立项,作为毫无手游开发经验的前端游研发团队,整个开发流程可以说是摸着石头过河,不过幸好我们整个团队已在一起工作六年,非常默契,能够较快地将想法实现。项目最初一个月,我们都在探索着尝试各种美术风格定位,后来开始着手研究Unity引擎开发,在2013年12月底,我们使用Unity做了一个Demo,基本上代表了之后的美术方向和整个玩法的基本雏形。
经过从α、β到Golden版本的优化演进,《天龙八部3D》从初具雏形到公测、正式上线,在此过程中真正运用了哪些Unity技术?
- 大量的Unity自带技术,比如导航的组件等;
- 遮挡删除;
- LightMapping,用以解决光照问题;
- 将NGUI与Unity相结合可以很方便地构建出一个强大的UI系统;
- Unity自带的粒子系统;
- Editor功能,可以很方便地开发各种小工具,大幅提高工作效率,比如UI辅助、图片处理、编译、国际化、阻挡生成等;
- AssetBundle,一种非常有效的资源管理方式,既可以打包、控制内存使用,还可实现资源的动态更新;
- Unity自带的性能分析工具Profiler,能解决所有性能问题。
- 缓存池机制
- 资源释放机制
《天龙八部3D》中常用的释放点有两个,分别为转场景时释放一些非全局资源、每次打开界面一秒后进行一次主动调用GC的操作。这是我们权衡了很久的做法,但实际效果还很不错。当时我们为了兼容低端机型运用了缓存池的功能,在512MB设备上运行会变卡,而且还无法控制,最终我们在打开操作界面时执行缓存池,尽管实际出现卡顿但玩家却不会有感觉,这属于是一种比较取巧的方式。
值得开发者们注意的是,在将所有东西打包成AssetBundle时,需划分出依赖关系,单个界面的AssetBundle最好不要超过1M,单个模型骨骼数不超过32个,角色和NPC控制在2000面以下。
最后,再来说一下《天龙八部3D》游戏中使用到的优化方案。
- 客户端大小优化
- 内存优化
- 尽可能多地重用资源
按照C++的思想来管理内存,比如使用内存池、对象池、手动卸载、主动GC等,能够在内存和帧率之间做好平衡。另外,规划好美术资源的重复利用也相当重要,它能够减少包的大小,比如NPC变色多场景可共用,制备、水等很多场景的美术资源制作也可重复利用。
佟庆 《天龙八部3D》制作人;王华 《天龙八部3D》主程