即时动作类网络卡牌游戏开发真的非常难

我的《凤舞三国》--即时动作策略类网络手机戏从策划到实施现在已经过了16个月了。最终到今年4月(2016年4月)有望出一个内測包给众多期望代理偶家产品的发行们。蓦然回首才发现,偶从2011年3月进入手游开发行业现在已经过去5年了~ 不由发出一声感叹:“光阴如梭、人生苦短啊。

我们也像其它众多小游戏公司。在2014年确定了开发三代即时动作类网络卡牌游戏的目标。由于先找到了一个很好的美术外包合作伙伴,所以当时我们很有信心8个月可以定搞定该游戏。

我们当时觉得:就游戏产品开发来说,美术首先是一个充分条件:假设美术都不能打动开发人员,以及其它发行商。那么不必从策划上和程序来实现这个产品。

一个好的美术资源是一款成功游戏产品的前提,而且如今我们还是这样觉得。因此,我们花在这款游戏美术资源外包上就花了150多万RMB。而且这还是仅仅是前期上线的美术资源。当然,光有美术不可能就是一个好游戏。接下来策划和程序实现是必要条件。没有好的策划,而且没有好的程序保障实现策划的要求,那么美术投入也是白搭。从參加2015年GMGC大会到今年參加DoGame游戏兵工厂的路演,我们发现,事实上真正展示即时动作类卡牌游戏产品的中小游戏公司很少,为什么?由于,做了之后才发现。即时动作网络游戏真的技术上实现难度很大。先不说网络通讯时长连接与短连接技术实现与切换的问题,单就怎么实现流畅的多人即时战斗效果就很难。这里还不包含各种特效的技术实现。比方多目标攻击、追踪技术、范围伤害、buffer效果等等AI技术的准确实现是很难的。因此。这也是为什么到2015年一大批想开发即时动作类卡牌游戏的小游戏公司都死了。先不说小公司的美术是否可以过关,就单从程序技术上想要实现,而且要达到《刀塔城传奇》产品那种细节效果,这本身就是一个很难的技术门槛。那些创业失败者说这样的三代卡牌游戏是烂大街的游戏。简直就是胡说八道。由于真正可以做出这样的产品的小公司到眼下我就还没有看到过,当然除了我们公司。

好了我们如今就从技术来说吧。首先游戏程序猿要面临一个问题:那就是策划案会不断变更~这是一个全部的游戏公司都会存在的现象。

假设策划不变,那就不是在开发游戏,那是在做练习项目--逗你玩儿呢。也就是说你不是在游戏公司上班,你是在某某游戏开发培训学校上课呢。你可能说,先实现功能再说啊。对,当你先实现了一个功能,但是实际上会立即出现策划们让我们要这样改,还要那样改的情况。。。于是,假设你不想好了怎么从程序结构上应对策划的变更。那么你就会每天加班到死也做不完。

你会不断重写这个、重写那个。最后,你都不知道怎么写了。由于。已经太多、太乱、太复杂了--最后仅仅有36计走为上了

假设你的老板不懂程序,或者你的主管不会写代码,那么你还可能会找一些优美的盾辞跟老板说--“我要离职,由于偶看不到产品的希望,请批准我离职吧”--呵呵~这样的行为非常可耻

刚才我说过了,所谓即时动作类游戏,那就是游戏执行时必须即时表现人物的打击感、受伤害、加buffer等视觉效果,以及即时表现对应的数值响应,包含网络通讯哦。要让10个人物加各种特效流畅的实现战斗效果,这种要求事实上是很难的。由于,要实现10个人中每一个人都要攻击、受伤、死亡、中断、击退的效果。而每一帧仅仅有一个这种状态存在。而且下一帧还要依据别人对你的攻击、辅助等来计算下一帧自己的状态,这是一个乘法运算次数:10*4*10。我们以一屏10人战斗。不算技能,每一帧的至少须要运算400次循环,在这一帧中要求计算一个人物是否攻击会其它9个人,同一时候其它9个人还是否攻击了你。。

想一想这种即时运算,单让你想一想可能的if语句就是很头痛的事情。

而我们的Cocos2d-x
3.0.2引擎每秒呈现60帧,也就是说你须要在大约17毫秒内完毕这第多运算啊~不做不知道,一做才会吓一跳。怪不得一般的小游戏公司仅仅会做单机游戏。不做网络游戏,怪不得一般小游戏公司仅仅能做技术实现比較简单的游戏。事实上,这样的技术难度要求高的游戏,真的一般仅仅有大游戏公司才可以做啊:首先,美术他们可以保障:有钱啊呀。买得起;其次,程序技术实现可以保障:有钱啊。请得起这样的高级程序猿。

