【分享】图片放大效果(自己动手)

下面的演示可能存在一些与页面JS冲突的问题。如果想要演示或者完整的放大效果 html

可以联系我QQ:271412542

或者Email:idche@qq.com

我可以直接发给你。

标题有点冷!好吧,我承认!

 
 

 

 

刚才发帖由于JS冲突所以又重新发了一次。悲剧了。

不废话了!

看上面效果。我们怎么开始呢。

 

首先:我们需要一个可以移动的DIV

这个DIV 可以移动,你可以测试下。

 

 

 

 

 

 

代码
<div style="border:1px solid #CCC;position:absolute; width:200px; height:100px; cursor:move;" id="jelle_test_div quot;>
这个DIV 可以移动,你可以测试下。
</div>
<script type="text/javascript">



var getMouseP=function (e){//获取鼠标坐标 请传递evnet参数

e
= e || window.event;
var m=(e.pageX || e.pageY)?{ x:e.pageX, y:e.pageY } : { x:e.clientX + document.body.scrollLeft - document.body.clientLeft, y:e.clientY + document.body.scrollTop - document.body.clientTop };
return m;

};

move
=function(o,t){
o
=$j(o);
t
=$j(t);
o.onmousedown
=function(ev){
var mxy=getMouseP(ev);//获取当前鼠标坐标
var by={x:mxy.x-(t.offsetLeft),y:mxy.y-(t.offsetTop)};
o.style.cursor
="move";
document.onmousemove
=function(ev){
var mxy=getMouseP(ev);
t.style.left
=mxy.x-by.x+"px";
t.style.top
=mxy.y-by.y+"px";
};
document.onmouseup
=function(){
window.getSelection
? window.getSelection().removeAllRanges() : document.selection.empty();
this.onmousemove=null;
}
}
}
move(
"jelle_test_div","jelle_test_div");
</script>

 

然后:我们需要控制他的移动范围
 
代码
<div style="border:1px solid #CCC; width:500px; height:415px; background:url(xxx/c.jpg);" id="jelle_warpper">
<div style="width:100px; height:50px; border:1px solid #CCC;" id="jelle_move"></div>
</div>

<script type="text/javascript">

var mp=function (e){//获取鼠标坐标 请传递evnet参数
e = e || window.event;
var m=(e.pageX || e.pageY)?{ x:e.pageX, y:e.pageY } : { x:e.clientX + document.body.scrollLeft - document.body.clientLeft, y:e.clientY + document.body.scrollTop - document.body.clientTop };
return m;

}
var move2=function(o,t){//请提前设置CSS position:absolute;并激活filter:alpha(opacity=100);
//o相应鼠标拖动的区域ID T被移动对象的ID
o=$j(o);
t
=$j(t);
by_o
={x:o.offsetLeft,y:o.offsetTop};
o.onmousemove
=function(ev){
//var mxy=Jelle.getMouseP(ev);//获取当前鼠标坐标
var by={x:t.offsetLeft,y:t.offsetTop};
var ms=mp(ev);
t.innerHTML
=(by_o.x-by.x)+"---"+(by_o.x-by.y);

jy
=ms.y-by_o.y-25;
jx
=ms.x-by_o.x-50;

maxy
=415-50;//减去移动框的高度
maxx=500-100;//减去移动框的宽度

var y=jy>=maxy?maxy:jy<=0?0:jy;
var x=jx>=maxx?maxx:jx<=0?0:jx;
t.style.marginTop
=y+"px";
t.style.marginLeft
=x+"px";
}
}
move2(
"jelle_warpper","jelle_move")
</script>

 

解决了上面的我问题。那么这个效果就不难了。!
我们可以获得了 一个 x y, 恰好这个 x y 可以用来设置大图背景的 x y。
这里我们值得注意的事。要把握好大图与小图的比例。
还有就是显示图片的DIV 与移动的DIV 比例。
 
比如我这里的比例: 大图800*800 小图是200*200
                          显示大图的DIV 200*200  移动的div 50*50。
其实我还没总结出这个公式。绕的有点头晕呵呵。
 
下面我贴出全部代码:
 
全部代码
<!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"/>
<meta name="Author" content="jelle.lu jelle.lu[at]gmail.com"/>
<title>图片放大效果</title>

</head>

