微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

酷炫jQuery全屏3D焦点图动画效果

这又是一款很不错的jQuery焦点图动画,它的特点是整个焦点图基本是全屏显示的,非常大气,而且图片的倾斜也给整个焦点图3D立体的视觉效果,而且焦点图的图片切换非常流畅,相当实用。

HTML代码

rush:xhtml;">

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


<div class="pxs_bg2">

<div class="pxs_bg3">

First Image
  • Second Image
  • Third Image
  • Forth Image
  • Fifth Image
  • Sixth Image
    • First Image
    • Second Image
    • Third Image
    • Forth Image
    • Fifth Image
    • Sixth Image

    JavaScript代码

    <div class="jb51code">
    <pre class="brush:js;">
    (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_prev = $('.pxs_prev',//the bg images
    $pxs_bg1 = $('.pxs_bg1',$pxs_bg2 = $('.pxs_bg2',$pxs_bg3 = $('.pxs_bg3',//current image
    current = 0,//the thumbs container
    $pxs_thumbnails = $('.pxs_thumbnails',//the thumbs
    $thumbs = $pxs_thumbnails.children(),//the interval for the autoplay mode
    slideshow,//the loading image
    $pxs_loading = $('.pxs_loading',$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);
    $('').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.thum<a href="https://www.jb51.cc/tag/bro/" target="_blank" class="keywords">bro</a>tation){
    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,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,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,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,$pxs_prev);
    slide(current,1,o.easingBg);
    });

    }
    }).error(function(){
    alert('here')
    }).attr('src',$img.attr('src'));
    });

    });
    };

    //the current windows width
    var w_w = $(window).width();

    var slide = function(current,speed,easing,easingBg){
    var slide_to = parseInt(-w_w * current);
    $pxs_slider.stop().animate({
    left : slide_to + 'px'
    },easing);
    $pxs_bg3.stop().animate({
    left : slide_to/2 + 'px'
    },easingBg);
    $pxs_bg2.stop().animate({
    left : slide_to/4 + 'px'
    },easingBg);
    $pxs_bg1.stop().animate({
    left : slide_to/8 + 'px'
    },easingBg);
    }

    var highlight = function($elem){
    $elem.siblings().removeClass('selected');
    $elem.addClass('selected');
    }

    var setWidths = function($pxs_slider,$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代码

    rush:js;"> $(function() { var $pxs_container = $('#pxs_container'); $pxs_container.parallaxSlider(); });

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

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

    相关推荐