jquery + css 特效 之 一款基于jQuery/CSS3实现拼图效果的相册

     今天我们要来分享一款很酷的jQuery相册插件,首先相册中的图片会以一定的角度倾斜放置在页面上,点击图片缩略图就可以展开图片,并且图片是由所有缩略图拼接而成,图片展开和收拢的动画效果也非常不错。当然图片倾斜需要CSS3支持。效果图如下:


本章主要参照了如下文章进行学习

jquery:http://www.itmmd.com/tag/jquery.html

jQuery教程(31)-jQuery插件开发之全局函数插件
jQuery教程(30)-jQuery插件开发之自定义选择符
jQuery教程(29)-jQuery插件开发之为插件方法指定参数
jQuery教程(28)-jQuery插件开发之使用插件
jQuery教程(27)-jQueryajax操作之修改默认选项


实现的代码。

html代码:

复制代码
 <div id="im_wrapper" class="im_wrapper">
        <div style="background-position: 0px 0px;">
            <img src="images/thumbs/1.jpg" alt="" /></div>
        <div style="background-position: -125px 0px;">
            <img src="images/thumbs/2.jpg" alt="" /></div>
        <div style="background-position: -250px 0px;">
            <img src="images/thumbs/3.jpg" alt="" /></div>
        <div style="background-position: -375px 0px;">
            <img src="images/thumbs/4.jpg" alt="" /></div>
        <div style="background-position: -500px 0px;">
            <img src="images/thumbs/5.jpg" alt="" /></div>
        <div style="background-position: -625px 0px;">
            <img src="images/thumbs/6.jpg" alt="" /></div>
        <div style="background-position: 0px -125px;">
            <img src="images/thumbs/7.jpg" alt="" /></div>
        <div style="background-position: -125px -125px;">
            <img src="images/thumbs/8.jpg" alt="" /></div>
        <div style="background-position: -250px -125px;">
            <img src="images/thumbs/9.jpg" alt="" /></div>
        <div style="background-position: -375px -125px;">
            <img src="images/thumbs/10.jpg" alt="" /></div>
        <div style="background-position: -500px -125px;">
            <img src="images/thumbs/11.jpg" alt="" /></div>
        <div style="background-position: -625px -125px;">
            <img src="images/thumbs/12.jpg" alt="" /></div>
        <div style="background-position: 0px -250px;">
            <img src="images/thumbs/13.jpg" alt="" /></div>
        <div style="background-position: -125px -250px;">
            <img src="images/thumbs/14.jpg" alt="" /></div>
        <div style="background-position: -250px -250px;">
            <img src="images/thumbs/15.jpg" alt="" /></div>
        <div style="background-position: -375px -250px;">
            <img src="images/thumbs/16.jpg" alt="" /></div>
        <div style="background-position: -500px -250px;">
            <img src="images/thumbs/17.jpg" alt="" /></div>
        <div style="background-position: -625px -250px;">
            <img src="images/thumbs/18.jpg" alt="" /></div>
        <div style="background-position: 0px -375px;">
            <img src="images/thumbs/19.jpg" alt="" /></div>
        <div style="background-position: -125px -375px;">
            <img src="images/thumbs/20.jpg" alt="" /></div>
        <div style="background-position: -250px -375px;">
            <img src="images/thumbs/21.jpg" alt="" /></div>
        <div style="background-position: -375px -375px;">
            <img src="images/thumbs/22.jpg" alt="" /></div>
        <div style="background-position: -500px -375px;">
            <img src="images/thumbs/23.jpg" alt="" /></div>
        <div style="background-position: -625px -375px;">
            <img src="images/thumbs/24.jpg" alt="" /></div>
    </div>
    <div id="im_loading" class="im_loading">
    </div>
    <div id="im_next" class="im_next">
    </div>
    <div id="im_prev" class="im_prev">
    </div>
    <div>
    </div>
复制代码

js代码:

