91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

前端vue cropperjs怎么實現圖片裁剪

發布時間:2022-07-12 14:43:50 來源:億速云 閱讀:262 作者:iii 欄目:開發技術

這篇文章主要介紹“前端vue cropperjs怎么實現圖片裁剪”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“前端vue cropperjs怎么實現圖片裁剪”文章能幫助大家解決問題。

圖片裁剪

圖片裁剪的流程

  • 首先使用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) => {
          // ...
     })
}
實現效果

前端vue cropperjs怎么實現圖片裁剪

前端vue cropperjs怎么實現圖片裁剪

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"
    ],
});
實現效果

前端vue cropperjs怎么實現圖片裁剪

關于“前端vue cropperjs怎么實現圖片裁剪”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

云南省| 修武县| 西乡县| 漯河市| 盐池县| 梅州市| 三河市| 宜宾市| 苍南县| 平南县| 两当县| 泰州市| 莱阳市| 酉阳| 大英县| 江达县| 延吉市| 深州市| 文安县| 民乐县| 台湾省| 石家庄市| 宜丰县| 柳州市| 尉氏县| 明溪县| 安庆市| 和龙市| 威宁| 海晏县| 衡阳市| 福安市| 靖州| 玉溪市| 滕州市| 玉门市| 大丰市| 青河县| 博兴县| 湘西| 密云县|