关于我们 广告服务 社区论坛
设为首页 加入收藏

行业新闻
服 务 器
模版下载
建站指南
冲浪宝典
办公软件
网站运营
操作系统
QQ 专题
网页制作
安全防御
视频教程
网络编程
SEO专区
软件下载
图像设计
Cisco
网页特效
Wap 技术
联盟赚钱
网页素材
 首页 | 企业建站 | 网页制作 | 网站运营 | 网络编程 | 图像设计 | 冲浪宝典 | 操作系统 | SEO专区 | 联盟赚钱 | Cisco

欢迎来到e天下网络首页>>图像设计>>FLASH>>正文|Flash游戏开发系列一:游戏中的敌人(4)

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

[ 来路:闪客帝国      时间:2007-7-10 3:29:33    点击: ]

 

  第三篇: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);

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

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

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

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

::::站长友情提示:多花一分钟学点什么都好::::

 

上一篇:Flash游戏开发系列一:游戏中的敌人(5)  下一篇:Flash游戏开发系列一:游戏中的敌人(3)

 ::热点信息::

 

= = 免责声明 = =

① 欢迎转载我网所刊信息,请注明“来源:E天下网络”。
② 凡本网注明“来源:XXX(非E天下网络)”的作品,均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如因作品内容、版权和其它问题需要同本网联系的,请在30日内进行。
※联系方式:Airtofly@163.com

::推荐文章::

 

Photoshop 轻松打造神秘银河系

::网页制作::

 

初学:什么是DIV+CSS?有什么
网页制作实例CSS用一张图片实
用CSS控制图片自适应大小的方
小技巧:CSS列表标签出现问题
CSS网页设计中使用背景图片须
想让DIV居中,如何编写CSS的
总结两年以来使用DIV网页排版
DIV CSS技巧:对CSS命名的一
更多内容..

 

 

关于我们 广告服务 友情链接 合作伙伴 社区论坛 免责声明

Copyright © 2007   21kn.com Inc. All rights reserved.e天下网络工作室

网站白天客服QQ:26875416 (非24小时)  合作QQ:597004688    粤ICP备06026423号