独立游戏《Purgatory Ashes》的经验与总结
1.引子
游戏的灵感萌生于2015年,当时只有一些概念性的设计图。
后来我利用资源商店的素材搭建了最早的原型。
游戏的最终画面:
早期以D.P作为代号进行开发,来源于两个单词的缩写 Devil Prototype。
去年秋季我离开了当时的公司开始全职开发这款游戏,鉴于游戏的体量和一定的情怀原因,我选择了线上开发的形式招募一些队友
在群内发了一些信息以及一阵子磨合后,最终拉拢了3名小伙伴入伙,总共4人。
期间遇到了许许多多的难题,以及若干未解决的问题。但最终仍然发布到了steam商店上(即将解锁):
http://store.steampowered.com/app/716060/Purgatory_Ashes/
并不算是合格的作品,但有许多内容可以写一下。
2.关于合作
我本身有一定的C4D基础,可完成一定的美术资源。甚至有一些偏执,例如之前开发的C2U工具。
众所周知,线上合作的问题是不能及时给予反馈。但这个问题在这款游戏的合作中并不是很突出。
最多隔一个上午或者下午就可以得到回复,真正最大的问题是拉不到合适的人。
所以这次合作的成员中,除了美术是专业美术以外,其他人则都是'野路子'。这一直是一个伴随开发非常头疼的问题。
到了后期基本上是我一个人在做,变成了其他人帮忙的形式。不过还算好,开发这款游戏所花费的时间尚能接受。
而在网络上不断地组队发广告又是一件非常拉嘲讽的事情。双刃剑吧。
2.踩过的坑
2.1 游戏设计方面
传统关卡制模式的弊端
我觉得对于独立游戏而言,做这类长关卡制的游戏实在有点吃力不讨好。只能说是这样做情怀的比重更大一些。
与其做传统模式的游戏,不如把战斗节奏的把控,出怪间隙调整好,来设计一个纯血宫,Rougelike模式的游戏要来的好。
关卡场景的比例问题
关卡设计上有个比较大的问题是大小比例问题,很容易造成场景过大角色过小的情况。控制好比例需要合理的场景摆件/物件
特别是高度到角色脚部,腿部,肩部这几个地方的参照物物件。摆放得当才显合理。
特殊的建筑风格
一些古建筑其实比较难做,棱角边数等都有讲究,特别是哥特的穹顶。
而要塞类或者一些现代建筑要好做一些。不要无意识的踩了这个坑。
室内室外空间的来回切换
尽量避开这类复杂的空间结构,游戏中经常要用到一些本来就不合理的结构填充到关卡中去(比如凭空出现的跳台,传送台)。
2.2 技术方面
优先考虑用混合树 而不是 Layer
很多问题用同步层可以解决,但用混合树也可以解决,而且更灵活。只需要指定一个float变量当成bool用即可。
例如变身的处理,变身后的招式以及动画状态和变身前其实是有较大变化的,这时候用混合树就更为合适。
手柄适配
统一键位的手柄适配使用InControl,这款插件能保证xbox,ps4,北通等手柄都是同样的键位
但使用时需要勾选XInput支持,否则北通手柄无效。另外对于不支持InControl的手柄需要自行自定义键位来处理。
使用InControl还有一个锅,就是PS4手柄没有震动,但作者说这不是他的问题,这需要一个支持ps4震动的dll。
如果只上steam的话,可以模拟成steam控制器来解决震动问题。若是其他平台则需要另想办法了。
敌人AI的简化
Unity这一块比较常规的做法是用Behavior Designer来设计AI。建议是一上来不要设计太复杂的敌兵AI,特别是涉及需要'黑板'这种小队逻辑的
否则会衍生出非常多的bug。所以不一定非得设计出强AI敌人,有很多变通的方法,例如通过一些特殊的技能来增加可玩性,一些弹幕类技能的释放等等。
3.取舍还是死磕
如果你做ARPG你就要强化剧情部分,养成部分。如果你做ACT你就要强化战斗部分。
独立游戏想要把整体给做好,就需要在核心模块上下文章,其余则做减法。
拿ACT来说,战斗部分又有以下4点可取舍:
1.可以弱化AI逻辑,强化AI技能。避开小队AI这样难以调试容易出bug的内容。
2.敌人模型复用。例如身着盔甲的敌人,通过换武器变为法师,战士,枪兵等。
3.优先考虑人形敌人,半身怪,漂浮怪物。这类角色在美术制作上会节省时间,且人形敌人的动画可以复用。
4.通过改变不同敌人的组合让战斗不至于枯燥。
其他部分,则有这几点可取舍:
1.用文字对话配合程序驱动的演出来代替过场动画。
2.考虑好关卡中的场景复用,一个场景来回跑。而不是堆量。还有角色也是。
3.一些部分的处理逻辑少不了HardCode,改成节点或者配表反而没HardCode来的简练。
4.结语
终于把这个坑给填上了。也算结束一事,有始有终吧。
以后也是往这个方向去做新的游戏,不过什么时候开始谁知道呢。
独立游戏《Purgatory Ashes》的经验与总结的更多相关文章
- Unity3D独立游戏开发日记(二):摆放建筑物
在沙盒游戏里,能自由建造是很重要的特点,比如说风靡全球的<我的世界>,用一个个方块就能搭建出规模宏大的世界.甚至有偏激的人说,没有自由建造,就不是一个真正的沙盒游戏.的确,沙盒游戏的魅力有 ...
- Unity3D独立游戏开发日记(一):动态生成树木
目前写的独立游戏是一个沙盒类型的游戏.游戏DEMO视频如下: 提到沙盒类型的游戏,就有人给出了这样的定义: 游戏世界离现实世界越近,自由度.随机度越高才叫沙盒游戏.所谓自由度,就是你在游戏里想干啥就干 ...
- 独立游戏大电影 原名(Indie.Game)
电影链接 独立游戏大电影 感觉很不错呢!!
- 半年收入超2亿RMB 独立游戏开发者的艰苦创业路
一款叫做<监狱建筑师>的模拟经营游戏,目前在Steam平台获得了3000万美元(近2亿元)以上的收入.这款游戏由英国独立工作室Introversion Software发布,而团队最困难的 ...
- 用Qt制作的Android独立游戏《吃药了》公布
一个多月的努力最终有了回报,我自己研究制作的独立游戏<吃药了>.最终在360应用商店上线了. 这一款游戏呢.使用的是Qt开发的.事实上开发这款简单的应用之前.我 ...
- funhub 独立游戏团队诚邀策划,美术,技术,QA 大大加入(可远程办公)
我们刚成立的的独立游戏团队,base:广州,团队陆陆续续已经有 6 个成员了,现在还缺的岗位有策划,美术.不过有其 他岗位的仁人志士也可加入. 另外,我们支持远程办公,这是互联网行业的天然优势,一定要 ...
- 总结使用Unity 3D优化游戏运行性能的经验
原地址:http://www.gameres.com/msg_221889.html 作者:Amir Fasshihi 流畅的游戏玩法来自流畅的帧率,而我们即将推出的动作平台游戏<Shadow ...
- 【转】独立游戏如何对接STEAM SDK
独立开发者在对接STEAM SDK之前 首先得先登上青睐之光,也就是我们俗称的"绿光" 一般要先对接G胖家的SDK,然后提交版本,最后等待审核... 我本身是unity 开发,对C ...
- (转)总结使用Unity 3D优化游戏运行性能的经验
http://www.199it.com/archives/147913.html 流畅的游戏玩法来自流畅的帧率,而我们即将推出的动作平台游戏<Shadow Blade>已经将在标准iPh ...
随机推荐
- python 异常 反射
异常 反射 一.异常处理: AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x IOError 输入/输出异常:基本上是无法打开文件 ImportError ...
- mysql基础练习题
一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 /* Navicat MySQL Data Transfer Source Server : mysql5.7.1 Sour ...
- python基础——继承与派生、组合
python基础--继承与派生 1 什么是继承: 继承是一种创建新的类的方式,在python中,新建的类可以继承自一个或者多个父类,原始类成为基类或超累,新建的类成为派生类或子类 1.1 继承分为:单 ...
- Lua中table的实现-《Lua设计与实现》
本文来自<Lua设计与实现>的阅读笔记,推荐Lua学习者可以购买一本,深入浅出讲解lua的设计和实现原理,很赞,哈哈 Lua中对于表的设计,是基于数组和散列表,和其他语言不同,对于数组 ...
- [转]使用awk批量杀进程的命令
1. ps -ef|grep aaa|grep -v grep 这是大家很熟悉的命令,这里就不再多说,就是从当前系统运行的进程的进程名中包含aaa关键字的进程. 2. 后面部分就是awk命令了,一般a ...
- html如何实现的
超文本标记语言是标准通用标记语言下的一个应用,也是一种规范,一种标准,它通过标记符号来标记要显示的网页中的各个部分.网页文件本身是一种文本文件,通过在文本文件中添加标记符,可以告诉浏览器如何显示其中的 ...
- Animations in UWP Community Toolkit - Overview
概述 UWP Community Toolkit 中有一个 Animations 的集合,它们可以帮助开发者实现很多的动画,本篇我们先来看一下 Animations 的功能都有哪些,再后面会针对每一 ...
- java中的方法引用
引用静态方法:类名称::static 方法名称: 引用某个对象的方法:对象::普通方法: 引用特定类方法:特定类::方法 引用构造方法:类名称::new 范例:引用静态方法 package com.j ...
- 0418 jQuery笔记(添加事件、each、prop、$(this))
1.添加点击事件.each.prop.$(this) //全选框的被动操作 //定义一个标志保存最终状态 var flag = false; //为每一个选择框添加点击事件,数组.click() $( ...
- [LeetCode] Two Sum IV - Input is a BST 两数之和之四 - 输入是二叉搜索树
Given a Binary Search Tree and a target number, return true if there exist two elements in the BST s ...