Как поставить в предыдущую и следующую функцию - PullRequest
0 голосов
/ 23 февраля 2012

Может кто-нибудь помочь мне с этим сценарием? Интересно, как поставить предыдущую и следующую функцию? Функция запуска и остановки работает отлично. Надеюсь, что сценарий хорошо читается.

Еще один вопрос. Можно ли сделать предыдущую и следующую функцию похожей, когда вы нажимаете предыдущий bttn, сценарий останавливается, и вам нужно нажать play bttn, чтобы запустить его снова?

Спасибо за помощь.

<script type="text/javascript">
// SET THIS VARIABLE FOR DELAY, 1000 = 1 SECOND
var delayLength = 10000;

function doMove(panelWidth, tooFar) {
    var leftValue = $("#mover").css("left");

    // Fix for IE
    if (leftValue == "auto") { leftValue = 0; };

    var movement = parseFloat(leftValue, 10) - panelWidth;

    if (movement == tooFar) {
        $(".slide img").animate({
            "top": -200
        }, function() {
            $("#mover").animate({
                "left": 0
            }, function() {
                $(".slide img").animate({
                    "top": 80
                });
            });
        });
    }
    else {
        $(".slide img").animate({
            "top": -200
        }, function() {
            $("#mover").animate({
                "left": movement
            }, function() {
                $(".slide img").animate({
                    "top": 80
                });
            });
        });
    }
}

jQuery(function($){


    var $slide1 = $("#slide-1");

    var panelWidth = $slide1.css("width");
    var panelPaddingLeft = $slide1.css("paddingLeft");
    var panelPaddingRight = $slide1.css("paddingRight");

    panelWidth = parseFloat(panelWidth, 10);
    panelPaddingLeft = parseFloat(panelPaddingLeft, 10);
    panelPaddingRight = parseFloat(panelPaddingRight, 10);

    panelWidth = panelWidth + panelPaddingLeft + panelPaddingRight;

    var numPanels = $(".slide").length;
    var tooFar = -(panelWidth * numPanels);
    var totalMoverwidth = numPanels * panelWidth;
    $("#mover").css("width", totalMoverwidth);

    $("#slider").append('<a href="#2" id="slider-stopper">Stop</a>');

    sliderIntervalID = setInterval(function(){
        doMove(panelWidth, tooFar);
    }, delayLength);

    $("#slider-stopper").click(function(){
        if ($(this).text() == "Stop") {
            clearInterval(sliderIntervalID);
            $(this).text("Start");
        }
        else {
            sliderIntervalID = setInterval(function(){
                doMove(panelWidth, tooFar);
            }, delayLength);
            $(this).text("Stop");
        }

    });

});
</script>
...