自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

超贊的jQuery幻燈插件 附下載

開發(fā) 前端
應(yīng)朋友的邀請(qǐng),幫他公司做jQuery縮略圖正中間的為當(dāng)前播放到的圖片,兩邊呈發(fā)散狀,逐漸縮小并降低透明度。假設(shè)當(dāng)前正播放到第0張圖片,則排列情況如下:

應(yīng)朋友的邀請(qǐng),幫他公司做jQuery縮略圖正中間的為當(dāng)前播放到的圖片,兩邊呈發(fā)散狀,逐漸縮小并降低透明度。假設(shè)當(dāng)前正播放到第0張圖片,則排列情況如下:

jQuery

縮略圖正中間的為當(dāng)前播放到的圖片,兩邊呈發(fā)散狀,逐漸縮小并降低透明度。假設(shè)當(dāng)前正播放到第0張圖片,則排列情況如下:

0

1 4

2   3

按逆時(shí)針方向轉(zhuǎn)一張圖后的排列情況如下:

4

0 3

1    2

這個(gè)只是縮略圖的播放效果,縮略圖輪轉(zhuǎn)時(shí),后面有對(duì)應(yīng)大圖跟著從右到左滾進(jìn),并且大圖進(jìn)入的速度要對(duì)應(yīng)著縮略圖輪轉(zhuǎn),整體效果如下:

一個(gè)幻燈播放效果,效果如下:

jQuery

本人考慮將縮略圖輪轉(zhuǎn)與大圖的滾進(jìn)分開兩部分,縮略圖輪轉(zhuǎn)做為一個(gè)單獨(dú)的jQuery插件,由此插件中的事件帶動(dòng)大圖的滾進(jìn)。下面先來說說縮略圖的輪轉(zhuǎn)插件的實(shí)現(xiàn):

1、插件的參數(shù):

  1. this.defaults = {  
  2.        auto: false,        //是否自動(dòng)播放  
  3.        width: 85,          //縮略圖的寬度  
  4.        height: 42,         //縮略圖的高度  
  5.        onstart: null,      //開始滾動(dòng)  
  6.        onchange: null     //滾動(dòng)事件  
  7. }; 

2、插件的事件:

onstart事件,為每次開始啟動(dòng)輪轉(zhuǎn)時(shí)觸發(fā)一次,轉(zhuǎn)出的參數(shù)有:當(dāng)前縮略圖的jQuery對(duì)象與輪轉(zhuǎn)到下一次縮略圖的jQuery對(duì)象:

  1. opt.onstart && opt.onstart  
  2. (me.Images.img[curIdx].img$, me.Images.img[idx].img$); 

onchange事件,為每滾動(dòng)一次距離就觸發(fā)一次,并且當(dāng)前滾動(dòng)至百分之多少的進(jìn)度參數(shù):

  1. opt.onchange && opt.onchange(stepPercent[step]); 

下面將要說到 stepPercent[step] 這個(gè)數(shù)組:

縮略圖輪轉(zhuǎn)采用定時(shí)不定速度的方式,即每次輪轉(zhuǎn)不過時(shí)輪轉(zhuǎn)一張圖還是兩張圖,時(shí)間都是固定的,但是輪轉(zhuǎn)兩張圖的速度要比輪轉(zhuǎn)一張圖速度要快,這樣即使有再多的圖,滾動(dòng)的距離再遠(yuǎn),也不至于要很久才能滾到。

stepPercent[step] 這個(gè)數(shù)組正是為這個(gè)設(shè)計(jì)的,每次輪轉(zhuǎn),都固定走15步,每一步輪轉(zhuǎn)的距離都逐漸縮小.

  1. var stepPercent = new Array(15);      
  2. //固定走15步,每步走至百分之多少的一個(gè)數(shù)列。 表示經(jīng)過時(shí)間一定,速度不固定  
  3. stepPercent[0] = 0.2;               //起始20%  
  4. stepPercent[1] = 0.2 + 0.2 * 0.81;   //第二步  
  5. for (var i = 2, total = stepPercent[1];   
  6. i < stepPercent.length; i++) {  
  7.     stepPercent[i] = total + (total - stepPercent[i - 2]) * 0.81;    
  8. //初始化數(shù)列。  
  9.     total = stepPercent[i];  
  10.      if (i == stepPercent.length - 1)  
  11.          stepPercent[i] = 1;  

起始第一步走20%,此后每一步都是前一步的81%,即速度每次遞減19%,但是小數(shù)計(jì)算有個(gè)誤差,到第15步時(shí)可能是個(gè)很接近于1,但是不是1的一個(gè)數(shù)值,所以,將第15步直接設(shè)置成1,即100%,滾動(dòng)結(jié)束。

(注:這個(gè)數(shù)列是如何設(shè)計(jì)出來的呢,我是用Excel,找一個(gè)單元格填上0.2,下一格公式為上一格的0.81,然后往下多拖一點(diǎn),然后將上面的累加到接近1的數(shù)值,就是要的步數(shù)了。)

這個(gè)數(shù)列如果不用JS生成,其實(shí)也可以將Excel中創(chuàng)建出來的數(shù)列直接定義一個(gè)數(shù)組,以后如果想要修改速度,再照做一次就行。

輪轉(zhuǎn)時(shí),縮略圖的尺寸、透明度、位置等信息的計(jì)算,都采用此stepPercent數(shù)組設(shè)定好的比例因子。

關(guān)于插件其他不在贅述,請(qǐng)直接下載源代碼查看,下面說說大圖如何跟著縮略圖滾動(dòng)。

3、大圖滾動(dòng)

大圖在隨著縮略圖滾動(dòng)時(shí),不過滾動(dòng)到第幾張,表現(xiàn)出來的效果都是緊跟著當(dāng)前大圖的后面滾進(jìn),以防跳過太多張時(shí),由于速度太快,造成眼花繚亂的感覺,所以這里這個(gè)onstart事件就派上用場了。

在onstart事件中,先將當(dāng)前圖移動(dòng)到大圖列表首位、再將目標(biāo)圖移動(dòng)到當(dāng)前圖的后面,(注:要將當(dāng)前圖移動(dòng)到大圖列表首位,是因?yàn)橛锌赡芟乱粡堅(jiān)诋?dāng)前張的前面,當(dāng)前張移到后面,滾動(dòng)條位置會(huì)動(dòng))。

