js實現(xiàn)截圖功能_第1頁
js實現(xiàn)截圖功能_第2頁
js實現(xiàn)截圖功能_第3頁
js實現(xiàn)截圖功能_第4頁
js實現(xiàn)截圖功能_第5頁
已閱讀5頁,還剩19頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領

文檔簡介

1、js實現(xiàn)截圖功能javascript 2010-08-11 17:12:53 閱讀723 評論0 字號:大中小 訂閱 今日想試下弄個截圖功能,在網(wǎng)上找了些資料,終于把它實現(xiàn)了,步驟如下:首先要準備4個js文件:1)prototype.jsvar Class = create: function() return function() this.initialize.apply(this, arguments); var Extend = function(destination, source) for (var property in source) destinationproperty

2、= sourceproperty; var Bind = function(object, fun) return function() return fun.apply(object, arguments); var BindAsEventListener = function(object, fun) var args = Atotype.slice.call(arguments).slice(2); return function(event) return fun.apply(object, event | window.event.concat(args); var

3、CurrentStyle = function(element) return element.currentStyle | document.defaultView.getComputedStyle(element, null);function addEventHandler(oTarget, sEventType, fnHandler) if (oTarget.addEventListener) oTarget.addEventListener(sEventType, fnHandler, false); else if (oTarget.attachEvent) oTarget.att

4、achEvent(on + sEventType, fnHandler); else oTargeton + sEventType = fnHandler; ;function removeEventHandler(oTarget, sEventType, fnHandler) if (oTarget.removeEventListener) oTarget.removeEventListener(sEventType, fnHandler, false); else if (oTarget.detachEvent) oTarget.detachEvent(on + sEventType, f

5、nHandler); else oTargeton + sEventType = null; ;2)ImgCropper.js/圖片切割var ImgCropper = Class.create();ImgCtotype = /容器對象,控制層,圖片地址 initialize: function(container, handle, url, options) this._Container = $(container); /容器對象 this._layHandle = $(handle); /控制層 this.Url = url; /圖片地址 this._layBase