复制代码
 (function ($, sr) {

            var debounce = function (func, threshold, execAsap) {
                var timeout;
                return function debounced() {
                    var obj = this, args = arguments;
                    function delayed() {
                        if (!execAsap)
                            func.apply(obj, args);
                        timeout = null;
                    };
                    if (timeout)
                        clearTimeout(timeout);
                    else if (execAsap)
                        func.apply(obj, args);
                    timeout = setTimeout(delayed, threshold || 100);
                };
            }
            //smartresize
            jQuery.fn[sr] = function (fn) { return fn ? this.bind('resize', debounce(fn)) : this.trigger(sr); };
        })(jQuery, 'smartresize');
    </script>
    <script type="text/javascript">
        $(function () {
            //check if the user made the
            //mistake to open it with IE
            var ie = false;
            if ($.browser.msie)
                ie = true;
            //flag to control the click event
            var flg_click = true;
            //the wrapper
            var $im_wrapper = $('#im_wrapper');
            //the thumbs
            var $thumbs = $im_wrapper.children('div');
            //all the images
            var $thumb_imgs = $thumbs.find('img');
            //number of images
            var nmb_thumbs = $thumbs.length;
            //image loading status
            var $im_loading = $('#im_loading');
            //the next and previous buttons
            var $im_next = $('#im_next');
            var $im_prev = $('#im_prev');
            //number of thumbs per line
            var per_line = 6;
            //number of thumbs per column
            var per_col = Math.ceil(nmb_thumbs / per_line)
            //index of the current thumb
            var current = -1;
            //mode = grid | single
            var mode = 'grid';
            //an array with the positions of the thumbs
            //we will use it for the navigation in single mode
            var positionsArray = [];
            for (var i = 0; i < nmb_thumbs; ++i)
                positionsArray[i] = i;


            //preload all the images
            $im_loading.show();
            var loaded = 0;
            $thumb_imgs.each(function () {
                var $this = $(this);
                $('<img/>').load(function () {
                    ++loaded;
                    if (loaded == nmb_thumbs * 2)
                        start();
                }).attr('src', $this.attr('src'));
                $('<img/>').load(function () {
                    ++loaded;
                    if (loaded == nmb_thumbs * 2)
                        start();
                }).attr('src', $this.attr('src').replace('/thumbs', ''));
            });

            //starts the animation
            function start() {
                $im_loading.hide();
                //disperse the thumbs in a grid
                disperse();
            }

            //disperses the thumbs in a grid based on windows dimentions
            function disperse() {
                if (!flg_click) return;
                setflag();
                mode = 'grid';
                //center point for first thumb along the width of the window
                var spaces_w = $(window).width() / (per_line + 1);
                //center point for first thumb along the height of the window
                var spaces_h = $(window).height() / (per_col + 1);
                //let's disperse the thumbs equally on the page
                $thumbs.each(function (i) {
                    var $thumb = $(this);
                    //calculate left and top for each thumb,
                    //considering how many we want per line
                    var left = spaces_w * ((i % per_line) + 1) - $thumb.width() / 2;
                    var top = spaces_h * (Math.ceil((i + 1) / per_line)) - $thumb.height() / 2;
                    //lets give a random degree to each thumb
                    var r = Math.floor(Math.random() * 41) - 20;
                    /*
                    now we animate the thumb to its final positions;
                    we also fade in its image, animate it to 115x115,
                    and remove any background image    of the thumb - this
                    is not relevant for the first time we call disperse,
                    but when changing from single to grid mode
                    */
                    if (ie)
                        var param = {
                            'left': left + 'px',
                            'top': top + 'px'
                        };
                    else
                        var param = {
                            'left': left + 'px',
                            'top': top + 'px',
                            'rotate': r + 'deg'
                        };
                    $thumb.stop()
                        .animate(param, 700, function () {
                            if (i == nmb_thumbs - 1)
                                setflag();
                        })
                        .find('img')
                        .fadeIn(700, function () {
                            $thumb.css({
                                'background-image': 'none'
                            });
                            $(this).animate({
                                'width': '115px',
                                'height': '115px',
                                'marginTop': '5px',
                                'marginLeft': '5px'
                            }, 150);
                        });
                });
            }

            //controls if we can click on the thumbs or not
            //if theres an animation in progress
            //we don't want the user to be able to click
            function setflag() {
                flg_click = !flg_click
            }

            /*
            when we click on a thumb, we want to merge them
            and show the full image that was clicked.
            we need to animate the thumbs positions in order
            to center the final image in the screen. The
            image itself is the background image that each thumb
            will have (different background positions)
            If we are currently seeing the single image,
            then we want to disperse the thumbs again,
            and with this, showing the thumbs images.
            */
            $thumbs.bind('click', function () {
                if (!flg_click) return;
                setflag();

                var $this = $(this);
                current = $this.index();

                if (mode == 'grid') {
                    mode = 'single';
                    //the source of the full image
                    var image_src = $this.find('img').attr('src').replace('/thumbs', '');

                    $thumbs.each(function (i) {
                        var $thumb = $(this);
                        var $image = $thumb.find('img');
                        //first we animate the thumb image
                        //to fill the thumbs dimentions
                        $image.stop().animate({
                            'width': '100%',
                            'height': '100%',
                            'marginTop': '0px',
                            'marginLeft': '0px'
                        }, 150, function () {
                            //calculate the dimentions of the full image
                            var f_w = per_line * 125;
                            var f_h = per_col * 125;
                            var f_l = $(window).width() / 2 - f_w / 2
                            var f_t = $(window).height() / 2 - f_h / 2
                            /*
                            set the background image for the thumb
                            and animate the thumbs postions and rotation
                            */
                            if (ie)
                                var param = {
                                    'left': f_l + (i % per_line) * 125 + 'px',
                                    'top': f_t + Math.floor(i / per_line) * 125 + 'px'
                                };
                            else
                                var param = {
                                    'rotate': '0deg',
                                    'left': f_l + (i % per_line) * 125 + 'px',
                                    'top': f_t + Math.floor(i / per_line) * 125 + 'px'
                                };
                            $thumb.css({
                                'background-image': 'url(' + image_src + ')'
                            }).stop()
                                .animate(param, 1200, function () {
                                    //insert navigation for the single mode
                                    if (i == nmb_thumbs - 1) {
                                        addNavigation();
                                        setflag();
                                    }
                                });
                            //fade out the thumb's image
                            $image.fadeOut(700);
                        });
                    });
                }
                else {
                    setflag();
                    //remove navigation
                    removeNavigation();
                    //if we are on single mode then disperse the thumbs
                    disperse();
                }
            });

            //removes the navigation buttons
            function removeNavigation() {
                $im_next.stop().animate({ 'right': '-50px' }, 300);
                $im_prev.stop().animate({ 'left': '-50px' }, 300);
            }

            //add the navigation buttons
            function addNavigation() {
                $im_next.stop().animate({ 'right': '0px' }, 300);
                $im_prev.stop().animate({ 'left': '0px' }, 300);
            }

            //User clicks next button (single mode)
            $im_next.bind('click', function () {
                if (!flg_click) return;
                setflag();

                ++current;
                var $next_thumb = $im_wrapper.children('div:nth-child(' + (current + 1) + ')');
                if ($next_thumb.length > 0) {
                    var image_src = $next_thumb.find('img').attr('src').replace('/thumbs', '');
                    var arr = Array.shuffle(positionsArray.slice(0));
                    $thumbs.each(function (i) {
                        //we want to change each divs background image
                        //on a different point of time
                        var t = $(this);
                        setTimeout(function () {
                            t.css({
                                'background-image': 'url(' + image_src + ')'
                            });
                            if (i == nmb_thumbs - 1)
                                setflag();
                        }, arr.shift() * 20);
                    });
                }
                else {
                    setflag();
                    --current;
                    return;
                }
            });

            //User clicks prev button (single mode)
            $im_prev.bind('click', function () {
                if (!flg_click) return;
                setflag();
                --current;
                var $prev_thumb = $im_wrapper.children('div:nth-child(' + (current + 1) + ')');
                if ($prev_thumb.length > 0) {
                    var image_src = $prev_thumb.find('img').attr('src').replace('/thumbs', '');
                    var arr = Array.shuffle(positionsArray.slice(0));
                    $thumbs.each(function (i) {
                        var t = $(this);
                        setTimeout(function () {
                            t.css({
                                'background-image': 'url(' + image_src + ')'
                            });
                            if (i == nmb_thumbs - 1)
                                setflag();
                        }, arr.shift() * 20);
                    });
                }
                else {
                    setflag();
                    ++current;
                    return;
                }
            });

            //on windows resize call the disperse function
            $(window).smartresize(function () {
                removeNavigation()
                disperse();
            });

            //function to shuffle an array
            Array.shuffle = function (array) {
                for (
                    var j, x, i = array.length; i;
                    j = parseInt(Math.random() * i),
                    x = array[--i], array[i] = array[j], array[j] = x
                );
                return array;
            };
        });
