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

ActionScript
AS教程:ActionScript优化
AS3教程:密码强度验证
AS3编程心得
AS 3.0未公开的addFrameScript()方法
网页FLASH动画禁止右键菜单的方法
代码最优化实例
AS3实现以二进制方式播放mp3文件
Flex开发的基于浏览器的WEB操作系统
WEBJX收集的AS3非常有用的类库
通过实例学习flash AS3.0:案例二
Flash教程:ActionScript编程基础
Flash as入门(2):面向对象编程基础
Flex的背景和技术特点
参考:AS3及Flex的常用实用问题
Flash AS实例:随机移动动画特效
Flash AS教程:对拖到指定区域小球计数
Flash AS:用Point简单制作虚线特效
Flash的AS3代码制作模糊滤镜动画特效
Flash as入门(6):文本与字符串游戏实例
Flash as入门(7):创建影片剪辑

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-03-20   浏览: 393 ::
收藏到网摘: 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;

}