electron系列(一)调用dll

用electron的目的,其实很简单。就是web架构要直接使用前端电脑的资源,但是浏览器限制了使用,所以用electron来达到这个目的。其中调用dll是一个非常基本的操作。

安装 ffi-napiref-napi 包:

javascript 复制代码
npm install ffi-napi ref-napi

main.js,并添加如下代码:

javascript 复制代码
const { app, BrowserWindow } = require('electron');
const path = require('path');
const ffi = require('ffi-napi');
const ref = require('ref-napi');

// 定义DLL中导出的函数和它们的参数、返回值类型
const exampleLibrary = ffi.Library(path.join(__dirname, 'example.dll'), {
  'Add': ['int', ['int', 'int']]  // Add函数接受两个整数作为参数,并返回一个整数
});

function createWindow() {
  const mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation: false
    }
  });

  mainWindow.loadFile('index.html');

  // 调用DLL中的Add函数并打印结果
  const result = exampleLibrary.Add(5, 3);
  console.log(`DLL Add result: ${result}`);
}

app.whenReady().then(createWindow);

app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();
  }
});

app.on('activate', () => {
  if (BrowserWindow.getAllWindows().length === 0) {
    createWindow();
  }
});
相关推荐
苏一恒7 分钟前
MP4 在 <video> 里,必须全量下载才能起播吗?—— moov、Range 与被误解的 FastStart
前端
Java小卷15 分钟前
低代码并没有过时!可拖拽表单设计器布局思路
前端·低代码
idcu17 分钟前
深入 Lyt.js 响应式系统:Proxy + Signal 双模式
前端
idcu18 分钟前
Vapor Mode 揭秘:无虚拟 DOM 的极致性能
前端
idcu20 分钟前
从 Vue 3 到 Lyt.js:无痛迁移指南
前端
尘世壹俗人21 分钟前
如何检查服务器上消耗资源的程序是那个
服务器·前端·chrome
LIO26 分钟前
Vue Router 进阶:深入用法与最佳实践
前端·vue-router
Hilaku36 分钟前
做了 6 年前端,技术不差却拿不到 Offer?
前端·javascript·程序员
古茗前端团队36 分钟前
钉钉小程序蓝牙打印探索与实践
前端·蓝牙
LIO43 分钟前
一文看懂 Vue Router:精简、易懂、直接用
前端·vue-router