html5 canvas宇宙粒子星系网页背景动画特效

来源:https://www.sucaihuo.com/js/3765.html 2018-06-23 11:33浏览(1522) 收藏

一款十分简洁的html5 canvas宇宙粒子星系网页背景动画特效,动态粒子背景动画效果。
html5 canvas宇宙粒子星系网页背景动画特效
分类:html5 > canvas 难易:初级
查看演示 下载资源 下载积分: 10 积分

js代码

<script>
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
var w = canvas.width;
var h = canvas.height;

var part_count = 600;
var P = [];
var X, Y;
var angle = 0.01;
var centerX = w * 0.5,
    centerY = h * 0.5;

var part = function(x,y,ix,iy,vx,vy,a,dist) {
  this.x = x;
  this.y = y;
	this.ix = ix;
  this.iy = iy;
  this.vx = vx;
  this.vy = vy;
  this.a = a;
  this.dist = dist;
}

function init(){
  var x,y,ix,iy,vx,vy,a,dist;
  for(var i=0; i<part_count;i++){
    ix = x;
    iy = y;
    vx = random(-1,1);
    vy = random(-1,1);
    rand = random(-80,100);
    dist = part_count/10+i;
    a = 1;
    
    P.push(new part(x,y,ix,iy,vx,vy,a,dist));
  }
}
init();

function bg(){
  ctx.fillStyle = '#000000';
  ctx.globalAlpha=0.25;
  ctx.fillRect(0,0,canvas.width,canvas.height,1);
}

function distance(dx,dy){
  return Math.sqrt(dx * dx + dy * dy);
}

function draw(){
  for(var i=0; i<P.length;i++){
    var p = P[i];
    
    p.a += 0.008;
    p.x = centerX + Math.cos(i+p.a) * (p.dist*i*0.1);
    p.y = centerY + Math.sin(i+p.a) * (p.dist);
    ctx.fillStyle = '#FFFFFF';
    ctx.fillRect(p.x, p.y,2, 2);
  }
}


function loop(){
  bg();
  draw();
  window.requestAnimationFrame(loop);
}
loop();

function resize(){
  canvas.width = window.innerWidth;
  canvas.height = window.innerHeight;
  centerX = window.innerWidth * 0.5;
  centerY = window.innerHeight * 0.5;
}

function random(min, max) {
  return Math.random() * (max - min) + min;
}

window.onresize = resize;</script>
评论0
头像

系统已开启自动识别垃圾评论机制,识别到的自动封号,下载出错或者资源有问题请联系全栈客服QQ 1915635791

1 2