亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > html5使用canvas壓縮圖片的示例代碼

html5使用canvas壓縮圖片的示例代碼

熱門標簽:ok電銷機器人 智能電銷機器人被禁用了么 惡搞電話機器人 欣鼎電銷機器人 效果 地圖標注軟件打印出來 電話機器人技術 如何查看地圖標注 黃石ai電銷機器人呼叫中心 高德地圖標注商戶怎么標

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

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

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

知識點:

  • canvas 的 toDataURL('image/png', 0.9) ; 把 canvas 畫的圖片轉換為 base64,第一個參數表示的是圖片的類型,第二個參數表示的是圖片的清晰度。
  • 規定一個最大尺寸,如果圖片本身的寬高大于這個尺寸,按照最大的一個邊進行縮放,另一個根據圖片的 比例 進行設置,然后設置給 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);
      }))
    }
}

調用:

test.js

onChangeImg = async (files, type, index) => {
    let previous = this.props.imagePicker.files;
    if(type === "add") {
      let result = miniSize(files[files.length-1]);
      //使用 .then() 調用獲得結果
      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壓縮圖片的示例代碼》,本文關鍵詞  html5,使用,canvas,壓縮,圖片,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5使用canvas壓縮圖片的示例代碼》相關的同類信息!
  • 本頁收集關于html5使用canvas壓縮圖片的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    亚洲www美色| 国产麻豆精品| 国产精品1024在线永久免费| 黄色福利片| 99色视频在线观看| 黄视频网站在线免费观看| 日韩男人天堂| 可以免费看毛片的网站| 国产一区二区精品尤物| 日本在线不卡视频| 一级女性全黄久久生活片| 欧美激情一区二区三区视频 | 美女免费精品视频在线观看| 九九九网站| 色综合久久天天综线观看| 精品国产一区二区三区精东影业| 日本免费看视频| 四虎影视精品永久免费网站| 精品国产一区二区三区免费 | 午夜家庭影院| 国产不卡精品一区二区三区| 可以在线看黄的网站| 免费毛片播放| 91麻豆精品国产片在线观看| 日韩一级黄色片| 91麻豆国产| 999久久66久6只有精品| 久久精品店| 二级片在线观看| 日韩女人做爰大片| 精品久久久久久综合网| 91麻豆精品国产高清在线| 高清一级做a爱过程不卡视频| 日本伦理片网站| 亚洲 欧美 成人日韩| 欧美大片一区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日韩在线观看视频黄| 免费毛片播放| 久久99这里只有精品国产| 国产欧美精品午夜在线播放| 九九久久国产精品| 999久久狠狠免费精品| 精品在线免费播放| 国产一区二区福利久久| 久久国产精品自由自在| 青青久久精品国产免费看| 色综合久久天天综合| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 免费一级片在线| 亚洲精品久久久中文字| 日本伦理网站| 成人免费观看网欧美片| 国产视频一区在线| 亚洲 激情| 色综合久久久久综合体桃花网| 一级毛片看真人在线视频| 免费国产在线观看不卡| 成人免费网站视频ww| 亚洲 激情| 欧美18性精品| 成人免费观看视频| 一级毛片视频免费| 国产不卡高清| 国产成人精品影视| 亚洲 欧美 成人日韩| 亚洲天堂免费| 亚洲精品影院久久久久久| 日本伦理片网站| 亚洲 欧美 成人日韩| 久久精品欧美一区二区| 精品久久久久久综合网| 日韩专区一区| 国产综合成人观看在线| 国产福利免费观看| 日韩专区亚洲综合久久| 韩国毛片基地| 国产一级强片在线观看| 国产a视频| 超级乱淫伦动漫| 日本特黄一级| 毛片的网站| 精品视频免费在线| 精品视频在线观看免费| 国产国语在线播放视频| 九九久久99综合一区二区| 久久99青青久久99久久| 国产伦久视频免费观看 视频| 黄视频网站免费观看| 色综合久久天天综合观看| 亚洲精品中文一区不卡| 国产一区二区精品久久| 精品视频免费看| 国产亚洲精品成人a在线| 欧美另类videosbestsex视频| 日本特黄特色aaa大片免费| 91麻豆精品国产片在线观看| 欧美另类videosbestsex视频| 中文字幕一区二区三区精彩视频| 国产麻豆精品| 欧美日本免费| 国产视频一区在线| 亚洲 国产精品 日韩| 香蕉视频亚洲一级| 国产伦久视频免费观看视频| 91麻豆精品国产综合久久久| 久草免费资源| 欧美电影免费| 青青久久国产成人免费网站| 欧美日本国产| 日本免费看视频| 韩国三级香港三级日本三级| 91麻豆精品国产自产在线| 亚欧成人乱码一区二区| 999久久久免费精品国产牛牛| 麻豆午夜视频| 成人免费观看男女羞羞视频| 日韩专区亚洲综合久久| 日韩中文字幕在线观看视频| 韩国三级香港三级日本三级la | 日韩一级黄色大片| 九九久久99| 一级毛片看真人在线视频| 国产成人精品影视| 精品国产一区二区三区国产馆| 九九免费精品视频| 日韩中文字幕一区| 国产成人欧美一区二区三区的| 国产网站免费在线观看| 一级片免费在线观看视频| 国产网站免费| 精品国产三级a∨在线观看| 日本免费乱理伦片在线观看2018| 久久久成人影院| 久久久成人网| 在线观看成人网| 国产原创视频在线| 欧美日本国产| 国产亚洲免费观看| 色综合久久天天综线观看| 精品在线观看国产| 美国一区二区三区| 国产一区免费观看| 国产精品1024永久免费视频| 成人免费观看视频| 国产网站免费视频| 日韩专区亚洲综合久久| 国产成+人+综合+亚洲不卡 | 日韩中文字幕在线亚洲一区| 天天做日日爱| 国产视频久久久| 国产极品精频在线观看| 国产成人精品一区二区视频| 亚洲天堂在线播放| 日韩在线观看免费| 久草免费在线观看| 亚洲精品中文字幕久久久久久| 久久精品大片| 日韩中文字幕一区| 日韩中文字幕在线亚洲一区| 999精品视频在线| 亚洲精品久久玖玖玖玖| a级毛片免费全部播放| 成人影院一区二区三区| 成人高清视频免费观看| 四虎影视久久久免费| 国产一区免费在线观看| 日韩专区亚洲综合久久| 日韩一级黄色| 欧美激情影院| 欧美激情一区二区三区视频高清 | 精品国产一区二区三区久| 黄色免费三级| 九九久久国产精品| 日日夜夜婷婷| 日韩欧美一二三区| 日韩免费片| 精品国产三级a∨在线观看| 欧美激情影院| 国产91精品一区| 国产成+人+综合+亚洲不卡 | 精品视频在线观看免费| 中文字幕一区二区三区 精品| 精品国产一区二区三区精东影业| 国产麻豆精品免费视频| 久久国产精品永久免费网站| 欧美激情一区二区三区在线播放| 亚洲天堂免费| 韩国三级香港三级日本三级la | 久久国产影院| 国产成人精品综合| 久久99爰这里有精品国产| 亚洲天堂在线播放| 99久久精品国产麻豆| 天天色成人网| 国产一区二区福利久久| 日韩字幕在线| 二级片在线观看| 久久99中文字幕久久| 午夜在线亚洲男人午在线|