Flash游戏开发系列一:游戏中的敌人(4)

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

第三篇:Flash游戏开发系列一:游戏中的敌人

四(插)、半随机移动的敌人

看看这个例子:

我们可以看到,一个敌人按照一定的规律从上面到下面移动。主要的规律是自上而下,但是移动的范围是随机的。这种方法在早期的游戏里面经常使用,包括一些大型的游戏。其实这是一种非常简单的运动方式,但是如果使用得当,也很有威胁。

我们大概瞧一下原理:

敌人每次向一个方向以随机的速度走八步,然后再改变方向,再走八步。在这个例子里面,为了简单说明,敌人走到画面底部以后,我们会让它重新回到原来的位置,重新再走。

我们创建一个对象 enemy_obj 来保存敌人的运动状态,当然你也可以把这个对象的属性直接赋予给 enemy 这个 MovieClip。我们这么做应该会清晰一些。 enemy_obj 有一些属性,我来介绍一下:

speedX : x 方向速度

speedY : y 方向速度

dirX : 方向, -1 or +1

cur : 当前步数

我们写一个初始化函数 init() 来初始化这些数据:

init = function () {

enemy_obj.sppedX = enemy_obj.sppedY=0;

enemy_obj.dirX = -1;

enemy_obj.cur = 0;

enemy._x = 150;

enemy._y = 50;

};

初始化完成以后,就是敌人运动的函数了

我们初始定义的方向是(-1),也就是向 x 的负方向。然后开始不断的增加步数,enemy_obj.cur = (++enemy_obj.cur)%8 可以让步数维持在 8 步以内,不明白的闪客可以跟踪一下数据看看,其实是很简单的,就是不断增加步数,并且针对 8 取模。取模的用法大家可以去查一下帮助看看,这里不多说了。

一旦达到某一步数,这里是第一步,那么就开始改变方向,通过 enemy_obj.dirX = (enemy_obj.dirX == 1) ? -1 : 1 来实现。接下来就开始随机生成速度,我们这里规定敌人向下走,所以 y 方向是固定的,x 方向随 enemy_obj 的方向来改变,所以我们在随机生成 x 的速度以后,要再乘以 enemy_obj.dirX,如果您是新手,现在应该理解为什么 enemy_obj.dirX 要在 -1 和 +1 之间变动了吧?

剩下的可能就不用多解释了,下面是完整的第一帧源代码:

var enemy_obj:Object = new Object();

init = function () {

enemy_obj.sppedX = enemy_obj.sppedY=0;

enemy_obj.dirX = -1;

enemy_obj.cur = 0;

enemy._x = 150;

enemy._y = 50;

};

/* functions */

tracker = function () {

enemy_obj.cur = (++enemy_obj.cur)%8;

if (enemy_obj.cur == 1) {

enemy_obj.dirX = (enemy_obj.dirX == 1) ? -1 : 1;

enemy_obj.speedX = (15+random(5))*enemy_obj.dirX;

enemy_obj.speedY = 1+random(5);

}

enemy._x += enemy_obj.speedX;

enemy._y += enemy_obj.speedY;

if (enemy._y>380) {

init();

}

updateAfterEvent();

};

/* run it*/

init();

setInterval(tracker, 25);

程序还是采用了比较简单的结构,以便大家看得明白。如果您是新手,那么请务必要理解这些语句的作用和效果,我之所以把这么老的题材拿出来,主要是为了开拓新手的思路,如果您是高手,那么这些东西再简单不过了。

程序运行起来看着很丑陋是吧?不要紧,因为本教程主要是介绍这种方式,真正应用到你自己的程序中的时候,是要加入很多元素的,如果能够用得好,会很有效的。

我为这一系列教程开了一个帖子,大家可以去讨论,当然,在这里提问也没问题。

这次的源代码请在这里下载

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航