前端vue-cropperjs實現(xiàn)圖片裁剪方案
引言
做了個圖片的裁剪的功能和預(yù)覽的功能,前端圖片的裁剪方案,大多數(shù)都是用cropperjs進行封裝,npm上有vue-cropperjs可以直接用起來,viewerjs是用來實現(xiàn)圖片的預(yù)覽,這里直接使用了v-viewer來實現(xiàn)。
可以點擊現(xiàn)在地址體驗喔
圖片裁剪
圖片裁剪的流程
- 首先使用el-upload組件,渲染已經(jīng)存在或者裁剪過的圖片
- 點擊文件上傳,選中需要裁剪的圖片
- 彈出一個彈框,在彈框中使用vue-cropperjs實現(xiàn)圖片裁剪
- 裁剪完成后,通過回調(diào)函數(shù),將處理后的圖片文件(Blob格式)上傳到服務(wù)器或者本地預(yù)覽出來
- 裁剪完成的圖片列表,通過v-viewer實現(xiàn)點擊全屏預(yù)覽(輔助作用)
vue-cropperjs的使用
代碼實現(xiàn)
- 首先在組件注冊VueCropper組件
- 直接可以通過vue-cropper標簽使用組件
- 設(shè)置this.$refs.cropper.setAspectRatio(1)之后,圖片只能按照一定的比例裁剪,想要隨意裁剪可以不設(shè)置
- 通過this.$refs.cropper.relativeZoom、this.onRotateDegreeChange、this.$refs.cropper.move、this.$refs.cropper.scaleX 等API,可以對圖片進行平移、縮放、翻轉(zhuǎn)、旋轉(zhuǎn)等操作
- 通過this.$refs.cropper.getCroppedCanvas().toBlob()獲取到處理后圖片的Blob格式文件
- Blob格式文件處理成File格式后,上傳到服務(wù)器
// 引入組件并注冊 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方法中設(shè)置裁剪的寬高比例 this.$refs.cropper.setAspectRatio(this.aspectRatioValue); // 縮放圖片 this.$refs.cropper.relativeZoom(percent); // 圖片旋轉(zhuǎn)角度 this.onRotateDegreeChange(this.rotateDegree); // 圖片平移 this.$refs.cropper.move(offsetX, offsetY); // 圖片翻轉(zhuǎn) this.$refs.cropper.scaleX(scale); this.$refs.cropper.scaleY(scale); // 重置 this.$refs.cropper.reset(); // 獲取修改后的圖片的數(shù)據(jù) this.$refs.cropper .getCroppedCanvas({ // 限制畫布大小,限制生成的圖片體積 maxWidth: 2056, maxHeight: 2056, }) .toBlob( (blob) => { // 調(diào)用確定的回調(diào)函數(shù),將blob上傳到服務(wù)器或者本地預(yù)覽 this.$emit("confirm", blob); }, // 如果旋轉(zhuǎn)角度不為直角,則圖片一定會出現(xiàn)空白區(qū)域,空白區(qū)域默認透明,使用 png 格式 //this.rotateDegree % 90 === 0 ? this.file.type : 'image/png', this.file.type, // 質(zhì)量 this.quality ); // 將文件上傳到服務(wù)器 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) => { // ... }) }
實現(xiàn)效果
v-viewer的使用
代碼實現(xiàn)
v-viewer主要的實現(xiàn)圖片的全屏預(yù)覽,基于viewerjs封裝
- 首先在main.js中引入css和注冊v-viewer插件
- 在頁面中可以直接通過this.$viewerApi 調(diào)用,傳入圖片路徑的數(shù)組和對應(yīng)的索引,實現(xiàn)全屏預(yù)覽圖片
// 首先在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" ], });
實現(xiàn)效果
參考資料
推薦 js前端實現(xiàn)word excel pdf ppt mp4圖片文本等文件預(yù)覽
最后
圖片剪裁使用插件實現(xiàn)的話,只能說CV工程師不要太爽,要了解原理的話,還是需要花費很多時間研究的;更多關(guān)于前端vue-cropperjs圖片裁剪的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue3的setup在el-tab中動態(tài)加載組件的方法
公司某項目需求在頁面顯示的組件是根據(jù)角色變化而變化的,怎么實現(xiàn)這個效果呢,下面小編給大家介紹下Vue3的setup在el-tab中動態(tài)加載組件的方法,需要的朋友可以參考下2022-11-11vue2+tracking實現(xiàn)PC端的人臉識別示例
本文主要介紹了vue2+tracking實現(xiàn)PC端的人臉識別示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05vue-router中的鉤子函數(shù)和執(zhí)行順序說明
這篇文章主要介紹了vue-router中的鉤子函數(shù)和執(zhí)行順序說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07解決vue父組件調(diào)用子組件只執(zhí)行一次問題
開發(fā)中,需求是將內(nèi)容展示作為一個組件,輸入為contentId,請求在組件中,只需根據(jù)父組件傳過來的contentId去請求內(nèi)容的詳情即可,但是過程中卻發(fā)現(xiàn)一個問題,父組件調(diào)用子組件只執(zhí)行一次,所以本文就給大家介紹解決vue父組件調(diào)用子組件只執(zhí)行一次問題2023-09-09Vue報錯:Injection?"xxxx"?not?found的解決辦法
這篇文章主要給大家介紹了關(guān)于Vue報錯:Injection?"xxxx"?not?found的解決辦法,文中通過圖文將解決的辦法介紹的非常詳細,對大家的學(xué)習(xí)具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07vue使用better-scroll實現(xiàn)下拉刷新、上拉加載
這篇文章主要為大家詳細介紹了vue使用better-scroll實現(xiàn)下拉刷新、上拉加載,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-11-11