相思资源网 Design By www.200059.com
实现原理:
这里用到了两张图片,一张小图,一张大图。将大图设置为放大镜的背景图片,当鼠标在小图上移动时,同时控制背景大图在放大镜中的位置。两张图片大小最好是等比例的,这样才能达到最佳效果。当没有大图时,则默认为小图本身,这时由于两张图片大小一样,因此放大镜效果不明显,就跟没放大是一样的。
此插件用到了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 "src"); //将图片放入放大镜内 magnifier.css({ backgroundImage: "url('" + backgroundImg + "')" }); //缩放比例 var WRatio = 0; //宽度 var HRatio = 0; //高度 //图片加载完,计算缩放比例 //由于图片原本不在DOM文档里,因此页面加载时不会触发load事件,因此要通过执行appendTo来触发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); //判断鼠标是否在图片上 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="/UploadFiles/2021-04-02/222.gif">关于jquery实现图片放大镜功能的内容就介绍到这里,希望大家仔细研究,学以致用。
标签:
jquery,放大镜
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无jquery实现图片放大镜功能的评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。