Forked from: nutsu's forked from: Liquid10000 diff:5 forked from: forked from: Liquid10000 50,000 ぐらいやとなんとか動くかなぁ nutsu forked:5favorite:3lines:96license : All rights reserved modified : 2009-04-15 11:45:49 Embed Tweet // forked from nutsu's forked from: Liquid10000 // forked from zin0086's Liquid10000 // 50,000 ぐらいやとなんとか動くかなぁ package { import flash.display.Stage; import flash.display.StageAlign; import flash.display.StageScaleMode; import flash.display.Sprite; import flash.display.Bitmap; import flash.display.BitmapData; import flash.geom.ColorTransform; import flash.geom.Rectangle; import flash.events.Event; import flash.events.MouseEvent; [SWF(width="465", height="465", backgroundColor="0x000000", frameRate="60")]; public class Liquid extends Sprite { private const nums:uint = 50000; private var bmpDat:BitmapData; private var vectorDat:BitmapData; private var randomSeed:uint = Math.floor( Math.random() * 0xFFFF ); private var bmp:Bitmap; private var vectorList:Array; private var rect:Rectangle; private var cTra:ColorTransform; public function Liquid() { initialize(); } private function initialize():void { stage.align = StageAlign.TOP_LEFT; stage.scaleMode = StageScaleMode.NO_SCALE; stage.frameRate = 60; bmpDat= new BitmapData( 465, 465, false, 0x000000 ); vectorDat= new BitmapData( 465, 465, false, 0x000000 ); randomSeed= Math.floor( Math.random() * 0xFFFF ); vectorDat.perlinNoise( 230, 230, 4,randomSeed, false, true, 1|2|0|0 ); bmp= new Bitmap( bmpDat ); addChild( bmp ); rect = new Rectangle( 0, 0, 465, 465 ) cTra = new ColorTransform( 0, .8, .8, .9 ); vectorList = []; for (var i:uint = 0; i < nums; i++) { var px:Number = Math.random()*465; var py:Number = Math.random()*465; vectorList.push( new VectorDat(px,py) ); } addEventListener( Event.ENTER_FRAME, loop ); stage.addEventListener( MouseEvent.CLICK, resetFunc ); } private function loop( e:Event ):void { bmpDat.lock(); bmpDat.colorTransform( rect, cTra ); var len:uint = vectorList.length; for (var i:uint = 0; i < len; i++) { var dots:VectorDat = vectorList[i]; var col:Number = vectorDat.getPixel( dots.px, dots.py ); dots.ax += ( (col >> 16 & 0xff)-128 ) * .0005; dots.ay += ( (col >> 8 & 0xff)-128 ) * .0005; dots.vx += dots.ax; dots.vy += dots.ay; dots.px += dots.vx; dots.py += dots.vy; var _posX:Number = dots.px; var _posY:Number = dots.py; dots.ax *= .96; dots.ay *= .96; dots.vx *= .92; dots.vy *= .92; ( _posX > 465 )?dots.px = 0: ( _posX < 0 )?dots.px = 465:0; ( _posY > 465 )?dots.py = 0: ( _posY < 0 )?dots.py = 465:0; bmpDat.setPixel( dots.px, dots.py, 0xffffff ); } bmpDat.unlock(); } private function resetFunc(e:MouseEvent):void{ randomSeed= Math.floor( Math.random() * 0xFFFF ); vectorDat.perlinNoise( 230, 230, 4,randomSeed, false, true, 1|2|0|0 ); vectorList= []; for (var i:uint = 0; i < nums; i++) { var px:Number = Math.random()*465; var py:Number = Math.random()*465; vectorList.push( new VectorDat( px, py ) ); } } } } class VectorDat { public var vx:Number = 0; public var vy:Number = 0; public var ax:Number = 0; public var ay:Number = 0; public var px:Number; public var py:Number; function VectorDat( px:Number, py:Number ) { this.px = px; this.py = py; } } Code Fullscreen Preview Fullscreen nilab yoshifuto cellfusion perlinNoise Math.floor colorTransform Rectangle unlock lock setPixel getPixel rect push MouseEvent.ENTER_FRAME MouseEvent.CLICK MouseEvent BitmapData Math.random length uint Array Number sort new page view favorite forked pv1029 forked from: forked from: fork.. XELF forked:0 favorite:2lines:101 (diff:57) tag: PerlinNoise lines liquid noise particle particles random waves pv0 forked from: forked from: fork.. lapin forked:0 favorite:0lines:96 (diff:1) pv308 forked from: forked from: fork.. hacker_m7kirhoe forked:0 favorite:1lines:98 (diff:8) tag: liquid particles pv0 forked from: forked from: fork.. Iceshower forked:0 favorite:0lines:96 (diff:1) pv3163 forked from: forked from: fork.. Saqoosha forked:5 favorite:20lines:99 (diff:25) tag: Particle filter liquid particles particule perlinNoise パーティクル