前端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其它相關文章!
推薦閱讀:
- cropperjs實現裁剪圖片功能
- vue 如何使用vue-cropper裁剪圖片你知道嗎
- JavaScript實現更換頭像功能
- js前端上傳文件縮略圖技巧示例詳解
- Vue使用formData格式類型上傳文件的示例