Śnieg tylko w nagłówku

Założony przez  Qurczax.

wersja skryptu MyBB: 1.8.6
adres forum: utysia.pl
na czym polega problem (screen, opis, komunikaty, nazwa stylu/theme/szablonu):
jak zrobić aby śnieg padał tylko w obszarze nagłówka? (https://webboard.pl/thread-3397.html)
Nie wiem jak się to zachowa ale pokusił bym się o umieszczenie tego kodu w szablonie odpowiedzialnym za nagłówek
<script type="text/javascript" src="{$mybb->settings['bburl']}/jscripts/snow.js"></script
W ten sposób kod wywoła się wszędzie gdzie wczytywany jest szablon nagłówka, ale w żaden sposób nie ograniczy wysokości opadania.

Albo
doc_width = 800, doc_height = 100;
Zmienić wartości, choć wątpię.

if (ns4up||ns6up) {
doc_width = self.innerWidth;
doc_height = self.innerHeight;
} else if (ie4up) {
doc_width = document.body.clientWidth;
doc_height = document.body.clientHeight;
}
Zdaje się odczytywać wielkość okna z przeglądarki i dostosowywać śnieg do tejże wysokości. Można by to ustawić na stałe wartości, pozbyć się tych ifów.
"Try not. Do... or do not. There is no try."
Poświęć 5 minut. Nie bądź ignorantem!  -  Jak zbadać element?
nic nie pomaga
usunąłem "ify" i spróbowałem pozmieniać wartości doc_width i doc_height ale wciąż pada tak samo
kod:
//<?php
//    
//    header("Cache-Control: must-revalidate");
//    $offset = 60*60*24*60;
//    $ExpStr = "Expires: ".gmdate("D, d M Y H:i:s",time() + $offset)." GMT";
//    header($ExpStr);
//    header('Content-Type: application/x-javascript');
//
//    global $mosConfig_live_site;
//
?>

//Javasript by Mario Boro (c) 2006-2007

var no = 8; // Liczba sniezek
var speed = 5; // Szybkosc sniegu - czym mniejsza tym szybciej leci
var schneeflocke = "images/square/snow.png"; // Link do obrazka sniegu

//Don't touch

var ns4up = (navigator.appName=="Netscape" && navigator.appVersion.charAt(0)=="4") ? 1 : 0;
var ie4up = (document.all) ? 1 : 0;
var ns6up = (document.getElementById&&!document.all) ? 1 : 0;
var dx, xp, yp;
var am, stx, sty;
var i, doc_width = 345, doc_height = 92;
dx = new Array();
xp = new Array();
yp = new Array();
am = new Array();
stx = new Array();
sty = new Array();
for (i = 0; i < no; ++ i) {
dx[i] = 0; // Koordinaten-Variable setzen
xp[i] = Math.random()*(doc_width-50); // Position-Variable setzen
yp[i] = Math.random()*doc_height;
am[i] = Math.random()*20; // Amplituden-Variable setzten
stx[i] = 0.02 + Math.random()/10; // Variable für Schrittweite setzen
sty[i] = 0.7 + Math.random(); // Variable für Schrittweite setzen

// Layer konfigurieren für Netscape
if (ns4up) {
if (i == 0) {
document.write("<layer name=\"dot"+ i +"\" left=\"15\" ");
document.write("top=\"15\" visibility=\"show\"><img src=\"");
document.write(schneeflocke + "\" border=\"0\"></layer>");
} else {
document.write("<layer name=\"dot"+ i +"\" left=\"15\" ");
document.write("top=\"15\" visibility=\"show\"><img src=\"");
document.write(schneeflocke + "\" border=\"0\"></layer>");
}

// Layer konfigurieren für NS4
} else if (ie4up||ns6up) {
if (i == 0) {
document.write("<div id=\"dot"+ i +"\" style=\"POSITION: ");
document.write("absolute; Z-INDEX: "+ i +"; VISIBILITY: ");
document.write("visible; TOP: 15px; LEFT: 15px;\"><img src=\"");
document.write(schneeflocke + "\" border=\"0\"></div>");
} else {
document.write("<div id=\"dot"+ i +"\" style=\"POSITION: ");
document.write("absolute; Z-INDEX: "+ i +"; VISIBILITY: ");
document.write("visible; TOP: 15px; LEFT: 15px;\"><img src=\"");
document.write(schneeflocke + "\" border=\"0\"></div>");
}
}
}

// Haupt-Animations-Funktion für Netscape
function schneeflockeNS() {
for (i = 0; i < no; ++ i) {
yp[i] += sty[i];
if (yp[i] > doc_height-50) {
xp[i] = Math.random()*(doc_width-am[i]-30);
yp[i] = 0;
stx[i] = 0.02 + Math.random()/10;
sty[i] = 0.7 + Math.random();
doc_width = self.innerWidth;
doc_height = self.innerHeight;
}
dx[i] += stx[i];
document.layers["dot"+i].top = yp[i];
document.layers["dot"+i].left = xp[i] + am[i]*Math.sin(dx[i]);
}
setTimeout("schneeflockeNS()", speed);
}

// Haupt-Animations-Funktion für Internet Explorer
function schneeflockeIE() {
for (i = 0; i < no; ++ i) {
yp[i] += sty[i];
if (yp[i] > doc_height-50) {
xp[i] = Math.random()*(doc_width-am[i]-30);
yp[i] = 0;
stx[i] = 0.02 + Math.random()/10;
sty[i] = 0.7 + Math.random();
doc_width = document.body.clientWidth;
doc_height = document.body.clientHeight;
}
dx[i] += stx[i];
document.all["dot"+i].style.pixelTop = yp[i];
document.all["dot"+i].style.pixelLeft = xp[i] + am[i]*Math.sin(dx[i]);
}
setTimeout("schneeflockeIE()", speed);
}
// Haupt-Animations-Funktion für Netscape6 und Mozilla
function schneeflockeNS6() {
for (i = 0; i < no; ++ i) {
yp[i] += sty[i];
if (yp[i] > doc_height-50) {
xp[i] = Math.random()*(doc_width-am[i]-30);
yp[i] = 0;
stx[i] = 0.02 + Math.random()/10;
sty[i] = 0.7 + Math.random();
doc_width = self.innerWidth;
doc_height = self.innerHeight;
}
dx[i] += stx[i];
document.getElementById("dot"+i).style.top = yp[i]+"px";
document.getElementById("dot"+i).style.left = xp[i] + am[i]*Math.sin(dx[i])+"px";
}
setTimeout("schneeflockeNS6()", speed);
}
if (ns4up) {
schneeflockeNS();
} else if (ie4up) {
schneeflockeIE();
}else if (ns6up) {
schneeflockeNS6();

doc_width = self.innerWidth;
doc_height = self.innerHeight;

doc_width = document.body.clientWidth;
doc_height = document.body.clientHeight;

W dalszych częściach kodu w zależności od przeglądarki nadal odczytywane są parametry z rozmiaru okna.
Możesz dalej eksperymentować tym tokiem rozumowania bądź poczekać na kogoś obeznanego w temacie.
"Try not. Do... or do not. There is no try."
Poświęć 5 minut. Nie bądź ignorantem!  -  Jak zbadać element?
https://stackoverflow.com/questions/2742...w-in-a-div
Może Ci pomóc :)
:: Akcja DZIĘKUJĘ ZA POMOC ::
Pomocy udzielam jedynie na forum. Wszystkie rzeczy wykraczające poza tą dziedzinę wykonuję odpłatnie.
@"Nidrax" ax ale to stronę lagguje... zmieniłem:
ww = $(window).width();
wh = $(window).height();
na
ww = $(window).width();
wh = 200;
wciąż nic
Wrzuć linijkę z ładowaniem JS zaraz pod znacznik <body> :)
zrezygnowałem - dałem gifa ze śnieżkami na tło headeru :D



Użytkownicy przeglądający ten wątek:

1 gości