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

jQuery Plugin – PS Mobile Gallery – Eine Bildergalerie für mobile Endgeräte

PS Image Gallery gibt es jetzt auch für mobile Endgeräte. Deutlich schlichter gehalten und mit Touch-Steuerung, wie Wischeffekt für diese Geräte optimiert. Zudem werden die Bilder je nach Haltung des Geräts im Portrait bzw. Querformat richtig auf die komplette Bildschirmgröße skaliert und zentriert.
jQuery

Die mobile Variante von PS Image Gallery ist als jQuery-Plugin verpackt. Bevor ich die doch überschaubaren, aber sicherlich ausreichenden Einstellungsmöglichkeiten, die HTML-Konfiguration und die Einbindung zeige, möchte ich zuerst die Funktionsweise der Bildergalerie präsentieren.

Steuerung und Funktion

Untenstehend siehst du drei Bilder. Die Bildergalerie öffnet sich, wie bei einer Lightbox, per Klick auf das entsprechende Bild. Das Bild wird nun im kompletten Browserfenster angezeigt. Zur Navigation wische nach links bzw. rechts um zum nächsten bzw. vorhergehenden Bild zu gelangen. Um den Vollbildmodus zu verlassen tippe auf deinen Bildschirm.

PS Mobile Gallery erlaubt kurze Ladezeiten, indem immer nur die nächsten beiden, die vorherigen beiden Bilder und das aktuell angezeigte Bild geladen werden. Sprich bei Initialisierung werden fünf Bilder geladen. Beim Wischen nach links bzw. rechts ein Bild.

Demo

Am Besten testest du dieses Demo natürlich mit einem mobilen Endgerät, aber auch ein Test in einem Desktop-Browser ist möglich. Um den Wischeffekt zu simulieren, halte die rechte Maustaste gedrückt und schiebe die Maus in dieser Zeit nach rechts oder links.

Einbindung in HTML

<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="utf-8" />
<link href="jquery-ps-mobile-gallery.css" rel="stylesheet" media="all" />
<title>PS Mobile Gallery</title>
</head>
<body>
<a class="ps-mobile-gallery" href="jquery-ps-mobile-gallery/2_001.jpg"><img src="jquery-ps-mobile-gallery/0_001.jpg"></a>
<a class="ps-mobile-gallery" href="jquery-ps-mobile-gallery/2_002.jpg"><img src="jquery-ps-mobile-gallery/0_002.jpg"></a>
<a class="ps-mobile-gallery" href="jquery-ps-mobile-gallery/2_003.jpg"><img src="jquery-ps-mobile-gallery/0_003.jpg"></a>  
    
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.js"></script>
<script src="jquery-ps-mobile-gallery.js"></script>
</body>
</html>

Die Bilder der Galerie werden mit einem a-Element umschlossen, welches die Klasse ps-mobile-gallery und als Ziel die Quelle des Bildes bekommt.

Das Plugin benötigt neben der jQuery-Bibliothek, die jQuery-Mobile-Bibliothek.

Einstellungen und Initialisierung

Die Einstellungen werden dem Plugin in einem Objekt übergeben. Hierzu eine Liste der möglichen Attribute des Objekts:

backgroundColor: '#000'

Hintergrundfarbe der Bildergalerie. Standardwert: #333.

scaleSmallImagesBigger: true

Bei true werden Bilder, die kleiner als das Browserfenster sind, auf die Größe des Fensters vergrößert und zentriert. Bei false werden sie nur zentriert. Standardwert: false

loadingCircle: 'jquery-ps-mobile-gallery/ps-mobile-gallery-loader.gif'

Absoluter oder relativer Pfad zum Loading-Spinner. Wird dieses Attribut nicht übergeben, so wird kein Loading-Spinner beim Ladevorgang der Bilder angezeigt.

Code des jQuery-Plugins

Das gesamte Projekt inkl. minifizierte Versionen des jQuery- und CSS-Codes kann am Ende der Seite heruntergeladen werden.

