您好,登錄后才能下訂單哦!
這篇文章主要介紹“前端vue cropperjs怎么實現圖片裁剪”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“前端vue cropperjs怎么實現圖片裁剪”文章能幫助大家解決問題。
首先使用el-upload組件,渲染已經存在或者裁剪過的圖片
點擊文件上傳,選中需要裁剪的圖片
彈出一個彈框,在彈框中使用vue-cropperjs實現圖片裁剪
裁剪完成后,通過回調函數,將處理后的圖片文件(Blob格式)上傳到服務器或者本地預覽出來
裁剪完成的圖片列表,通過v-viewer實現點擊全屏預覽(輔助作用)
首先在組件注冊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主要的實現圖片的全屏預覽,基于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" ], });
關于“前端vue cropperjs怎么實現圖片裁剪”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。