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

Flash动画制作
AS3.0实用代码:绘制各种各样三角形
AS代码研究实例:随即运动参数的传递应用
Flash制作3D类动画的教程
Flash AS3制作个性的旋转圆形网页导航
Flash AS2实例:跳动的小球动画效果
Flash交互动画制作技巧:按钮控制动画
Flash AS教程:详细讲解Math对象
Flash动画制作技巧:搞笑动画制作实例
Flash制作技巧:人物行走动画制作剖析
Flash AS3常用的关于MC的代码
Flash AS3.0教程:间隔循环的3种表现方式
Flash动画实例:简单的流星雨动画特效
Flash制作高级的人物行走动画
10个让你大饱眼福的创意Flash网站
Flash实例教程:吸管喝饮料动画
Flash CS4实例教程:漂亮的气泡动画
汇总网页传递参数到flex中的三种方法
AS教程:加载与被加载swf内部变量相互调用
Flash CS4教程:文字颜色缓动特效
Flash CS实例教程:幸运大抽奖动画

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-22   浏览: 123 ::
收藏到网摘: 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了,别忘了把背景图放到最下层哦.你也可以多复制一些调整大小,这个大家自己发挥了