所以,在游戏圈里看到非常多2014年下海创业的人员。然后2015年失败后又回去打工的人一说起即时动作类游戏就怨气非常深时,我如今已经非常可以理解了他们了

这不是装逼,这是实话,由于我已经走过来了。

前面我还说了,游戏公司的程序猿必须直面策划的不断变更--这是必须的。

那么。在客观上也要求我们程序猿必需要想办法从技术上解决问题。

于是问题来了。我想什么办法来解决问题呢?假设。你是一个刚大学生的菜菜鸟,你会怎么办?我看仅仅有凉拌--想怎么写就怎么写呗。假设你原来是Java程序猿又或者是C#程序猿出身。你又会怎么办?一般你会想用OO的思想呗。好。那么问题又来了,假设你像我一样使用Cocos2d-x引擎纯C++语言来开发,那么怎么把你过使用Java或者C#开发过的OO思想使用C++语言正确的体现出来呢?假设你想用过去的OO思想让C++语言表现,那你一定会发现:这件事情本身也就是一个非常困难的事情:C++不支持反射,C++没有那么多现存的框架可用,包含你想使用一个第三方的C++正則表達式库都非常难。。。

你曾经的编程经验在这里会受到严峻的挑战,所以。你一定会迷失方向的:我怎么如今就OO不起来了呢???我们的程序设计怎么那么难啊。。

结构怎么设计得这么复杂,对象之间的调用关系怎么这么乱呢,大编译一次怎么需要这么长的时间啊。。

。我们的类都多到让VS编译器瘫痪了。。。

还有,

假设你中途增加一个没有OO思想的所谓有两三年经验的程序猿。那么你还会常常跟他吵架、争论,而且回答他各种奇葩的问题。于是你看他时认为他是火星人,他看你时认为你是猿人。你们根本不在一个频道上。。。最后你说:“好吧。这个功能我来写吧。你不用管了。”

那就这样吧。大家都各做各的功能吧。相互独立即可了三。可是,当你做QA角色须要进行代码审核时,假设你看到火星人的代码,你会很纠结和痛苦:"为什么他要这样写代码啊?"你一边看他的代码,一边不停的问自己,最后还要一边想办法不让自己暴走--这样的感觉真是让人很抓狂~于是,假设火星人负责的功能出了问题。而且这个火星人又辞职走了,那么你仅仅能又一次自己写一遍该功能的代码。而绝对不会去改火星人的代码的

唉~最终过去16个月了。我们产品最终要出測试包了。看到如今产品实现的效果--我认为曾经所受的痛苦是值得的。由于。即时动作类网络卡牌游戏开发真的非常难啊。我写这篇文章是想感谢我兄弟小强。感谢我的团队陪我走到如今。也写给未来的希望进入这个行业的小团队,假设你想使用纯C++做即时动作类网络游戏产品时,你一定要知道这是一件非常困难的事情,光有想理解是不够的,你一定要有足够的技术贮备,这样走起来才不会非常困难啊。

原文地址:https://www.cnblogs.com/llguanli/p/8475507.html

时间: 2024-10-11 15:03:46

即时动作类网络卡牌游戏开发真的非常难的相关文章

即时动作类网络卡牌游戏开发真的很难

我的<凤舞三国>--即时动作策略类网络手机戏从策划到实施如今已经过了16个月了,终于到今年4月(2016年4月)有望出一个内测包给众多期望代理偶家产品的发行们.蓦然回首才发现,偶从2011年3月进入手游开发行业如今已经过去5年了- 不由发出一声感叹:"光阴如梭.人生苦短啊." 我们也像其他众多小游戏公司,在2014年确定了开发三代即时动作类网络卡牌游戏的目标,因为先找到了一个非常好的美术外包合作伙伴,所以当时我们非常有信心8个月能够定搞定该游戏.我们当时认为:就游戏产品开发

Android 游戏开发(一)了解View

Android游戏当中主要的除了控制类外就是显示类View.SurfaceView是从View基类中派生出来的显示类.android游戏开发中常用的三种视图是:view.SurfaceView和GLSurfaceView. View:显示视图,内置画布,提供图形绘制函数.触屏事件.按键事件函数等:必须在UI主线程内更新画面,速度较慢. SurfaceView:基于view视图进行拓展的视图类,更适合2D游戏的开发:是view的子类,类似使用双缓机制,在新的线程中更新画面所以刷新界面速度比view

Android JNI/NDK开发(一)NDK真的很难吗?

