手把手教你开发photoshop面板插件(附demo和工具)
手把手教你开发photoshop面板插件(附demo和工具)
- 一、前言
- 二、插件演示
- 三、目录文件介绍
- 3.1 插件安装
- 3.2 开启ps开发模式
- 3.3 插件文件介绍
- 3.4 manifest 文件介绍
- 3.5 jsx文件加载的2中方式
- 3.6 js和jsx交互
- 3.7 index.html 程序入口
- 3.8 main.js
- 3.9 main.jsx
- 四、打包插件
- 五、源码和相关工具
- 六、参考资料
- 6.1 photoshop插件开发教程
- 6.2 photoshop脚本官方文档
- 6.3 photoshop脚本中文文档
一、前言
phtoshop插件通常有2中方式,一种是以“脚本运行”的方式,另一种是“面板插件”的方式,最近自己需要做一个面板插件,但是发现相关教程实在太少了,本文以我所了解到的介绍给大家。
二、插件演示
先看看成果,我使用的ps是cc2018(19.1.4版本),这个H标志的插件就是本文制作的插件,功能很简单,就是按所填参数新建一份文档。
三、目录文件介绍
3.1 插件安装
自从cc2015之前,面板插件是使用flash开发的,2015(含2015)之后是使用html开发的,所以你想使用本插件,请把ps更新到cc2015之后,并且你需具有前端技术(html+css+js)。
插件目录位置为:ps安装目录\Required\CEP\extensions\插件文件夹
例如本示例插件目录为:ps安装目录\Required\CEP\extensions\dhzx.CreatNewDocument
3.2 开启ps开发模式
ps如果加载没签名的插件会提示“无法加载xxx扩展,因为它未经正确签署”:
所以我们要先开启ps的开发模式,请执行附件“相关工具”中的
开启ps扩展开发者模式(解决无法加载扩展,因为它未经正确签署).reg
关闭ps扩展开发者模式.reg
3.3 插件文件介绍
插件基本目录结构如下,建议你开发插件以本示例为基础进行开发:
dhzx.CreatNewDocument
├─ CSXS
│ └─ manifest.xml (规定文件,定义插件的信息和属性)
├─ css
│ └─ style.css (样色文件)
├─ img
│ └─ icon.png (插件图标)
├─ index.html (程序入口)
├─ js
│ ├─ CSInterface.js (保留文件,js和jsx交互所需的接口)
│ └─ main.js (js文件用于与html和jsx交互)
└─ jsx└─ main.jsx (jsx文件用于与ps交互)
- 其中 manifest.xml文件为必须文件,定义了插件的信息和属性;
- CSInterface.js 是js和jsx交互所需的接口,只有jsx文件可以操作ps,js是不能直接操作的,所以要通过CSInterface.js这个接口来实现js和jsx的交换;
- index.html是程序入口文件;
- 主要文件之间的关联是这样的:
index.html <--> main.js <--> CSInterface.js <--> main.jsx <--> ps
3.4 manifest 文件介绍
manifest.xml文件为必须文件,定义了插件的信息和属性,必要的地方我添加了注释
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<ExtensionManifest Version="4.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ExtensionBundleId="dhzx.CreatNewDocument" ExtensionBundleName="dhzx.CreatNewDocument" ExtensionBundleVersion="5.0.18"><Author>大话主席</Author><Contact mailto="**@abc.com" /><Abstract href="http://www.superslide2.com/" /><ExtensionList><Extension Id="dhzx.CreatNewDocument" Version="1.0" /> <!-- 插件ID 和 版本--></ExtensionList><ExecutionEnvironment><HostList><!-- 设置插件能在 14.0 版本之后 PhotoShop 中运行--><Host Name="PHXS" Version="14.0" /><Host Name="PHSP" Version="14.0" /><Host Name="ILST" Version="17.0" /></HostList><LocaleList><Locale Code="All" /></LocaleList><RequiredRuntimeList><RequiredRuntime Name="CSXS" Version="6.0" /></RequiredRuntimeList></ExecutionEnvironment><DispatchInfoList><Extension Id="dhzx.CreatNewDocument"><DispatchInfo><Resources><MainPath>./index.html</MainPath> <!-- 程序入口--><ScriptPath>./jsx/main.jsx</ScriptPath> <!-- 插件自动加载的jsx文件 --></Resources><Lifecycle><AutoVisible>true</AutoVisible><StartOn></StartOn></Lifecycle><UI><Type>Panel</Type> <!-- 插件模式:面板--><Menu>CreatNewDocument</Menu> <!-- 插件在面板上的标题--><Geometry> <!-- 插件尺寸--><Size><Height>320</Height><Width>260</Width></Size><MaxSize><Height>320</Height><Width>260</Width></MaxSize><MinSize><Height>300</Height><Width>260</Width></MinSize></Geometry><Icons><!-- 插件图标--><Icon Type="Normal">./img/icon.png</Icon><Icon Type="RollOver">./img/icon.png</Icon><Icon Type="DarkNormal">./img/icon.png</Icon><Icon Type="DarkRollOver">./img/icon.png</Icon></Icons></UI></DispatchInfo></Extension></DispatchInfoList>
</ExtensionManifest>
- 其中插件id是唯一的,用于区分其它插件,例如本示例中的id为“dhzx.CreatNewDocument”,所以你新建插件的时候要替换文件中的所有 “dhzx.CreatNewDocument”为你的插件id。
<MainPath>./index.html</MainPath> <!-- 程序入口--> <ScriptPath>./jsx/main.jsx</ScriptPath> <!-- 插件自动加载的jsx文件 -->
MainPath 和 ScriptPath 2个节点比较重要,用于定义程序入口,和激活程序时自动加载的jsx文件。
3.5 jsx文件加载的2中方式
jsx文件加载有2中方式:
- 一种是在manifest.xml文件中以
<ScriptPath>./jsx/main.jsx</ScriptPath>
节点来加载,但貌似只能加载一个文件。 - 另一种是在js里面动态加载,个人推荐第二种方式,比较灵活
var cs = new CSInterface();
function loadJSX(fileName)
{var extensionRoot = cs.getSystemPath(SystemPath.EXTENSION) + "/jsx/";// 这里是指插件目录下的 jsx 文件夹,可自行设为任意目录cs.evalScript('$.evalFile("' + extensionRoot + fileName + '")');
}
loadJSX("a.jsx");
loadJSX("b.jsx");
3.6 js和jsx交互
js和jsx是分别运行在不同环境的,所以二者交换要通过 CSInterface.js 提供的接口。
js 中用 CSInterface 的 evalScript()方法就可以执行 JSX 代码:
var cs = new CSInterface();
cs.evalScript("app.documents.add();")
evalScript(script, callback)方法接受 2 个参数,第一个是要执行的 JSX 代码,第二个是接受执行返回值的回调函数。
3.7 index.html 程序入口
主要是制作插件界面,引用css、js文件
<!DOCTYPE html>
<html><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><link href="./css/style.css" type="text/css" rel="stylesheet"></head><body><div class="app"><h3>新建文档</h3><main class="main"><div class="in"><div class="row"><label> 宽:</label><input type="number" value="100" id="width"> 像素</div><div class="row"><label> 高:</label><input type="number" value="100" id="height"> 像素</div><div class="row"><label>分辨率:</label><input type="number" value="72" id="resolution"> 像素/英寸</div><div class="row"><label> 名称:</label><input type="text" value="New Document" id="docName"></div><div class="row"><label> </label><button id="btnCreate">创建</button></div></div></main></div><script type="text/javascript" src="./js/CSInterface.js"></script><script type="text/javascript" src="./js/main.js"></script></body>
</html>
3.8 main.js
main.js获取index.html上输入的信息,然后通过cs.evalScript 执行 main.jsx 定义的 creatNewDocument 方法。
//js和jsx的交互接口
var cs = new CSInterface();
//创建按钮点击
document.getElementById("btnCreate").addEventListener("click",function(){var width = document.getElementById("width").value;var height = document.getElementById("height").value;var resolution = document.getElementById("resolution").value;var docName = document.getElementById("docName").value;//执行main.jsx里面定义的creatNewDocument() 方法cs.evalScript("creatNewDocument("+width+","+height+","+resolution+",'"+docName+"')");
})
3.9 main.jsx
main.jsx 定义了creatNewDocument 方法,然后通过 app.documents.add() 方法来创建文档。
var creatNewDocument = function (width, height, resolution, docName) {//使用photoshop api创建文档app.documents.add(width, height, resolution, docName);
}
四、打包插件
打包插件可以使用附件“相关工具”中的“ZXP WinGUI.exe”,先创建“证书”,再打包插件。
注意,打包成zip文件即可,别人使用的时候解压缩到插件目录就可以使用了。
ps安装目录\Required\CEP\extensions\
注意:打包后的插件,对插件做任何修改ps都不会生效,是为了防止插件被他人恶意写入程序,只能在开发模式才可以修改。
五、源码和相关工具
GitHub地址
欢迎 Star!
六、参考资料
6.1 photoshop插件开发教程
photoshop插件开发教程
6.2 photoshop脚本官方文档
photoshop脚本官方文档
6.3 photoshop脚本中文文档
photoshop脚本中文文档
手把手教你开发photoshop面板插件(附demo和工具)相关推荐
- zencart1.55手把手教你开发stripe支付插件
第一步:在includes/modules/payment目录下创建名称为c_stripe的文件夹,用于存放stripe支付logo 第二步:在同includes/modules/payment目录下 ...
- java 注册探探账号_零基础手把手教你开发探探类社交软件Tinder
原标题:零基础手把手教你开发探探类社交软件Tinder 目录介绍 1.关于项目App整体架构 1.1项目整体架构 1.1.1 目前项目使用架构 1.1.2 目前常见的架构 1.1.3 MVP架构优点及 ...
- 解放前端工程师——手把手教你开发自己的自定义列表和自定义表单系列之二接口
前言 阅读前请按照顺序参看系列文章,效果更佳! Vue中路由到一个公共组件,然后根据路径中是否存在文件动态加载组件 解放前端工程师--手把手教你开发自己的自定义列表和自定义表单系列之一缘起 据说系列文 ...
- 手把手教你开发IOT设备
手把手教你开发IOT设备 1.概述 IOT设备的开发是基于rt-thread rtos实现.rt-thread是一个国产RTOS,它是一个RTOS,但又不仅仅是RTOS,支持大量的芯片,驱动,还包含大 ...
- 手把手教你开发Pro/TOOLKIT应用程序(一)
前言 本教程采用VS2008 + Pro/E Wildfire5.0来讲解怎样开发Pro/TOOLKIT应用程序. 开发Pro/TOOLKIT应用程序时,Pro/E和Visual Studio的版本需 ...
- 手把手教你开发chrome扩展一:开发Chrome Extenstion其实很简单
手把手教你开发chrome扩展一:开发Chrome Extenstion其实很简单 参考地址为:手把手教你开发chrome扩展一:开发Chrome Extenstion其实很简单
- 物联网全栈教程--手把手教你开发一个智能浇花器
下面来说一下课程的安排,本教程可以分为三大章节,30个小章节,在1-10章节,手把手讲解了如何实现一个定时/实时控制的浇花器,可以对浇花器电量进行显示,可以进行定时设置,以及实时控制,低功耗模式等等, ...
- 视频教程手把手教你学Photoshop
视频教程手把手教你学Photoshop 第一章:photoshop7.0概述 1.1 概述 1.2 基本界面 第二章:工具箱介绍 2.1 选择与切割类 2.1.1 选区和移动工具 2.1.2 套索和魔 ...
- 大数据江湖之即席查询与分析(下篇)--手把手教你搭建即席查询与分析Demo
上篇小弟分享了几个"即席查询与分析"的典型案例,引起了不少共鸣,好多小伙伴迫不及待地追问我们:说好的"手把手教你搭建即席查询与分析Demo"啥时候能出?说到就得 ...
最新文章
- 200万!这所“双一流”也开始高薪抢人了!
- 【搬砖】【Python数据分析】Pycharm中plot绘图不能显示出来
- python实现搜索之二分查找
- MYSQL SHELL 到底是个什么局 剑指 “大芒果”
- 用正则表达式输出rdf文档的三元组格式数据
- 阿里飞猪曝杀熟;贾跃亭“没有抛弃”恒大;百度起诉搜狗浏览器劫持流量 | 极客头条...
- HackerOne 发布《2021年黑客报告》:黑客的动力、发展和未来
- verilog 入门教程
- 图灵奖抬不起Algorand |链捕手
- 华为android已锁定,教你如何查看华为手机是否己解锁bootloader
- 【T3】打印凭证没有任何反应
- jsp注册页面java代码_使用Servlet和JSP实现用户注册功能
- 【腾讯云】记录一次Could not connect to SMTP host: smtp.163.com, port: 25的解决办法
- android手机连接esp32视频
- NVIDIA系列显卡与AMD系列显卡性能对比,以及购买显卡的时候应该看哪些性能指标,NVIDIA显卡与AMD显卡的区别
- 护眼台灯显色指数是什么意思?led灯显色指数80够吗
- 《算法导论》第22章 基本的图算法 个人笔记
- Python Tkinter教程(二)——Label控件、Frame控件、Button控件的完整参数和所有方法及详细用法
- 【转载】谈SCI、EI、ISTP三大索引收录号的检索
- unity2d粒子特效
热门文章
- 计算机音乐告白之夜,温柔版:《告白之夜(纯音乐)》
- html有序列表序号字体大小,css – 对不同字体大小的排序列表编号进行样式化
- C++代码静态分析与优化(7)_vera++
- 解决ubantu里面报错findfont: Font family ['sans-serif'] not found. Falling back to Bitstream Vera Sans
- ios之实现自动无限循环滚动视图(1)
- 大学四年---一个快要毕业学生的反思
- 分享一个外国免费在线领各类软件激活码的网站
- 【VM】权限不足,无法访问文件
- python 的numpy库中的mean()函数用法介绍
- CDH安装手册(自整理)