jQuery制作圖片旋轉效果
以前用JQuery寫過一個縱深方向上的圖片旋轉效果,在這里拿出來跟大家分享下,貼上一張圖片看看效果是如何的:
其實現(xiàn)原理并不復雜,在數(shù)學上只用到了其中的正弦函數(shù),制作過程大致如下:
(1)先定義好圖片旋轉的半徑
(2)圖片旋轉的過程需要用到setInterval()方法,來獲取每一張圖片所在位置的的角度,角度會根據(jù)時間變化逐漸變化
(3)根據(jù)一個數(shù)學公式:x=R*SIN(deg)可以獲得圖片在X方向的位置
(4)透明度的設置其實也是根據(jù)圖片旋轉時候的角度來定的。初始設置圖片在正前方時是0度,無論是正時針還是逆時針方式旋轉,當圖片旋轉角度大于0度
小于180度時圖片的透明度是逐漸減小的,這里為了圖片在180度時不至于完全透明加了個小小的計算公式,代碼會在下面展示。
(5)圖片的縮放也是根據(jù)圖片旋轉角度而定的,相信容易理解。
(6)有了圖片的X軸位置信息,縮放信息,透明度信息后,接下來就是很簡單的事情了,只要將所有的信息通過CSS樣式顯示出來就可以了。
css的樣式會通過setInterval()方法逐漸改變。
下面來看下主要代碼:
var thisleft=-(o.radius)*Math.sin((360/imgnum)*$(this).data("index")*(Math.PI*2/360))+(holderwidth/2); var thiszindex=360/imgnum*$(this).data("index")>180?360/imgnum*$(this).data("index")-360:-360/imgnum*$(this).data("index"); var thisopacity=360/imgnum*$(this).data("index")<=180?(180-360/imgnum*$(this).data("index"))/180*1.2: (360/imgnum*$(this).data("index")-180)/180*1.2;
第二行的thiszindex是圖片的深度信息,對每張圖片我都給它加了一個index屬性保存其索引值,圖片會根據(jù)這個信息通過計算得到相應的深度值。
第三行的thisopacity是圖片的透明度信息。
每一張圖片都會被賦予一下的CSS樣式:
$(this).css({ "left":thisleft-(o.width*thisopacity)/2+"px", "top":(holderheight/2)-o.width*(thisopacity+1)/4, "z-index":thiszindex+180, "opacity":(thisopacity+0.2)/1.2, "width":o.width*(thisopacity+1)/2, "height":o.height*(thisopacity+1)/2 });
第五行的opacity用了一個簡單的公式使其在最深度時不至于完全透明。
在功能上我加了左右轉的功能,其原理也就是將圖片的X軸信息的正負值轉換而已,代碼如下:
if(dir=='left'){ thisleft=-(o.radius)*Math.sin(xx*(Math.PI*2/360))+(holderwidth/2); }else{ thisleft=(o.radius)*Math.sin(xx*(Math.PI*2/360))+(holderwidth/2); }
整個效果中用戶可以自定義一下參數(shù):
$.fn.scroll3d.defaults={ speed:25, radius:100, width:200, height:150, direction:'left' }
下面附上效果的完整代碼:
(function($) { $.fn.scroll3d = function(options) { var opts = $.extend({}, $.fn.scroll3d.defaults, options); var $this = $(this); var o = $.meta ? $.extend({}, opts, $(this).data()) : opts; var radius = o.radius; var timer = 0; var xx = 0; var speed = o.speed; var dir = o.direction; $(this).hide(); return this.each(function() { var $img = $(this).find('img').css({'position': 'absolute'}), num = 0; var imgnum = $img.length; var holderwidth = $(this).width(), holderheight = $(this).height(); $img.each(function(i) { var imgsrc = $(this).attr("src"); $(this).data({ "index": i }); $(this).load(function() { ++num; if (num == imgnum) { $this.show(); } }).attr({ "src": imgsrc }); var thisleft = -(o.radius) * Math.sin((360 / imgnum) * $(this).data("index") * (Math.PI * 2 / 360)) + (holderwidth / 2); var thiszindex = 360 / imgnum * $(this).data("index") > 180 ? 360 / imgnum * $(this).data("index") - 360 : -360 / imgnum * $(this).data("index"); var thisopacity = 360 / imgnum * $(this).data("index") <= 180 ? (180 - 360 / imgnum * $(this).data("index")) / 180 * 1.2 : (360 / imgnum * $(this).data("index") - 180) / 180 * 1.2; $(this).attr({ "nowdeg": (360 / imgnum) * $(this).data("index") }); $(this).css({ "left": thisleft - (o.width * thisopacity) / 2 + "px", "top": (holderheight / 2) - o.width * (thisopacity + 1) / 4, "z-index": thiszindex + 180, "opacity": (thisopacity + 0.2) / 1.2, "width": o.width * (thisopacity + 1) / 2, "height": o.height * (thisopacity + 1) / 2 }); }); function scrollimg() { $img.each(function() { var thisdeg = $(this).attr('nowdeg'); var thisleft; xx = thisdeg; if (dir == 'left') { thisleft = -(o.radius) * Math.sin(xx * (Math.PI * 2 / 360)) + (holderwidth / 2); } else { thisleft = (o.radius) * Math.sin(xx * (Math.PI * 2 / 360)) + (holderwidth / 2); } var thiszindex = xx > 180 ? xx - 360 : -xx; var thisopacity = xx <= 180 ? (180 - xx) / 180 : ($(this).attr('nowdeg') - 180) / 180; $(this).css({ "left": thisleft - (o.width * thisopacity) / 2 + "px", "top": (holderheight / 2) - o.width * (thisopacity + 1) / 4, "z-index": thiszindex + 180, "opacity": (thisopacity + 0.2) / 1.2, "width": o.width * (thisopacity + 1) / 2, "height": o.height * (thisopacity + 1) / 2 }); xx++; if (xx > 360) xx = 0; $(this).attr({ "nowdeg": xx }); }); }; var tt = setInterval(scrollimg, speed); $img.hover(function() { clearInterval(tt); }, function() { tt = setInterval(scrollimg, speed); }); }); }; $.fn.scroll3d.defaults = { speed: 25, radius: 300, width: 200, height: 150, direction: 'left' } })(jQuery);
在HTML中只需要有一個DIV包含你所需要的圖片就可以完成這個效果,例如:
<div class="holder" style="width:550px;height:300px;position:relative;"> <img src="img/1.jpg" /> <img src="img/2.jpg" /> <img src="img/3.jpg" /> <img src="img/1.jpg" /> <img src="img/2.jpg" /> </div>
代碼的調用可以這樣寫:
$('.holder').scroll3d();
寫的有點亂七八糟,還望各位見諒!
壓縮包:test_jb51.rar
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
- jQuery實現(xiàn)圖像旋轉動畫效果
- 基于jQuery插件實現(xiàn)環(huán)形圖標菜單旋轉切換特效
- jQuery+CSS3實現(xiàn)3D立方體旋轉效果
- jQuery右下角旋轉環(huán)狀菜單特效代碼
- jQuery實現(xiàn)炫麗的3d旋轉星空效果
- jquery實現(xiàn)LED廣告牌旋轉系統(tǒng)圖片切換效果代碼分享
- jQuery實現(xiàn)的模仿雨滴下落動畫效果
- jQuery實現(xiàn)數(shù)字自動增加或者減少的動畫效果示例
- jQuery實現(xiàn)切換頁面過渡動畫效果
- jQuery實現(xiàn)點擊旋轉,再點擊恢復初始狀態(tài)動畫效果示例
相關文章
jQuery插件echarts實現(xiàn)的單折線圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件echarts實現(xiàn)的單折線圖效果,結合完整實例形式分析了echarts插件繪制簡單折線圖的操作步驟與相關實現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03JQuery DataTable刪除行后的頁面更新利用Ajax解決
使用Jquery的DataTable進行數(shù)據(jù)表處理非常方便,常遇到的一個問題就是刪除一行后頁面必須進行更新,下面與大家分享下使用Ajax的解決方法2013-05-05