当前位置: 首页 > 图文教程 > Flash动画 > Flash动画制作 > Flash教程:AS制作复制美丽爱心效果

Flash动画制作
Flash制作超酷的旋转图像像册视觉效果
Flash轻松制作2008北京奥运邮票
Flash入门:制作圆形路径运动动画的技巧
在Flash中制作紧紧跟随鼠标的按钮说明文字
Flash制作动画的经典问题问答
Flash入门实例:制作有趣的拍照效果动画
高级游戏制作:Flash制作物体弹跳电脑游戏
Flash形状补间打造霓虹灯效果
用Flash AS简单制作可以任意拖动的四边形
Flash游戏制作基础:跟随鼠标的曲线
用Flash制作课件中的倒计时动画效果
Flash形状补间动画:看我七十二变教程
用Flash制作折扇动画
Flash简单制作文字遮罩效果
Flash打造美丽星空特效
Flash简单制作打字效果
Flash在课件中加个画水平线工具
Flash绘制卡通女孩头像
Flash鼠标跟随教程:制作蜻蜒点水
Flash教程:浇筑效果的制作

Flash动画制作 中的 Flash教程:AS制作复制美丽爱心效果


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-22   浏览: 135 ::
收藏到网摘: n/a

效果演示:(鼠标移到影片剪辑中心位置,看看效果)

1:先在场景绘制一个任意形,图像也可以,f8转换为影片剪辑

2:紧接着,按f8再转换一次影片剪辑"元件2"(也可以ctrl+F8拖进去,这里是个人习惯)

3:双击进入"元件2",给影片剪辑起名称为"aqua0"

4:新建图层2,层2第一帧点右键,给动作.

5:给第二层依次按f7插入三个空白关键帧.他们的action依次是

第一帧:

d = 0;
i = 0;
numAqua = 0;
minAlpha = 70;
threshold = 500;
clp = aqua0;
maxChange = 1.57;
maxChange2 = 1.04666666666667;
halfMax = maxChange/2;
halfMax2 = maxChange2/2;
maxSpeed2 = 2;
trajectory = new Array(15);
trajectory[0] = 0;

第二帧:

i = numAqua;
while (i>=0) {
baseClip = eval("aqua"+i);
dx = baseClip._x-_xmouse;
dy = baseClip._y-_ymouse;
d = Number(Math.sqrt((dx*dx)+(dy*dy)));
if (threshold<d) {
            d = threshold;
}
closeness = (Math.pow(((threshold-d)/threshold)*10, 1.8)*0.016)*100;
if (!closeness) {
            closeness = 0;
}
if (0<closeness) {
            if (97<closeness) {
             if (baseClip._xscale<20) {
              removeMovieClip(baseClip);
             }
             if (numAqua<15) {
              numAqua = numAqua+1;
              duplicateMovieClip("aqua"+i, "aqua"+numAqua, numAqua);
              newClip = eval("aqua"+numAqua);
              trajectory[numAqua] = 0;
              colors[numAqua] = new Color(newClip);
              currentColor[numAqua] = new Object();
              colors[numAqua].setTransform(currentColor[numAqua]);
              newClip._x = newClip._x+(random(5)+5);
              newClip._y = newClip._y+(random(5)+5);
              baseClip._xscale = baseClip._xscale-20;
              baseClip._yscale = baseClip._yscale-20;
              newClip._xscale = baseClip._xscale;
              newClip._yscale = baseClip._yscale;
             }
            }
            currentColor[i].ra = startR-((closeness*0.01)*(startR-endR));
            currentColor[i].ga = startG-((closeness*0.01)*(startG-endG));
            currentColor[i].ba = startB-((closeness*0.01)*(startB-endB));
            colors[i].setTransform(currentColor[i]);
            a = (closeness*(100-minAlpha))*0.01;
            baseClip._alpha = a+minAlpha;
            speed = closeness/8;
            angle = (Math.random()*100)%maxChange;
            trajectory[i] = (trajectory[i]-halfMax)+angle;
} else {
            currentColor[i].ra = startR-((closeness*0.01)*(startR-endR));
            currentColor[i].ga = startG-((closeness*0.01)*(startG-endG));
            currentColor[i].ba = startB-((closeness*0.01)*(startB-endB));
            colors[i].setTransform(currentColor[i]);
            a = (closeness*(100-minAlpha))*0.01;
            baseClip._alpha = a+minAlpha;
            speed = maxSpeed2;
            angle = (Math.random()*100)%maxChange2;
            trajectory[i] = (trajectory[i]-halfMax2)+angle;
}
vx = speed*Math.cos(trajectory[i]);
vy = speed*Math.sin(trajectory[i]);
baseClip._x = baseClip._x+vx;
baseClip._y = baseClip._y+vy;
i = i-1;
}

第三帧:

gotoAndPlay(2); 

6:基本上大功告成,最后,回到场景,新建一个层,加个背景图就ok了,别忘了把背景图放到最下层哦.你也可以多复制一些调整大小,这个大家自己发挥了