关于electron中使用ffi-napi窗口遍历的过程及问题

使用环境:electorn19 、node16、ffi-napi、user32

前言:这里先提一嘴,windows api也是有32位和64位的区别的,因为我是要快速完成项目,就没用C++写(不熟练),我想着直接用易语言写DLL,但易语言从来就只有32位,也就是编译出来的DLL也是32位的,导致我的node也必须要跟着切到32位才能使用易语言编译出来的DLL,因此就有了现在这个问题。

问题开始:

在原先的项目中,我使用的是64位的user32,在这里我们通常会使用EnumWindows这个api去遍历当前打开的所有窗口,代码如下

javascript 复制代码
const enumWindows = (callback) => {
  user32.EnumWindows(ffi.Callback('bool', ['long', 'int32'], (hwnd, lParam) => {
    const win = new WindowInfo(hwnd);
    if (!callback(win)) {
      return false;
    }
    // 获取子窗口
    user32.EnumChildWindows(win.hwnd, ffi.Callback('bool', ['long', 'int32'], (childHwnd, lParam) => {
      console.log("childHwnd", childHwnd, lParam)
      const childWin = new WindowInfo(childHwnd);
      return callback(childWin);
    }), lParam);
  }), 0);
};

上方这样获取在node为64位的情况下是完全没有问题的,会返回所有的窗口句柄,但在32位的node中,他只会返回一个莫名奇妙的句柄,也并不是我需要的。所以在32位的node环境中我采取了GetWindow这个API,且成功返回所有窗口句柄(可以根据自己需要过滤)

javascript 复制代码
  const windows = [];
  const windowsHwnd = user32.GetDesktopWindow();
  console.log("windowsHwnd", windowsHwnd)

  let hwndTemp =  user32.GetWindow(windowsHwnd, 5)

  while (hwndTemp != 0) {
    // let className =  user32.getWindowClassName(hwndTemp);
    // console.log("className", className)
    windows.push(hwndTemp);
    hwndTemp = user32.GetWindow(hwndTemp, 2)
  }
  console.log("windows233243242", windows)
相关推荐
轮子大叔16 小时前
CSS基础入门
前端·css
踩着两条虫16 小时前
强强联合!VTJ.PRO 正式接入 DeepSeek V4,AI 编码能力再跃升
前端·vue.js·ai编程
Lily.C16 小时前
DOMPurify 前端富文本 XSS 防护使用指南
前端
一叶渡江16 小时前
深挖 iOS 16 以下 flex column-reverse 滚动失效问题
前端
众创岛16 小时前
回调函数、闭包概念、场景及python实战
前端
im_AMBER16 小时前
Leetcode 160 最小覆盖子串 | 串联所有单词的子串
开发语言·javascript·数据结构·算法·leetcode
得想办法娶到那个女人16 小时前
项目中 TypeScript 类型推导 极简实战总结
前端·javascript·typescript
Beginner x_u16 小时前
前端八股整理(Vue 02)|组件通信、生命周期、v-if 与 v-show
前端·javascript·vue.js
一颗青果17 小时前
Cookie 与 Session 超详细讲解
服务器·前端·github
zs宝来了17 小时前
React 18 并发模式:Fiber 架构与时间切片
前端·javascript·框架