欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

html5使用canvas壓縮圖片的操作詳解-創(chuàng)新互聯(lián)

這期內(nèi)容當中小編將會給大家?guī)碛嘘P(guān)html5使用canvas壓縮圖片的操作詳解,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)肇慶免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

前倆天做了一個圖片轉(zhuǎn)base64上傳的功能,發(fā)現(xiàn)如果圖片的base64過大的話,請求會變的很慢,嚴重的直接超時了,所以想到了在上傳前壓縮一下圖片,然后再上傳到后臺,這樣可以大大的提高效率,在這里記錄一下利用 canvas 壓縮圖片遇到的幾個坑。完整代碼會在文末給出。

第一個坑,在壓縮圖片的時候沒獲取圖片本身的寬高,給了一個 600*480 的定寬定高,因為是手機端的,在上傳圖片的時候都是幾兆的圖片,所以這塊沒任何問題。出問題的地方在 修改頭像的時候,測試的時候上傳的圖片都是小圖片,然后就出現(xiàn)了 壓縮后的圖片顯示不完全,大部分都是空白的現(xiàn)象,這就是因為在壓縮的時候沒有考慮圖片原本的寬高的情況。

第二個坑,解決第一個坑的辦法就是在圖片加載完成后(onload),獲取圖片本身的寬高,然后賦值給 canvas ,這樣進行操作,但是這有個坑就是,圖片加載是異步的,在你 return 的時候,返回的可能是 undefined 而不是你需要的 壓縮后的 base64。這里的解決方法是,新建一個 Promise ,然后把結(jié)果 resolve() 返回去,在調(diào)用的時候 .then() 得到結(jié)果。

知識點:

  • canvas 的 toDataURL('image/png', 0.9) ; 把 canvas 畫的圖片轉(zhuǎn)換為 base64,第一個參數(shù)表示的是圖片的類型,第二個參數(shù)表示的是圖片的清晰度。

  • 規(guī)定一個大尺寸,如果圖片本身的寬高大于這個尺寸,按照大的一個邊進行縮放,另一個根據(jù)圖片的 比例 進行設(shè)置,然后設(shè)置給 canvas .

miniImage.js

export default async function miniSize(imgData, maxSize = 200*1024){
    // const maxSize = 200 * 1024;

    if(imgData && imgData.files && imgData.files.size < maxSize) {
        return imgData.url;
    }else{
      console.log('----------------壓縮圖片-------------------');
      const canvas = document.createElement('canvas');
      let img = new Image();
      img.src = imgData.url;
      let ctx = canvas.getContext('2d');
      return new Promise((resolve =>{
        img.addEventListener('load', function(){
          //圖片原始尺寸
          let originWidth = this.width;
          let originHeight = this.height;
          // 大尺寸限制
          let maxWidth = 400, maxHeight = 400;
          // 目標尺寸
          let targetWidth = originWidth, targetHeight = originHeight;
          // 圖片尺寸超過400x400的限制
          if (originWidth > maxWidth || originHeight > maxHeight) {
            if (originWidth / originHeight > maxWidth / maxHeight) {
              // 更寬,按照寬度限定尺寸
              targetWidth = maxWidth;
              targetHeight = Math.round(maxWidth * (originHeight / originWidth));
            } else {
              targetHeight = maxHeight;
              targetWidth = Math.round(maxHeight * (originWidth / originHeight));
            }
          }
          canvas.width = targetWidth;
          canvas.height = targetHeight;
          ctx.drawImage(img, 0, 0, targetWidth, targetHeight);
          let base64 = canvas.toDataURL('image/png', 0.9);
          resolve(base64);
        }, false);
      }))
    }
}

調(diào)用:

test.js

onChangeImg = async (files, type, index) => {
    let previous = this.props.imagePicker.files;
    if(type === "add") {
      let result = miniSize(files[files.length-1]);
      //使用 .then() 調(diào)用獲得結(jié)果
      await result.then(res => {
         previous.push({url: res});
      });
    }else if(type === "remove") {
        previous.splice(index,1);
    }
    await this.props.dispatch({
      type: 'imagePicker/saveImage',
      payload: {
        files: previous
      }
    })
  }

上述就是小編為大家分享的html5使用canvas壓縮圖片的操作詳解了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)站標題:html5使用canvas壓縮圖片的操作詳解-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://aaarwkj.com/article32/dgospc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導航、標簽優(yōu)化營銷型網(wǎng)站建設(shè)、虛擬主機、微信小程序、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
亚洲精品一区二区午夜| 亚洲欧美综合精品二区| 日韩久久这里只有精品视频| 亚洲激情欧美激情在线| 99久久精品人妻一区| 中文字幕熟女av一区二区| 99热这里只有精品免费播放| 欧美亚洲国语精品一区二区| 麻豆久久av免费观看| 高清国语对白刺激av在线播放| 97成人在线视频免费| 加勒比中文字幕日本道| 中文字幕女同系列av厨房| 亚洲欧洲国产视频一区二区| 无码精品人妻一区二区三区中| 日本理论午夜三级在线观看| 美味人妻手机在线观看| 亚洲黄色片大奶子水多| 欧美精品国产一区二区免费| 亚洲国产欧美日韩国产| 精品国产熟女成人av| 亚洲精品日韩一区二区| 亚洲中文字幕一区乱码| 日韩国产欧美亚洲一区| 国产亚洲av一区二区三区| 日本顶级片一区二区三区| 国产午夜精品福利爽爽| 久久精品国产亚洲av久| 欧美日本在线区一区二| 久热99在线视频免费观看| 四虎最新永久在线网站| 精品欧美日韩国产一区| 国产欧美日韩国产欧美日| 在线观看中文字幕一区| 国欧美一区二区三区| 日韩精品毛片精品一区到三区| 免费啪啪视频一区二区| 欧美黄色一区在线观看| 日本免费精品人成视频| 国产三级精品在线免费| 国产成年人拍拍免费视频|