forked from: のんびり眺める用
forked from のんびり眺める用 (diff: 32)
角度の黄金比分割とか 出展 - Nature by Number http://www.etereaestudios.com/movies/nbyn_movies/nbyn_mov_youtube.htm
ActionScript3 source code
/**
* Copyright neconi ( http://wonderfl.net/user/neconi )
* MIT License ( http://www.opensource.org/licenses/mit-license.php )
* Downloaded from: http://wonderfl.net/c/jPp5
*/
// forked from keno42's のんびり眺める用
// forked from keno42's ひまわりっぽいやつ
// 角度の黄金比分割とか 出展 - Nature by Number http://www.etereaestudios.com/movies/nbyn_movies/nbyn_mov_youtube.htm
package
{
import flash.display.*;
import flash.events.*;
import flash.geom.*;
import flash.filters.*;
import flash.utils.*;
public class Main extends Sprite {
private var MAX_NUM:int = 900;
private var num:int = MAX_NUM;
//private var gv:Number = 0;
//private var ga:Number = 0;
private var angle:Number = 0;
private var firstP:Particle = new Particle();
private var lastP:Particle = firstP;
private var bmpData:BitmapData = new BitmapData(465,465,false,0x0);
private var timer:Timer = new Timer(4000);
public function Main() {
// write as3 code here..
this.addEventListener(Event.ENTER_FRAME, onEnterFrame);
var bmp:Bitmap = new Bitmap( bmpData );
bmp.blendMode = BlendMode.HARDLIGHT;
addChild(bmp);
shoot(firstP, angle);
timer.addEventListener(TimerEvent.TIMER, onTimer);
stage.addEventListener(MouseEvent.CLICK, onClick);
timer.start();
}
private function onClick(e:MouseEvent):void{
randomRefresh();
}
private function onTimer(e:TimerEvent):void{
randomRefresh();
}
private function randomRefresh():void{
if( num != 0 ) return;
var tempNum:int = MAX_NUM;
var p:Particle = firstP;
var angleDiff:Number = Math.random() * Math.PI * 2;
//var rBase:int = Math.random() * 0xFF;
//var gBase:int = Math.random() * 0xFF;
//var bBase:int = Math.random() * 0xFF;
//var rGoal:int = Math.random() * 0xFF;
//var gGoal:int = Math.random() * 0xFF;
//var bGoal:int = Math.random() * 0xFF;
angle = 0;
do {
tempNum--;
angle += angleDiff;
p.toX = 232 + Math.sqrt(tempNum) * Math.cos(angle) / (MAX_NUM / 9000);
p.toY = 232 + Math.sqrt(tempNum) * Math.sin(angle) / (MAX_NUM / 9000);
p.color = 0x66DDFF; //メモ:色決めの計算が分からないので後で理解する
//Math.floor(rBase + ( (rGoal-rBase) * tempNum / MAX_NUM )) << 16 |
//Math.floor(gBase + ( (gGoal-gBase) * tempNum / MAX_NUM )) << 8 |
//Math.floor(bBase + ( (bGoal-bBase) * tempNum / MAX_NUM ));
} while( p = p.next );
}
private function onEnterFrame(e:Event):void{
var p:Particle = firstP;
bmpData.lock();
do {
p.update();
bmpData.setPixel(p.x, p.y, p.color);
} while( p = p.next )
bmpData.applyFilter(bmpData,bmpData.rect,new Point(),new BlurFilter(3,3));
bmpData.unlock();
//if( num > 0 ){
for( var i:int = 0; i < num; i++ ){
num--;
var temp:Particle = new Particle();
angle += Math.PI * 137.5077 / 180;
shoot(temp, angle);
lastP.next = temp;
lastP = temp;
if( num == 0 ) break;
}
//gv += ga;
//ga += 1;
//}
}
private function shoot(p:Particle, angle:Number):void{
p.x = 232;
p.y = 232;
p.toX = 232 + Math.sqrt(num) * Math.cos(angle) / (MAX_NUM / 9000);
p.toY = 232 + Math.sqrt(num) * Math.sin(angle) / (MAX_NUM / 9000);
p.color = 0x66DDFF;
//(0xCC + Math.ceil( 0x33 - 0x33 * num / MAX_NUM )) << 16 |
//(0x88 + Math.ceil( 0x77 - 0x77 * num / MAX_NUM )) << 8 |
//(Math.ceil( 0x44 * num / MAX_NUM ));
}
}
}
final class Particle
{
public var x:Number;
public var y:Number;
public var toX:Number;
public var toY:Number;
public var color:uint;
public var next:Particle;
public function update():void{
x += 1 * (toX-x); //メモ:移動量の計算変えた
y += 0.1 * (toY-y);
}
}