adobe uxp与layer图层

记录使用uxp操作图层的几个功能。

预览图层

Blob url

Data URL

注意:getPixels()的一个奇怪的参数字段: applyAlpha: true

实时预览active图层

uxp使用action.addNotificationListener监听宿主事件。PS图层受影响的事件分别是:

  1. historyStateChanged 历史记录
  2. close 关闭文档
  3. select 切换图层、文档

很多操作会触发select事件,通过过滤可以优化预览次数:

ts 复制代码
const refs = ['document', 'layer']; // 切换事件
if (!descriptor._target?.some((item: { _ref: string }) => refs.includes(item._ref))) return;
// 预览图层
// ...

以png格式读取图层数据

背景:需要把某个图层的数据以png格式保存到云端,待后续使用。但uxp未提供接口把imagedata转换成png文件,也没有提供web canvas的高级用法添加imagedata。本实现借助batchPlay,把单图层保存成临时的png文件。关键代码:

js 复制代码
action.batchPlay([{
    _obj: 'exportSelectionAsFileTypePressed',
    _target: {
        _ref: 'layer',
        _enum: 'ordinal',
        _value: 'targetEnum'
    },
    fileType: 'png',
    quality: 32,
    metadata: 0,
    destFolder: folder.nativePath, // string 临时目录
    sRGB: true,
    openWindow: false,
    _options: {
        dialogOptions: 'dontDisplay'
    },
},
], {});

有了png文件后,使用storage.localFileSystem的方法处理文件,上传数据

ts 复制代码
// 图层中文名要解码
const file = (await folder.getEntry(`${decodeURI(layer.name)}.png`)) as storage.File;
return (await file.read({ format: formats.binary })) as ArrayBuffer;

把图片当作新图层创建

背景:本地或远端图片添加到ps图层中。方法有两种

  1. 把图片转成imagedata(canvas),然后使用imaging方法完成操作。
  2. 使用batchPlay把图片导入到选框selection里。ps为了图片显示,会默认对图片大小做调整,导入后可能需要对图层做layer.scale()缩放。

方法1思路比较简单。难点在把图片转成imagedata,要用到webview(iframe)转换。本文只提供思路。 方法2,把文件置入图层placeEvent关键代码:

ts 复制代码
  await executeAsModal(
    async () =>
      batchPlay(
        [
          {
            _obj: 'placeEvent',
            null: {
              _path: token, // storage.localFileSystem.createSessionToken(file)
              _kind: 'local',
            },
            freeTransformCenterState: {
              _enum: 'quadCenterState',
              _value: 'QCSCorner0',
            },
            offset: {
              _obj: 'offset',
              horizontal: { _unit: 'pixelsUnit', _value: 0.0 },
              vertical: { _unit: 'pixelsUnit', _value: 0.0 },
            },
            _isCommand: true,
            _options: {
              dialogOptions: 'dontDisplay',
            },
          },
        ],
        {}
      ),
    {
      commandName: 'import image file',
    }
  );

总结

uxp插件开发体验类似小程序开发,增加了一些nodejs能力,也弱化了web的能力,比如canvas。操作图片的API还不健全,很多时候只能借助魔法batchPlay处理。

欢迎一起交流学习

参考

相关推荐
加班是不可能的,除非双倍日工资3 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip4 小时前
vite和webpack打包结构控制
前端·javascript
excel4 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼5 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy5 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
ZXT5 小时前
promise & async await总结
前端
Jerry说前后端5 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
画个太阳作晴天5 小时前
A12预装app
linux·服务器·前端