X
  • Дизайн та розробка сайту
  • Дизайн і створення сайтів. Розробка тем для WordPress. Створення Landing Page.
  • office@gnatkovsky.com.ua
  • @vgnat
  • Написати мені
Замовити послугу

Скрипт падающего снега

Приклад
  • 2024-03-28
  • 39391 переглядів

  • Дизайн та розробка сайту

Доброго времени суток. 🙂

Зима уже на носу, скоро снег, а у некоторых он уже давно пустился, не успеешь моргнуть, а там и новый год. Поэтому много вебмастеров приукрашают свои сайты различными эффектами. Решил я тут, выложить парочку скриптов, которые придадут Вашему сайту зимнее и новогоднее настроение.

Скрипт падающего снега

В этой статье, я покажу как сделать падающий снег на страницах Вашего сайта, а в следующей - Скрипт гирлянды.

Данный скрипт мне нравится больше всего. В свое время, я перерыл много разных скриптов и каждый из них был своеобразен, но именно это мне понравился. Он имеет много настроек, простой и прикольно смотрится. Чтобы его установить, Вам потребуется, всего лишь добавить в шапку или подвал сайта данный код:



Пример

<script type="text/javascript">
var snowmax=35;
var snowcolor=new Array("#AAAACC","#DDDDFF","#CCCCDD","#F3F3F3","#F0FFFF","#FFFFFF","#EFF5FF")
var snowtype=new Array("Arial Black","Arial Narrow","Times","Comic Sans MS");
var snowletter="*";
var sinkspeed=0.6; 
var snowmaxsize=40;
var snowminsize=8;
var snowingzone=1;
 
 
var snow=new Array();
var marginbottom;
var marginright;
var timer;
var i_snow=0;
var x_mv=new Array();
var crds=new Array();
var lftrght=new Array();
var browserinfos=navigator.userAgent;
var ie5=document.all&&document.getElementById&&!browserinfos.match(/Opera/);
var ns6=document.getElementById&&!document.all;
var opera=browserinfos.match(/Opera/);
var browserok=ie5||ns6||opera;
function randommaker(range) {
	rand=Math.floor(range*Math.random());
	return rand;
}
function initsnow() {
	if (ie5 || opera) {
		marginbottom=document.body.clientHeight;
		marginright=document.body.clientWidth;
	}
	else if (ns6) {
		marginbottom=window.innerHeight;
		marginright=window.innerWidth;
	}
	var snowsizerange=snowmaxsize-snowminsize;
	for (i=0;i<=snowmax;i++) {
		crds[i]=0;
		lftrght[i]=Math.random()*15;
		x_mv[i]=0.03+Math.random()/10;
		snow[i]=document.getElementById("s"+i);
		snow[i].style.fontFamily=snowtype[randommaker(snowtype/length)];
		snow[i].size=randommaker(snowsizerange)+snowminsize;
		snow[i].style.fontSize=snow[i].size+"px";
		snow[i].style.color=snowcolor[randommaker(snowcolor.length)];
		snow[i].sink=sinkspeed*snow[i].size/5;
		if (snowingzone==1) {snow[i].posx=randommaker(marginright-snow[i].size)}
		if (snowingzone==2) {snow[i].posx=randommaker(marginright/2-snow[i].size)}
		if (snowingzone==3) {snow[i].posx=randommaker(marginright/2-snow[i].size)+marginright/4}
		if (snowingzone==4) {snow[i].posx=randommaker(marginright/2-snow[i].size)+marginright/2}
		snow[i].posy=randommaker(2*marginbottom-marginbottom-2*snow[i].size);
		snow[i].style.left=snow[i].posx+"px";
		snow[i].style.top=snow[i].posy+"px";
	}
	movesnow();
}
function movesnow() {
	for(i=0;i<=snowmax;i++) {
		crds[i]+=x_mv[i];
		snow[i].posy+=snow[i].sink;
		snow[i].style.left=snow[i].posx+lftrght[i]*Math.sin(crds[i])+"px";
		snow[i].style.top=snow[i].posy+"px";
		if (snow[i].posy>=marginbottom-2*snow[i].size || parseInt(snow[i].style.left)>(marginright-3*lftrght[i])) {
			if (snowingzone==1) {snow[i].posx=randommaker(marginright-snow[i].size)}
			if (snowingzone==2) {snow[i].posx=randommaker(marginright/2-snow[i].size)}
			if (snowingzone==3) {snow[i].posx=randommaker(marginright/2-snow[i].size)+marginright/4}
			if (snowingzone==4) {snow[i].posx=randommaker(marginright/2-snow[i].size)+marginright/2}
			snow[i].posy=0;
		}
	}
	var timer=setTimeout("movesnow()",50);
}
for (i=0;i<=snowmax;i++) {
	document.write("<span id='s"+i+"' style='position:absolute;top:-"+snowmaxsize+"px;'>"+snowletter+"</span>");
}
if (browserok) {
	window.onload=initsnow;
}
</script>

Давайте разберем настройки данного скрипта. Их не много, но они очень помогут дробиться нужного результата.

snowmax=35 - количество снежинок на странице.

snowcolor - цвета снежинок на странице. По желанию, можете добавлять любые цвета, в любом количестве.

snowtype - шрифты, которые будут формировать Ваши снежинки. Ситуация как и с цветами, добавлять можно по желанию, в любом количестве.

snowletter - символ который будет снежинкой. Можно даже написать слово или целый текст, если Вам надо не снегопад, а словопад 🙂

sinkspeed - скорость падения снега. Задавайте любую, но рекомендую, не больше 3 ибо выше, начнется просто мигание.

snowmaxsize - задается максимальный размер снежинки.

snowminsize - наоборот, задается минимальный размер снежинки

snowingzone - это настройки размещения снегопада. В зависимости от числа, снег будет:

  • 1 - снег идет по всей ширине страницы.
  • 2 - расположение снега слева.
  • 3 - снег будет колонкой по средине.
  • 4 - снег будет справа.

Также посоветую, не вставлять код целиком на страницу, а сделать подключение. То есть добавить код в отельный файл, например - snow.js и уже его подключить в подвале, указав правильный путь. Например:

<script type="text/javascript" src="js/snow.js"></script>

Все, скрипт установлен и настроен, можете посмотреть результат и по нужде еще подкорректировать. надеюсь Вам понравится и Вы приукрасите свой сайт.

На этом все, спасибо за внимание. 🙂

Якщо Вам була корисна моя праця, можете фінансово підтримати сайт або відключити блокувальник реклами, що займе 2 хвилини :)

Хочу підтримати фінансово Хочу відключити блокувальник

Оцініть статтю
  1. 5
  2. 4
  3. 3
  4. 2
  5. 1
Проголосовало: 28, в среднем: 4.9 из 5
Читайте також