前端vue-cropperjs實現圖片裁剪方案

引言

做瞭個圖片的裁剪的功能和預覽的功能,前端圖片的裁剪方案,大多數都是用cropperjs進行封裝,npm上有vue-cropperjs可以直接用起來,viewerjs是用來實現圖片的預覽,這裡直接使用瞭v-viewer來實現。

可以點擊現在地址體驗喔

git倉庫地址 以及在線demo地址

圖片裁剪

圖片裁剪的流程

  • 首先使用el-upload組件,渲染已經存在或者裁剪過的圖片
  • 點擊文件上傳,選中需要裁剪的圖片
  • 彈出一個彈框,在彈框中使用vue-cropperjs實現圖片裁剪
  • 裁剪完成後,通過回調函數,將處理後的圖片文件(Blob格式)上傳到服務器或者本地預覽出來
  • 裁剪完成的圖片列表,通過v-viewer實現點擊全屏預覽(輔助作用)

vue-cropperjs的使用

代碼實現

  • 首先在組件註冊VueCropper組件
  • 直接可以通過vue-cropper標簽使用組件
  • 設置this.$refs.cropper.setAspectRatio(1)之後,圖片隻能按照一定的比例裁剪,想要隨意裁剪可以不設置
  • 通過this.$refs.cropper.relativeZoom、this.onRotateDegreeChange、this.$refs.cropper.move、this.$refs.cropper.scaleX 等API,可以對圖片進行平移、縮放、翻轉、旋轉等操作
  • 通過this.$refs.cropper.getCroppedCanvas().toBlob()獲取到處理後圖片的Blob格式文件
  • Blob格式文件處理成File格式後,上傳到服務器
// 引入組件並註冊
import "cropperjs/dist/cropper.css";
import VueCropper from "vue-cropperjs";

// 直接使用組件
<vue-cropper
  overflow-hidden
  ref="cropper"
  :src="src"
  preview=".preview"
  :minContainerHeight="500"
  background
  :ready="onReady"
/>

// 圖片可以在onReady方法中設置裁剪的寬高比例
this.$refs.cropper.setAspectRatio(this.aspectRatioValue);

// 縮放圖片
this.$refs.cropper.relativeZoom(percent);

// 圖片旋轉角度
this.onRotateDegreeChange(this.rotateDegree);

// 圖片平移
this.$refs.cropper.move(offsetX, offsetY);

// 圖片翻轉
this.$refs.cropper.scaleX(scale);
this.$refs.cropper.scaleY(scale);

// 重置
this.$refs.cropper.reset();

// 獲取修改後的圖片的數據
  this.$refs.cropper
      .getCroppedCanvas({
        // 限制畫佈大小,限制生成的圖片體積
        maxWidth: 2056,
        maxHeight: 2056,
      })
      .toBlob(
        (blob) => {
          // 調用確定的回調函數,將blob上傳到服務器或者本地預覽
          this.$emit("confirm", blob);
        },
        // 如果旋轉角度不為直角,則圖片一定會出現空白區域,空白區域默認透明,使用 png 格式
        //this.rotateDegree % 90 === 0 ? this.file.type : 'image/png',
        this.file.type,
        // 質量
        this.quality
      );
      
// 將文件上傳到服務器
function onCropperConfirm(blob) {
    let file = new File([blob], filename, { type: blob.type,});
     const formData = new FormData();
     formData.append("file", file);
     // ...
     axios.post("/upload", formData).then((res) => {
          // ...
     })
}

實現效果

v-viewer的使用

代碼實現

v-viewer主要的實現圖片的全屏預覽,基於viewerjs封裝

  • 首先在main.js中引入css和註冊v-viewer插件
  • 在頁面中可以直接通過this.$viewerApi 調用,傳入圖片路徑的數組和對應的索引,實現全屏預覽圖片
// 首先在main.js中引入組件
import "viewerjs/dist/viewer.css";
import VueViewer from "v-viewer";
Vue.use(VueViewer);

// 組件中使用
this.$viewerApi({
    options: {
      toolbar: true,
      initialViewIndex: 1,
    },
    images: [
        "https://placem.at/people?random=1&txt=0&w=500&h=500",
        "https://placem.at/people?random=1&txt=0&w=1000&h=500"
    ],
});

實現效果

參考資料

www.npmjs.com/package/v-v…

www.npmjs.com/package/vue…

推薦 js前端實現word excel pdf ppt mp4圖片文本等文件預覽

最後

圖片剪裁使用插件實現的話,隻能說CV工程師不要太爽,要瞭解原理的話,還是需要花費很多時間研究的;更多關於前端vue-cropperjs圖片裁剪的資料請關註WalkonNet其它相關文章!

推薦閱讀: