http://www.citydna.cn/works/etboy.asp
以Flash 8制作烟花粒子特效
动作代码如下:(代码来自flash8,现学现用,HOHO~~)
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);
//白色闪光点
}
Flash 8制作烟花粒子特效相关推荐:
无相关信息Recommend design / flashl教程精彩推荐
-
Flash制作“时空穿梭” 本教程主要利用Flash 8制作一个“时空穿梭”效果动画,不涉及...
-
Flash制作随意飘飞的彩 本文中我们用Flash制作随意飘飞的彩色肥皂泡动画。 完成效果如...
-
Flash实例教程:“蝶恋 通过这个蝴蝶在花丛中翻飞的实例我们可以学习Flash图层、引导...
-
Flash鼠标触发模糊图片 这个互动特效很有意思:大家将鼠标指针放到模糊图片上,即可...
« 返回顶部 « 返回flashl教程 « 返回Design80首页
Design Search / 搜索
Last update / flashl教程近期更新
Other design / 此文章读者还会浏览
-
看各国跑车风格去分析各国的设计 由于国情、民风、技术的不同,世界各国在跑车的设计理念上,有着...
-
中国民俗文化宝-门神人物欣赏(一 门神:旧时农历新年贴于门上的一种画类。 门神是道教和民间共同信...
-
中国民俗文化宝-门神人物欣赏(二 随着社会的发展和意识形态的变化,人们对于门神的要求,已不仅是...
-
东方商厦全套VI设计欣赏(图文) 优秀的VI设计在于明显地将该企业与其他企业区分开来的同时又确立...
-
MAX品牌全套VI设计 VI视觉设计,是企业VI形象设计的重要组成部分。随着社会的现代化...
Comments / 发表评论
-
发表评论,请使用文明用语,遵守网上公德以及相关法律法规。评论在审核通过后才会显示。
- More Comments ( 条)
Copyright © Design80.com.CN. All Rights Reserved. Template Design by Design80.com.CN 友情合作:gululu8#gmail.com
粤ICP备08007657号




PREV




