Как бы я замедлил анимацию этого слайдера jquery - PullRequest
2 голосов
/ 22 декабря 2010

У меня есть следующий код, который я получил от http://css -tricks.com / StartStop-Slider / У меня все это работает, вы можете просмотреть его в http://www.mrskitson.ca/revised с именем пользователя: стек & пароль: стек То, что я хочу сделать, это замедлить скорость анимации, я могу изменить время задержки между ними, но анимация сама по себе быстрая и кажется резкой. Заранее спасибо

// SET THIS VARIABLE FOR DELAY, 1000 = 1 SECOND
var delayLength = 5000;

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": -600
        }, function() {
            $("#mover").animate({
                "left": 0
            }, function() {
                $(".slide img").animate({
                    "top": 40
                });
            });
        });
    }
    else {
        $(".slide img").animate({
            "top": -600
        }, function() {
            $("#mover").animate({
                "left": movement
            }, function() {
                $(".slide img").animate({
                    "top": 40
                });
            });
        });
    }
}

$(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="#" 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");
        }

    });

});

1 Ответ

2 голосов
/ 22 декабря 2010

Первым параметром после} считается время в миллисекундах.Отрегулируйте в соответствии с вашей целью.

$(".slide img").animate({
            "top": -600
        }, 500, function() {...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...