《杰克和苔丝冒险记》手游开发者的七个建议

《杰克和苔丝冒险记》手游开发者的七个建议

大家好,我叫Gabriela Valentin Thobias,在位于巴西马瑙斯城的黑河工作室工作,职位是UI/UX设计师。它给我提供了一个创建全新高品质原创游戏的机会。但最大的好处就是可以接触Gear VR。从事VR开发与之前工作完全不同。作为设计师,当然要考虑易读性,可用性,组织架构等等,但是目前来说这都是个巨大挑战,因为没有任何规则或指导手册。

我们的游戏《杰克和苔丝冒险记》是一款手游。游戏的主要目标是画风可爱,超酷怪兽和高分。游戏很棒,最近在GooglePlay上成功发布了。当时VR项目与手游同时开始,我们曾想从手游中移植。但发现移植令人烦恼,因为我们不会使用VR的所有功能,体验有很多问题,比如:交互性或反馈不足,大家都很迷茫。在放弃移植的想法之后,开发了一个独立的VR版本。先开发的这个小Demo,能够充分反映问题,并获得大量的反馈。从而发现玩家想要的更多,比如:离怪兽更近,能感受四周环境,流畅舒适的体验,这样就进一步获得了全新的VR经验。

中国风游戏ui_游戏ui制作软件_游戏ui设计师

从项目初期开始,我们已经积累了很多关于易用性和用户对VR的体验,所以,希望下面七个建议可以帮助其他开发者。下面是我们的一些经验:

1、 不要臆想,要实践。

在项目之初,我们有一个信息板用来给玩家提供关卡信息。把它放在了相机前面,并在Unity中测试,它看起来很不错。但是,在打包后测试,位置完全错了。纹理太亮了,信息板比预想的要近,有点幽闭症患者的感觉。

游戏ui制作软件_中国风游戏ui_游戏ui设计师

红色方框是玩家不移动时可看见的区域。起初,觉得上下看来交互很不错,但是结果证明大多数玩家都很讨厌这种做法。

游戏ui制作软件_中国风游戏ui_游戏ui设计师

中国风游戏ui_游戏ui设计师_游戏ui制作软件

从那以后,每个很小的改动,我们都会打包在Gear VR中测试。最大的收获就是每次都测试所有情况,并且当我做了较大修改后,和其他人一起测试的时候。大家的关注点都不同。VR比手游更感性、主观性更强,有时候界面没有表达出你的想法,这是因为测试的不够。需要倾听玩家反馈。

2、多研究

在项目之初,我们专门花时间来做研究。找到所有你可以找到的VR相关内容。从John Carmack的演讲到一些VR玩法,从中吸收经验尽最大努力创建最棒的体验效果。

每当有人问我,关于VR设计最好的演讲有哪些中国风游戏ui中国风游戏ui,我总会推荐下面两个:

由Alex Chu演讲----VR设计:2D转3D设计范例

由Mike Alger演讲-----VR界面设计预览方法

这两个演讲(及其它)帮助我们更好的理解人体工程学和视域。尽管没有明确的实践指导手册,我们仍可以从他们研究分享中学习到很多。

3、 根据距离来设置易读性

在大多数情况下,信息要易读。在我们的项目中,有些文本例如引导,玩家要很容易看到。在VR中,文本距离根据环境和文本大小调整。若在一个小房间内,文本应尽可能远离墙面。若文本比墙面要远的多,就可能发生:

中国风游戏ui_游戏ui制作软件_游戏ui设计师

它将出现超大的锯齿,因为变大了,资源看起来被缩小与文本形成较大差异。玩家会觉得不舒服,因为它不自然。在现实世界中,你不可能透过墙来阅读很远很大的书,对么?

我们有工程师开发了很棒的工具来帮助跟踪距离的远近。在项目之初,我们打算在玩家周围放置一些信息资源,就像博览会上的展板。我们想给玩家这样的感觉。故此,工程师创建一个展板编辑器,这个工具可以将资源放置到想要的位置,合适的距离,朝向相机,并且可以设置每个资源不同距离角度。

展板编辑器怎么工作

4、眩晕,NO!

你知道坐到车最后的座位上阅读是什么感觉吗,会觉得恶心么?那就是动晕症。当你周围环境在移动而你不动时,它就会产生。有些人更敏感。维基百科:

在虚拟现实中,由于外部所有参考点都被视觉屏蔽了,所以动晕更严重,模拟图像是三维的材质材料,有时还有立体声也会给你移动的感觉。

在VR中,移动相机需要非常谨慎。在我们的游戏中,为避免动晕症,当玩家照相时,玩家就不动了。只有一个关卡的相机会移动,在该关卡中,相机一开始轻微移动,然后随着时间而逐渐变快。不要强制把相机从一个地方移动到其他地方,让玩家选择观看方向。我们还研究发现,当玩家在驾驶舱中时,相机移动产生的不适感较轻,所以我们把相机放到一个怪兽上面。尽管在游戏中不使用,但是用蓝牙控制可以减轻用户的动晕症,因为玩家在控制一切游戏开发素材,包括相机。

在第三关的月亮关卡,玩家骑着一个怪兽。我们通过轻微移动和不控制相机甚至是当怪兽改变方向时侯也不控制相机,来避免动晕症。

文章来源:http://dj.sina.com.cn/article/fxnqrkc6576880.shtml