2010-10-29 4 views
0

Comment ajouter un bouton de pause dans ce curseur d'image jQuery? Je veux ajouter Pause sur le bouton enfin après ?Comment ajouter le bouton "pause" dans ce curseur jquery?

Comme ceci: voir l'exemple pic http://shup.com/Shup/431390/110929231254-My-Desktop.png

alt text

http://www.sohtanaka.com/web-design/examples/image-slider/

Je veux ajouter un autre bouton de lien pour mettre en pause le curseur sur la diapositive en cours. et il ne devrait pas revenir en arrière sur la première diapositive. J'ai besoin d'un bouton toogle pour activer/désactiver l'animation.

Ceci est le code html des boutons.

<div class="paging"> 

     <a href="#" rel="1">1</a> 
     <a href="#" rel="2">2</a> 
     <a href="#" rel="3">3</a> 
     <a href="#" rel="4">4</a> 
    </div> 

Ceci est le code jquery des boutons.

$(document).ready(function() { 

    //Set Default State of each portfolio piece 
    $(".paging").show(); 
    $(".paging a:first").addClass("active"); 

    //Get size of images, how many there are, then determin the size of the image reel. 
    var imageWidth = $(".window").width(); 
    var imageSum = $(".image_reel img").size(); 
    var imageReelWidth = imageWidth * imageSum; 

    //Adjust the image reel to its new size 
    $(".image_reel").css({ 
     'width': imageReelWidth 
    }); 

    //Paging + Slider Function 
    rotate = function() { 
     var triggerID = $active.attr("rel") - 1; //Get number of times to slide 
     var image_reelPosition = triggerID * imageWidth; //Determines the distance the image reel needs to slide 

     $(".paging a").removeClass('active'); //Remove all active class 
     $active.addClass('active'); //Add active class (the $active is declared in the rotateSwitch function) 

     //Slider Animation 
     $(".image_reel").animate({ 
      left: -image_reelPosition 
     }, 500); 

    }; 

    //Rotation + Timing Event 
    rotateSwitch = function() { 
     play = setInterval(function() { //Set timer - this will repeat itself every 3 seconds 
      $active = $('.paging a.active').next(); 
      if ($active.length === 0) { //If paging reaches the end... 
       $active = $('.paging a:first'); //go back to first 
      } 
      rotate(); //Trigger the paging and slider function 
     }, 7000); //Timer speed in milliseconds (3 seconds) 
    }; 

    rotateSwitch(); //Run function on launch 

    //On Hover 
    $(".image_reel a").hover(function() { 
     clearInterval(play); //Stop the rotation 
    }, function() { 
     rotateSwitch(); //Resume rotation 
    }); 

    //On Click 
    $(".paging a").click(function() { 
     $active = $(this); //Activate the clicked paging 
     //Reset Timer 
     clearInterval(play); //Stop the rotation 
     rotate(); //Trigger rotation immediately 
     rotateSwitch(); // Resume rotation 
     return false; //Prevent browser jump to link anchor 
    }); 

}); 

Essayez ici l'exemple modifiable en direct http://jsfiddle.net/3TJrj/128/

Répondre

3

donner une variable et vérifier lors de la rotation

var chk=0; 
$('id').click(function(){ 
chk=1;}); 

donner ifcondition en fonction rotate et aussi en jeu, je l'espère cela fonctionne. .

+0

S'il vous plaît fournir plus de détails –

+0

http://jsfiddle.net/pahnin/fakeu/ voir ce désolé pour la fin j'étais occupé et si vous êtes satisfait s'il vous plaît approuver la réponse – pahnin

+0

merci ça marche –

Questions connexes