欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

奇妙的Javascript圖片放大鏡

 更新時間:2006年07月20日 00:00:00   作者:  
在Flash中我們用蒙板加上一些簡單的腳本便可實現(xiàn)一個動態(tài)的圖片放大鏡?,F(xiàn)在我們只用JavaScript結(jié)合CSS語言也可以輕易做出這個效果。

  制作思路:“放大鏡”后有一幅背景圖,它是“放大了”的圖的原本。我們通過移動“放大鏡”時適當調(diào)整背景圖的位置,使它顯示的剛好是需要要放大的部分。

  效果演示: (點這里在新窗口中查看)

  制作步驟

 ?。保┫葴蕚鋬煞鶅?nèi)容相同尺寸不同的圖片,這里我們找了一個400×300像素的縮略圖small_hill.gif,一個800×600像素的大圖big_hill.gif。然后再準備一個“放大鏡”的圖片,注意它中間部分必須是透明的,這里我們準備了一個綠色的方框 viewer.gif。

 ?。玻┚帉懭缦碌拇a:

  以下是兩幅圖的代碼,都它們作為層。第一幅是縮略圖,第二幅是“放大鏡”,首先將它的背景移到不可見的地方; 其中“ 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"; //放大鏡的背景色,建議設(shè)成和網(wǎng)頁背景色相同。
  var bigmap="big_hill.gif"; //大圖路徑

  document.all.myviewer.style.backgroundImage='url('+bigmap+')';
  document.all.myviewer.style.backgroundColor=viewer_bgcolor;
  //因為大圖作為背景無法設(shè)定和讀取它的尺寸,只好把它的一個副本作為實圖,但不可見:
  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;

     //以下幾行調(diào)整當“放大鏡”移動時其背景圖的位置,使其中心移到縮略圖的某點時,其背景圖上相應(yīng)的點也移動到其中心。
     //其中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>


[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]

相關(guān)文章

最新評論