Главная » Файлы » Прочие скрипты » HTML5

Великолепный объёмный снег на HTML5 canvas для вашего сайта
08.11.14, 01:06:20



Очень здорово смотрится, есть настройки. При удачно подобранном фоне видно, что снежок очень объёмный и выглядит очень реалистично

Для начала посмотрите ДЕМО

Моё тестирование в фидле: КЛИК

Установка:

В самый низ вашего css вставляйте:
Код
#cvs {
  position: fixed;
  top:0px;
  left:0px;
  z-index:-1;
}


Следующий код вставляйте на нужных страницах после < /head >:
Код
<canvas id="cvs" height="500" width="1920"></canvas>
<script>
/************* SHIM ************************/
window.requestAnimFrame = (function () {
  return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (callback) {
  window.setTimeout(callback, 1000 / 60);
  };
})();
/********************************************/
var canvas = document.getElementById('cvs'),
  ctx = canvas.getContext('2d'),
  height = canvas.height = document.body.offsetHeight,
  width = canvas.width = document.body.offsetWidth,
  collection = [],
  num_drops = 500, // количество снежинок
  gravity = 1, // скорость падения  
  windforce = 5, // хрень какая-то
  windmultiplier = 5, // тож непонятная переменная
  maxspeed = 3, // максимальная скорость движения снежинки
  gutter = 0; // процент расстояния от низа экрана, где снежинки тают

function Drop() {
  this.x;
  this.y;
  this.radius;
  this.distance;
  this.color;
  this.speed;
  this.vx;
  this.vy;
}
Drop.prototype = {
  constructor: Drop,

  random_x: function () {
  var n = width * (1 + gutter);
  return (1 - (1 + gutter)) + (Math.random() * n);
  },
  draw: function (ctx) {
  ctx.fillStyle = this.color;
  ctx.beginPath();
  ctx.arc(this.x, this.y, this.radius, 0, Math.PI * 2, false);
  ctx.closePath();
  ctx.fill();
  }
};

function draw_frame() {
  // this was recommended (see comments)
  // check it out, just comment out the  
  // ctx.clearRect(0, 0, width, height);
  // line and uncomment the three below:

  //ctx.globalCompositeOperation="darker";
  //ctx.fillStyle="rgba(0,0,0,0.5)";
  //ctx.fillRect(0,0,width,height);  
  ctx.clearRect(0, 0, width, height);

  // in a previous attempt I even go as far
  // as to ensure i'm drawing the furthest particles  
  // first for the z-index overlay.
  // in this run I felt it was unneeded
  collection.forEach(function (drop) {
  // costly but ultimatly I think it's worth it for now
  // I muck with the opacity to help with the illusion of depth
  ctx.globalAlpha = (drop.distance + 1) / 10;
  drop.draw(ctx);
  ctx.globalAlpha = 1;
  drop.x += drop.vx;
  drop.y += drop.vy;
  var lx = drop.vx + windforce;
  lx < maxspeed && lx > 1 - maxspeed && (drop.vx = lx);
  if (drop.y > (drop.distance + 1) / 10 * height) {
  drop.y = Math.random() * -drop.radius * (num_drops / 10);
  drop.x = drop.random_x();
  }
  if (drop.x > width * (1 + gutter)) {
  drop.x = 1 - (width * gutter);
  }
  if (drop.x < 1 - (width * gutter)) {
  drop.x = width * (1 + gutter);
  }
  });
}

function animate() {
  requestAnimFrame(animate);
  draw_frame();
}

function windtimer() {
  // this is a super cheap way to do this,
  // i will need to look into how to properly  
  // emulate wind
  windforce = Math.random() > 0.5 ? windmultiplier : -windmultiplier;
  setTimeout(windtimer, Math.random() * (1000 * 30));
}

function init() {
  collection = [];
  while (num_drops--) {
  var drop = new Drop(); // todo: make constructor do this shit
  drop.color = "#eee";
  drop.distance = Math.random() * 10 | 0;
  drop.speed = Math.random() * (drop.distance / 10) + gravity;
  drop.vx = 0;
  drop.vy = Math.random() * drop.speed + (drop.speed / 2);
  drop.radius = (drop.distance + 1) / 16 * 3;
  drop.x = drop.random_x();
  drop.y = Math.random() * height;
  collection.push(drop);
  }
  windtimer();
  animate();
  window.onresize = function () {
  height = canvas.height = document.body.offsetHeight;
  width = canvas.width = document.body.offsetWidth;
  };
}
init();
</script>


Источник статьи вы можете найти в демо

Материал подготовлен Apocalypse
Категория: HTML5 | Добавил: Apocalypse | Теги: Canvas, Великолепный, на, Вашего, HTML5, снег, объёмный, сайта, для
Просмотров: 831 | Загрузок: 0 | Комментарии: 2 | Рейтинг: 1.0/1
Всего комментариев: 2
0
Спасибо, пригодился)

0
Пажалста smile

Имя *:
Email: