基于jquery的鼠标滚动放大缩小图片
2014-08-21 23:18
405 查看
一直以来都想写一个图片放大和缩小的小玩意,本来以为会很复杂,这几天自己思考了一下,原来是so easy啊。目前实现的放大缩小,主要时依据鼠标的滚轮触发事件来实现的,废话少说直接上源码。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>图片放大缩小</title>
<style type="text/css">
*{
margin:0; padding:0;
}
body {
width:100%; height:100%; overflow:auto;
}
#img {
display:block;
width:20%;
margin:20px auto;
cursor:-webkit-zoom-in;
cursor:-moz-zoom-in;
border:4px solid #ccc;
}
</style>
<script src="./jquery/jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
var img=$("#img");
var i=0;
img.bind('DOMMouseScroll mousewheel function(e) {
var ev=window.event||e;//处理浏览器兼容性问题
var scrollUnit=Math.max(-1,Math.min(1,(ev.wheelDelta||-ev.detail)));
var newWith=Math.max(100,Math.min(1600,parseInt(img.css("width"))+(30*scrollUnit)))+"px";
img.css("width",newWith);
console.log(i++);
console.log(img.css("width"));
});
});
</script>
</head>
<body>
<img id="img" src="images/drag.jpg"/>
</body>
</html>
针对源码,做几点说明和补充:
1,ev.wheelDelta和ev.detail
ev.wheelDelta, 除出火狐外的浏览器IE,chrome,Opera、Safari基本支持属性,该属性取值为+,-,120; ev.detail,为火狐特有的事件属性,取值+,-3;2,Math.min,Math.max 这个地方的取最大值和最小值,最好自己琢磨一下,稍微有一个绕。3,放大缩小的倍数和最值问题 1和-1控制缩小和放大速率,绝对值越大缩放效果越明显。 100,1600,分别为缩小的最小值和放大的最大值。基本就这么多了,欢迎大家提出宝贵建议和想法。
本文出自 “shuizhongyue” 博客,转载请与作者联系!
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>图片放大缩小</title>
<style type="text/css">
*{
margin:0; padding:0;
}
body {
width:100%; height:100%; overflow:auto;
}
#img {
display:block;
width:20%;
margin:20px auto;
cursor:-webkit-zoom-in;
cursor:-moz-zoom-in;
border:4px solid #ccc;
}
</style>
<script src="./jquery/jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
var img=$("#img");
var i=0;
img.bind('DOMMouseScroll mousewheel function(e) {
var ev=window.event||e;//处理浏览器兼容性问题
var scrollUnit=Math.max(-1,Math.min(1,(ev.wheelDelta||-ev.detail)));
var newWith=Math.max(100,Math.min(1600,parseInt(img.css("width"))+(30*scrollUnit)))+"px";
img.css("width",newWith);
console.log(i++);
console.log(img.css("width"));
});
});
</script>
</head>
<body>
<img id="img" src="images/drag.jpg"/>
</body>
</html>
针对源码,做几点说明和补充:
1,ev.wheelDelta和ev.detail
ev.wheelDelta, 除出火狐外的浏览器IE,chrome,Opera、Safari基本支持属性,该属性取值为+,-,120; ev.detail,为火狐特有的事件属性,取值+,-3;2,Math.min,Math.max 这个地方的取最大值和最小值,最好自己琢磨一下,稍微有一个绕。3,放大缩小的倍数和最值问题 1和-1控制缩小和放大速率,绝对值越大缩放效果越明显。 100,1600,分别为缩小的最小值和放大的最大值。基本就这么多了,欢迎大家提出宝贵建议和想法。
本文出自 “shuizhongyue” 博客,转载请与作者联系!
相关文章推荐
- 基于jquery的滚动鼠标放大缩小图片效果
- jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
- 基于jquery实现一张图片点击鼠标放大再点缩小
- jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
- JQuery滚动鼠标放大缩小图片
- 基于jquery实现一张图片点击鼠标放大再点缩小
- 一张图片 点击鼠标放大,再点缩小 ( 基于jquery1.8.3), 另外推荐一款插件:lightBox...效果不错。
- 【求助】自定义事件/鼠标滚轮滚动放大缩小图片,chrome下失效求解?
- js实现图片旋转 js滚动鼠标中间对图片放大缩小
- 鼠标滚动实现图片的放大和缩小(C#2.0)
- 鼠标滚动实现图片放大缩小[转]
- 图片实现鼠标滚轮滚动放大缩小图片
- 图片放大缩小,滚动鼠标
- 基于jQuery的鼠标悬停时放大图片的效果制作
- Jquery鼠标滚轮放大缩小图片
- 鼠标滚动实现图片放大缩小[转]
- 基于jquery的滚动鼠标放大缩小图片效果
- jQuery仿QQ空间图片查看特效(全屏,放大,缩小,旋转,镜像,鼠标滚轮缩放)
- 鼠标在图片上滚动放大或者缩小图片的代码