零基礎(chǔ)的 PhotoShop CEP 6 開(kāi)發(fā)教程 「 4 」Hello World !

《零基礎(chǔ)的 PhotoShop CEP 6 開(kāi)發(fā)教程》系列目錄

「 0 」目錄
「 1 」配置開(kāi)發(fā)環(huán)境
「 2 」CEP 文件結(jié)構(gòu)
「 3 」CEP 的運(yùn)行機(jī)制
「 4 」Hello World !
「 5 」事件(EVENTS)
「 6 」調(diào)用 JSX 并傳遞信息
「 7 」UI - HTML 開(kāi)發(fā)的一些細(xì)節(jié)
「 8 」API - 文件讀寫(xiě)與二進(jìn)制數(shù)據(jù)
「 9 」簽名打包與 ZXPSignCmd
「 X 」CEP 更新到 6.1版了


前面的預(yù)備知識(shí)已經(jīng)說(shuō)完了,可以先完成一個(gè)最簡(jiǎn)單的 Hello World 辫秧!擴(kuò)展了。

建立擴(kuò)展目錄

在擴(kuò)展存放路徑中新建一個(gè)文件夾存放我們要?jiǎng)?chuàng)建的擴(kuò)展被丧。

建立文件夾

在擴(kuò)展存放路徑:
Win 32bit:C:\Program Files\Common Files\Adobe\CEP\extensions\
Win 64bit:C:\Program Files (x86)\Common Files\Adobe\CEP\extensions\

創(chuàng)建 manifest.xml

建立一個(gè) manifest.xml 盟戏,放在 擴(kuò)展目錄\CSXS\

Paste_Image.png

其內(nèi)容在 「 2 」CEP 文件結(jié)構(gòu)中有詳細(xì)說(shuō)明。

manifest.xml:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<ExtensionManifest xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ExtensionBundleId="com.nullice.helloworld" ExtensionBundleVersion="1.0" Version="6.0"> <!-- MAJOR-VERSION-UPDATE-MARKER -->
    <ExtensionList>
        <Extension Id="com.nullice.helloworld" Version="1.0"/> <!-- 設(shè)置擴(kuò)展 ID-->
    </ExtensionList>

    <ExecutionEnvironment>
        <HostList> <!-- 設(shè)置擴(kuò)展能在 11.0 版本之后 PhotoShop 中運(yùn)行-->
            <Host Name="PHXS" Version="[11.0,99.9]"/>
            <Host Name="PHSP" Version="[11.0,99.9]"/>
        </HostList>

        <LocaleList>
            <Locale Code="All"/>
        </LocaleList>

        <RequiredRuntimeList>
            <RequiredRuntime Name="CSXS" Version="6.0"/> 
        </RequiredRuntimeList>

    </ExecutionEnvironment>
    <DispatchInfoList>
        <Extension Id="com.nullice.helloworld"> <!-- 為 com.nullice.helloworld 設(shè)置屬性-->
            <DispatchInfo>
                <Resources>
                    <MainPath>./index.html</MainPath> <!-- 指定起始載入的網(wǎng)頁(yè)-->
                    <ScriptPath>./jsx/main.jsx</ScriptPath> <!-- 指定用到的 JSX 文件-->
                </Resources>

                <Lifecycle>
                    <AutoVisible>true</AutoVisible> <!-- 設(shè)置擴(kuò)展面板為可視-->
                    <StartOn>
                    </StartOn>
                </Lifecycle>

                <UI>
                    <Type>Panel</Type> <!-- 設(shè)置擴(kuò)展顯示為面板模式-->
                    <Menu>Hello world</Menu> <!-- 設(shè)置擴(kuò)展標(biāo)題-->
                    <Geometry>
                        <Size>  <!-- 設(shè)置擴(kuò)展面板尺寸-->
                            <Height>300</Height>
                            <Width>300</Width>
                        </Size>
                        <MaxSize>
                            <Height>900</Height>
                            <Width>900</Width>
                        </MaxSize>
                        <MinSize>
                            <Height>300</Height>
                            <Width>300</Width>
                        </MinSize>
                    </Geometry>
                    <Icons>  <!-- 設(shè)置擴(kuò)展面板尺寸-->
                        <Icon Type="Normal">./img/icon1.png</Icon>
                        <Icon Type="DarkNormal">./img/icon1.png</Icon>
                    </Icons>
                </UI>
            </DispatchInfo>
        </Extension>
    </DispatchInfoList>
</ExtensionManifest>

創(chuàng)建 HTML 頁(yè)面

由于我們已經(jīng)在 manifest.xml 中定義了初始頁(yè)面的位置: <MainPath>./index.html</MainPath>
所以我們會(huì)在擴(kuò)展目錄中創(chuàng)建一個(gè) HTML 頁(yè)面 index.html

