电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 图形图象-> FLASH教程
flash 8制作烟花粒子的特效代码_flash教程
作者:网友供稿 点击:0
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 

  我这个Flash烟花粒子特效的制作其实很简单。

  第一步:在Flash中建立画布550*400(宽度随便设的,高度应在200以上,因为烟花显示的高度是200,这个也可以在代码里修改,代码第六行 var rect:Rectangle = new Rectangle(0, 0, Stage.width, 200); 这个200就是高度)
  第二步:在空白帧上点右键-动作 输入以下Action Script代码。

Stage.scaleMode = "noScale";
import flash.display.BitmapData;
import flash.filters.ConvolutionFilter;
import flash.geom.Rectangle;
var con = new ConvolutionFilter(3, 3, [1, 1, 1, 1, 30, 1, 1, 1, 1], 38);
var rect:Rectangle = new Rectangle(0, 0, Stage.width, 200);
var bitmap1 = new BitmapData(rect.width, rect.height, false,0x00000000);
var bitmap2 = new BitmapData(rect.width, rect.height, true,0x00000000);
var bitmapShow1 = createEmptyMovieClip("bitmapShow1", 1).attachBitmap(bitmap1, 1);
//粒子的显示画布
var bitmapShow2 = createEmptyMovieClip("bitmapShow2", 2).attachBitmap(bitmap2, 2);
//白色闪光点的显示画布
var m_mouseX;//鼠标x坐标
var m_mouseY;//鼠标y坐标
var sound1 = new Sound();
//上升过程的声音
var sound2 = new Sound();//爆炸声音
var bit_px = new Array(bits);//爆炸过程的x坐标
var bit_py = new Array(bits);//爆炸过程的y坐标
var bit_vx = new Array(bits);//爆炸过程的x速度
var bit_vy = new Array(bits);//爆炸过程的y速度
var bit_sx = new Array(bits);//上升过程的x坐标
var bit_sy = new Array(bits);//上升过程的y坐标
var bit_l = new Array(bits);//粒子的生命时间
var bit_f = new Array(bits);//是上升还是爆炸的标志
var bit_p = new Array(bits);//随机出现白色闪光点的标志
var bit_c = new Array(bits);//粒子颜色
init();
function init() {
 sound1.attachSound("sound1");
 sound2.attachSound("sound2");
 bits = 500;//总的最大粒子数
 bit_max = 50;//一次出现的粒子数
 bit_sound = 2;
 for (var j = 0; j<bits; j++) {
  bit_f[j] = 0;
 }
}
onEnterFrame = function () {
 bitmap2.fillRect(new Rectangle(0, 0, rect.width, rect.height), 0x00000000);
//白色闪光点清除
//bitmap2.applyFilter(bitmap, bitmap.rectangle, new Point(0, 0), con);
 rend();
 bitmap1.applyFilter(bitmap1, bitmap1.rectangle, new Point(0, 0), con);
//模糊滤镜
};
onMouseDown = function () {
 m_mouseX = _root._xmouse;
 m_mouseY = _root._ymouse;
 if (rect.contains(m_mouseX, m_mouseY)) {
  var k = int(Math.random()*256);
  var l = int(Math.random()*256);
  var i1 = int(Math.random()*256);
  var j1 = k << 16 | l << 8 | i1;
  var k1 = 0;
  for (var l1 = 0; l1<bits; l1++) {
   if (bit_f[l1] != 0) {
   continue;
  }
 bit_px[l1] = m_mouseX;
 bit_py[l1] = m_mouseY;
 var d = Math.random()*6.28;
 var d1 = Math.random();
 bit_vx[l1] = Math.sin(d)*d1/2;
 bit_vy[l1] = Math.cos(d)*d1/2;
 bit_l[l1] = int(Math.random()*100)+100;
 bit_p[l1] = int(Math.random()*3);
 if (random(4) == 0) {
  bit_c[l1] = 0xFFFFFF;
 } else {
  bit_c[l1] = j1;
 }
 bit_sx[l1] = m_mouseX;
 bit_sy[l1] = rect.height-5;
 bit_f[l1] = 2;
 if (++k1 == bit_max) {
  break;
 }
}
sound1.start(0);
}
};
function rend() {
 var flag:Boolean = false;
 var flag1:Boolean = false;
 var flag2:Boolean = false;
  for (var k = 0; k<bits; k++) {
   switch (bit_f[k]) {
   case 1 : // 爆炸过程
    bit_vy[k] += Math.random()/100;
    bit_px[k] += bit_vx[k];
    bit_py[k] += bit_vy[k];
    bit_l[k]--;
    if (bit_l[k] == 0 || !rect.contains(bit_px[k], bit_py[k])) {
     bit_c[k] = 0x000000;
     bit_f[k] = 0;
    } else if (bit_p[k] == 0) {
     if (int(Math.random()*2) == 0) {
      bit_setwhite(int(bit_px[k]), int(bit_py[k]), 0xFFFFFFFF);
     }
     bit_set(int(bit_px[k]), int(bit_py[k]), int(bit_c[k]));
    } else {
     bit_set(int(bit_px[k]), int(bit_py[k]), int(bit_c[k]));
    }
    break;
   case 2 :  // 上升过程
    bit_sy[k] -= 5;
    if (bit_sy[k]<=bit_py[k]) {
     bit_f[k] = 1;
     flag2 = true;
    }
    if (int(Math.random()*20) == 0) {
     var i = int(Math.random()*2);
     var j = int(Math.random()*5);
     bit_set(bit_sx[k]+i, bit_sy[k]+j, 0xFFFFFF);
    }
    break;
   }
  }
  if (flag2) {
   sound2.start(0);
  }
 }
 function bit_set(i:Number, j:Number, k:Number) {
 bitmap1.setPixel(i, j, k);
}
function bit_setwhite(i:Number, j:Number, k:Number) {
 bitmap2.setPixel32(i, j, k);//白色闪光点
}
 

  最后测试影片。


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·用photoshop打造红砖墙上的粉笔画_photoshop教程
·vb中使用dde技术为应用程序增辉_visualbasic教程
·用vb测定可移动驱动器是否准备好_visualbasic教程
·用photoshop通道制作立体光影质感_photoshop教程
·flash动态解析web应用程序服务器路径_flash教程
·flash+xml 在 dnn系统开发中的应用 _flash教程
·浮动视口_autocad教程
·photoshop滤镜特效:染色布纹肌理_photoshop教程
·如何恢复被破坏的windows xp系统文件_windows xp
·把按钮藏起来 谈制作flash课件时的隐形处理_flash教程

最新文章
·flash中作毛笔写字动画效果_flash教程
·用flash as代码制作按钮弹出窗口_flash教程
·让flash动画适应任何分辨率的网页_flash教程
·用photoshop去除照片中文字_photoshop教程
·用flash 8 as代码写摄像头拍照功能_flash教程
·flash as代码简单实现动态文本包边效果_flash教程
·深入了解flash as中的setinterval方法_flash教程
·关于flash中注册点与中心点的区别_flash教程
·flash与后台编码兼容性问题的解决方案_flash教程
·用flash轻松制作鼠标点击发散特效动画_flash教程


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号