然后在onchange事件中,只要根據(jù)傳入的進(jìn)度參數(shù),設(shè)置橫滾動(dòng)條的滾動(dòng)距離就行了,大圖的滾動(dòng)就這么簡單。具體JS如下:
 

  1. $(function() {  
  2.     $("#div_Slide").Slide({  
  3.         auto: true,  
  4.         width: 85,  
  5.         height: 42,  
  6.         onstart: function(curImg, nextImg) {  
  7.             var cData = curImg.attr("data");  
  8.             var nData = nextImg.attr("data");  
  9.             var bigCur = $("#" + cData), bigNext = $("#" + nData);  
  10.  
  11.             var allBigImg = bigCur.parent().children("img");  
  12.             var curIndex = allBigImg.index(bigCur[0]);  
  13.             var nextIndex = allBigImg.index(bigNext[0]);  
  14.  
  15.             var firstImg = $(allBigImg[0]);  
  16.             if (firstImg.attr("id") != bigCur.attr("id"))  
  17.                 bigCur.insertBefore(firstImg);  
  18.             $("#div_BigImg").scrollLeft(0);  
  19.             bigNext.insertAfter(bigCur);  
  20.         },  
  21.         onchange: function(percent) {  
  22.             $("#div_BigImg").scrollLeft(1263 * percent);  
  23.         }  
  24.     });  
  25.     var bigDiv = $("#div_BigImg");  
  26.     var bigDivPos = bigDiv.position();  
  27.     bigDiv.scrollLeft(0);   
  28.    //初始時(shí)將滾動(dòng)條滾到頭,是因?yàn)槲野l(fā)現(xiàn)當(dāng)滾動(dòng)條不在頭時(shí),按F5刷新,滾動(dòng)條不會(huì)跳到頭。  
  29.  
  30.     $("#div_Slide").css({  
  31.         "top": (bigDivPos.top + bigDiv.height() - $("#div_Slide").height()) + "px",  
  32.         "left": bigDivPos.left + "px" 
  33.     });  
  34. }); 

源碼下載:SlideDemo

原文鏈接:http://www.cnblogs.com/homeLu/archive/2011/01/24/1943090.html

【編輯推薦】

  1. 10款給力構(gòu)建易用性網(wǎng)站的jQuery插件
  2. 10個(gè)超贊超實(shí)用的免費(fèi)jQuery圖片插件 附下載
  3. jQuery 1.5第一個(gè)Beta版發(fā)布 付下載
  4. 超炫無比 10個(gè)免費(fèi)的jQuery相冊(cè)(附下載)
  5. 好戲連臺(tái) 2010年最佳jQuery插件揭曉(附下載)
責(zé)任編輯:陳貽新 來源: Home.Lu的博客
相關(guān)推薦

2011-01-21 07:22:48

jQuerywebJavaScript

2012-02-01 09:11:00

jQuery插件

2012-03-19 16:50:03

jQuery插件

2011-06-07 09:22:43

jQueryjQuery插件

2011-10-27 15:08:03

jQuery

2010-12-13 13:33:23

jQuery相冊(cè)

2011-08-01 15:18:45

jQuery

2018-09-13 21:56:26

深度學(xué)習(xí)機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)

2011-11-25 09:51:26

jQuery插件

2011-02-17 09:29:45

WebjQueryJavascript

2016-01-25 09:49:20

jQuery圖片滑塊動(dòng)畫

2011-07-06 09:47:05

2010-12-08 09:13:50

jQuery插件

2011-04-01 11:13:57

jQuery

2011-03-18 11:09:42

jQuery

2011-03-22 13:16:49

jQueryjQuery插件

2011-05-10 09:08:09

jQuery插件

2012-11-21 09:53:19

jQueryWeb

2011-11-04 09:09:38

jQuery

2011-05-04 08:36:19

jQueryjavascript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)