index

index.html:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  <meta http-equiv="content-type" content="text/html" charset="UTF-8">
  <link href="./css/styles.css" type="text/css" rel="stylesheet">
      <script type="text/javascript" src="./js/test.js"></script>
      <script type="text/javascript" src="./js/CSInterface.js"></script>
      <script type="text/javascript" src="./js/Vulcan.js"></script>
      <script type="text/javascript" src="./js/AgoraLib.js"></script>
  </head>
    
  <body style="background-color: #a2a1a3; text-align: center;" >
  <span style="font-family: '微軟雅黑'; font-style: normal; font-weight: normal; font-size: 16pt; color: white"> CEP 6 開(kāi)發(fā)教程 </span>
    <br>
    <br>
    <br>
    <span >
      <span style="font-family: 'Castellar'; font-style: normal; font-weight: normal; font-size: 34pt;"> Hello World ! </span>
    </span>
  <br>

  <input type="button" value="新建文檔" onclick="pop()">

  </body>
</html>

在瀏覽器中打開(kāi)的樣子

在 HTML 文件中我們引入了一個(gè) Javascript 文件 :

test.js:

var pop = function ()
{
    var cs = new CSInterface();
    cs.evalScript("dodo()");
}

并給一個(gè)按鈕綁定了其中一個(gè)方法 "pop()" 這個(gè)方法會(huì)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的功能:在 PhotoShop 中新建一個(gè)文檔晚碾。

運(yùn)行在 CEP VM 中的 JavaScript 無(wú)法直接調(diào)用 PhotoShop 的功能抓半,所以我們會(huì)用 CSInterface.js 最為橋梁調(diào)用 JSX 。
我們?cè)?HTML 文件中已經(jīng)引用了 CSInterface.js 格嘁。 CSInterface.js需要放入你的擴(kuò)展文件夾中笛求,它可以從官方獲取

可以看到我們?cè)?JavaScript 中調(diào)用了 dodo() 方法(cs.evalScript("dodo()")),這個(gè)方法的實(shí)現(xiàn)在 manifest.xml 中定義的 jsx/main.jsx 文件 探入。(實(shí)際上也可以直接在 JavaScript 中寫(xiě) cs.evalScript(" app.documents.add()"); 來(lái)實(shí)現(xiàn))

main.jsx:

var dodo = function (info)
{
    app.documents.add();// 新建一個(gè)文檔
}

到此我們的擴(kuò)展已經(jīng)完成了:

示例下載
這是一個(gè)最簡(jiǎn)單的擴(kuò)展示例了狡孔,它展示如何構(gòu)建 CEP 和運(yùn)行一個(gè) CEP 插件

后面會(huì)介紹一些進(jìn)階的內(nèi)容,包括如何從 CEP 的 JavaScript 傳遞數(shù)據(jù)到 JAX蜂嗽、使用 PhotoShop 的事件苗膝、通過(guò) ExtendScript 操作 PhotoShop 等等

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市植旧,隨后出現(xiàn)的幾起案子辱揭,更是在濱河造成了極大的恐慌,老刑警劉巖病附,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件问窃,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡完沪,警方通過(guò)查閱死者的電腦和手機(jī)域庇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)覆积,“玉大人听皿,你說(shuō)我怎么就攤上這事】淼担” “怎么了尉姨?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)吗冤。 經(jīng)常有香客問(wèn)我啊送,道長(zhǎng),這世上最難降的妖魔是什么欣孤? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮昔逗,結(jié)果婚禮上降传,老公的妹妹穿的比我還像新娘。我一直安慰自己勾怒,他們只是感情好婆排,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著笔链,像睡著了一般段只。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鉴扫,一...
    開(kāi)封第一講書(shū)人閱讀 51,258評(píng)論 1 300
  • 那天赞枕,我揣著相機(jī)與錄音,去河邊找鬼。 笑死炕婶,一個(gè)胖子當(dāng)著我的面吹牛姐赡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柠掂,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼项滑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了涯贞?” 一聲冷哼從身側(cè)響起枪狂,我...
    開(kāi)封第一講書(shū)人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎宋渔,沒(méi)想到半個(gè)月后州疾,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡傻谁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年孝治,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片审磁。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡谈飒,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出态蒂,到底是詐尸還是另有隱情杭措,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布钾恢,位于F島的核電站手素,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏瘩蚪。R本人自食惡果不足惜泉懦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望疹瘦。 院中可真熱鬧崩哩,春花似錦、人聲如沸言沐。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)险胰。三九已至汹押,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間起便,已是汗流浹背棚贾。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工窖维, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鸟悴。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓陈辱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親细诸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子沛贪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容