我正在Electron开发一个小应用程序,我可以将图像上传到Instagram,并且我已经陷入了第一步:/
我想从文件系统中选择一个图像并将其显示在我的应用程序中。
这是我到目前为止所获得的代码:
CODE:
remote.dialog.showOpenDialog((filenames) => {
fs.readFile(filepath, 'utf-8', (err, data) => {
if(err){
alert("An error ocurred reading the file :" + err.message);
return;
}
});
});
答案 0 :(得分:4)
选择,阅读和显示png图像的最小示例。
渲染器进程:::
var remote = require('electron').remote;
var fs = remote.require('fs');
remote.dialog.showOpenDialog(remote.getCurrentWindow(),
{
filters: [
{name: 'Images', extensions: ['png']}
]
},
function(filepaths, bookmarks) {
//read image (note: use async in production)
var _img = fs.readFileSync(filepaths[0]).toString('base64');
//example for .png
var _out = '<img src="data:image/png;base64,' + _img + '" />';
//render/display
var _target = document.getElementById('image_container');
_target.insertAdjacentHTML('beforeend', _out);
return;
});
<div id="image_container"></div>
答案 1 :(得分:4)
使用电子 11,https://www.electronjs.org/docs/api/protocol 中的以下代码段有效
app.whenReady().then(() => {
protocol.registerFileProtocol('atom', (request, callback) => {
console.log(request.url)
const url = request.url.substr(7)
callback({ path: url })
})
})
注意不要使用通常的file://
协议,而是使用自定义的“atom”或“my_whatever”协议
您现在可以通过这种方式获取图像:
<img src="atom://C:\\Users\\my_path\\myfile.png" />
但是,如果您不想在渲染端保留 file
协议的语法,您可以执行以下操作:
protocol.registerFileProtocol('file', ()=>...)
现在您可以通过这种方式获取图像
<img src="file://C:\\Users\\my_path\\myfile.png" />
但是您必须禁用 webSecurity
const mainWindow = new BrowserWindow({
webPreferences: {
nodeIntegration : true,
webSecurity: false
}
答案 2 :(得分:2)
这是一个解决方案,其中包含有关main
进程和renderer
的分离以及es6
的用法的更多信息
主要流程
import { ipcMain, dialog } from "electron";
import fs from 'fs';
ipcMain.on("chooseFile", (event, arg) => {
const result = dialog.showOpenDialog({
properties: ["openFile"],
filters: [{ name: "Images", extensions: ["png","jpg","jpeg"] }]
});
result.then(({canceled, filePaths, bookmarks}) => {
const base64 = fs.readFileSync(filePaths[0]).toString('base64');
event.reply("chosenFile", base64);
});
});
渲染器过程
import electron from 'electron';
// trigger file prompt
electron.ipcRenderer.send('chooseFile');
// handle response
electron.ipcRenderer.on('chosenFile', (event, base64) => {
const src = `data:image/jpg;base64,${base64}`
})