Die Abspielreihenfolge kann zufällig oder nach der Bildnummerierung sortiert sein. Beim Bilderwechsel werden die Bilder eine gewisse Zeit (Einstellungen) überblendet.
In den ersten Zeilen des JavaScript-Codes kann die Diashow individuell eingestellt werden. Im CSS-Code kann zusätzlich noch die Position der Diashow und die Größe der Bilder festgelegt werden.
- Überblendung beim Bilderwechsel
- Zufälliges Startbild (optional)
- Zufällige Abspielreihenfolge (optional)
- Vorladen des nächsten Bildes im Hintergrund
Unten kann der Code eingesehen werden, ein anschauliches Beispiel ist vorhanden und die Diashow steht als Download bereit.
NEU: Ein paar Performanceverbesserungen wurden vorgenommen und zusätzlich ist der Diashow-Code jetzt gekapselt.
Beispiel
Der JavaScript-Code:
// -------------------------------------------------------------------
// ------------- Autor: Patrick Saar - www.patrick-saar.de -----------
// ----------------------- JS Diashow v. 1.1 -------------------------
// ------------------ Copyright 2012 Patrick Saar --------------------
// -------------------------------------------------------------------
(function() {
// -------------------------------------------------------------------
// ----------------------- Einstellungen -----------------------------
// -------------------------------------------------------------------
var fade_time = 800; // wie lange soll ueberblendet werden? [ms]
var fade_steps = 20; // Frames der Ueberblendung. Je mehr, desto glatter die Ueberblendung.
var img_time = 3000; // wie lange soll ein Bild gezeigt werden? [ms]
var img_length = 5; // wie viele Bilder gibt es?
var img_path = 'js-diashow'; // relativer oder absoluter Pfad zum Verzeichnis in dem die Bilder liegen
var img_suffix = 'dia'; // Praefix des Dateinamens der Bilder
var img_format = 'jpg'; // Format der Bilder
var randomize = true; // Abspielreihenfolge zufaellig?
var img = [];
var number = [];
var random1, random2, temp;
var i, k;
var f=fade_steps;
var fade_frame, opacity;
var img1dia, img2dia;
var fadein, fadeout;
var init = false;
for(k = img_length; k--;) {
number[k] = k; // Schreibe Array mit Zahlen 0,1,2,3, ... ,img_length-1
}
if(randomize === true) {
for(k = (img_length*3); k--;) {
random1=Math.floor(Math.random()*img_length);
random2=Math.floor(Math.random()*img_length);
temp=number[random1];
number[random1]=number[random2]; // permutiere diese Zahlen zufaellig fuer eien zufaellige Abspielreihenfolge
number[random2]=temp;
}
}
function init_function() {
img[0]=new Image();
img[0].src=img_path + "/" + img_suffix + number[0] + "." + img_format; // lade das erste Bild
img[1]=new Image();
img[1].src=img_path + "/" + img_suffix + number[1] + "." + img_format; // lade das zweite Bild
k=0;
img1dia = document.images["img1dia"];
img2dia = document.images["img2dia"];
fadein = img1dia;
fadeout = img2dia;
fade_frame = fade_time/fade_steps;
opacity_frame = 100/fade_steps;
}
function setAlpha(element, value) {
// Browserabhaengige Transparenz fuer Ueberblendung
var opacity = value/100;
if(img1dia.style.filter !== null) {element.style.filter="Alpha(opacity="+value+")";} // IE
if(img1dia.style.opacity !== null) {element.style.opacity=opacity;} // Opera, Chrome, Firefox, Safari
if(img1dia.style.KhtmlOpacity !== null) {element.style.KhtmlOpacity=opacity;} // alte Safaris
if(img1dia.style.MozOpacity !== null) {element.style.MozOpacity=opacity;} // alte Firefox
}
animation = function() {
if (!init) {
init = true;
init_function();
}
if(img[k+1].complete === false) {
setTimeout(animation, 200); // warte mit dem Bilderwechsel bis das naechste Bild geladen ist
}
else {
if (f === fade_steps) {
f = 0;
k++;
img[k+1] = new Image();
img[k+1].src = img_path + "/" + img_suffix + number[(k+1)%img_length] + "." + img_format; // uebernaechstes Bild vorladen
fadeout.src = img[k-1].src; // aktuelles Bild ausblenden
fadein.src = img[k].src; // naechstes Bild einblenden
setAlpha(fadein, 0);
setAlpha(fadeout, 100);
setTimeout(animation, img_time); // zeige Bild 'img_time' Sekunden lang
return;
}
else {
f++; // hier ist die Funktion fuer's Ueberblenden
setAlpha(fadein, f*opacity_frame);
setAlpha(fadeout, 100-(f*opacity_frame));
setTimeout(animation, fade_frame);
}
}
}
setTimeout(animation, 0);
})();
Der CSS-Code:
#img1dia, #img2dia, #noscriptdia {
position: absolute; /* Bilder uebereinanderlegen */
top: 10px; /* Abstand von der linken oberen Ecke des Elternelements vertikal */
left: 50%; /* Abstand von der linken oberen Ecke des Elternelements horizontal */
margin-left: -150px;
border: 0;
display: block;
}
#noscriptdia { /* Auf die Aktivierung von JavaScript hinweisen */
position: absolute;
top: 60px; /* Abstand von der linken oberen Ecke des Elternelements vertikal */
left: 50%; /* Abstand von der linken oberen Ecke des Elternelements horizontal */
text-align: center;
font-size: 10pt;
font-weight: bold;
width: 200px;
color: #a00003;
padding: 5px;
margin-left: -106px;
}
Der HTML-Code:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="author" content="Patrick Saar" />
<link rel="stylesheet" href="js-diashow.css" media="all" />
<title>PHP Bilderdownload</title>
</head>
<body>
<script>
document.write('<img id="img1dia" />');
document.write('<img id="img2dia" />');
</script>
<noscript id="noscriptdia">Bitte aktivieren Sie JavaScript um die Diashow genießen zu können.</noscript>
<script src="js-diashow.js"></script>
</body>
</html>
137,56 KB - Downloads: 5116