1. Главная страница » Как сделать...? » Эффект падающих снежинок на своем сайте

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

Автор: | 10.02.2013

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

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

Использование скрипта предельно просто: нужно поместить его в корневой каталог сайта и добавить в 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
}
 

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

  1. Сергей

    Сергей Спасибо! Падающие снежинки работают! Очень признателен за материал!

  2. SLAWAMONOLIT

    SLAWAMONOLIT Спасибо! Установил-всё работает,ждём декабря! Снежинки-супер!

  3. Татьяна

    Татьяна вопросик можно? Что если картинку вместо символа , то изменение размера и цвета нет, или можно прикрутить?

  4. sasha

    sasha Конечно можно, по моему, даже размер не нужно прикручивать, у нас же есть snowmaxsize=35 и snowminsize=8. Как-то я экспериментировал с картинками, если мне память не изменяет, то я просто менял символ на картинку, и все…

  5. Артём

    Артём Интересная статья, спасибо большое! Я думал, что для этого непременно необходим, какой либо специальный плагин но, как оказалось всё гораздо проще.

  6. Куляш

    Куляш Добрый день! Очень давно ищу эффекты падающих снежинок на сайт, а не знаю как его установить. Огромная просьба, объясните как мне его установить на мой сайт   http://74202s043.edusite.ru/ Заранее благодарна!

  7. sasha

    sasha Скачайте архив нажав на «Скачать скрипт можно здесь». Залейте архив на хостинг где находится Ваш сайт, а точнее рядом с файлом index.php(если Вы хотите чтобы снег падал на главной странице) и распакуйте архив, после вставьте в код файла index.php, между тегами head, код который и будет подключать js файл из архива(snow-fall.js) ««. Вот и все!

  8. Татьяна

    Татьяна Спасибо огромное! Теперь и на моем сайте предновогоднее настроение

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

*

code