另一款有意思的JS图片放大镜

开发 前端
先准备两幅内容相同尺寸不同的图片,这里我们找了一个400×300像素的缩略图small_hill.gif,一个800×600像素的大图big_hill.gif。然后再准备一个“放大镜”的图片,注意它中间部分必须是透明的。

制作思路:“放大镜”后有一幅背景图,它是“放大了”的图的原本。我们通过移动“放大镜”时适当调整背景图的位置,使它显示的刚好是需要要放大的部分。

效果预览:

在线效果演示: (点这里在新窗口中查看)

制作步骤

先准备两幅内容相同尺寸不同的图片,这里我们找了一个400×300像素的缩略图small_hill.gif,一个800×600像素的大图big_hill.gif。然后再准备一个“放大镜”的图片,注意它中间部分必须是透明的,这里我们准备了一个绿色的方框 viewer.gif。

编写如下的代码:

以下是两幅图的代码,都它们作为层。第一幅是缩略图,第二幅是“放大镜”,首先将它的背景移到不可见的地方; 其中“ onclick="moveme=!moveme" ”表示每次点击它都改变“moveme”的布尔值。

  1. <img src="small_hill.gif" id="bgLayer" style="position:absolute; left:150px; top:50px;">   
  2. <img src="viewer.gif" id="myviewer" onclick="moveme=!moveme" onmousemove="viewit(this)"   
  3. style="left:0;top:0;background-repeat:no-repeat; background-position:2000px 2000px;position:absolute;">   

以下是JavaScript脚本:

  1. <script language="JavaScript">   
  2. <!--   
  3. var viewer_bgcolor="#FFFFFF"//放大镜的背景色,建议设成和网页背景色相同。   
  4. var bigmap="big_hill.gif"//大图路径   
  5.  
  6. document.all.myviewer.style.backgroundImage='url('+bigmap+')';   
  7. document.all.myviewer.style.backgroundColor=viewer_bgcolor;   
  8. //因为大图作为背景无法设定和读取它的尺寸,只好把它的一个副本作为实图,但不可见:   
  9. document.write('<img id="getsize" style="position:absolute; left:-2000px; top:-2000px;" src="'+bigmap+'">');   
  10. var moveme=false//该布尔值决定“放大镜”是否随鼠标移动,初始值为否   
  11. function viewit(obj){   
  12. if (moveme){   
  13. //以下两行控制“放大镜”的移动:   
  14. obj.style.left=event.x+parseInt(document.body.scrollLeft)-parseInt(obj.width)/2;   
  15. obj.style.top=event.y+parseInt(document.body.scrollTop)-parseInt(obj.height)/2;   
  16. //以下几行调整当“放大镜”移动时其背景图的位置,使其中心移到缩略图的某点时,其背景图上相应的点也移动到其中心。   
  17. //其中Nx,Ny指大图宽和高分别是小图的几倍,bgx,bgy是背景图当移到的X,Y坐标。   
  18. Nx=parseInt(document.all.getsize.width)/parseInt(document.all.bgLayer.width);   
  19. bgx=(-1)*(Nx-1)*(event.x-parseInt(document.all.bgLayer.style.left)+parseInt(document.body.scrollLeft))-parseInt(obj.style.left)+parseInt(document.all.bgLayer.style.left);   
  20. Ny=parseInt(document.all.getsize.height)/parseInt(document.all.bgLayer.height);   
  21. bgy=(-1)*(Ny-1)*(event.y-parseInt(document.all.bgLayer.style.top)+parseInt(document.body.scrollTop))-parseInt(obj.style.top)+parseInt(document.all.bgLayer.style.top);   
  22.  
  23. obj.style.backgroundPosition=bgx+" "+bgy;   
  24. }   
  25. }   
  26. //-->   
  27. </script>   
  28.  

【编辑推荐】

  1. 中文前端UI框架Kit:超酷的瀑布流特效动画
  2. JavaScript图片变换效果(IE only)
  3. 中文前端UI框架Kit:摇头动画
  4. JavaScript马赛克遮罩图片幻灯片切换类
  5. 看JavaScript如何实现页面自适
责任编辑:张伟 来源: 源码天空
相关推荐

2012-05-30 10:43:47

jQuery

2023-05-15 09:16:18

CSSCSS Mask

2017-01-22 17:25:55

Android放大镜效果源码分析

2015-03-10 11:36:25

jQuery仿淘宝产品图片放大镜代码

2020-12-12 13:50:16

云开发

2018-06-24 16:39:28

Tomcat异常线程

2021-01-27 13:54:05

开发云原生工具

2021-03-25 06:12:55

SVG 滤镜CSS

2023-08-02 08:00:00

JavaScriptWeb

2022-06-15 07:21:47

鼠标指针交互效果CSS

2022-08-15 22:34:47

Overflow方向裁切

2022-07-11 13:09:26

mmapLinux

2017-08-01 00:52:07

kafka大数据消息总线

2011-09-08 17:50:34

Windows7放大镜

2012-06-19 16:49:19

Web开发

2021-04-23 07:51:56

CSS Container Q Chrome

2013-08-28 09:46:09

Debian LinuLinux发行版

2010-04-09 11:24:59

Oracle 排序

2012-05-22 10:12:59

jQuery

2015-10-28 13:57:29

融合架构华三UIS
点赞
收藏

51CTO技术栈公众号