Electron實現(xiàn)右鍵保存圖片到本地功能
Electron是開發(fā)跨平臺pc客戶端的利器,最近在使用它時遇到一個需要右鍵保存頁面中圖片的功能,我們知道Chrome瀏覽器本身在圖片上右鍵保存圖片即可,但Electron雖使用了Chromium內核但卻無法直接使用系統(tǒng)右鍵,需要自定義右鍵菜單,然后添加圖片保存功能。以下是我的使用方法。
Electron
是雙進程模式,即用于頁面渲染的渲染器進程,和作為程序入口及窗口管理的主進程,想必大家都曉得。
保存圖片的核心原理即: 在渲染進程中監(jiān)聽右鍵context
事件,獲取到圖片的src
,然后將src
發(fā)送到主進程,主進程監(jiān)聽到發(fā)送事件后,獲取src
地址,然后調用axios
等http請求圖片下載圖片數(shù)據(jù),復制到粘貼板并保存到計算機中。
聽起來很簡單對吧,事實上也確實簡單。就是一個渲染進程和主進程進行一次通信,就ok。
渲染進程監(jiān)聽context事件獲取圖片地址
和普通網(wǎng)頁中監(jiān)聽一樣,使用window.addEventListen('context'
,唯一需要注意的是獲取electron
的方式,可以通過preload
腳本將electron
注入到網(wǎng)頁,也可以直接在創(chuàng)建主窗口時 nodeIntegration
設為true
,contextIsolation
設為false
從而在網(wǎng)頁中直接使用,當然后者并不安全,不建議使用。
window.addEventListener('contextmenu',function(e){ let Renderer = (window.require && window.require('electron')) || window.electron || {}; const ipc = Renderer.ipcRenderer || undefined; if(ipc){ ipc.invoke('saveimg', {src:e.srcElement && e.srcElement.currentSrc?e.srcElement.currentSrc:''}).then(r => { // r為返回的數(shù)據(jù) console.log(r); }) e.preventDefault(); } });
如上代碼,當在圖片上右鍵時,可通過e.srtElement.currentSrc
取得圖片地址,然后使用 Render.ipcRenderer.invoke
發(fā)送給主進程,當然如果不需要接收返回數(shù)據(jù),使用 send
也是可以
主進程接收數(shù)據(jù)并保存圖片
主進程通過 ipcMain.handle
監(jiān)聽渲染進程發(fā)來的數(shù)據(jù),第二個參數(shù)args
即是渲染進程發(fā)送的數(shù)據(jù),通過args.src
可獲取到圖片地址,然后調用 saveImage
函數(shù)保存圖片到本地。
為方便使用,可在接到該事件時,添加一個右鍵菜單,只有當點擊右鍵菜單中的“保存圖片到本地”才真正執(zhí)行保存動作。
const { app, BrowserWindow, ipcMain,nativeImage, dialog,Menu, MenuItem } = require('electron') ipcMain.handle(event,args){ const template = [ { label: '保存圖片到本地', accelerator: 'CmdOrCtrl+I', enabled: args.src?true:false, click: () => { if(args.src){ saveImage(mainWindow,args.src) } } } ] const menu=Menu.buildFromTemplate(template); menu.popup() }
獲取圖片數(shù)據(jù)并保存
這一步就比較簡單了,使用axios
請求圖片數(shù)據(jù),然后調用fs.writeFile
寫入本地文件即可
const axios =require('axios'); const fs =require('fs'); const path = require('path'); async function saveImage(mainWindow,imageUrl) { try { const { filePath } = await dialog.showSaveDialog(mainWindow, { title: '保存圖片', defaultPath: path.join(app.getPath('downloads'), (new Date()).getTime()+'image.jpg'), // 默認保存路徑 }); if (!filePath) { throw new Error('用戶取消了保存操作'); } // 使用 axios 獲取圖片數(shù)據(jù) const response = await axios({ url: imageUrl, method: 'GET', responseType: 'arraybuffer', }); if (!response || response.status !== 200) { throw new Error(`圖片下載失敗,狀態(tài)碼:${response.status}`); } // 將響應數(shù)據(jù)寫入文件 const buffer = Buffer.from(response.data); fs.writeFile(filePath, buffer, (err) => { if (err) { throw err; } console.log('圖片保存成功'); }); } catch (error) { console.error('保存圖片時發(fā)生錯誤:', error.message); } }
最終效果如右圖,額外加了復制和粘貼等功能
到此這篇關于Electron實現(xiàn)右鍵保存圖片到本地功能的文章就介紹到這了,更多相關Electron右鍵保存圖片內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
收集的比較全的automation服務器不能創(chuàng)建對象 異常原因和解決方法
對于出現(xiàn)automation服務器不能創(chuàng)建對象的問題,下面有幾種解決方法大家可以試試。2008-10-10實例詳解display:none與visible:hidden的區(qū)別
這篇文章主要介紹了實例詳解display:none與visible:hidden的區(qū)別的相關資料,需要的朋友可以參考下2017-03-03JavaScript通過RegExp實現(xiàn)客戶端驗證處理程序
通過RegExp實現(xiàn)客戶端驗:讓文本框只允許輸入數(shù)字、文本框只允許輸入中文、郵箱輸入格式的判斷等等,具體實現(xiàn)如下,感興趣的朋友可以參考下哈2013-05-05JavaScript實現(xiàn)俄羅斯方塊游戲過程分析及源碼分享
這篇文章主要介紹了JavaScript實現(xiàn)俄羅斯方塊游戲過程分析及源碼分享,本文分解了游戲規(guī)則、實現(xiàn)過程、難點分析及實現(xiàn)源碼,需要的朋友可以參考下2015-03-03