var BitmapData0:BitmapData = new BitmapData(550, 400, false, 0x0);
var Bitmap0:Bitmap = new Bitmap(BitmapData0);
addChild(Bitmap0);
var dotArr:Array = new Array();
stage.addEventListener(MouseEvent.MOUSE_DOWN,mouse_down);
function mouse_down(evt:MouseEvent) {
var color:Number = 0xff000000+int(Math.random()*0xffffff);
for (var i:Number = 0; i<500; i++) {
var v:Number = Math.random()*10;
var a:Number =Math.random()*Math.PI*2;
var xx:Number = v*Math.cos(a)+stage.mouseX;
var yy:Number = v*Math.sin(a)+stage.mouseY;
var mouseP:Point=new Point(stage.mouseX,stage.mouseY);
if (Math.random()>0.6) {
var cc:Number = 0xffffffff;
} else {
cc= color;
}
dotArr.push([xx, yy, v*Math.cos(a), v*Math.sin(a), cc,mouseP]);
}
}
var cf:ConvolutionFilter = new ConvolutionFilter(3, 3, [1, 1, 1, 1, 32, 1, 1, 1, 1], 40,0);
stage.addEventListener(Event.ENTER_FRAME,enter_frame);
function enter_frame(evt:Event) {
for (var i:Number = 0; i<dotArr.length; i++) {
BitmapData0.setPixel32(dotArr[i][0],dotArr[i][1],dotArr[i][4]);
dotArr[i][0] += dotArr[i][2]*Math.random();
dotArr[i][1] += dotArr[i][3]*Math.random();
var dotP:Point=new Point(dotArr[i][0],dotArr[i][1]);
var b1:Boolean=Point.distance(dotP,dotArr[i][5])>80;
var b2:Boolean=Math.abs(dotArr[i][2])+Math.abs(dotArr[i][3])<0.5;
if ((b1 || b2) && Math.random()>0.9) {
dotArr.splice(i,1);
}
}
BitmapData0.applyFilter(BitmapData0.clone(),BitmapData0.rect,new Point(0, 0),cf);
}
AS3×××效果(鼠标点击-纯代码)
精选 转载上一篇:AS3连线效果
下一篇:WAMPServer配置
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章