酷炫jQuery全屏3D焦点图动画效果
来源: 阅读:848 次 日期:2016-07-19 14:08:42
温馨提示: 小编为您整理了“酷炫jQuery全屏3D焦点图动画效果”,方便广大网友查阅!

这篇文章主要介绍了一款非常酷炫的jQuery全屏3D焦点图动画效果其特点是整个焦点图基本是全屏显示的,非常大气,感兴趣的小伙伴们可以参考一下

HTML代码:

<div class="wrapper">

</div>

<div id="pxs_container" class="pxs_container">

 <div class="pxs_bg">

 <div class="pxs_bg1"></div>

 <div class="pxs_bg2"></div>

 <div class="pxs_bg3"></div>

 </div>

 <div class="pxs_loading">Loading images...</div>

 <div class="pxs_slider_wrapper">

 <ul class="pxs_slider">

  <li><img src="images/1.jpg" alt="First Image" /></li>

  <li><img src="images/2.jpg" alt="Second Image" /></li>

  <li><img src="images/3.jpg" alt="Third Image" /></li>

  <li><img src="images/4.jpg" alt="Forth Image" /></li>

  <li><img src="images/5.jpg" alt="Fifth Image" /></li>

  <li><img src="images/6.jpg" alt="Sixth Image" /></li>

 </ul>

 <div class="pxs_navigation">

  <span class="pxs_next"></span>

  <span class="pxs_prev"></span>

 </div>

 <ul class="pxs_thumbnails">

  <li><img src="images/thumbs/1.jpg" alt="First Image" /></li>

  <li><img src="images/thumbs/2.jpg" alt="Second Image" /></li>

  <li><img src="images/thumbs/3.jpg" alt="Third Image" /></li>

  <li><img src="images/thumbs/4.jpg" alt="Forth Image" /></li>

  <li><img src="images/thumbs/5.jpg" alt="Fifth Image" /></li>

  <li><img src="images/thumbs/6.jpg" alt="Sixth Image" /></li>

 </ul>

 </div>

</div>

JavaScript代码

