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

為德惠等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及德惠網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、德惠網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
最近用electron-vue(Electron :基于 Chromium 和 Node.js, 讓你可以使用 HTML, CSS 和 JavaScript 構(gòu)建應(yīng)用)擼了一個(gè)圖片壓縮的小軟件,平時(shí)工作還是需要用得到的,支持常用的圖片格式;
可以設(shè)置壓縮比例
1、支持設(shè)置固定寬高
2、支持固定寬或高(按原圖比例縮小)
3、支持等比例縮小
具體操作如下:
1、前端把圖片的路徑和保存壓縮后的路徑傳給后端,這個(gè)通過electron事件通訊就可以了
調(diào)用的是ipcRenderer.send事件,傳入一個(gè)事件名,后端用ipcRenderer.on接收即可,
這里需要注意一下,我們使用ipcRenderer.once接收一次就可以,避免重復(fù)接收消息。
具體參考如下代碼:
await request('resize', this.form.imgPath , this.form.imgSavePath)
request方法是對(duì)ipcRenderer.send做的一個(gè)封裝
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這個(gè)庫獲取圖片的寬高;用法如下:只需要傳入圖片的路徑即可
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)了一點(diǎn)小問題,就是偶爾出現(xiàn)獲取失敗的情況,既然有問題那就不能使用了。后面經(jīng)查詢用這個(gè)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.height3、最后執(zhí)行壓縮即可,傳入輸出圖片路徑和保存的寬高,調(diào)用resize-optimize-images這個(gè)庫,代碼如下:
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)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
文章名稱:electron-vue圖片壓縮的示例分析
當(dāng)前地址:http://chinadenli.net/article14/jggcde.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、搜索引擎優(yōu)化、App開發(fā)、自適應(yīng)網(wǎng)站、營銷型網(wǎng)站建設(shè)、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)