6、= this._Container.appendChild(document.createElement(img); /底層 this._layCropper = this._Container.appendChild(document.createElement(img); /切割層 this._layCropper.onload = Bind(this, this.SetPos); /用來設置大小 this._tempImg = document.createElement(img); this._tempImg.onload = Bind(this, this.SetSize); thi

7、s.SetOptions(options); this.Opacity = Math.round(this.options.Opacity); this.Color = this.options.Color; this.Scale = !this.options.Scale; this.Ratio = Math.max(this.options.Ratio, 0); this.Width = Math.round(this.options.Width); this.Height = Math.round(this.options.Height); /設置預覽對象 var oPreview =

8、$(this.options.Preview); /預覽對象 if (oPreview) oPreview.style.position = relative; oPreview.style.overflow = hidden; this.viewWidth = Math.round(this.options.viewWidth); this.viewHeight = Math.round(this.options.viewHeight); /預覽圖片對象 this._view = oPreview.appendChild(document.createElement(img); this._

9、view.style.position = absolute; this._view.onload = Bind(this, this.SetPreview); /設置拖放 this._drag = new Drag(this._layHandle, Limit: true, onMove: Bind(this, this.SetPos), Transparent: true ); /設置縮放 this.Resize = !this.options.Resize; if (this.Resize) var op = this.options, _resize = new Resize(this

10、._layHandle, Max: true, onResize: Bind(this, this.SetPos) ); /設置縮放觸發(fā)對象 op.RightDown & (_resize.Set(op.RightDown, right-down); op.LeftDown & (_resize.Set(op.LeftDown, left-down); op.RightUp & (_resize.Set(op.RightUp, right-up); op.LeftUp & (_resize.Set(op.LeftUp, left-up); op.Right & (_resize.Set(op.

11、Right, right); op.Left & (_resize.Set(op.Left, left); op.Down & (_resize.Set(op.Down, down); op.Up & (_resize.Set(op.Up, up); /最小范圍限制 this.Min = !this.options.Min; this.minWidth = Math.round(this.options.minWidth); this.minHeight = Math.round(this.options.minHeight); /設置縮放對象 this._resize = _resize;

12、/設置樣式 this._Container.style.position = relative; this._Container.style.overflow = hidden; this._layHandle.style.zIndex = 200; this._layCropper.style.zIndex = 100; this._layBase.style.position = this._layCropper.style.position = absolute; this._layBase.style.top = this._layBase.style.left = this._lay

13、Cropper.style.top = this._layCropper.style.left = 0; /對齊 /初始化設置 this.Init(); , /設置默認屬性 SetOptions: function(options) this.options = /默認值 Opacity: 50, /透明度(0到100) Color: , /背景色 Width: 0, /圖片高度 Height: 0, /圖片高度 /縮放觸發(fā)對象 Resize: false, /是否設置縮放 Right: , /右邊縮放對象 Left: , /左邊縮放對象 Up: , /上邊縮放對象 Down: , /下邊縮放

14、對象 RightDown: , /右下縮放對象 LeftDown: , /左下縮放對象 RightUp: , /右上縮放對象 LeftUp: , /左上縮放對象 Min: false, /是否最小寬高限制(為true時下面min參數(shù)有用) minWidth: 50, /最小寬度 minHeight: 50, /最小高度 Scale: false, /是否按比例縮放 Ratio: 0, /縮放比例(寬/高) /預覽對象設置 Preview: , /預覽對象 viewWidth: 0, /預覽寬度 viewHeight: 0/預覽高度 ; Extend(this.options, options

15、| ); , /初始化對象 Init: function() /設置背景色 this.Color & (this._Container.style.backgroundColor = this.Color); /設置圖片 this._tempImg.src = this._layBase.src = this._layCropper.src = this.Url; /設置透明 if (isIE) this._layBase.style.filter = alpha(opacity: + this.Opacity + ); else this._layBase.style.opacity = t

16、his.Opacity / 100; /設置預覽對象 this._view & (this._view.src = this.Url); /設置縮放 if (this.Resize) with (this._resize) Scale = this.Scale; Ratio = this.Ratio; Min = this.Min; minWidth = this.minWidth; minHeight = this.minHeight; , /設置切割樣式 SetPos: function() /ie6渲染bug if (isIE6) with (this._layHandle.style)

17、 zoom = .9; zoom = 1; ; ; /獲取位置參數(shù) var p = this.GetPos(); /按拖放對象的參數(shù)進行切割 this._layCropper.style.clip = rect( + p.Top + px + (p.Left + p.Width) + px + (p.Top + p.Height) + px + p.Left + px); /設置預覽 this.SetPreview(); , /設置預覽效果 SetPreview: function() if (this._view) /預覽顯示的寬和高 var p = this.GetPos(), s = t

18、his.GetSize(p.Width, p.Height, this.viewWidth, this.viewHeight), scale = s.Height / p.Height; /按比例設置參數(shù) var pHeight = this._layBase.height * scale, pWidth = this._layBase.width * scale, pTop = p.Top * scale, pLeft = p.Left * scale; /設置預覽對象 with (this._view.style) /設置樣式 width = pWidth + px; height = p

19、Height + px; top = -pTop + px ; left = -pLeft + px; /切割預覽圖 clip = rect( + pTop + px + (pLeft + s.Width) + px + (pTop + s.Height) + px + pLeft + px); , /設置圖片大小 SetSize: function() var s = this.GetSize(this._tempImg.width, this._tempImg.height, this.Width, this.Height); /設置底圖和切割圖 this._layBase.style.w

20、idth = this._layCropper.style.width = s.Width + px; this._layBase.style.height = this._layCropper.style.height = s.Height + px; /設置拖放范圍 this._drag.mxRight = s.Width; this._drag.mxBottom = s.Height; /設置縮放范圍 if (this.Resize) this._resize.mxRight = s.Width; this._resize.mxBottom = s.Height; , /獲取當前樣式 G

21、etPos: function() with (this._layHandle) return Top: offsetTop, Left: offsetLeft, Width: offsetWidth, Height: offsetHeight , /獲取尺寸 GetSize: function(nowWidth, nowHeight, fixWidth, fixHeight) var iWidth = nowWidth, iHeight = nowHeight, scale = iWidth / iHeight; /按比例設置 if (fixHeight) iWidth = (iHeight

22、 = fixHeight) * scale; if (fixWidth & (!fixHeight | iWidth fixWidth) iHeight = (iWidth = fixWidth) / scale; /返回尺寸對象 return Width: iWidth, Height: iHeight 3)Drag.js/拖放程序var Drag = Class.create();Dtotype = /拖放對象 initialize: function(drag, options) this.Drag = $(drag); /拖放對象 this._x = this._y =

23、0; /記錄鼠標相對拖放對象的位置 this._marginLeft = this._marginTop = 0; /記錄margin /事件對象(用于綁定移除事件) this._fM = BindAsEventListener(this, this.Move); this._fS = Bind(this, this.Stop); this.SetOptions(options); this.Limit = !this.options.Limit; this.mxLeft = parseInt(this.options.mxLeft); this.mxRight = parseInt(this

24、.options.mxRight); this.mxTop = parseInt(this.options.mxTop); this.mxBottom = parseInt(this.options.mxBottom); this.LockX = !this.options.LockX; this.LockY = !this.options.LockY; this.Lock = !this.options.Lock; this.onStart = this.options.onStart; this.onMove = this.options.onMove; this.onStop = thi

25、s.options.onStop; this._Handle = $(this.options.Handle) | this.Drag; this._mxContainer = $(this.options.mxContainer) | null; this.Drag.style.position = absolute; /透明 if(isIE & !this.options.Transparent) /填充拖放對象 with(this._Handle.appendChild(document.createElement(div).style) width = height = 100%; b

26、ackgroundColor = #fff; filter = alpha(opacity:0); fontSize = 0; /修正范圍 this.Repair(); addEventHandler(this._Handle, mousedown, BindAsEventListener(this, this.Start); , /設置默認屬性 SetOptions: function(options) this.options = /默認值 Handle: , /設置觸發(fā)對象(不設置則使用拖放對象) Limit: false, /是否設置范圍限制(為true時下面參數(shù)有用,可以是負數(shù)) m

27、xLeft: 0, /左邊限制 mxRight: 9999, /右邊限制 mxTop: 0, /上邊限制 mxBottom: 9999, /下邊限制 mxContainer: , /指定限制在容器內(nèi) LockX: false, /是否鎖定水平方向拖放 LockY: false, /是否鎖定垂直方向拖放 Lock: false, /是否鎖定 Transparent: false, /是否透明 onStart: function(), /開始移動時執(zhí)行 onMove: function(), /移動時執(zhí)行 onStop: function() /結(jié)束移動時執(zhí)行 ; Extend(this.opti

28、ons, options | ); , /準備拖動 Start: function(oEvent) if(this.Lock) return; this.Repair(); /記錄鼠標相對拖放對象的位置 this._x = oEvent.clientX - this.Drag.offsetLeft; this._y = oEvent.clientY - this.Drag.offsetTop; /記錄margin this._marginLeft = parseInt(CurrentStyle(this.Drag).marginLeft) | 0; this._marginTop = pars

29、eInt(CurrentStyle(this.Drag).marginTop) | 0; /mousemove時移動 mouseup時停止 addEventHandler(document, mousemove, this._fM); addEventHandler(document, mouseup, this._fS); if(isIE) /焦點丟失 addEventHandler(this._Handle, losecapture, this._fS); /設置鼠標捕獲 this._Handle.setCapture(); else /焦點丟失 addEventHandler(windo

30、w, blur, this._fS); /阻止默認動作 oEvent.preventDefault(); ; /附加程序 this.onStart(); , /修正范圍 Repair: function() if(this.Limit) /修正錯誤范圍參數(shù) this.mxRight = Math.max(this.mxRight, this.mxLeft + this.Drag.offsetWidth); this.mxBottom = Math.max(this.mxBottom, this.mxTop + this.Drag.offsetHeight); /如果有容器必須設置positio

31、n為relative或absolute來相對或絕對定位,并在獲取offset之前設置 !this._mxContainer | CurrentStyle(this._mxContainer).position = relative | CurrentStyle(this._mxContainer).position = absolute | (this._mxContainer.style.position = relative); , /拖動 Move: function(oEvent) /判斷是否鎖定 if(this.Lock) this.Stop(); return; ; /清除選擇 w

32、indow.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty(); /設置移動參數(shù) var iLeft = oEvent.clientX - this._x, iTop = oEvent.clientY - this._y; /設置范圍限制 if(this.Limit) /設置范圍參數(shù) var mxLeft = this.mxLeft, mxRight = this.mxRight, mxTop = this.mxTop, mxBottom = this.mxBottom; /如果

33、設置了容器,再修正范圍參數(shù) if(!this._mxContainer) mxLeft = Math.max(mxLeft, 0); mxTop = Math.max(mxTop, 0); mxRight = Math.min(mxRight, this._mxContainer.clientWidth); mxBottom = Math.min(mxBottom, this._mxContainer.clientHeight); ; /修正移動參數(shù) iLeft = Math.max(Math.min(iLeft, mxRight - this.Drag.offsetWidth), mxLef

34、t); iTop = Math.max(Math.min(iTop, mxBottom - this.Drag.offsetHeight), mxTop); /設置位置,并修正margin if(!this.LockX) this.Drag.style.left = iLeft - this._marginLeft + px; if(!this.LockY) this.Drag.style.top = iTop - this._marginTop + px; /附加程序 this.onMove(); , /停止拖動 Stop: function() /移除事件 removeEventHandl

35、er(document, mousemove, this._fM); removeEventHandler(document, mouseup, this._fS); if(isIE) removeEventHandler(this._Handle, losecapture, this._fS); this._Handle.releaseCapture(); else removeEventHandler(window, blur, this._fS); ; /附加程序 this.onStop(); ;4)Resize.js/縮放程序var Resize = Class.create();Re

36、totype = /縮放對象 initialize: function(obj, options) this._obj = $(obj); /縮放對象 this._styleWidth = this._styleHeight = this._styleLeft = this._styleTop = 0; /樣式參數(shù) this._sideRight = this._sideDown = this._sideLeft = this._sideUp = 0; /坐標參數(shù) this._fixLeft = this._fixTop = 0; /定位參數(shù) this._scaleLeft =

37、 this._scaleTop = 0; /定位坐標 this._mxSet = function(); /范圍設置程序 this._mxRightWidth = this._mxDownHeight = this._mxUpHeight = this._mxLeftWidth = 0; /范圍參數(shù) this._mxScaleWidth = this._mxScaleHeight = 0; /比例范圍參數(shù) this._fun = function(); /縮放執(zhí)行程序 /獲取邊框?qū)挾?var _style = CurrentStyle(this._obj); this._borderX = (

38、parseInt(_style.borderLeftWidth) | 0) + (parseInt(_style.borderRightWidth) | 0); this._borderY = (parseInt(_style.borderTopWidth) | 0) + (parseInt(_style.borderBottomWidth) | 0); /事件對象(用于綁定移除事件) this._fR = BindAsEventListener(this, this.Resize); this._fS = Bind(this, this.Stop); this.SetOptions(opti

39、ons); /范圍限制 this.Max = !this.options.Max; this._mxContainer = $(this.options.mxContainer) | null; this.mxLeft = Math.round(this.options.mxLeft); this.mxRight = Math.round(this.options.mxRight); this.mxTop = Math.round(this.options.mxTop); this.mxBottom = Math.round(this.options.mxBottom); /寬高限制 this

40、.Min = !this.options.Min; this.minWidth = Math.round(this.options.minWidth); this.minHeight = Math.round(this.options.minHeight); /按比例縮放 this.Scale = !this.options.Scale; this.Ratio = Math.max(this.options.Ratio, 0); this.onResize = this.options.onResize; this._obj.style.position = absolute; !this._

41、mxContainer | CurrentStyle(this._mxContainer).position = relative | (this._mxContainer.style.position = relative); , /設置默認屬性 SetOptions: function(options) this.options = /默認值 Max: false, /是否設置范圍限制(為true時下面mx參數(shù)有用) mxContainer:, /指定限制在容器內(nèi) mxLeft: 0, /左邊限制 mxRight: 9999, /右邊限制 mxTop: 0, /上邊限制 mxBottom:

42、 9999, /下邊限制 Min: false, /是否最小寬高限制(為true時下面min參數(shù)有用) minWidth: 50, /最小寬度 minHeight: 50, /最小高度 Scale: false, /是否按比例縮放 Ratio: 0, /縮放比例(寬/高) onResize: function() /縮放時執(zhí)行 ; Extend(this.options, options | ); , /設置觸發(fā)對象 Set: function(resize, side) var resize = $(resize), fun; if(!resize) return; /根據(jù)方向設置 swit

43、ch (side.toLowerCase() case up : fun = this.Up; break; case down : fun = this.Down; break; case left : fun = this.Left; break; case right : fun = this.Right; break; case left-up : fun = this.LeftUp; break; case right-up : fun = this.RightUp; break; case left-down : fun = this.LeftDown; break; case r

44、ight-down : default : fun = this.RightDown; ; /設置觸發(fā)對象 addEventHandler(resize, mousedown, BindAsEventListener(this, this.Start, fun); , /準備縮放 Start: function(e, fun, touch) /防止冒泡(跟拖放配合時設置) e.stopPropagation ? e.stopPropagation() : (e.cancelBubble = true); /設置執(zhí)行程序 this._fun = fun; /樣式參數(shù)值 this._styleWi

45、dth = this._obj.clientWidth; this._styleHeight = this._obj.clientHeight; this._styleLeft = this._obj.offsetLeft; this._styleTop = this._obj.offsetTop; /四條邊定位坐標 this._sideLeft = e.clientX - this._styleWidth; this._sideRight = e.clientX + this._styleWidth; this._sideUp = e.clientY - this._styleHeight;

46、 this._sideDown = e.clientY + this._styleHeight; /top和left定位參數(shù) this._fixLeft = this._styleLeft + this._styleWidth; this._fixTop = this._styleTop + this._styleHeight; /縮放比例 if(this.Scale) /設置比例 this.Ratio = Math.max(this.Ratio, 0) | this._styleWidth / this._styleHeight; /left和top的定位坐標 this._scaleLeft

47、 = this._styleLeft + this._styleWidth / 2; this._scaleTop = this._styleTop + this._styleHeight / 2; ; /范圍限制 if(this.Max) /設置范圍參數(shù) var mxLeft = this.mxLeft, mxRight = this.mxRight, mxTop = this.mxTop, mxBottom = this.mxBottom; /如果設置了容器,再修正范圍參數(shù) if(!this._mxContainer) mxLeft = Math.max(mxLeft, 0); mxTop

48、 = Math.max(mxTop, 0); mxRight = Math.min(mxRight, this._mxContainer.clientWidth); mxBottom = Math.min(mxBottom, this._mxContainer.clientHeight); ; /根據(jù)最小值再修正 mxRight = Math.max(mxRight, mxLeft + (this.Min ? this.minWidth : 0) + this._borderX); mxBottom = Math.max(mxBottom, mxTop + (this.Min ? this.minHeight : 0) + this._borderY); /由于轉(zhuǎn)向時要重新設置所以寫成function形式 this._mxSet = function() this._mxRightWidth = mxRight - this._styleLeft - this._borderX; this._mxDownHeight = mxBottom - this._styleTop - this._borderY; this._mxUpHeight = Math.max(this._fixTop - mxTop, this.Min ? this.min

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論