当前位置: 首页 > 图文教程 > Flash动画 > ActionScript > Flash AS实例:随风飘摆的大红灯笼

ActionScript
将FlashVars写在JS函数中,实现变量更新与后台同步
Flash与Flex3结合学习心得体会
Flash AS简单制作画线条动画
Flash教程:如何把库中的元件加载到场景中
Flash AS3运行错误参考文档
Flash AS3制作自由落体运动代码解析
多层级加载相对路径遇到的问题解决方法
加载PNG后其透明区域不响应事件
AS3教程:按顺序播放多个FLV视频
Flash AS与JS的互动
Flash AS实例:智力过河小游戏源代码
Flash as教程:图片模糊运动
Flash AS3实例教程:物体运动速度向量(velocity)
Flash AS3.0教程:学习帧循环的运用
Flash AS3动态改变影片剪辑元件颜色
Flash AS 制作创意的鼠标经过的网页导航
Flash AS实例教程 会眨眼的美女
Flash AS2实例 跳动的小球动画效果
Flash AS3实例:制作好看的七彩小球动画
AS2.0高级滤镜效果如何用在JPG图片上

ActionScript 中的 Flash AS实例:随风飘摆的大红灯笼


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-03-20   浏览: 387 ::
收藏到网摘: n/a

 灯笼——全脚本绘制,先看绘制效果:


详细代码:


[SWF(backgroundColor=0x004890,width=550,height=400)]

var denglong:MovieClip =new MovieClip();

addChild(denglong);

denglong.x=275;

denglong.y=0;

denglong.rotation=5;

var rota:Number=0;

denglong.addEventListener(Event.ENTER_FRAME ,frame);

function frame(e) {

        var xs:Number=(0-denglong.rotation)*0.01;

        rota+=xs;

        denglong.rotation+=rota;

}

var diaoxian:Shape =new Shape();

denglong.addChild(diaoxian);

diaoxian.graphics.lineStyle(6, 0xcc6600);

diaoxian.graphics.moveTo(0,0);

diaoxian.graphics.lineTo(0,50);

function Rect():Sprite {

        var sp:Sprite =new Sprite();

        sp.graphics.beginGradientFill("linear" ,[0xffbe17,0xf8fd97,0xffbe17],[1,1,1],[0,128,255]);

        sp.graphics.drawRoundRect(-50,-10,100,20,15,13);

        var mc:Shape=new Shape();

        sp.addChild(mc);

        mc.graphics.lineStyle(1.5,0x996633,1);

        mc.graphics.drawRoundRect(-48,-9,96,18,13,12);

        return sp;

}

for (var c:int=0; c<4; c++) {

        var rect:Sprite=Rect();

        denglong.addChild(rect);

        c%2==0?[rect.scaleX=rect.scaleY=0.7,rect.y=50+c*107]:rect.y=c*90-23;

}

function Huxian(n:int):Shape {

        var hu:Shape=new Shape();

        hu.graphics.beginFill(0xffbe17,1);

        hu.graphics.moveTo(0,0);

        hu.graphics.curveTo(n,80,0,160);

        hu.graphics.curveTo(n+5,80,0,0);

        return hu;

}

var ellip:Sprite=new Sprite();

denglong.addChildAt(ellip,0);

ellip.y=158;

ellip.graphics.beginGradientFill("radial" ,[0xfea408,0xe20708],[1,1],[0,255]);

ellip.graphics.drawEllipse(-120,-85,240,170);

for (var d:int=0; d<4; d++) {

        var n:int;

        var huxian:Shape=Huxian(d%4==0?n=-80:d%4==1?n=-60:d%4==2?n=60:d%4==3?n=80:0);

        ellip.addChild(huxian);

        huxian.x=-45+d*30;

        huxian.y=-80;

}

function line():Sprite {

        var sp:Sprite =new Sprite();

        sp.graphics.lineStyle(0.5,0xffff00,1);

        sp.graphics.moveTo(0,0);

        sp.graphics.lineTo(0,60);

        return sp;

}

for (var a:int=0; a<15; a++) {

        var mc:Sprite=line();

        denglong.addChild(mc);

        mc.x=a*4-28;

        mc.y=270;

}