首页 | 网页设计 | w3c标准 | flash动画 | 平面设计 | 经典文章 | 特约专题 | 资源下载 | 健康频道 | 重庆品牌网站 | 留言簿 | 
技术文章  资源下载 经典素材  社区论坛
   
 您现在的位置: vi设计在线 >> 经典文章 >> ccqvi动态 >> 技术应用 >> 正文  
  as3打造轻纱般的变幻线效果         
[ 作者:佚名    转贴自:本站原创    点击数:1347    更新时间:2010/5/31    文章录入:diyi880

减小字体 增大字体

as3打造轻纱般的变幻线效果


详细代码:

package {



        import flash.display.Sprite;

        import flash.display.Bitmap;

        import flash.display.BitmapData;

        import flash.events.MouseEvent;

        import flash.events.Event;

        import flash.geom.Point;

        import frocessing.math.PerlinNoise;

        import frocessing.color.ColorHSV;

        //import org.libspark.utils.GeomUtil;



        [SWF(backgroundColor="#000000", width="465", height="465", frameRate="30")]



        public class Main13 extends Sprite {

                private var canvas:Sprite;

                private var bitmap:Bitmap;

                private var bitmapData:BitmapData;

                private static var bWidth:uint = 600;

                private static var bHeight:uint = 600;

                private static var segments:uint = 5;

                private static var ratio:Number = 1/segments;

                private static var colors:uint = 360;

                private var perlin:PerlinNoise;

                private var color:ColorHSV;

                private var t:Number = 0;

                private var c:uint = 0;

                private static var tightness:uint = 40;



                public function Main13() {

                        //Wonderfl.capture_delay(30);

                        stage.frameRate = 120;

                        init();

                }



                private function init():void {

                        graphics.beginFill(0x000000);

                        graphics.drawRect(0, 0, 465, 465);

                        graphics.endFill();

                        canvas = new Sprite();

                        bitmapData = new BitmapData(bWidth, bHeight, true, 0x00000000);

                        bitmap = new Bitmap(bitmapData);

                        addChild(bitmap);

                        bitmap.y = uint((bWidth - bHeight)/2);

                        perlin = new PerlinNoise();

                        color = new ColorHSV();

                        addEventListener(Event.ENTER_FRAME, draw, false, 0, true);

                        stage.addEventListener(MouseEvent.CLICK, reset, false, 0, true);

                }

                private function draw(evt:Event):void {

                        canvas.graphics.clear();

                        color.h = c;

                        canvas.graphics.lineStyle(0, color.value, 0.2);

                        c ++;

                        c %= colors;

                        bitmapData.lock();

                        var points:Array = new Array();

                        points.push(new Point(-bWidth*ratio, bHeight*0.5));

                        for (var n:uint = 1; n <= segments+1; n++) {

                                var xPos:Number = n*bWidth*ratio;

                                var yPos:Number = perlin.noise(n*0.25, t)*bHeight;

                                points.push(new Point(xPos-bWidth*ratio, yPos));

                        }

                        t += 0.01;

                        points.push(new Point(bWidth*(1+ratio), bHeight*0.5));

                        points.unshift(points[0]);

                        points.push(points[points.length-1]);

                        canvas.graphics.moveTo(points[0].x, points[0].y);

                        for (var p:uint = 0; p < points.length-3; p++) {

                                var p0:Point = points[p];

                                var p1:Point = points[p+1];

                                var p2:Point = points[p+2];

                                var p3:Point = points[p+3];

                                for (var s:uint = 1; s < tightness+1; s++) {

                                        //var px:Number = GeomUtil.spline(p0.x, p1.x, p2.x, p3.x, s/tightness);

                                        //var py:Number = GeomUtil.spline(p0.y, p1.y, p2.y, p3.y, s/tightness);

                                        var px:Number = spline(p0.x, p1.x, p2.x, p3.x, s/tightness);

                                        var py:Number = spline(p0.y, p1.y, p2.y, p3.y, s/tightness);

                                        canvas.graphics.lineTo(px, py);

                                }

                        }

                        bitmapData.draw(canvas);

                        bitmapData.scroll(0,1);                

                        bitmapData.unlock();

                }

                private function spline(p0:Number, p1:Number, p2:Number, p3:Number, t:Number):Number {

                        var v0:Number = (p2 - p0) * 0.5;

                        var v1:Number = (p3 - p1) * 0.5;

                        var t2:Number = t * t;

                        var t3:Number = t2 * t;

                        return (2 * p1 - 2 * p2 + v0 + v1) * t3 + ( -3 * p1 + 3 * p2 - 2 * v0 - v1) * t2 + v0 * t + p1;

                }

                private function reset(evt:MouseEvent):void {

                        bitmapData.lock();

                        bitmapData.fillRect(bitmapData.rect, 0x00000000);

                        bitmapData.unlock();

                }



        }



 上一篇文章: FLASH中设置动态文本的半透明效果(as2)
 下一篇文章: AS3文档类打造绚烂星形变幻效果
发表评论】【告诉好友】【打印此文】【关闭窗口


技术文章  资源下载
经典素材  社区论坛
 中大型美容美发店老…[1183]
 重庆多达学习俄语培…[2469]
 重庆恒祥广告有限公…[2085]
 重庆市南方阻燃电线…[2496]
 重庆舞美灯光音响有…[3255]
 重庆德鼎滤油机有限…[2010]
 重庆民生建材有限公…[2446]
 重庆集元科技有限公…[4222]
 重庆倍润商贸有限公…[2088]
 重庆腾达展览有限公…[3155]
 帝一网络创始人宣…--[3278]
 重庆vi设计在线祝…--[2826]
 重庆帝一网络书生…--[2942]
 馋嘴鸭的起伏和经…--[3107]
 机器感觉“卡”的…--[3015]
 ActionScript3打造…--[6031]
 在ASP文件中读取H…--[7326]
 vi设计经典案例--[64330]
 帅到掉渣-爆笑版勇…--[7190]
 一个女孩写的经典…--[6967]
没有相关文章
 (只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    没有任何评论
设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 重庆网站建设 | 
版权所有: vi设计在线  © 2005-2018 网站备案序号:渝ICP备06003824号
技术支持:帝一网络(重庆网站建设专家)