(function ($) {
    $.fn.psMobileGallery = function (settings) {
        var currentIndex;
        var numberOfImages;
        var width, height;
        var overflow = $('body').css('overflow');
        var mobileGallery = $(this);

        mobileGallery.click(function () {

            $(document).on('touchmove', function (e) { e.preventDefault(); });

            $('body').css('overflow', 'hidden');
            width = $(window).width();
            height = $(window).height();

            currentIndex = mobileGallery.index(this);
            numberOfImages = mobileGallery.length;

            create();

            return false;
        });

        $(document).ready(function () {

            $.event.special.swipe.durationThreshold = 2000;
            $.event.special.swipe.verticalDistanceThreshold = 100;
            $.event.special.swipe.horizontalDistanceThreshold = 50;

            $(document).on('swipeleft', '#ps-mobile-gallery-over', function (event) {
                swipeleft();
            });

            $(document).on('swiperight', '#ps-mobile-gallery-over', function (event) {
                swiperight();
            });
            $(document).on('click', '#ps-mobile-gallery-over', function () {
                close();
            });

            $(window).on('orientationchange', function () {
                recalculate();
            });

            $(window).on('resize', function () {
                recalculate();
            });

            if (settings.loadingCircle) {
                $('<img/>')[0].src = settings.loadingCircle;
            }
        });

        function recalculate() {
            width = $(window).width();
            height = $(window).height();
            scaleImage($('.ps-mobile-gallery-image'), true);

            $('#ps-mobile-gallery, #ps-mobile-gallery-over, .ps-mobile-gallery-item').css({
                'display': 'block',
                'width': width,
                'height': height
            });

            $('#ps-mobile-gallery-belt').css({
                'width': width * (numberOfImages + 1),
                'height': height,
                'margin-left': -width * currentIndex
            });
        }

        function create() {
            var src, alt;
            var num = numberOfImages;
            var index = currentIndex;

            setDefaults();

            $('<div id="ps-mobile-gallery"><div id="ps-mobile-gallery-over"></div><div id="ps-mobile-gallery-belt"></div></div>').prependTo('body');

            $('#ps-mobile-gallery').css('background', settings.backgroundColor);

            $('#ps-mobile-gallery, #ps-mobile-gallery-over').css({
                'display': 'block',
                'width': width,
                'height': height
            });

            loading();

            $('#ps-mobile-gallery-belt').css({
                'width': width * (num + 1),
                'height': height,
                'margin-left': -width * index
            });

            appendItems();

            for (var i = 0; i < 5; i++) {
                append((num + index + i - 2) % num, null, true);
            }

            loadingDone($('.ps-mobile-gallery-image'));
        }

        function setDefaults() {
            settings.backgroundColor = '#333';
            settings.scaleSmallImagesBigger = false;
        }

        function appendItems() {

            for (var i = 0; i < numberOfImages; i++) {
                $('<div class="ps-mobile-gallery-item" id="ps-mobile-gallery-item-' + i + '"></div>').appendTo('#ps-mobile-gallery-belt');
            }
            $('<div class="ps-mobile-gallery-item" id="ps-mobile-gallery-item-' + numberOfImages + '"></div>').appendTo('#ps-mobile-gallery-belt');
            append(0, numberOfImages);

            $('.ps-mobile-gallery-item').css({
                'width': width,
                'height': height
            });
        }

        function close() {
            $('body').css('overflow', overflow);

            $(document).unbind('touchmove');

            $('#ps-mobile-gallery').fadeOut(400, function () {
                $('#ps-mobile-gallery').remove();
            })
        }

        function loading() {
            $('<div id="ps-mobile-gallery-loading-wrap"></div>').appendTo('#ps-mobile-gallery');

            $('#ps-mobile-gallery-loading-wrap').css('background', settings.backgroundColor);

            if (settings.loadingCircle) {
                $('<img src="' + settings.loadingCircle + '" id="ps-mobile-gallery-loading" />').appendTo('#ps-mobile-gallery-loading-wrap');
                var loadingImg = $('#ps-mobile-gallery-loading');
                loadingImg.css({
                    'position': 'absolute',
                    'top': '50%',
                    'left': '50%',
                    'margin-left': loadingImg.width() / (-2),
                    'margin-top': loadingImg.height() / (-2),
                    'width': loadingImg.width(),
                    'height': loadingImg.height(),
                    'z-index': 1
                });
            }
        }

        function loadingDone(image) {
            if ($('#ps-mobile-gallery-loading-wrap').length > 0) {
                var int = setInterval(function () {
                    var loaded = 0;
                    image.each(function () {
                        if ($(this).attr('data-loaded') == 'true') {
                            loaded++;
                        }
                    });
                    if (loaded == image.length) {
                        $('#ps-mobile-gallery-loading-wrap').fadeOut(200);
                        clearInterval(int);
                    }
                }, 100);
            }
        }

        function swipe(direction) {
            var offset = parseFloat($('#ps-mobile-gallery-belt').css('margin-left'));
            var width = parseFloat($('.ps-mobile-gallery-item').css('width'));
            if (offset == 0 && direction == -1) {
                offset = -(width * numberOfImages);
            } else if (-offset == width * numberOfImages && direction == 1) {
                offset = 0;
            }
            $('#ps-mobile-gallery-belt').css({ 'margin-left': offset });
            $('#ps-mobile-gallery-belt').animate({ 'margin-left': offset - direction * width }, 400);
        }

        function swipeleft() {
            currentIndex = (currentIndex + 1) % numberOfImages;
            append((currentIndex + 2) % numberOfImages);
            swipe(1);
            if ($('#ps-mobile-gallery-image-' + currentIndex).attr('data-loaded') != 'true') {
                loading();
            }
        }

        function swiperight() {
            currentIndex = (numberOfImages + currentIndex - 1) % numberOfImages;
            prepend((numberOfImages + currentIndex - 2) % numberOfImages);
            swipe(-1);
            if ($('#ps-mobile-gallery-image-' + currentIndex).attr('data-loaded') != 'true') {
                loading();
            }
        }

        function remove(index) {
            $('.ps-mobile-gallery-item').eq(index).remove();
        }

        function append(index, id, init) {
            if (init == null) {
                init = false;
            }
            if (!$('#ps-mobile-gallery-item-' + index).empty()) {
                return;
            }

            if (!id) {
                id = index;
            }

            var source = mobileGallery.eq(index).attr('href');
            $('<img src="' + source + '" class="ps-mobile-gallery-image" id="ps-mobile-gallery-image-' + id + '" />').css({ 'display': 'none' }).appendTo('#ps-mobile-gallery-item-' + id);
            scaleImage($('#ps-mobile-gallery-image-' + id), false);

            if (init === false) {
                loadingDone($('#ps-mobile-gallery-image-' + id));
            }
        }

        function prepend(index, init) {
            if (init == null) {
                init = false;
            }
            if (!$('#ps-mobile-gallery-item-' + index).empty()) {
                return;
            }

            var source = mobileGallery.eq(index).attr('href');
            $('<img src="' + source + '" class="ps-mobile-gallery-image" id="ps-mobile-gallery-image-' + index + '" />').css({ 'display': 'none' }).appendTo('#ps-mobile-gallery-item-' + index);
            scaleImage($('#ps-mobile-gallery-image-' + index), false);

            if (init === false) {
                loadingDone($('#ps-mobile-gallery-image-' + index));
            }
        }

        function scaleImage(image, event) {
            image.each(function () {
                if (event == false) {
                    $(this).load(function () {
                        var element = $(this);
                        scale(element);
                        element.attr({ 'data-loaded': 'true' });
                    });
                }
                else {
                    scale($(this));
                }
            });
        }

        function scale(element) {
            var imageWidth = element.width();
            var imageHeight = element.height();
            var boxWidth = width;
            var boxHeight = height;

            if (imageWidth / boxWidth < imageHeight / boxHeight) {
                if (imageHeight >= boxHeight || settings.scaleSmallImagesBigger === true) {
                    element.css({ 'width': imageWidth * (boxHeight / imageHeight), 'height': boxHeight });
                }
            }
            else {
                if (imageWidth >= boxWidth || settings.scaleSmallImagesBigger === true) {
                    element.css({ 'width': boxWidth, 'height': imageHeight * (boxWidth / imageWidth) });
                }
            }

            element.css({
                'position': 'absolute',
                'top': '50%',
                'left': '50%',
                'margin-left': -(parseFloat(element.css('width')) / 2),
                'margin-top': -(parseFloat(element.css('height')) / 2),
                'display': 'block'
            });
        }
    }
})(jQuery);

$(function () {
    // Use PS Mobile Gallery only on mobile devices
    //if (navigator.userAgent.search(/(Android|iPhone|iPad|iPod|webOS|Windows Phone|Blackberry)/i) != -1) {
        $('.ps-mobile-gallery').psMobileGallery({
            backgroundColor: '#000',
			scaleSmallImagesBigger: true,
			loadingCircle: 'jquery-ps-mobile-gallery/ps-mobile-gallery-loader.gif'
		});
    //}
});

CSS-Code

Zum Abschluss noch der Code des Stylesheets.

#ps-mobile-gallery {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000000000;
    overflow: hidden;
    display: none;
}

#ps-mobile-gallery-over {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000000001;
}

.ps-mobile-gallery-item {
    float: left;
    position: relative;
}

#ps-mobile-gallery-loading-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

835,43 KB - Downloads: 2449

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