奇妙的Javascript圖片放大鏡

來源:互聯網
上載者:User

在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>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"><center><br />--JS放大鏡顯示-- </p><p>單擊"放大鏡"開始瀏覽,再次單擊停止。</center><br /><!--縮圖和放大鏡圖--><br />
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.