您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)electron-vue圖片壓縮的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
最近用electron-vue(Electron :基于 Chromium 和 Node.js, 讓你可以使用 HTML, CSS 和 JavaScript 構(gòu)建應(yīng)用)擼了一個圖片壓縮的小軟件,平時工作還是需要用得到的,支持常用的圖片格式;
可以設(shè)置壓縮比例
1、支持設(shè)置固定寬高
2、支持固定寬或高(按原圖比例縮?。?/p>
3、支持等比例縮小
具體操作如下:
1、前端把圖片的路徑和保存壓縮后的路徑傳給后端,這個通過electron事件通訊就可以了
調(diào)用的是ipcRenderer.send事件,傳入一個事件名,后端用ipcRenderer.on接收即可,
這里需要注意一下,我們使用ipcRenderer.once接收一次就可以,避免重復(fù)接收消息。
具體參考如下代碼:
await request('resize', this.form.imgPath , this.form.imgSavePath) request方法是對ipcRenderer.send做的一個封裝 async function request( event = '', ...params) { if (!event) { return } // 構(gòu)造promise const reply = new Promise((resolve, reject) => { // 數(shù)據(jù)返回事件,事先約定 const eventReply = `${event}-reply` ipcRenderer.once(eventReply, (event, data) => { resolve(data) }) }) // 觸發(fā)事件 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
經(jīng)測試后發(fā)現(xiàn)了一點小問題,就是偶爾出現(xiàn)獲取失敗的情況,既然有問題那就不能使用了。后面經(jīng)查詢用這個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、最后執(zhí)行壓縮即可,傳入輸出圖片路徑和保存的寬高,調(diào)用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, } //執(zhí)行壓縮. await resizeOptimizeImages(options) }) })
感謝各位的閱讀!關(guān)于“electron-vue圖片壓縮的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。