奇妙的Javascript图片放大镜

在Flash中我们用蒙板加上一些简单的脚本便可实现一个动态的图片放大镜。现在我们只用JavaScript结合CSS语言也可以轻易做出这个效果。

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

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

  制作步骤

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

  2)编写如下的代码:

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

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

以下是JavaScript脚本:

<script language="JavaScript">
  <!--
  var viewer_bgcolor=https://www.jb51.net/article/"#FFFFFF"; //放大镜的背景色,建议设成和网页背景色相同。
  var bigmap=https://www.jb51.net/article/"big_hill.gif"; //大图路径

  document.all.myviewer.style.backgroundImage=https://www.jb51.net/article/'url('+bigmap+')';
  document.all.myviewer.style.backgroundColor=https://www.jb51.net/article/viewer_bgcolor;
  //因为大图作为背景无法设定和读取它的尺寸,只好把它的一个副本作为实图,但不可见:
  document.write('<img src="'+bigmap+'">');

  var moveme=https://www.jb51.net/article/false; //该布尔值决定“放大镜”是否随鼠标移动,初始值为否
  function viewit(obj){
    if (moveme){
      //以下两行控制“放大镜”的移动:
      obj.style.left=https://www.jb51.net/article/event.x+parseInt(document.body.scrollLeft)-parseInt(obj.width)/2;
      obj.style.top=https://www.jb51.net/article/event.y+parseInt(document.body.scrollTop)-parseInt(obj.height)/2;

     //以下几行调整当“放大镜”移动时其背景图的位置,使其中心移到缩略图的某点时,其背景图上相应的点也移动到其中心。
     //其中Nx,Ny指大图宽和高分别是小图的几倍,bgx,bgy是背景图当移到的X,Y坐标。 
      Nx=https://www.jb51.net/article/parseInt(document.all.getsize.width)/parseInt(document.all.bgLayer.width);
      bgx=https://www.jb51.net/article/(-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);

      Ny=https://www.jb51.net/article/parseInt(document.all.getsize.height)/parseInt(document.all.bgLayer.height);
      bgy=https://www.jb51.net/article/(-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);

      obj.style.backgroundPosition=https://www.jb51.net/article/bgx+" "+bgy;
    }
  }
  //-->
</script>


[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wjjfsw.html