Du verwendest einen Internet Explorer in einer Version kleiner gleich 8. Dieser Browser wird nicht unterstützt. Bitte aktualisiere mindestens auf Version 9.
Patrick Saar - Codes

Codes

Patrick Saar

Eine einfache Diashow mit JavaScript

Hier gibt es eine Diashow unterstützt durch JavaScript, welche auch in meinen Webprojekten zum Einsatz kommt.
JavaScript

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: 5007

Diese Seite verwendet Cookies um die beste Nutzerfreundlichkeit zu bieten. Falls Du auf der Seite weitersurfst, stimmst Du der Cookie-Nutzung zu.
Details Ok