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

溫馨提示×

溫馨提示×

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

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

electron-vue圖片壓縮的示例分析

發布時間:2021-07-21 15:01:46 來源:億速云 閱讀:198 作者:小新 欄目:web開發

這篇文章給大家分享的是有關electron-vue圖片壓縮的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

最近用electron-vue(Electron :基于 Chromium 和 Node.js, 讓你可以使用 HTML, CSS 和 JavaScript 構建應用)擼了一個圖片壓縮的小軟件,平時工作還是需要用得到的,支持常用的圖片格式;

可以設置壓縮比例

1、支持設置固定寬高

2、支持固定寬或高(按原圖比例縮小)

3、支持等比例縮小

具體操作如下:

1、前端把圖片的路徑和保存壓縮后的路徑傳給后端,這個通過electron事件通訊就可以了

調用的是ipcRenderer.send事件,傳入一個事件名,后端用ipcRenderer.on接收即可,

這里需要注意一下,我們使用ipcRenderer.once接收一次就可以,避免重復接收消息。

具體參考如下代碼:

await request('resize', this.form.imgPath , this.form.imgSavePath)
  request方法是對ipcRenderer.send做的一個封裝
  async function request( event = '', ...params) {
  if (!event) {
    return
  }
  // 構造promise
  const reply = new Promise((resolve, reject) => {
    // 數據返回事件,事先約定
    const eventReply = `${event}-reply`
    ipcRenderer.once(eventReply, (event, data) => {
      resolve(data)
    })
  })
  // 觸發事件
  ipcRenderer.send(event, ...params)
  // 返回promise
  return reply
}

2、后端剛開始考慮用image-size這個庫獲取圖片的寬高;用法如下:只需要傳入圖片的路徑即可

const sizeOf = require('image-size')
 let dimensions = sizeOf(path)
  if(!dimensions){
    return
  }
  let width = dimensions.width
  let height = dimensions.height

經測試后發現了一點小問題,就是偶爾出現獲取失敗的情況,既然有問題那就不能使用了。后面經查詢用這個probe-image-size庫是沒有問題的,使用方式如下:

const probe = require('probe-image-size');
 let dimensions = probe.sync(require('fs').readFileSync(path))
  if(!dimensions){
    return
  }
  let width = dimensions.width
  let height = dimensions.height

3、最后執行壓縮即可,傳入輸出圖片路徑和保存的寬高,調用resize-optimize-images這個庫,代碼如下:

fs.readFile(path, function (err, originBuffer) {
    if (err) {
      return
    }
    output = output + `/${basename(path)}`
    fs.writeFile(output, originBuffer, async function (err) {
      if (err) {
        return
      }
      const options = {
        images: [output],
        width,
        height,
        quality: 95,
      }
      //執行壓縮.
      await resizeOptimizeImages(options)
    })
  })

感謝各位的閱讀!關于“electron-vue圖片壓縮的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

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

AI

鄂托克前旗| 汕头市| 承德县| 台湾省| 康定县| 扶风县| 惠水县| 田东县| 舟山市| 古交市| 大厂| 芦山县| 民权县| 平江县| 汕头市| 句容市| 天祝| 静海县| 哈巴河县| 海南省| 兴仁县| 寻乌县| 台北市| 东至县| 桃源县| 饶平县| 恭城| 磐石市| 虹口区| 滨州市| 开平市| 叙永县| 贵港市| 娄底市| 来凤县| 安化县| 普陀区| 苗栗市| 延安市| 桂林市| 兴化市|