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

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

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

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

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

 

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

  五、跟踪导弹(续完)

  上次我们已经知道怎样让导弹的旋转看起来像那么回事,紧接着就是让导弹运动起来了。

  导弹的一些属性,我们需要好好定义一下,这是完整的初始化函数:

init = function () {
enemy._x = 40;
enemy._y = 350;
enemy._rotation = 0;
enemy_obj.MAXAngle = 6;
enemy_obj.MAXSpeed = 4;
enemy_obj.speedX = enemy_obj.speedY=0;
clickable = true;
};

  我们有了一个新的属性:enemy_obj.MAXSpeed,这个属性代表这导弹的速度,不管导弹的朝向如何,速度总是有一个值的,我们在这里设置它。在导弹运动的时候,就按照上一讲里面已经计算出来的方向和速度来前进。下面我们来看,怎样确定 x 和 y 方向的速度:

  从上面的图片,我们可以根据三角计算得到导弹在 x 和 y 方向的速度,而速度之和正好是等于导弹的 MAXSpeed。

  于是我们很容易的得到下面的代码:

dir = (refineAngle(enemy._rotation)>180) ? -1 : 1;
tempTan = Math.tan((90-enemy._rotation)*Math.PI/180);
enemy_obj.speedX = enemy_obj.MAXSpeed/Math.sqrt(1+Math.pow(tempTan, 2))*dir;
enemy_obj.speedY = tempTan*enemy_obj.speedX;

  tempTan 是取得的三角函数值,具体的运算请对照图上的公式和上一讲的内容。

  最后,我们要判断一下是否碰撞,如果碰撞的话,就重新来过。

if (player.hitTest(enemy._x, enemy._y, false)) {
clearInterval(intervalID);
init();
}

  下面是完整的第一帧源代码,带颜色的应该在一行:

var clickable:Boolean;
var enemy_obj:Object = new Object();
var intervalID:Number;
//
init = function () {
enemy._x = 40;
enemy._y = 350;
enemy._rotation = 0;
enemy_obj.MAXAngle = 6;
enemy_obj.MAXSpeed = 4;
enemy_obj.speedX = enemy_obj.speedY=0;
clickable = true;
};
onMouseMove = function () {
player._x = _xmouse-10;
player._y = _ymouse-10;
updateAfterEvent();
};
onMouseDown = function () {
if (clickable) {
intervalID = setInterval(run, 10);
clickable = false;
}
};
getAngle = function ():Number {
var dx:Number = player._x-enemy._x;
var dy:Number = player._y-enemy._y;
return ((Math.atan2(dy, dx)*180/Math.PI+450)%360);
};
refineAngle = function (angle:Number):Number {
return ((angle+360)%360);
};
run = function () {
var dx:Number = player._x-enemy._x;
var dy:Number = player._y-enemy._y;
var tempTan:Number;
var angle:Number = getAngle();
var tempAngle:Number = refineAngle(enemy._rotation-angle);
var dir:Number = (refineAngle(tempAngle)>=180) ? 1 : -1;
enemy._rotation = (Math.abs(tempAngle)
>enemy_obj.MAXAngle)
? (enemy._rotation+enemy_obj.MAXAngle*dir) : angle;
// Get Speed
dir = (refineAngle(enemy._rotation)>180) ? -1 : 1;
tempTan = Math.tan((90-enemy._rotation)*Math.PI/180);
enemy_obj.speedX = enemy_obj.MAXSpeed/Math.sqrt(1+Math.pow(tempTan, 2))*dir;
enemy_obj.speedY = tempTan*enemy_obj.speedX;
// Move Enemy
enemy._x += enemy_obj.speedX;
enemy._y -= enemy_obj.speedY;
if (player.hitTest(enemy._x, enemy._y, false)) {
clearInterval(intervalID);
init();
}
};
// Run Program
init();

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

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

 

上一篇:金鸡贺岁!Flash制作鸡年新春动画贺卡  下一篇:Flash游戏开发系列一:游戏中的敌人(6)

 ::热点信息::

 

= = 免责声明 = =

① 欢迎转载我网所刊信息,请注明“来源: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号