前言:
不论何种游戏,一开始的时候必须要考虑v的事情那就是游戏的内容。
决定游戏内容是有一些要注意的事项,首先是操作简单 。还有一个要点是斩杀时的爽快感,画面上的大量怪物要夸张地向四处飞散
游戏演示
打怪兽
一、玩法介绍
- 武士能够自动行走
- 点击攻击键攻击怪物
- 一次性斩杀多个怪物
- 近处斩杀怪物将得到高分
- 如果不出现失误,怪物的数量将会增加
- 碰到怪物后将失败
二、无限滚动的背景
原理演示
打怪兽背景演示
在这个游戏中,代表玩家的武士一直向前方前进,在游戏结束之前势必将移动非常远的距离。如果将所需要的北京全部做到一个模型中,那么数据量将会非常大。而且还必须在游戏开始的时候就生成这些背景,非常麻烦。
在这个游戏中,背景仅仅用于显示,和游戏的内容们没有关系。即使重复出现同样的背景也不会影响游戏的内容。显示在画面中的也只局限于武士周围的一小部分而已。
既然这样,我们就可以反复利用几个相同的北京组件来合成背景,并且只在玩家的周边将各个组件逐个显示出来
本游戏准备了三种类型的背景组件。分别是背景A,B,C
通过循环并列显示A,B,C三种背景组件,就能够呈现出没有缝隙的背景,而实质上各个组件只有一个显示在了画面中。
刚开始时,ABC各个组件都显示在武士的周围。当游戏开始,武士移动了一定距离后,各个组件将移动到下一个合适的位置。因为总共有三种组件,所以组件的移动宽度=3×一个组件的宽度。
把这个流程用代码描述出来,就是下面这样:
FloorControl.Update方法(摘要)
cs
// 地面的宽度(X方向)
public const float WIDTH = 10.0f*4.0f;
// 地面模型的数量
public const int MODEL_NUM = 3;
void Update()
{
float total_width = FloorControl.WIDTH*FloorControl.MODEL_NUM;
// 背景的位置
Vector3 floor_position = this.transform.position;
// 摄像机的位置
Vector3 camera_position = this.main_camera.transform.position;
if(floor_position.x + total_width/2.0f < camera_position.x) {
// 移动到前面
floor_position.x += total_width;
this.transform.position = floor_position;
}
其中,floor_position表示背景组件的位置,camera_position表示摄像机的位置。虽然程序中使用了摄像机的位置来决定背景的移动,但为了便于理解,这里我们使用武士的位置来说明。由于武士位于画面中央偏左 的位置,严格来说摄像机和武士的X坐标值并不相同。但为了别与理解背景移动的算法,不妨认为这个等式成立:摄像机的X坐标=武士的X坐标。
组件位于floor_position.x时,该组件再次出现时的坐标为"floor_position.x+total_width"
如果摄像机的X坐标大于中间点floor_position.x+total_width/2.0f,那么距离下次出现的位置比距离现在的位置更近,组件将移动到下一地点
三、
小结这次我们介绍了无限循环的背景的基本制作方法。有时需要碰撞检测的游戏中会创建一个所谓的"地形"模型,但即便是在那种情况下,不影响游戏的远景也常常铜鼓这种循环显示背景组件的方法来实现。