联系站长 加入收藏 设为首页 繁體中文 RSS
  首页 | 生活百科 | 电脑网络 | 高手学堂 | 语录名言 | 读书文学 | 极品软件 | 奇趣图片 | 站长微博  
 您的位置: 精品百字节网 >> 电脑网络 >> 网络编程 >> 精品代码 >> 正文 当前没有通告!
   □  奇妙的Javascript图片放大镜    3星级
奇妙的Javascript图片放大镜
[ 作者:作者不详     来源:互连网     点击数:     更新时间:2006-10-17     文章录入:Admin
【字体:
[内容提要]
暂无简介

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

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

效果演示:

onmousewheel="return bbimg(this)" style="ZOOM: 30%" alt="" src="http://www.xwei.net/UpLoadFiles/website/2006-10/small_hill.gif" onload="javascript:if(this.width>500)this.style.width=500;" border=0>

制作步骤:

  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;">

onmousewheel="return bbimg(this)" style="ZOOM: 60%" alt="" src="http://www.xwei.net/UpLoadFiles/website/2006-10/yl-020827-js-viewer.gif" onload="javascript:if(this.width>500)this.style.width=500;" border=0>

以下是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;         
//该布尔值决定“放大镜”是否随鼠标移动,初始值为否<BR>
  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 -
arseInt(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>

上一篇文章:265网站上的闹钟代码 下一篇文章:春节倒计时代码
发表评论 □告诉好友 □打印此文 □收藏此页 □关闭窗口 □返回顶部
 最新热点文章
 精品医院类网站网址大收集
 如何删除windows 2003或xp系统隐藏的...
 DedeCms管理员后台登陆经常自动退出的...
 知道IP如何用dos命令查出电脑名称
 WORD出错老是要求以安全模式打开文件...
 如何设置首页不显示页眉页脚?
 如何利用inurl命令查询网站外链及栏目...
 
 最新推荐文章
 精品医院类网站网址大收集
 如何利用宽带路由器控制局域网内电脑上...
 CSS圆角代码的实现方法
 带停顿的单行文字滚动代码
 实用的新网站免费收录提交地址精选
 Left join , Right Join, Inner Join用...
 趣话淘宝网衍生的多种新型职业
 
 最新图文
  ◇  网友评论:(只显示最新5条。评论内容只代表网友观点,与本站立场无关!)
关于本站 | 免责申明 | 网站地图 | 联系站长 | 友情链接 | 与我同在
冀ICP备06032589号【虚拟化精英群虚拟化精英群续
  Copyright© 2006-2009 100byte.Com All Rights Reserved
网站声明:本网站是公益性质网站,部分内容来源于网络,如有侵犯您权利的地方,请与精品百字节站长联系,尽快修正.
Powered By CreateLive CMS 本站法律顾问:(冀港)武镇海律师
点击这里给我发消息