首页  韩国资源  酷站加油  我的展厅  设计名站  古典元素  推荐下载  设计欣赏  每周专访  招募精英  人才专区  网页教程  平面设计  编程开发  设计竞赛
当前位置:首页 > 网页教程 > Flash教程 > 正文
Google
Flash制作红外线引导导弹爆炸视觉效果
来源:网页教学网 作者:闪电儿 2007年06月27日 15:16 网友评论:0条 点击:
  前几天的一篇文章,用Flash轻松制作电子发散视觉效果动画,好多人都问有什么用?今天就再继续一下!看看红外线引导导弹爆炸效果。

  爆炸的代码我们还使用前面那个教程中用到的代码,在这个效果里,我们首先把光标的形状变换一下,然后点鼠标就有一个导弹出现,然后发生爆炸。先看效果:(点击鼠标可以看到效果)

/UploadTeach/200706/20070625214802195.swf

新建立一个文件,按Ctrl+J调整大小和背景色(#999999)和帧频。

按此在新窗口浏览图片

制作一个红色的小圆影片剪辑作为鼠标的形状,制作一条有色的线条影片剪辑作为导弹,然后再制作一个白色小圆作为爆炸的影片剪辑。并在第一帧加入如下代码:

/* GLOBAL VARIABLES */
_global.gLEFT = 20;
_global.gTOP = 20;
_global.gRIGHT = Stage.width - 20;
_global.gBOTTOM = Stage.height - 20;
/* FUNCTION: Converts radians to degrees */
function rad2deg(radians:Number):Number {
  return radians * 180 / Math.PI;
}  
 
/* FUNCTION: Converts degrees to radians */
function deg2rad(degrees:Number):Number {
  return degrees * Math.PI / 180;
}
/* FUNCTION: Returns a random number between min and max (inclusive) */
function randRange(min:Number, max:Number):Number {
  var randomNum:Number = Math.floor(Math.random() * (max - min + 1)) + min;
  return randomNum;
}
/* FUNCTION: Creates an explosion */
explosion.maxSpeed = 25;
explosion.minSize = 4;
explosion.maxSize = 10;
explosion.minFragments = 10;
explosion.maxFragments = 50;
function explosion(originX:Number, originY:Number):Void {
  var totalFragments:Number = randRange(explosion.minFragments, explosion.maxFragments);
  var fragment_mc:MovieClip;
  var depth:Number = this.getNextHighestDepth();
  for (var i:Number = 0; i < totalFragments; i++, depth++) {
    fragment_mc = attachMovie("Fragment", "fragment" + depth, depth);
    fragment_mc._x = originX;
    fragment_mc._y = originY;
    fragment_mc._width = fragment_mc._height = randRange(explosion.minSize, explosion.maxSize);
    while (!fragment_mc.speedX) {
      fragment_mc.speedX = randRange(-explosion.maxSpeed, explosion.maxSpeed);
    }
    while (!fragment_mc.speedY) {
      fragment_mc.speedY = randRange(-explosion.maxSpeed, explosion.maxSpeed);
    }
    fragment_mc._alpha = randRange(10, 100);
    fragment_mc.cacheAsBitmap = true;
 
    fragment_mc.onEnterFrame = function():Void {
      this._x += this.speedX;
      this._y += this.speedY;
 
      if (this._x < gLEFT || this._x > gRIGHT || this._y < gTOP || this._y > gBOTTOM) {
        this.removeMovieClip();
      }
    };
  }
}
/* FUNCTION: Creates and initializes heat-seeking missiles */
createMissile.maxSpeed = 30;
createMissile.accel = 2;
function createMissile(target_mc:MovieClip, xPos:Number, yPos:Number):Void {
  var depth:Number = _root.getNextHighestDepth();
  var missile_mc:MovieClip = attachMovie("Missile", "missile" + depth, depth);
  missile_mc._x = xPos;
  missile_mc._y = yPos;
  missile_mc.speed = 0;
 
  missile_mc.setRotation = function():Void {
    var dy:Number = target_mc._y - this._y;
    var dx:Number = target_mc._x - this._x;
    this._rotation = rad2deg(Math.atan2(dy, dx));
  };
 
  missile_mc.onEnterFrame = function():Void {
    this.setRotation();
 
    if (this.speed < createMissile.maxSpeed) {
      this.speed += createMissile.accel;
    }
    this._x += Math.cos(deg2rad(this._rotation)) * this.speed;
    this._y += Math.sin(deg2rad(this._rotation)) * this.speed;
 
    if (this.hitTest(target_mc)) {
      explosion(target_mc._x, target_mc._y);
      this.removeMovieClip();
    }
  };
}
/* MAIN PROGRAM LOGIC */
var gameBG_mc:MovieClip = _root.createEmptyMovieClip("gameBG", 0);
gameBG_mc.beginFill(0x222222);
gameBG_mc.moveTo(gLEFT, gTOP);
gameBG_mc.lineTo(gRIGHT, gTOP);
gameBG_mc.lineTo(gRIGHT, gBOTTOM);
gameBG_mc.lineTo(gLEFT, gBOTTOM);
gameBG_mc.endFill(gLEFT, gTOP);
 
var target_mc:MovieClip = attachMovie("Target", "target", _root.getNextHighestDepth());
var startX:Number = (gRIGHT - gLEFT) / 2 + gLEFT;
var startY:Number = (gBOTTOM - gTOP) / 2 + gTOP;
startDrag(target_mc, true);
Mouse.hide();
 
onMouseDown = function():Void {
  createMissile(target_mc, startX, startY);
};
上一篇:利用材质和遮照创建真实的小球动画   下一篇:一个取颜色的东东
收藏此页】【打印】【关闭
 相关文章  我要点评
·FLASH小游戏开发 第七节
·让"Flash" 写文件(AS3)
·渐退方格效果(AS3)
·BitmapData与Matrix类打造超酷逼真水波效果
·flash中图形位置的半像素渲染问题
·婚纱影楼首页flash入口页设计大赛
·FLASH打造较酷菜单效果
·70多行颜色配对游戏Demo

免责声明:本站刊载此文不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。对本文有任何异议,请联络:68design#163.com
转载要求:作者及来源信息必需保留。转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印。



关于我们 | 在线反馈 | 广告报价 | 友情链接 | 联系我们 | 免责声明 | 在线投稿 | 网站地图
Copyright © 2003-2007 68design.net, All Rights Reserve 【找网页设计师,当然上网页设计师联盟】