奇妙的Javascript圖片放大鏡
制作思路:“放大鏡”后有一幅背景圖,它是“放大了”的圖的原本。我們通過移動(dòng)“放大鏡”時(shí)適當(dāng)調(diào)整背景圖的位置,使它顯示的剛好是需要要放大的部分。
效果演示: (點(diǎn)這里在新窗口中查看)
制作步驟:
1)先準(zhǔn)備兩幅內(nèi)容相同尺寸不同的圖片,這里我們找了一個(gè)400×300像素的縮略圖small_hill.gif,一個(gè)800×600像素的大圖big_hill.gif。然后再準(zhǔn)備一個(gè)“放大鏡”的圖片,注意它中間部分必須是透明的,這里我們準(zhǔn)備了一個(gè)綠色的方框 viewer.gif。
?。玻┚帉懭缦碌拇a:
以下是兩幅圖的代碼,都它們作為層。第一幅是縮略圖,第二幅是“放大鏡”,首先將它的背景移到不可見的地方; 其中“ onclick="moveme=!moveme" ”表示每次點(diǎn)擊它都改變“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;
//因?yàn)榇髨D作為背景無法設(shè)定和讀取它的尺寸,只好把它的一個(gè)副本作為實(shí)圖,但不可見:
document.write('<img id="getsize" style="position:absolute; left:-2000px; top:-2000px;" src="'+bigmap+'">');
var moveme=false; //該布爾值決定“放大鏡”是否隨鼠標(biāo)移動(dòng),初始值為否
function viewit(obj){
if (moveme){
//以下兩行控制“放大鏡”的移動(dòng):
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)整當(dāng)“放大鏡”移動(dòng)時(shí)其背景圖的位置,使其中心移到縮略圖的某點(diǎn)時(shí),其背景圖上相應(yīng)的點(diǎn)也移動(dòng)到其中心。
//其中Nx,Ny指大圖寬和高分別是小圖的幾倍,bgx,bgy是背景圖當(dāng)移到的X,Y坐標(biāo)。
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)文章
javascript document.images實(shí)例
js document.images獲取頁面中的所以圖片并顯示出來2008-05-05js怎樣實(shí)現(xiàn)下拉框改變,它旁邊的圖像也改變
一般用于用戶選擇頭像或選擇性別的需要2008-09-09感應(yīng)鼠標(biāo)的圖片遮罩動(dòng)畫效果
感應(yīng)鼠標(biāo)的圖片遮罩動(dòng)畫效果,鼠標(biāo)放上后會(huì)動(dòng)畫顯示文字提示,有意思哦,有興趣的朋友運(yùn)行一下看效果。2010-10-10JS+FLASH幻燈片播放圖片腳本,整理了代碼,使得調(diào)用更加方便!
JS+FLASH幻燈片播放圖片腳本,整理了代碼,使得調(diào)用更加方便!...2007-01-01ie8.0下顯示本地圖片的js實(shí)現(xiàn)代碼 img.src
ie8.0下顯示本地圖片的js實(shí)現(xiàn)代碼,IE8.0 顯示本地圖片 img.src=本地圖片路徑 是無效,只能通過div來完成2012-03-03用js實(shí)現(xiàn)上傳圖片前的預(yù)覽(TX的面試題)
用js實(shí)現(xiàn)上傳圖片前的預(yù)覽(TX的面試題)...2007-08-08一個(gè)不錯(cuò)的給圖片添加說明文字的動(dòng)態(tài)層的實(shí)現(xiàn)代碼
一個(gè)不錯(cuò)的給圖片添加說明文字的動(dòng)態(tài)層的實(shí)現(xiàn)代碼,需要的朋友可以參考下2013-04-04用dom+xhtml+css制作的一個(gè)相冊(cè)效果代碼打包下載
2008-01-01javascript 指定區(qū)域內(nèi)圖片等比例縮放實(shí)現(xiàn)代碼 腳本之家整合版
javascript 區(qū)域內(nèi) 圖片等比例縮放實(shí)現(xiàn)代碼 腳本之家整合版,兼容ie跟firefox。2009-10-10