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();
  }
});
相关推荐
q1cheng2 分钟前
基于Spring Boot + Vue项目online_learn的权限控制机制分析
前端
扶苏10028 分钟前
深入理解 Vue 3 的 watch
前端·javascript·vue.js
前端 贾公子10 分钟前
组件 v-model 的封装实现原理及 Input 组件的核心实现(上)
服务器·前端·javascript
weixin1997010801614 分钟前
亚马逊商品详情页前端性能优化实战
前端·性能优化
全栈前端老曹16 分钟前
【Redis】 监控与慢查询日志 —— slowlog、INFO 命令、RedisInsight 可视化监控
前端·数据库·redis·缓存·全栈·数据库监控·slowlog
扶苏100220 分钟前
Vue 3 的组合式 API(Composition API)优势
前端·javascript·vue.js
万少35 分钟前
这可能是程序员离用AI赚钱最容易的一个机会了
前端·ai编程
范什么特西39 分钟前
狂神---死锁
java·前端·javascript
weixin1997010801642 分钟前
易贝(eBay)商品详情页前端性能优化实战
前端·性能优化
用户6000718191044 分钟前
【翻译】Rolldown 工作原理解析:符号关联、CJS/ESM 模块解析与导出分析
前端