复制代码
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用jQueryCSS实现滑动的标签分栏切换效果,具体步骤如下: HTML结构: ```html <div class="tab-wrap"> <div class="tabs"> <a href="#" class="active">Tab 1</a> <a href="#">Tab 2</a> <a href="#">Tab 3</a> </div> <div class="tab-content"> <div class="tab-pane active">Tab 1 Content</div> <div class="tab-pane">Tab 2 Content</div> <div class="tab-pane">Tab 3 Content</div> </div> </div> ``` CSS样式: ```css .tab-wrap { position: relative; width: 100%; overflow: hidden; } .tabs { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; } .tabs a { position: relative; padding: 10px; color: #000; text-decoration: none; cursor: pointer; } .tabs a.active:before { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 2px; background-color: #000; transform: scaleX(1); transition: transform 0.3s ease-in-out; } .tabs a:hover:before { transform: scaleX(1); } .tab-content { position: relative; height: 300px; overflow: hidden; } .tab-pane { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 0.3s ease-in-out; } .tab-pane.active { opacity: 1; } ``` JavaScript代码: ```javascript $(function() { var $tabs = $(".tabs a"); var $tabContent = $(".tab-content .tab-pane"); $tabs.on("click", function(e) { e.preventDefault(); var $this = $(this); var target = $this.attr("href"); $tabs.removeClass("active"); $this.addClass("active"); $tabContent.removeClass("active"); $(target).addClass("active"); var offsetLeft = $this.offset().left - $tabs.offset().left; $(".tabs:before").css("transform", "translateX(" + offsetLeft + "px)"); }); }); ``` 首先,我们给标签分栏容器设置了一个相对定位和一个隐藏溢出。然后,在标签容器中创建了一个带有活动类的链接,并将其余标签链接设置为不活动状态。接着,在内容容器中创建了一个带有活动类的选项卡面板,并将其余选项卡面板设置为不活动状态。 在CSS部分,我们使用了Flexbox布局来设置选项卡链接,使它们在选项卡容器中居中对齐并沿水平轴均匀分布。我们给选项卡链接添加了一个:hover伪类,以便在鼠标悬停时显示下划线。我们还使用了CSS过渡效果来创建平滑的动画效果。 JavaScript部分,我们使用jQuery来捕捉选项卡链接的点击事件,并在单击选项卡链接时将其标记为活动状态,并显示相应的选项卡面板。我们还使用jQuery计算出选项卡链接的偏移量,并使用CSS transform属性将指示器移动到正确的位置。 这就是滑动标签分栏切换效果实现方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值