jquery实现图片放大镜功能
作者:bea
实现原理: 这里用到了两张图片,一张小图,一张大图。将大图设置为放大镜的背景图片,当鼠标在小图上移动时,同时控制背景大图在放大镜中的位置。两张图片大小最好是等比例的,这样才能达到最佳效果。当没有大图时,则默认为小图本身,这时由于两张图片大小一样,因此放大镜效果不明显,就跟没放大是一样的。 此插件用到了html5,css3的一些属性,ie8及以下版本不兼容,放大镜是方形的。 运行效果截图如下: 具体代码如下: (function () { $.fn.Magnif
实现原理:
这里用到了两张图片,一张小图,一张大图。将大图设置为放大镜的背景图片,当鼠标在小图上移动时,同时控制背景大图在放大镜中的位置。两张图片大小最好是等比例的,这样才能达到最佳效果。当没有大图时,则默认为小图本身,这时由于两张图片大小一样,因此放大镜效果不明显,就跟没放大是一样的。
此插件用到了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='" + 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="../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>
关于jquery实现图片放大镜功能的内容就介绍到这里,希望大家仔细研究,学以致用。
有用 | 无用
这里用到了两张图片,一张小图,一张大图。将大图设置为放大镜的背景图片,当鼠标在小图上移动时,同时控制背景大图在放大镜中的位置。两张图片大小最好是等比例的,这样才能达到最佳效果。当没有大图时,则默认为小图本身,这时由于两张图片大小一样,因此放大镜效果不明显,就跟没放大是一样的。
此插件用到了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='" + 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="../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>
关于jquery实现图片放大镜功能的内容就介绍到这里,希望大家仔细研究,学以致用。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 超漂亮的jQuery图片轮播特效
- jquery解析json格式数据的方法(对象、字符串)
- Bootstrap每天必学之按钮(一)
- JavaScript DOM 学习总结(五)
- jQuery解析json数据实例分析
- 全面解析Bootstrap表单使用方法(表单按钮)
- 全面解析Bootstrap表单使用方法(表单控件状态)
- jQuery解析Json实例详解
- 带领大家学习javascript基础篇(一)之基本概念
- 全面解析Bootstrap表单使用方法(表单控件)
- 全面解析Bootstrap表单使用方法(表单样式)
- 基于JavaScript实现Json数据根据某个字段进行排序
- jquery彩色投票进度条简单实例演示
- js生成随机数的过程解析
- jquery制作图片时钟特效
- jQuery实现Tab选项卡切换效果简单演示
- JS鼠标拖拽实例分析
- 基于jQuery实现简单的折叠菜单效果
- jquery无限级联下拉菜单简单实例演示