手机
当前位置:查字典教程网 >网页设计 >Flash教程 >Flash as3代码打造漂亮的轻纱般变幻线效果
Flash as3代码打造漂亮的轻纱般变幻线效果
摘要:这篇教程是向查字典教程网的朋友介绍利用Flashas3代码打造漂亮的轻纱般变幻线效果,教程制作出来的效果非常漂亮,也很简单,适合新手学习,推...

这篇教程是向查字典教程网的朋友介绍利用Flash 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 as3代码打造漂亮的轻纱般变幻线效果过程,希望对大家有所帮助!

【Flash as3代码打造漂亮的轻纱般变幻线效果】相关文章:

教你用Flash AS行代码简单画一棵漂亮的树

Flash CS3制作卡片翻转效果

Flash实例教程:AS3.0打造漂亮水纹效果

Flash as3嵌入中文字体的方法

Flash AS3代码打造绚烂的星形变幻效果

flash AS打造图片滚动效果

用Flash制作按钮效果

Flash用AS2代码制作图片循环效果

Flash8 滤镜制作漂亮图片动画效果

Flash制作逐一出现的发光字动画效果

精品推荐
分类导航