預覽鏈接點擊預覽
效果圖如下所示,大家感覺不錯,請參考實現代碼。
需求
實現步驟
methods:funName() - 對應源碼中methods中的funName方法
data:dataName - 對應源碼中data中的dataName數據
1. 圖片選擇與讀取
2. 在canvas中展示圖片
需要掌握的 canvas 相關知識:
# 語法 ctx.drawImage(image, dx, dy); ctx.drawImage(image, dx, dy, dWidth, dHeight); ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight); # 參數 image # 繪制的元素(可以為HTMLImageElement,HTMLVideoElement,或者 HTMLCanvasElement。) dx,dy # 目標畫布(destination canvas)左上角的坐標 dWidth,dHeight # 目標畫布(destination canvas)上繪制圖像寬高 sx,sy # 源畫布(source canvase)左上角的坐標 sWidth,sHeight # 源畫布(source canvase)選擇的圖像寬高
5.剪裁圖片 ctx.clip() ;
具體步驟:
裁剪區域vue data示意圖:
3. 移動裁剪框
知識點: onmousedown、onmousemove、onmouseup
具體實現:
methods:drag()
記錄鼠標坐標,鼠標移動根據偏移量計算圓心位置。
canvas.onmousedown = e => { let [lastX, lastY] = [e.offsetX, e.offsetY]; self.movement = true; canvas.onmousemove = e => { self.circleCenter = { X: self.cropperCanvasSize.width > 2 * self.slectRadius ? self.circleCenter.X + (e.offsetX - lastX) : self.cropperCanvasSize.width / 2, Y: self.cropperCanvasSize.height > 2 * self.slectRadius ? self.circleCenter.Y + (e.offsetY - lastY) : self.cropperCanvasSize.height / 2 }; self.renderCropperImg(); [lastX, lastY] = [e.offsetX, e.offsetY]; }; canvas.onmouseup = e => { self.movement = false; canvas.onmousemove = null; canvas.onmouseup = null; }; };4. 上傳圖片至服務器
知識點:
具體實現:
methods:upload()this.$refs.preview.toBlob((blob)=> { const url = URL.createObjectURL(blob); const formData = new FormData(); formData.append(this.uploadProps.name, blob, `${Date.now()}.png`); if(this.data){ Object.keys(this.uploadProps.data).forEach(key => { formData.append(key, this.uploadProps.data[key]); }); } const request = new XMLHttpRequest(); request.open("POST", this.uploadProps.action, true); request.send(formData); request.onreadystatechange = () => { if (request.readyState === 4 && request.status === 200) { // ... } }; });總結
以上所述是小編給大家介紹的vue 實現剪裁圖片并上傳服務器功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答