Уроки:


  
HTML
  
  
CSS
  
  
PHP
  
  
JavaScript
  
  
jQuery
  
  
PHP+MySQL
  
  
Ajax
  

  Разделы:


  В помощь:


  Ещё:



  Авторизация:


  логин:   
  пароль: 
Программисты на работе общаются двумя фразами: "непонятно" и "вроде работает".

  Тренажер интуиции:


Тренажер интуиции


  Видеокурсы:


Бесплатный видеокурс: "Cайт-визитка за 1 день"

видеокурс: Сайт-визитка за один день



  Опрос:



  Топ комментаторов:


40

Страшный сон программиста - это когда забыл пароль и девичью фамилию своей матери.

  Моя группа в контакте:



Эффект падающих снежинок на своем сайте

Скачать скрипт можно здесь, посмотреть в действии — прямо на этой странице.

падающие снежинки на сайте

Использование скрипта предельно просто: нужно поместить его в корневой каталог сайта и добавить в HTML-код сайта тег <script> для его подключения (рекомендуется добавлять его перед закрывающим тегом </body>):

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

При желании вы можете поместить скрипт и в какой-либо другой каталог, но не забудьте при этом скорректировать путь.

В начало скрипта вынесены некоторые переменные с настройками. Их можно редактировать по своему усмотрению:

snowmax — количество снежинок, которое будет на экране одновременно. Несмотря на то, что скрипт достаточно легкий, злоупотреблять количеством не рекомендуется.

snowcolor — массив, в котором перечислены цвета для отрисовки снежинок. Для каждой конкретной снежинки цвет выбирается случайно из этого массива.

snowletter — Символ (*) и есть наша снежинка, в место нее можно вставить любой другой символ или изображение.

snowmaxsize — массив, в котором задается максимальный размер снежинок.

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

sinkspeed — Задает скорость падения снежинок.

Файл snow-fall.js:
var snowmax=35

// Set the colors for the snow. Add as many colors as you like
var snowcolor=new Array("#b9dff5","#b9dff5","#b9dff5","#b9dff5","#b9dff5")

// Set the fonts, that create the snowflakes. Add as many fonts as you like
var snowtype=new Array("Times")

// Set the letter that creates your snowflake (recommended: * )
var snowletter="*"

// Set the speed of sinking (recommended values range from 0.3 to 2)
var sinkspeed=0.6

// Set the maximum-size of your snowflakes
var snowmaxsize=35

// Set the minimal-size of your snowflakes
var snowminsize=8

// Set the snowing-zone
// Set 1 for all-over-snowing, set 2 for left-side-snowing
// Set 3 for center-snowing, set 4 for right-side-snowing
var snowingzone=1

// Do not edit below this line
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.scrollHeight
                marginright = document.body.clientWidth-15
        }
        else if (ns6) {
                marginbottom = document.body.scrollHeight
                marginright = window.innerWidth-15
        }
        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].style.zIndex=1000
                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+"'>"+snowletter+"</span>")
}
if (browserok) {
        window.onload=initsnow
}
 

Проверьте свою интуицию:


Мобильную версию можно скачать в google play

Комментарии


Спасибо! Падающие снежинки работают! Очень признателен за материал!
2013-12-13 05:57
Спасибо! Установил-всё работает,ждём декабря! Снежинки-супер!
2014-11-11 16:08
Татьяна
вопросик можно?
Что если картинку вместо символа , то изменение размера и цвета нет, или можно прикрутить?
2014-12-10 10:11
Конечно можно, по моему, даже размер не нужно прикручивать, у нас же есть snowmaxsize=35 и snowminsize=8. Как-то я экспериментировал с картинками, если мне память не изменяет, то я просто менял символ на картинку, и все...
2015-01-08 22:12
Интересная статья, спасибо большое! Я думал, что для этого непременно необходим, какой либо специальный плагин но, как оказалось всё гораздо проще.
2015-12-10 03:04
Добрый день! Очень давно ищу эффекты падающих снежинок на сайт, а не знаю как его установить. Огромная просьба, объясните как мне его установить на мой сайт   http://74202s043.edusite.ru/

Заранее благодарна!
2016-01-29 13:18
Скачайте архив нажав на "Скачать скрипт можно здесь". Залейте архив на хостинг где находится Ваш сайт, а точнее рядом с файлом index.php(если Вы хотите чтобы снег падал на главной странице) и распакуйте архив, после вставьте в код файла index.php, между тегами head, код который и будет подключать js файл из архива(snow-fall.js) "<script type="text/javascript" src="snow-fall.js"></script>". Вот и все!
2016-01-29 13:35
Татьяна
Спасибо огромное! Теперь и на моем сайте предновогоднее настроение
2016-12-23 21:53
Андрей
Как задать путь к картинке?
2017-04-21 05:11

Ваш комментарий



Почта: info@web-shpargalka.ru