Werbung:
MediaWiki:Common.js: Unterschied zwischen den Versionen
Aus TagTraum
Kiba (Diskussion | Beiträge) (Der Seiteninhalt wurde durch einen anderen Text ersetzt: „→Das folgende JavaScript wird für alle Benutzer geladen.: →-------: “) Markierung: Ersetzt |
Keine Bearbeitungszusammenfassung |
||
| Zeile 1: | Zeile 1: | ||
/* | /* Halloween */ | ||
(function () { | |||
var r = Math.random, | |||
n = 0, | |||
d = document, | |||
w = window, | |||
bats = [], | |||
numBats = 1, | |||
batImages = [ | |||
'' | |||
]; | |||
function createBat() { | |||
var i = d.createElement('img'), | |||
z = d.createElement('div'), | |||
zs = z.style, | |||
a = w.innerWidth * r(), | |||
b = w.innerHeight * r(), | |||
scaleFactor = 1.0, | |||
isFirstBat = bats.length === 0; | |||
if (!isFirstBat) { | |||
scaleFactor = r() * 0.75 + 0.5; | |||
} | |||
zs.position = 'fixed'; | |||
zs.left = 0; | |||
zs.top = 0; | |||
zs.opacity = 0; | |||
zs.transform = zs.webkitTransform = 'scale(' + scaleFactor + ')'; // Apply the scale factor | |||
zs.width = '60px'; | |||
zs.height = '60px'; | |||
z.appendChild(i); | |||
i.src = batImages[Math.floor(r() * batImages.length)]; // Randomly select a bat image | |||
d.body.appendChild(z); | |||
function R(o, m) { | |||
return Math.max(Math.min(o + (r() - 0.5) * 400, m - 50), 50); | |||
} | |||
function animateBat() { | |||
var x = R(a, w.innerWidth), | |||
y = R(b, w.innerHeight), | |||
distance = 5 * Math.sqrt((a - x) * (a - x) + (b - y) * (b - y)); | |||
zs.opacity = n; | |||
n = 1; | |||
zs.transition = zs.webkitTransition = distance / 1000 + 's linear'; | |||
zs.transform = zs.webkitTransform = 'translate(' + x + 'px,' + y + 'px) scale(' + scaleFactor + ')'; | |||
i.style.transform = i.style.webkitTransform = a > x ? '' : 'scaleX(-1)'; | |||
a = x; | |||
b = y; | |||
setTimeout(animateBat, distance); | |||
} | |||
setTimeout(animateBat, r() * 3000); | |||
if (!isFirstBat) { | |||
z.addEventListener('click', function () { | |||
var currentY = parseFloat(getComputedStyle(z).top); | |||
zs.transition = zs.webkitTransition = 'top 1s ease-in-out'; | |||
zs.top = (w.innerHeight - currentY) + 'px'; | |||
setTimeout(function () { | |||
z.parentNode.removeChild(z); | |||
bats.splice(bats.indexOf(z), 1); | |||
}, 1000); | |||
}); | |||
} | |||
return z; | |||
} | |||
var initialBat = createBat(); | |||
bats.push(initialBat); | |||
initialBat.addEventListener('click', function () { | |||
var newBat = createBat(); | |||
bats.push(newBat); | |||
}); | |||
function r() { | |||
return Math.random(); | |||
} | |||
})(); | |||
/* ------- */ | /* ------- */ | ||
Version vom 28. Oktober 2023, 09:03 Uhr
/* Halloween */
(function () {
var r = Math.random,
n = 0,
d = document,
w = window,
bats = [],
numBats = 1,
batImages = [
''
];
function createBat() {
var i = d.createElement('img'),
z = d.createElement('div'),
zs = z.style,
a = w.innerWidth * r(),
b = w.innerHeight * r(),
scaleFactor = 1.0,
isFirstBat = bats.length === 0;
if (!isFirstBat) {
scaleFactor = r() * 0.75 + 0.5;
}
zs.position = 'fixed';
zs.left = 0;
zs.top = 0;
zs.opacity = 0;
zs.transform = zs.webkitTransform = 'scale(' + scaleFactor + ')'; // Apply the scale factor
zs.width = '60px';
zs.height = '60px';
z.appendChild(i);
i.src = batImages[Math.floor(r() * batImages.length)]; // Randomly select a bat image
d.body.appendChild(z);
function R(o, m) {
return Math.max(Math.min(o + (r() - 0.5) * 400, m - 50), 50);
}
function animateBat() {
var x = R(a, w.innerWidth),
y = R(b, w.innerHeight),
distance = 5 * Math.sqrt((a - x) * (a - x) + (b - y) * (b - y));
zs.opacity = n;
n = 1;
zs.transition = zs.webkitTransition = distance / 1000 + 's linear';
zs.transform = zs.webkitTransform = 'translate(' + x + 'px,' + y + 'px) scale(' + scaleFactor + ')';
i.style.transform = i.style.webkitTransform = a > x ? '' : 'scaleX(-1)';
a = x;
b = y;
setTimeout(animateBat, distance);
}
setTimeout(animateBat, r() * 3000);
if (!isFirstBat) {
z.addEventListener('click', function () {
var currentY = parseFloat(getComputedStyle(z).top);
zs.transition = zs.webkitTransition = 'top 1s ease-in-out';
zs.top = (w.innerHeight - currentY) + 'px';
setTimeout(function () {
z.parentNode.removeChild(z);
bats.splice(bats.indexOf(z), 1);
}, 1000);
});
}
return z;
}
var initialBat = createBat();
bats.push(initialBat);
initialBat.addEventListener('click', function () {
var newBat = createBat();
bats.push(newBat);
});
function r() {
return Math.random();
}
})();
/* ------- */