少壮不努力,老大徒伤悲.大学时光的潇洒散漫导致今天连C/C++编程都不会.作为一个程序员,不会C/C++说出去简直丢人啊.最近浏览公司招聘信息(Android职位),发现对NDK开发的要求越来越普遍了.笔者学习的是java,从事Android开发,对于Android底层的东西多少有点畏惧,因为没有涉及过,但是我们知道,不能因为怕就放弃.如我曾经签名所言:现在开始行动,就比还在犹豫的人快了一步. 回到正题,NDK开发真的很难吗?其实不是的,觉得难是因为你没懂,不懂是因为没学.那就来吧 NDK:什么

【鹏派】网上棋类牌类游戏开发领军品牌-如何赚95%棋类牌类平台利润

[合肥鹏派]网上棋类牌类游戏开发领军品牌-如何赚95%棋类牌类游戏利润 曾孕育中国最早一批游戏玩家的街机电玩,在无比恋旧难舍情怀的时代,棋类牌类手游的代表作.百分之百移植捕鱼游戏等特色玩法的街机,获得了80后.90后这两代消费大军的广泛支持.万人在线同台竞技重温经典的移动电玩时代已全面到來.合肥鹏派于2015年从街机游戏植入网络版的碰碰车,飞禽走兽,森林舞会,金鲨银鲨等多款游戏开始,获得了广大玩家的热爱.但如何紧跟鹏派的步伐赚取棋类牌类游戏95%的利润,需要避免以下棋类牌类游戏开发商的引导误区!

Cocos2d-x 自定义按钮类控制精灵攻击----之游戏开发《赵云要格斗》

本篇要讲讲怎么自定义按钮类,并通过这个按钮类的对像来控制精灵的攻击.在看本篇之前最好先看看上一篇 Cocos2d-x虚拟摇杆控制精灵上下左右运动----之游戏开发<赵云要格斗>,要素材和项目代码的把邮箱留下吧,因为这个项目还没弄完,我一直在改. 精灵的攻击也是一个动画,只不过,这个动画只播放一次,相当于在界面上加一个按钮,然后你点一次按钮,精灵就播放一次动画. 一.自定义按钮类 按钮可以用COCOS2D-X自带的,想着方便一点,我就自己封装了一个按钮类ControlButton,在里面添加一个

Cocos2d-x手机游戏开发中-组合动作

动作往往不是单一,而是复杂的组合.我们可以按照一定的次序将上述基本动作组合起来,形成连贯的一套组合动作.组合动作包括以下几类:顺序.并列.有限次数重复.无限次数重复.反动作和动画.动画我们会在下一节介绍,本节我们重点顺序.并列.有限次数重复.无限次数重复和反动 下面我们通过一个实例介绍一下组合动作的使用,这个实例如下图所示,下图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的动作效果,点击Back按钮可以返回到菜单场景. 下面我们再看看具体的程序

Unity3D游戏开发之详解 Animation类和Animator类

Unity3D游戏开发之详解 Animation类和Animator类 Animation类 animation组件用于播放动画.可以指定动画剪辑到动画组件并从脚本控制动画播放.在Unity的动画系统基于权重并且支持动画融合,叠加动画,动画混合,标签和完全控制动画播放的各个方面. 如果想播放一个简单的动画,可以使用Animation.Play:如果想在动画之间交叉淡入,可以使用Animation.CrossFade:如果想改变动画模式(循环,一次,乒乓),可以改变动画导入设置里面的动画帧的Wra

24、Cocos2dx 3.0游戏开发找小三之网格动作:高炫酷的3D动作

重开发者的劳动成果,转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/37596763 网格动作类似于动作特效,可以实现翻转.震荡.抖动.水的波纹等效果. 网格的基类: GridBase* Grid 获取或设置该节点的网格特效状态.网格应用于绘图平面上,可以实现水纹等 3D 特效: 基类定义:cocos2d/2d/CCGrid.h中: 基于这个基类有两个子类: Grid3D TiledGrid3D 这两个子类的共同点是:网格

游戏开发经验谈(二):对战类全球服游戏的设计与实现

上篇文章<游戏开发经验谈(一):游戏架构里隐藏的五个坑及其应对方案>,我们主要讲解了游戏架构设计当中隐藏的一些坑及其应对方案,错过的小伙伴可以点击链接回溯之前的内容.本期内容,将会重点介绍对战类全球服游戏的设计思路与技术实现. 对战类游戏的设计思路 协议的选择 游戏设计之初,需要决定选择哪种协议来进行通讯.对于对战类游戏来说,首先推荐的肯定是UDP. 尽管UDP对开发基础有较高的要求,需要开发者自己实现传输成功检验.重传以及可靠性保证等,但相对于低开发成本的TCP,UDP在效率和时效性上都有极