jquery實現(xiàn)圖片放大鏡功能
實現(xiàn)原理:
這里用到了兩張圖片,一張小圖,一張大圖。將大圖設(shè)置為放大鏡的背景圖片,當(dāng)鼠標(biāo)在小圖上移動時,同時控制背景大圖在放大鏡中的位置。兩張圖片大小最好是等比例的,這樣才能達到最佳效果。當(dāng)沒有大圖時,則默認(rèn)為小圖本身,這時由于兩張圖片大小一樣,因此放大鏡效果不明顯,就跟沒放大是一樣的。
此插件用到了html5,css3的一些屬性,ie8及以下版本不兼容,放大鏡是方形的。
運行效果截圖如下:
具體代碼如下:
(function () { $.fn.Magnifier = function (options) { //默認(rèn)參數(shù)設(shè)置 var settings = { diameter: 150, //放大鏡的直徑大小 borderWidth: 2, //放大鏡邊框大小 borderColor: "white", //放大鏡邊框顏色 backgroundImg: "../img/111.jpg" //放大鏡內(nèi)的圖片(即大圖) }; //合并參數(shù) if (options) $.extend(settings, options); //鏈?zhǔn)皆瓌t return this.each(function () { //存儲當(dāng)前對象 var root = $(this); //當(dāng)前對象寬高 var WRoot = root.width(); var HRoot = root.height(); //偏移量 left 和 top var offset = root.offset(); //放大鏡樣式 var style = "background-position: 0px 0px;background-repeat: no-repeat;float: left;"; style += "position: absolute;box-shadow:0 0 5px #777, 0 0 10px #aaa inset;display: none;"; style += "width: " + String(settings.diameter) + "px;height: " + String(settings.diameter) + "px;"; style += "border-radius: " + String(settings.diameter / 2 + settings.borderWidth) + "px;"; style += "border: " + String(settings.borderWidth) + "px solid " + settings.borderColor + ";"; //創(chuàng)建放大鏡 var magnifier = $("<div style='" + style + "'></div>").appendTo(root.parent()); //圖片(當(dāng)沒有大圖時,為小圖本身) var backgroundImg = settings.backgroundImg ? settings.backgroundImg : root.attr("src"); //將圖片放入放大鏡內(nèi) magnifier.css({ backgroundImage: "url('" + backgroundImg + "')" }); //縮放比例 var WRatio = 0; //寬度 var HRatio = 0; //高度 //圖片加載完,計算縮放比例 //由于圖片原本不在DOM文檔里,因此頁面加載時不會觸發(fā)load事件,因此要通過執(zhí)行appendTo來觸發(fā)load事件 $("<img style='display:none;' src='" + backgroundImg + "' />").load(function () { WRatio = $(this).width() / WRoot; HRatio = $(this).height() / HRoot; }).appendTo(root.parent()); //放大鏡及其背景圖片位置控制 function Position(e) { var LPos = parseInt(e.pageX - offset.left); var TPos = parseInt(e.pageY - offset.top); //判斷鼠標(biāo)是否在圖片上 if (LPos < 0 || TPos < 0 || LPos > WRoot || TPos > HRoot) { magnifier.hide(); //不在隱藏放大鏡 } else { magnifier.show(); //反之顯示放大鏡 //控制放大鏡內(nèi)背景圖片的位置 (settings.diameter / 2)半徑 LPos = String(((e.pageX - offset.left) * WRatio - settings.diameter / 2) * (-1)); TPos = String(((e.pageY - offset.top) * HRatio - settings.diameter / 2) * (-1)); magnifier.css({ backgroundPosition: LPos + 'px ' + TPos + 'px' }); //控制放大鏡本身位置 LPos = String(e.pageX - settings.diameter / 2); TPos = String(e.pageY - settings.diameter / 2); magnifier.css({ left: LPos + 'px', top: TPos + 'px' }); } } //放大鏡 magnifier.mousemove(Position); //當(dāng)前對象 root.mousemove(Position); }); }; })();
實例DEMO如下:
<!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>CSS3+jQuery圖像放大鏡效果</title> <style type="text/css"> body { background-color: Black; } .box { width: 700px; margin: 50px auto; } </style> </head> <body> <div class="box"> <!--小圖--> <img alt="" id="img_02" src="../img/222.gif" width="700" height="500" /> </div> <script src="../Scripts/jquery-1.4.1.min.js" type="text/javascript"></script> <script src="../Scripts/jquery.similar.magnifier.js" type="text/javascript"></script> <script type="text/javascript"> $("#img_02").Magnifier(); </script> </body> </html>
關(guān)于jquery實現(xiàn)圖片放大鏡功能的內(nèi)容就介紹到這里,希望大家仔細研究,學(xué)以致用。
- jquery圖片放大鏡效果
- jquery實現(xiàn)放大鏡簡潔代碼(推薦)
- jQuery實現(xiàn)的放大鏡效果示例
- 基于jquery編寫的放大鏡插件
- jQuery實現(xiàn)圖片局部放大鏡效果
- jQuery實現(xiàn)放大鏡效果實例代碼
- 基于jQuery仿淘寶產(chǎn)品圖片放大鏡特效
- 基于jQuery實現(xiàn)放大鏡特效
- 基于jQuery仿淘寶產(chǎn)品圖片放大鏡代碼分享
- 基于jquery實現(xiàn)放大鏡效果
- 使用jquery實現(xiàn)放大鏡效果
- jquery放大鏡效果超漂亮噢
- jquery圖片放大鏡功能的實例代碼
- 基于jquery的放大鏡效果
- 實現(xiàn)jquery放大鏡的兩種方法
相關(guān)文章
jQuery EasyUI datagrid實現(xiàn)本地分頁的方法
這篇文章主要介紹了jQuery EasyUI datagrid實現(xiàn)本地分頁的方法,以實例形式較為詳細的分析了本地分頁的原理與相關(guān)的實現(xiàn)技巧,需要的朋友可以參考下2015-02-02jquery實現(xiàn)經(jīng)典的淡入淡出選項卡效果代碼
這篇文章主要介紹了jquery實現(xiàn)經(jīng)典的淡入淡出選項卡效果代碼,通過簡單的jQuery鼠標(biāo)事件及鏈?zhǔn)讲僮鲗崿F(xiàn)淡入淡出效果,非常簡單實用,需要的朋友可以參考下2015-09-09jQuery實現(xiàn)鼠標(biāo)選中文字后彈出提示窗口效果【附demo源碼】
這篇文章主要介紹了jQuery實現(xiàn)鼠標(biāo)選中文字后彈出提示窗口效果,涉及jQuery事件響應(yīng)及頁面元素動態(tài)操作相關(guān)技巧,非常簡便實用,需要的朋友可以參考下2016-09-09jquery怎樣實現(xiàn)ajax聯(lián)動框(二)
ajax聯(lián)動框想必大家早有所耳聞,接下來將介紹jquery實現(xiàn)另一種形式的聯(lián)動框,右邊的聯(lián)動框用jquery生成,仿照上篇的js方法修改的,感興趣的你可以參考下希望可以幫助到你2013-03-03解決jquery submit()提交表單提示:f[s] is not a function
jquery submit()無法提交表單 報錯:f[s] is not a function,很是疑惑搜集整理了一些解決方法,感興趣的朋友可以了解下啊,希望本文對你有所幫助2013-01-01