JavaScript 圖片放大鏡(可拖放、縮放效果)第1/4頁
更新時間:2008年09月15日 10:35:34 作者:
背景:很久之前就在marry5.com看到這個效果,當(dāng)時覺得很神奇,礙于水平有限,沒做出來。
前些日子突然想做一個透鏡效果,就突然想到了這個效果,于是找出當(dāng)年“珍藏”的代碼決定一嘗所愿。
前言:
這個程序主要分三部分:層的拖放、層的縮放、圖片切割(包括預(yù)覽)。
其中層的拖放是很常見的效果,層的縮放有點難度,圖片切割看著炫其實原理也很簡單。
不過在實現(xiàn)的過程中也學(xué)習(xí)到很多以前不知道的東西,下面都會說明,希望大家從中也能學(xué)到東西。
原理:
【拖放程序】
基本原理很簡單,不知道的看代碼就明白,其中參考了越兔和BlueDestiny的相關(guān)文章。
下面說一下比較有用的地方:
【范圍限制】
首先當(dāng)然是有拖放范圍參數(shù),分別是mxLeft(左邊的left最小值)、mxRight(右邊的left最大值)、mxTop(上邊的top最小值)、mxBottom(下邊的top最大值)。
然后在拖動程序Move()中看有沒有超過,超過的話設(shè)回極限值就行:
if(this.Limit){
//獲取超出長度
var iRight = iLeft + this._obj.offsetWidth - this.mxRight, iBottom = iTop + this._obj.offsetHeight - this.mxBottom;
//這里是先設(shè)置右邊下邊再設(shè)置左邊上邊,可能會不準(zhǔn)確
if(iRight > 0) iLeft -= iRight;
if(iBottom > 0) iTop -= iBottom;
if(this.mxLeft > iLeft) iLeft = this.mxLeft;
if(this.mxTop > iTop) iTop = this.mxTop;
}
【釋放選擇】
我以前就用的方法是設(shè)置ie的onselectstart和ff的MozUserSelect,
但BlueDestiny說“用user-select會相當(dāng)于event.preventDefault。阻止默認(rèn)動作就會在某些操作的時候?qū)е耺ouseup丟失。”,
最好的方法是ie用document.selection.empty(),ff用window.getSelection().removeAllRanges()。
所以可以在Move()中加入:
window.getSelection && window.getSelection().removeAllRanges();這種寫法是從越兔的程序中學(xué)到的。
因為ie的鼠標(biāo)捕獲默認(rèn)(下面會說)帶這個,所以ie就不用了。
【鼠標(biāo)捕獲】
以前不知道js有這個東西,使用很簡單:
設(shè)置捕獲:this.Drag.setCapture();
取消捕獲:this.Drag.releaseCapture()。
它的作用是:將鼠標(biāo)捕獲設(shè)置到指定的對象。這個對象會為當(dāng)前應(yīng)用程序或整個系統(tǒng)接收所有鼠標(biāo)輸入。
還不明白的話,試試拖放的時候把鼠標(biāo)拖放到瀏覽器外面,會發(fā)現(xiàn)拖動還在繼續(xù),
如果沒有這個鼠標(biāo)捕獲就會失效了。
但在瀏覽器外是觸發(fā)不了mouseup的,不過還可以用losecapture事件代替:
addEventHandler(this.Drag, "losecapture", this._fS);
this.Drag.setCapture();
程序中給ff的window添加blur時停止的事件,越兔說是為了可以檢測到alt+tab造成的mouseup丟失,完美一點,也加上去了。
這樣一個拖放程序就完成了。
前言:
這個程序主要分三部分:層的拖放、層的縮放、圖片切割(包括預(yù)覽)。
其中層的拖放是很常見的效果,層的縮放有點難度,圖片切割看著炫其實原理也很簡單。
不過在實現(xiàn)的過程中也學(xué)習(xí)到很多以前不知道的東西,下面都會說明,希望大家從中也能學(xué)到東西。
原理:
【拖放程序】
基本原理很簡單,不知道的看代碼就明白,其中參考了越兔和BlueDestiny的相關(guān)文章。
下面說一下比較有用的地方:
【范圍限制】
首先當(dāng)然是有拖放范圍參數(shù),分別是mxLeft(左邊的left最小值)、mxRight(右邊的left最大值)、mxTop(上邊的top最小值)、mxBottom(下邊的top最大值)。
然后在拖動程序Move()中看有沒有超過,超過的話設(shè)回極限值就行:
復(fù)制代碼 代碼如下:
if(this.Limit){
//獲取超出長度
var iRight = iLeft + this._obj.offsetWidth - this.mxRight, iBottom = iTop + this._obj.offsetHeight - this.mxBottom;
//這里是先設(shè)置右邊下邊再設(shè)置左邊上邊,可能會不準(zhǔn)確
if(iRight > 0) iLeft -= iRight;
if(iBottom > 0) iTop -= iBottom;
if(this.mxLeft > iLeft) iLeft = this.mxLeft;
if(this.mxTop > iTop) iTop = this.mxTop;
}
【釋放選擇】
我以前就用的方法是設(shè)置ie的onselectstart和ff的MozUserSelect,
但BlueDestiny說“用user-select會相當(dāng)于event.preventDefault。阻止默認(rèn)動作就會在某些操作的時候?qū)е耺ouseup丟失。”,
最好的方法是ie用document.selection.empty(),ff用window.getSelection().removeAllRanges()。
所以可以在Move()中加入:
window.getSelection && window.getSelection().removeAllRanges();這種寫法是從越兔的程序中學(xué)到的。
因為ie的鼠標(biāo)捕獲默認(rèn)(下面會說)帶這個,所以ie就不用了。
【鼠標(biāo)捕獲】
以前不知道js有這個東西,使用很簡單:
設(shè)置捕獲:this.Drag.setCapture();
取消捕獲:this.Drag.releaseCapture()。
它的作用是:將鼠標(biāo)捕獲設(shè)置到指定的對象。這個對象會為當(dāng)前應(yīng)用程序或整個系統(tǒng)接收所有鼠標(biāo)輸入。
還不明白的話,試試拖放的時候把鼠標(biāo)拖放到瀏覽器外面,會發(fā)現(xiàn)拖動還在繼續(xù),
如果沒有這個鼠標(biāo)捕獲就會失效了。
但在瀏覽器外是觸發(fā)不了mouseup的,不過還可以用losecapture事件代替:
addEventHandler(this.Drag, "losecapture", this._fS);
this.Drag.setCapture();
程序中給ff的window添加blur時停止的事件,越兔說是為了可以檢測到alt+tab造成的mouseup丟失,完美一點,也加上去了。
這樣一個拖放程序就完成了。
相關(guān)文章
ant design中實現(xiàn)table的表格行的拖拽
這篇文章主要介紹了ant design中實現(xiàn)table的表格行的拖拽,文章圍繞table表格行拖拽實現(xiàn)的相關(guān)資料展開詳細(xì)的代碼內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下2022-03-03
JS中的.length屬性和.size()方法的區(qū)別
length是js原生屬性,size()是jQuery方法,如果你只是想獲取元素的個數(shù),兩者效果一樣既.length和.size()獲取的值是一樣的2024-08-08
基于JS實現(xiàn)html中placeholder屬性提示文字效果示例
這篇文章主要介紹了基于JS實現(xiàn)html中placeholder屬性提示文字效果,涉及javascript事件響應(yīng)及頁面元素屬性動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-04-04
JS解決Date對象在IOS中的“大坑” 以及時間格式兼容問題
這篇文章主要介紹了JS解決Date對象在IOS中的“大坑” 以及時間格式兼容問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
學(xué)習(xí)JavaScript正則表達(dá)式
這篇文章主要介紹了JavaScript正則表達(dá)式,詳細(xì)深入的了解JavaScript正則表達(dá)式,從而更熟練掌握J(rèn)avaScript正則表達(dá)式,感興趣的小伙伴們可以參考一下2015-11-11