<body>
<style type="text/css">
.img_box,.show_box
{border:1px solid #CCC; width:200px;height:200px;float:left;float:left;margin:20px;margin:20px; overflow:hidden;}
.img_box,.show_box
{ background-position:0 0; background-repeat:no-repeat;}
.ms_box
{width:50px; height:50px;border:1px solid #CCC;background:#000;filter:alpha(opacity=20);opacity:0.2; display:none}
.show_box
{display:none}
</style>
<!--html-->
<div class="img_box" id="j_warp">
<div class="ms_box" id="j_ms"></div>
</div>
<div class="show_box" id="j_show"></div>
<!--end-->

<!--辅助-->
<div style="clear:both;"></div>
<input type="button" value="OK!我想换张图片" style="margin-left:50px;" onclick="jelle(imgss[Math.floor(Math.random()*4)]);"/>
<!--辅助 end-->


<script type="text/javascript">
var $j=function(id){return document.getElementById(id);};
var getstyle=function (obj,attribute){
return obj.currentStyle?obj.currentStyle[attribute]:document.defaultView.getComputedStyle(obj,false)[attribute]
};

var mp=function (e,j){//获取鼠标坐标 请传递evnet参数
e = e || window.event;
return (e.pageX || e.pageY)?{ x:e.pageX, y:e.pageY } :
{x:e.clientX
+ document.body.scrollLeft - document.body.clientLeft, y:e.clientY + document.body.scrollTop - document.body.clientTop + j};
};

var sys=(function(){//不必紧张这只是一个判断浏览器的函数,你可以使用很多方法来判断浏览器
window.sys={};
var ua=navigator.userAgent.toLowerCase();
sys.firefox
=ua.match(/firefox\/([\d\.]+)/);
sys.ie=ua.match(/msie\s([\d\.]+)/);
sys.chrome
=ua.match(/chrome\/([\d\.]+)/);
return sys;
})()

var zoomImg=function(imgs){

var o=$j("j_warp"),//鼠标相应的区域
t=$j("j_ms"),//跟随鼠标移动的div
s=$j("j_show"),//显示大图的div
by_o={x:o.offsetLeft,y:o.offsetTop},//最外面容器 具体页面的 x,y
msw=parseInt(getstyle(t,"width")),//跟随鼠标移动的DIV宽度
msh=parseInt(getstyle(t,"height")),//高度
maxy=parseInt(getstyle(o,"height"))-msh,//减去移动框的高度 MS_box的拖动界限 y
maxx=parseInt(getstyle(o,"width"))-msw,//减去移动框的宽度 MS_box的拖动界限 x
toggle=function(status){//用户鼠标激活以后显示或者隐藏需要的box
t.style.display=status;
s.style.display
=status;
},
setBackgroundImg
=function(imgs){
o.style.backgroundImage
='url('+imgs['small']+')';
s.style.backgroundImage
='url('+imgs['big']+')';
},
j
=0;//被卷曲的高度 --IE获得鼠标的坐标还要加上被卷曲的高度
//当然其实还应该加上 --水平被卷曲的高度。这里没做。一般也不需要
setBackgroundImg(imgs);

if(sys.ie){
window.onscroll
=function(){//哎 为了获取一个被卷去的高度 居然写了N多代码。看样子是该写个通用的方法了。
j=parent?(parent.document.body.scrollTop+parent.document.documentElement.scrollTop) :
(document.body.scrollTop
+document.documentElement.scrollTop);
}
};

o.onmousemove
=function(e){
toggle(
"block");//显示盒子
//var by={x:t.offsetLeft,y:t.offsetTop};
var ms=mp(e,j),//获取当前鼠标位置
jy=ms.y-by_o.y-msw/2,
//获取当前移动的ms_box位置 计算方法是 鼠标坐标 - 最外面容器的坐标 - 盒子的宽(高)的/2
jx=ms.x-by_o.x-msh/2,
y= jy>=maxy ? maxy : jy<=-1?-1 : jy,//判断是否超过界限
x= jx>=maxx ? maxx : jx<=-1?-1 : jx,
xx
= x*4<0?0 : x*4,//计算显示box的背景 的 x y
yy= y*4<0?0 : y*4;//这里*4 是因为我的大图跟小图的比例是4:1 请注意大盒子与小盒子的比例也要4:1
//不然可能会给你带来麻烦。当然你也可以使用其他比例!

t.style.marginTop
=y+"px";//设置ms_box的位置
t.style.marginLeft=x+"px";

$j(
"j_show").style.backgroundPosition="-"+xx+"px -"+yy+"px";//设置背景的xy坐标
}

o.onmouseout
=function(){
toggle(
"none");
}
return setBackgroundImg;//我们返回这个换图的方法。这样就可以变换图片了。
}



//-----------

var imgss=[
{
'big':"http://images.365sleep.com/taobao/100222/b1.jpg",'small':"http://images.cnblogs.com/cnblogs_com/idche/245996/r_s1.jpg"},
{
'big':"http:///images.365sleep.com/taobao/100222/b2.jpg",'small':"http://images.cnblogs.com/cnblogs_com/idche/245996/r_s2.jpg"},
{
'big':"http://images.365sleep.com/taobao/100222/b3.jpg",'small':"http://images.cnblogs.com/cnblogs_com/idche/245996/r_s3.jpg"},
{
'big':"http://images.365sleep.com/taobao/100222/b4.jpg",'small':"http://images.cnblogs.com/cnblogs_com/idche/245996/r_s4.jpg"}
];
//img地址数据


var jelle=zoomImg(imgss[3])//开始,了我比较喜欢最后一组图片
</script>

</body>
</html>

 

posted @ 2010-05-18 17:17 Jun.lu 阅读(2817) 评论(23) 编辑 收藏

 回复 引用 查看   
#1楼[楼主] 2010-05-18 22:02 jelle      
测试下!
 回复 引用 查看   
#2楼[楼主] 2010-05-18 22:16 jelle      
无法回复刷新下。!我也搞不清楚那里出了问题。
 回复 引用 查看   
#3楼 2010-05-18 23:29 博客园团队      
现在好了。
是你添加的脚本与jQuery冲突了,造成无法评论。

 回复 引用 查看   
#4楼[楼主] 2010-05-18 23:30 jelle      
@博客园团队
3Q

 回复 引用 查看   
#5楼 2010-05-19 00:16 月狩      
试一试~
 回复 引用 查看   
#6楼 2010-05-19 08:39 yanghao      
id="jelle_test_divquot;"> 这个位置确实结束“,切换图像后由问题。。
 回复 引用 查看   
#7楼 2010-05-19 09:02 金色海洋(jyk)      
你的代码怎么复制不了呀?不让复制吗?
IE下好像有bug哦。。 刚进来直接看没问题, 这时候如果用滚轮,滚动一下,就有问题了。。 我IE8
 回复 引用 查看   
#9楼 2010-05-19 09:18 cloudgamer      
挺好的
我也写过一个图片放大效果

 回复 引用 查看   
#10楼 2010-05-19 09:22 爱爱      
有BUG,点换图后,光标不能停留在移动层上,而是在它下面的地方
 回复 引用 查看   
#11楼 2010-05-19 09:37 treerain      
@金色海洋(jyk)
document.onmouseup=function(){			 window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
					this.onmousemove=null;
}

这段代码的问题造成的吧

 回复 引用 查看   
#12楼 2010-05-19 09:52 金色海洋(jyk)      
在遨游1.5里是这样的效果,但是在IE6里面却可以复制。

只是粘贴出来的没有换行,因为js里面有注释,没换行,那么后面的就都算是注释了,所以什么效果都没有。

弄了半天换行,晕死了。

后来直接看这个网页的html,找到了代码,copy,有换行了。但是在本地还是没有任何的效果,图片都看不到。

是不是我太菜了呀,晕死了。


 回复 引用 查看   
#13楼[楼主] 2010-05-19 10:36 jelle      
@cloudgamer
很早的时候 就看过你的这个放大效果了。所以我这几天也写了一个。呵呵。
没想到你也看到我的文章了。呵呵。

 回复 引用 查看   
#14楼[楼主] 2010-05-19 10:38 jelle      
@北京出差中。。。
这个是IE 里面 获取鼠标的位置。
还要减去页面 卷去的长度 或者高度。
由于这个文章。发了好几次。弄的我头有点大了。呵呵。

 回复 引用 查看   
#15楼[楼主] 2010-05-19 10:39 jelle      
@金色海洋(jyk)
你可以刷新下 试试。然后复制。
这可能是我页面上运行的JS 跟博客园的JS有冲突。我也发现一些问题。

如果你想要完整的源码。或者有什么实际的需求。可以直接联系我。
我给你做一个完整的API 给你。

 回复 引用 查看   
#16楼[楼主] 2010-05-19 13:31 jelle      
@爱爱
你用的什么浏览器!
我去测测。

 回复 引用 查看   
#17楼[楼主] 2010-05-19 13:34 jelle      
@yanghao
你真认真!这个地方估计是编辑器。搞的吧。我也不懂了。哈哈

 回复 引用 查看   
#18楼 2010-05-19 17:05 NDDAVID      
谢谢 楼主 分享
 回复 引用 查看   
#19楼 2010-05-19 18:04 yanghao      
@jelle
是我看错了,下面这个可以运行的 哈哈

 回复 引用 查看   
#20楼[楼主] 2010-05-19 18:06 jelle      
@yanghao
呵呵。

 回复 引用 查看   
#21楼[楼主] 2010-05-19 18:07 jelle      
@NDDAVID
客气,学习是需要分享 和记录的。

 回复 引用 查看   
#22楼 2010-05-21 21:34 .COM 缺氧      
超酷。
 回复 引用 查看   
#23楼 2010-09-11 18:00 Study by myself      
我对这个放大兴趣还算可以 我最大的兴趣是你咋把这个嵌入到这个博客里的 我如果要想在别的博客显示成这个放大的东西 怎么弄代码 光复制你的那些我试了好像不行啊 直接显示源码了 超级菜鸟 见笑了
发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1738449 mAosK+QuSog=