photoshop生成器引入到electron项目(electron与photoshop建立通信)

Photoshop引入了nodejs,在启动的时候,通过pipe调起nodejs运行时核心generator-builtin,通过KLVR机制与ps进行通信和交互,同时会加载用户编写的扩展。

这里记录一下引入时的踩坑过程

generator-core就是它的源码,electron的主进程是nodejs环境,如果可以将core这套代码在electron的主进程中运行,就达到我们建立electron与ps通信的目的了,生成器的功能非常强大,甚至可以获取图像原始数据

(这两套代码非常有年份,10年前的开源项目,还能跑起来兼容2023的ps版本,也是神奇)

下面是地址,分别是generator-core核心代码、core运行的插件demo

具体的原理可以看知乎一位大佬的文章:
https://zhuanlan.zhihu.com/p/643541900

https://github.com/adobe-photoshop/generator-core

https://github.com/adobe-photoshop/generator-getting-started

  1. 首先是将整套核心代码搬到项目中,安装相关依赖(generator-core)

运行electron主进程,发现会报错 Cannot find module 'minimist' 看了一下是optimist库的一个依赖

npm i minimist后再次运行 仍然无法解决(下面1、2是踩坑步骤,可以忽略)

  1. 在index.js直接require一个optimist模块,问题解决,后面发现是因为里面有minimist
  2. 后续出现了module q is not defined
    这时候再require q无效,说明1方案只是一个巧合,将minimist引到了主进程解决了minimist的报错,尝试将路径直接指向node_modules仍然无效,找不到对应的库

后面翻到core的入口文件:

发现他的入口文件改动了module路径指向,导致整个core找不到node_modules

把这里注释掉,问题解决

再次跑electron主进程,发现electron会闪退,可能是一些参数相关的问题

core的运行命令

复制代码
node app.js -v -f path1/path2

百度了一下这种命令是可以通过optimist这个库读取的,搜了一下入口文件,找到了optimist对象

这里将v参数加入改为true,f 填入core运行的插件plugin路径,从项目根目录出发指向plugin目录即可

-v -f的报错解决,但控制台打印出现问题

这里0.1.0有报错,全局搜了一下0.1.0,发现读的是electron的package.json,直接复制core的package.json进去,修改指向的路径

再次运行

插件的documentInfo已经打印成功,本次引入完成

相关推荐
riuphan1 小时前
揭秘 JS 类型转换:ToPrimitive 机制的神秘面纱
前端·javascript
sagima_sdu2 小时前
Vue 前端径向渐变背景制作
前端·javascript·vue.js
神奇小汤圆2 小时前
Java 并发编程核心原理与生产级最佳实践
javascript
叶落阁主2 小时前
Vue3 后台管理系统全局菜单搜索实战:Cmd/Ctrl + K、权限菜单与拼音过滤
前端·javascript·vue.js
橘猫走江湖3 小时前
Web 前端本地存储:localStorage 与 IndexedDB
前端·javascript·indexeddb
AKA__老方丈3 小时前
删除确认 Hook - 统一管理单删/批量删除的确认弹窗与执行
前端·javascript·vue.js
云间寄信3 小时前
JS:数据结构与集合
javascript
零度晚风3 小时前
JS:基础语法与控制结构
javascript
布兰妮甜4 小时前
Vue 项目 `localhost:3000` 打不开?404 常见原因排查指南
前端·javascript·vue.js·vuecli·4040排查
森林的尽头是阳光4 小时前
前端使用postman快速造数据
前端·javascript·vue·postman·造数·本地测试