成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jquery實現圖片放大鏡功能
全站頭部文字 我要出現在這里
jquery實現圖片放大鏡功能 681 2024-03-20   

實現原理:

  這里用到了兩張圖片,一張小圖,一張大圖。將大圖設置為放大鏡的背景圖片,當鼠標在小圖上移動時,同時控制背景大圖在放大鏡中的位置。兩張圖片大小最好是等比例的,這樣才能達到最佳效果。當沒有大圖時,則默認為小圖本身,這時由于兩張圖片大小一樣,因此放大鏡效果不明顯,就跟沒放大是一樣的。

  此插件用到了html5,css3的一些屬性,ie8及以下版本不兼容,放大鏡是方形的。

運行效果截圖如下:

查看圖片

具體代碼如下:

(function () {
 $.fn.Magnifier = function (options) {

  //默認參數設置
  var settings = {
   diameter: 150,     //放大鏡的直徑大小
   borderWidth: 2,     //放大鏡邊框大小
   borderColor: "white",   //放大鏡邊框顏色
   backgroundImg: "../img/111.jpg" //放大鏡內的圖片(即大圖)
  };

  //合并參數
  if (options)
   $.extend(settings, options);

  //鏈式原則
  return this.each(function () {
   //存儲當前對象
   var root = $(this);

   //當前對象寬高
   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 + ";";

   //創建放大鏡
   var magnifier = $("<div style='" + style + "'></div>").appendTo(root.parent());

   //圖片(當沒有大圖時,為小圖本身)
   var backgroundImg = settings.backgroundImg ? settings.backgroundImg : root.attr("src");

   //將圖片放入放大鏡內
   magnifier.css({ backgroundImage: "url('" + backgroundImg + "')" });

   //縮放比例
   var WRatio = 0; //寬度
   var HRatio = 0; //高度

   //圖片加載完,計算縮放比例
   //由于圖片原本不在DOM文檔里,因此頁面加載時不會觸發load事件,因此要通過執行appendTo來觸發load事件
   $("<img style='display:none;' src='http://www.gimoo.net/t/1904/5cba610279999.html" + 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);

    //判斷鼠標是否在圖片上
    if (LPos < 0 || TPos < 0 || LPos > WRoot || TPos > HRoot) {

     magnifier.hide(); //不在隱藏放大鏡

    } else {

     magnifier.show(); //反之顯示放大鏡

     //控制放大鏡內背景圖片的位置 (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);

   //當前對象
   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="http://www.gimoo.net/t/img/222.gif" width="700" height="500" />
 </div>
 <script src="http://www.gimoo.net/t/Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
 <script src="http://www.gimoo.net/t/Scripts/jquery.similar.magnifier.js" type="text/javascript"></script>
 <script type="text/javascript">
  $("#img_02").Magnifier();
 </script>
</body>
</html>

關于jquery實現圖片放大鏡功能的內容就介紹到這里,希望大家仔細研究,學以致用。



主站蜘蛛池模板: 抖音浏览器| 素人片| 魏凤| 黑帮大佬和我的三百六十五日| 青春之旅动漫| 香港之夜电视剧免费播放国语版| 《求知报》答案| 爆操女人逼| 小红书如何开通店铺| 田文仲个人资料| 庞勇| 香谱72图解详细解释大全| 高允贞| 乔迁之喜邀请函微信版| 巨乳女教师| 文熙俊| 春江花月夜理解性默写及答案| 免费操人视频| 甜蜜蜜电影粤语无删减版| 电影《重生》| 巨神战击队| 在线黄网站| 搜狐视频官网| 卡通频道| 豆包简历个人资料| 女同性恋视频网站| 林佑星| 心跳源计划演员表| 未来警察| 红色诗集手抄报简单又漂亮| 一夜风流| 15j401图集电子版免费查看| 扒开下面让我添| 黄金比例身材| 缺宅男女电视剧| 六一儿童节对联七字| kaori全部av作品大全| lol小孩子不能看的动画视频| 美娜个人资料简介| 王渝萱演过的所有影视作品| 一夜风流|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103