(function($) {

 $.fn.parallaxSlider = function(options) {

 var opts = $.extend({}, $.fn.parallaxSlider.defaults, options);

 return this.each(function() {

  var $pxs_container = $(this),

  o   = $.meta ? $.extend({}, opts, $pxs_container.data()) : opts;

  //the main slider

  var $pxs_slider = $('.pxs_slider',$pxs_container),

  //the elements in the slider

  $elems  = $pxs_slider.children(),

  //total number of elements

  total_elems = $elems.length,

  //the navigation buttons

  $pxs_next = $('.pxs_next',$pxs_container),

  $pxs_prev = $('.pxs_prev',$pxs_container),

  //the bg images

  $pxs_bg1 = $('.pxs_bg1',$pxs_container),

  $pxs_bg2 = $('.pxs_bg2',$pxs_container),

  $pxs_bg3 = $('.pxs_bg3',$pxs_container),

  //current image

  current  = 0,

  //the thumbs container

  $pxs_thumbnails = $('.pxs_thumbnails',$pxs_container),

  //the thumbs

  $thumbs  = $pxs_thumbnails.children(),

  //the interval for the autoplay mode

  slideshow,

  //the loading image

  $pxs_loading = $('.pxs_loading',$pxs_container),

  $pxs_slider_wrapper = $('.pxs_slider_wrapper',$pxs_container);

  //first preload all the images

  var loaded = 0,

  $images = $pxs_slider_wrapper.find('img');

  $images.each(function(){

  var $img = $(this);

  $('<img/>').load(function(){

   ++loaded;

   if(loaded == total_elems*2){

   $pxs_loading.hide();

   $pxs_slider_wrapper.show();

   //one images width (assuming all images have the same sizes)

   var one_image_w = $pxs_slider.find('img:first').width();

   /*

   need to set width of the slider,

   of each one of its elements, and of the

   navigation buttons

    */

   setWidths($pxs_slider,

   $elems,

   total_elems,

   $pxs_bg1,

   $pxs_bg2,

   $pxs_bg3,

   one_image_w,

   $pxs_next,

   $pxs_prev);

   /*

    set the width of the thumbs

    and spread them evenly

    */

   $pxs_thumbnails.css({

    'width'  : one_image_w + 'px',

    'margin-left' : -one_image_w/2 + 'px'

   });

   var spaces = one_image_w/(total_elems+1);

   $thumbs.each(function(i){

    var $this = $(this);

    var left = spaces*(i+1) - $this.width()/2;

    $this.css('left',left+'px');

    if(o.thumbRotation){

    var angle = Math.floor(Math.random()*41)-20;

    $this.css({

     '-moz-transform' : 'rotate('+ angle +'deg)',

     '-webkit-transform' : 'rotate('+ angle +'deg)',

     'transform'  : 'rotate('+ angle +'deg)'

    });

    }

    //hovering the thumbs animates them up and down

    $this.bind('mouseenter',function(){

    $(this).stop().animate({top:'-10px'},100);

    }).bind('mouseleave',function(){

    $(this).stop().animate({top:'0px'},100);

    });

   });

   //make the first thumb be selected

   highlight($thumbs.eq(0));

   //slide when clicking the navigation buttons

   $pxs_next.bind('click',function(){

    ++current;

    if(current >= total_elems)

    if(o.circular)

     current = 0;

    else{

    --current;

    return false;

    }

    highlight($thumbs.eq(current));

    slide(current,

    $pxs_slider,

    $pxs_bg3,

    $pxs_bg2,

    $pxs_bg1,

    o.speed,

    o.easing,

    o.easingBg);

   });

   $pxs_prev.bind('click',function(){

    --current;

    if(current < 0)

    if(o.circular)

     current = total_elems - 1;

    else{

    ++current;

    return false;

    }

    highlight($thumbs.eq(current));

    slide(current,

    $pxs_slider,

    $pxs_bg3,

    $pxs_bg2,

    $pxs_bg1,

    o.speed,

    o.easing,

    o.easingBg);

   });

   /*

   clicking a thumb will slide to the respective image

    */

   $thumbs.bind('click',function(){

    var $thumb = $(this);

    highlight($thumb);

    //if autoplay interrupt when user clicks

    if(o.auto)

    clearInterval(slideshow);

    current = $thumb.index();

    slide(current,

    $pxs_slider,

    $pxs_bg3,

    $pxs_bg2,

    $pxs_bg1,

    o.speed,

    o.easing,

    o.easingBg);

   });

   /*

   activate the autoplay mode if

   that option was specified

    */

   if(o.auto != 0){

    o.circular = true;

    slideshow = setInterval(function(){

    $pxs_next.trigger('click');

    },o.auto);

   }

   /*

   when resizing the window,

   we need to recalculate the widths of the

   slider elements, based on the new windows width.

   we need to slide again to the current one,

   since the left of the slider is no longer correct

    */

   $(window).resize(function(){

    w_w = $(window).width();

    setWidths($pxs_slider,$elems,total_elems,$pxs_bg1,$pxs_bg2,$pxs_bg3,one_image_w,$pxs_next,$pxs_prev);

    slide(current,

    $pxs_slider,

    $pxs_bg3,

    $pxs_bg2,

    $pxs_bg1,

    1,

    o.easing,

    o.easingBg);

   });

   }

  }).error(function(){

   alert('here')

  }).attr('src',$img.attr('src'));

  });

 });

 };

 //the current windows width

 var w_w  = $(window).width();

 var slide  = function(current,

 $pxs_slider,

 $pxs_bg3,

 $pxs_bg2,

 $pxs_bg1,

 speed,

 easing,

 easingBg){

 var slide_to = parseInt(-w_w * current);

 $pxs_slider.stop().animate({

  left : slide_to + 'px'

 },speed, easing);

 $pxs_bg3.stop().animate({

  left : slide_to/2 + 'px'

 },speed, easingBg);

 $pxs_bg2.stop().animate({

  left : slide_to/4 + 'px'

 },speed, easingBg);

 $pxs_bg1.stop().animate({

  left : slide_to/8 + 'px'

 },speed, easingBg);

 }

 var highlight = function($elem){

 $elem.siblings().removeClass('selected');

 $elem.addClass('selected');

 }

 var setWidths = function($pxs_slider,

 $elems,

 total_elems,

 $pxs_bg1,

 $pxs_bg2,

 $pxs_bg3,

 one_image_w,

 $pxs_next,

 $pxs_prev){

 /*

 the width of the slider is the windows width

 times the total number of elements in the slider

  */

 var pxs_slider_w = w_w * total_elems;

 $pxs_slider.width(pxs_slider_w + 'px');

 //each element will have a width = windows width

 $elems.width(w_w + 'px');

 /*

 we also set the width of each bg image div.

 The value is the same calculated for the pxs_slider

  */

 $pxs_bg1.width(pxs_slider_w + 'px');

 $pxs_bg2.width(pxs_slider_w + 'px');

 $pxs_bg3.width(pxs_slider_w + 'px');

 /*

 both the right and left of the

 navigation next and previous buttons will be:

 windowWidth/2 - imgWidth/2 + some margin (not to touch the image borders)

  */

 var position_nav = w_w/2 - one_image_w/2 + 3;

 $pxs_next.css('right', position_nav + 'px');

 $pxs_prev.css('left', position_nav + 'px');

 }

 $.fn.parallaxSlider.defaults = {

 auto  : 0, //how many seconds to periodically slide the content.

    //If set to 0 then autoplay is turned off.

 speed  : 1000,//speed of each slide animation

 easing  : 'jswing',//easing effect for the slide animation

 easingBg : 'jswing',//easing effect for the background animation

 circular : true,//circular slider

 thumbRotation : true//the thumbs will be randomly rotated

 };

 //easeInOutExpo,easeInBack

})(jQuery);

调用插件的JavaScript代码

$(function() {

 var $pxs_container = $('#pxs_container');

 $pxs_container.parallaxSlider();

});

以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map