网络编程
位置:首页>> 网络编程>> JavaScript>> 奇妙的Javascript图片放大镜

奇妙的Javascript图片放大镜

  发布时间:2024-04-30 08:51:22 

标签:奇妙的Javascript图片放大镜

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

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

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

制作步骤

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

2)编写如下的代码:

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

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

以下是JavaScript脚本:

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

  document.all.myviewer.style.backgroundImage='url('+bigmap+')';
  document.all.myviewer.style.backgroundColor=viewer_bgcolor;
  //因为大图作为背景无法设定和读取它的尺寸,只好把它的一个副本作为实图,但不可见:
  document.write('<img id="getsize" style="position:absolute; left:-2000px; top:-2000px;" src="'+bigmap+'">');

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

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

      Ny=parseInt(document.all.getsize.height)/parseInt(document.all.bgLayer.height);
      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);

      obj.style.backgroundPosition=bgx+" "+bgy;
    }
  }

  //-->
</script>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>放大镜</title> </head> <body bgcolor="#FFFFFF"> <center> --JS放大镜显示--  单击"放大镜"开始浏览,再次单击停止。</center>  <img src="http://www.softpure.com/soft/work/jsviewer/small_hill.gif" id="bgLayer" style="position:absolute; left:160px; top:50px;">  <img src="http://www.softpure.com/soft/work/jsviewer/viewer.gif" id="myviewer" onclick="moveme=!moveme" onmousemove="viewit(this)" style="background-repeat:no-repeat;background-position:2000px 2000px;position:absolute;"> <script language="JavaScript"> var viewer_bgcolor="#FFFFFF"; //放大镜的背景色,建议设成和网页背景色相同。 var bigmap="http://www.softpure.com/soft/work/jsviewer/big_hill.gif";    //大图路径 document.all.myviewer.style.backgroundImage='url('+bigmap+')'; document.all.myviewer.style.backgroundColor=viewer_bgcolor; document.write('<img id="getsize" style="position:absolute; left:-2000px; top:-2000px;" src="'+bigmap+'">'); var moveme=false; function viewit(obj){ if (moveme){ obj.style.left=event.x+parseInt(document.body.scrollLeft)-parseInt(obj.width)/2; obj.style.top=event.y+parseInt(document.body.scrollTop)-parseInt(obj.height)/2; Nx=parseInt(document.all.getsize.width)/parseInt(document.all.bgLayer.width); 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); Ny=parseInt(document.all.getsize.height)/parseInt(document.all.bgLayer.height); 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); obj.style.backgroundPosition=bgx+" "+bgy; }} </script> </body> </html>


 

0
投稿

猜你喜欢

  • 本文实例讲述了PHP在线打包下载功能实现方法。分享给大家供大家参考,具体如下:昨天晚上,为了弄这个打包下载的事,弄的事焦头烂额。有几个问题,
  • 很简单的教程,献给喜欢SEO的朋友们。把article.asp?logID=26   替换成article.asp?/a
  • 如下所示:#coding=utf-8import sys, re, osdef getDictList(dict):  regx
  • python实现日期判断和加减操作#====================================================
  • 前言本文是在GitHub上看到一个大牛总结的前端常见面试题,很多问题问的都很好,很经典、很有代表性。上面没有答案,我就整理了一下,从网上找了
  • 使用Northwind 数据库首先查询Employees表查询结果:city列里面只有5个城市使用ROW_NUMBER() OVER(PAR
  • 本文实例讲述了python+Django+apache的配置方法。分享给大家供大家参考,具体如下:下载安装xampp套件下载mod_pyth
  • 在进行文本分析、提取关键词时,新闻评论等文本通常是中英文及其他语言的混杂,若不加处理直接分析,结果往往差强人意。下面对中英文文本进行分离做一
  • 数据库操作类的优点优点可以说是非常多了,常见的优点就是便于维护、复用、高效、安全、易扩展。例如PDO支持的数据库类型是非常多的,与mysql
  • 本篇博文主要讲解Python爬虫实例,重点包括爬虫技术架构,组成爬虫的关键模块:URL管理器、HTML下载器和HTML解析器。爬虫简单架构程
  • 对于使用虚拟主机的站长朋友,我们可能不知道该服务器是否安装了某种我们需要的组件。这时我们可以使用下面的代码来判断。该函数功能:检查是否存在系
  • type()动态语言和静态语言最大的不同,就是函数和类的定义,不是编译时定义的,而是运行时动态创建的。比方说我们要定义一个Hello的cla
  • python之参数,定义时小括号中的参数,用来接收参数用的,称为 “形参”调用时小括号中的参数,用来传递给函数用的,称为 “实参”。1、思考
  • 本文实例讲述了Python3.5局部变量与全局变量作用域。分享给大家供大家参考,具体如下:1、局部变量与全局变量定义:在子程序(函数)中定义
  • 数据读取与保存Text文件对于 Text文件的读取和保存 ,其语法和实现是最简单的,因此我只是简单叙述一下这部分相关知识点,大家可以结合de
  • 本文实例为大家分享了Python感知器算法实现的具体代码,供大家参考,具体内容如下先创建感知器类:用于二分类# -*- coding: ut
  • 阅读上一篇:打造设计你自己的字体 Ⅱ永远都在寻觅字体设计的灵感。夏天过后,我买了一套便宜的书法钢笔,说服自己,它会让我的鸡爬字产生脱胎换骨的
  • collections中defaultdict的用法一、字典的键映射多个值将下面的列表转换成字典一个字典就是一个键对应一个单值得映射,而上面
  • 平时再用js写函数的时候,一般都是以惯例 function fn () {} 的方式来声明一个函数,在阅读一些优秀插件的时候又不免见到 va
  • 今天我们说一下使用python将word内容转换成html文件。下面一起来看一下。准备工作使用python类库PyDocX,安装方法(使用p
手机版 网络编程 asp之家 www.aspxhome.com