亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue 實現(xiàn)剪裁圖片并上傳服務(wù)器功能

 更新時間:2018年03月01日 10:50:15   作者:phoebeCodeSpace  
這篇文章主要介紹了vue 實現(xiàn)剪裁圖片并上傳服務(wù)器功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

預覽鏈接點擊預覽

效果圖如下所示,大家感覺不錯,請參考實現(xiàn)代碼。

 

需求

  • [x] 預覽:根據(jù)選擇圖像大小自適應(yīng)填充左側(cè)裁剪區(qū)域
  • [x] 裁剪:移動裁剪框右側(cè)預覽區(qū)域可實時預覽
  • [x] 上傳&清空:點擊確認上傳裁剪圖片,點擊取消按鈕清空圖像
  • [ ] 裁剪框可調(diào)節(jié)大小

實現(xiàn)步驟

methods:funName() - 對應(yīng)源碼中methods中的funName方法

data:dataName - 對應(yīng)源碼中data中的dataName數(shù)據(jù)

1. 圖片選擇與讀取

  • 選擇圖片 :(methods:selectPic) 使用 input[type="file"] 彈出選擇圖片框,js 主動觸發(fā)點擊事件;
  • 讀取圖片 : (methods:readImage) 創(chuàng)建圖片對象,使用createObjectURL顯示圖片。 objectURL = URL.createObjectURL(blob) ;

2. 在canvas中展示圖片

需要掌握的 canvas 相關(guān)知識:

  1. 清空畫布 ctx.clearRect(x,y,width,height) ;
  2. 填充矩形 ctx.fillRect(x,y,width,height) ;
  3. 繪制圓弧 ctx.arc(x,y,r,startAngle,endAngle,counterclockwise) ; 繪制矩形 ctx.rect(x,y,width,height);
  4. 繪制圖像drawImage

 

# 語法
 ctx.drawImage(image, dx, dy);
 ctx.drawImage(image, dx, dy, dWidth, dHeight);
 ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);
 # 參數(shù)
 image    # 繪制的元素(可以為HTMLImageElement,HTMLVideoElement,或者 HTMLCanvasElement。)
 dx,dy    # 目標畫布(destination canvas)左上角的坐標
 dWidth,dHeight  # 目標畫布(destination canvas)上繪制圖像寬高
 sx,sy    # 源畫布(source canvase)左上角的坐標
 sWidth,sHeight  # 源畫布(source canvase)選擇的圖像寬高

5.剪裁圖片 ctx.clip() ;

具體步驟:

  • 計算canvas寬高 :(methods:calcCropperSize) 根據(jù)圖片大小,計算canvas寬高(data:cropperCanvasSize),以致圖片能夠在裁剪區(qū)域自適應(yīng)展示,并確定裁剪的左上角位置(data:cropperLocation)。
  • 繪制左側(cè)裁剪區(qū)域圖像 :(methods:renderCropperImg)

裁剪區(qū)域vue data示意圖:

 

  • 繪制右側(cè)預覽圖片 :(methods:renderPreviewImg)

3. 移動裁剪框

知識點: onmousedown、onmousemove、onmouseup

具體實現(xiàn):

methods:drag()

記錄鼠標坐標,鼠標移動根據(jù)偏移量計算圓心位置。

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. 上傳圖片至服務(wù)器

知識點:

具體實現(xiàn):

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) {
    // ...
   }
  };
  });

總結(jié)

以上所述是小編給大家介紹的vue 實現(xiàn)剪裁圖片并上傳服務(wù)器功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Vue+Websocket簡單實現(xiàn)聊天功能

    Vue+Websocket簡單實現(xiàn)聊天功能

    這篇文章主要為大家詳細介紹了Vue+Websocket簡單實現(xiàn)聊天功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue簡易記事本開發(fā)詳解

    vue簡易記事本開發(fā)詳解

    這篇文章主要為大家詳細介紹了vue簡易記事本的開發(fā)過程,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Vue實現(xiàn)步驟條效果

    Vue實現(xiàn)步驟條效果

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)步驟條效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • elementUI的table表格改變數(shù)據(jù)不更新問題解決

    elementUI的table表格改變數(shù)據(jù)不更新問題解決

    最近在做vue的項目時發(fā)現(xiàn)了一個問題,今天就來解決一下,本文主要介紹了elementUI的table表格改變數(shù)據(jù)不更新問題解決,感興趣的可以了解一下
    2022-02-02
  • Vue局部組件數(shù)據(jù)共享Vue.observable()的使用

    Vue局部組件數(shù)據(jù)共享Vue.observable()的使用

    隨著組件的細化,就會遇到多組件狀態(tài)共享的情況,今天我們介紹的是 vue.js 2.6 新增加的 Observable API ,通過使用這個 api 我們可以應(yīng)對一些簡單的跨組件數(shù)據(jù)狀態(tài)共享的情況,感興趣的可以了解一下
    2021-06-06
  • Vue組件與Vue cli腳手架安裝方法超詳細講解

    Vue組件與Vue cli腳手架安裝方法超詳細講解

    CLI是一個全局安裝的npm包,提供了終端里的vue命令。它可以通過vue create快速搭建一個新項目,或者直接通過vue serve構(gòu)建新想法的原型。你也可以通過vue ui通過一套圖形化界面管理你的所有項目
    2022-11-11
  • vue axios封裝及API統(tǒng)一管理的方法

    vue axios封裝及API統(tǒng)一管理的方法

    這篇文章主要介紹了vue axios封裝以及API統(tǒng)一管理 ,需要的朋友可以參考下
    2019-04-04
  • Vue.js 圖標選擇組件實踐詳解

    Vue.js 圖標選擇組件實踐詳解

    這篇文章主要介紹了Vue.js 圖標選擇組件實踐詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • 手把手教你如何使用Vite構(gòu)建vue項目

    手把手教你如何使用Vite構(gòu)建vue項目

    這篇文章主要介紹了如何使用Vite構(gòu)建vue項目的相關(guān)資料,本文主要介紹了Vite構(gòu)建Vue項目的詳細步驟,包括檢查node.js和pnpm的安裝,構(gòu)建Vite+Vue項目,利用HBuilderX導入項目,需要的朋友可以參考下
    2024-10-10
  • Vue動態(tài)改變css樣式的3種方法總結(jié)

    Vue動態(tài)改變css樣式的3種方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Vue動態(tài)改變css樣式的3種方法,在Vue.js中我們經(jīng)常需要根據(jù)特定的條件或事件來動態(tài)地修改CSS樣式,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11

最新評論