【Photoshop】自力で同人誌の小口を装飾する人のためのスクリプト


概要

自力で同人誌の小口を装飾する人のためのスクリプトです
 ・装飾に使う小口染画像のイメージ領域を作成するスクリプト
 ・小口染画像を実際に完成原稿に貼り付けるスクリプト
 上記2種のスクリプトからなりたっています

アイデア元

百さんのツイート【同人誌の小口を自力で装飾する方法】を参考に作成しました
ただし本スクリプトは全て私(超.S)が組んでいるのでスクリプト実行において問題が発生したとしても百さんに関係はまったくございませんのでご注意下さい

スクリプトのDL

 スクリプトはここからDL

使い方

まずは使い方から説明します

動作確認済環境

  • photoshopCC 2015
  • Windows7 64bit 

必要なこと

  • 完成原稿psdファイルのみがはいったフォルダ
  • 完成原稿の名前は半角英数字でないと文字化けする
  • 完成原稿の紙余白天地と左右は同じ長さでなければいけない

スクリプトを実行するとおこること

  • 指定のフォルダに小口画像が貼付け結合されたファイルが自動生成されます(上書きしません)
  • 生成されたファイル名の命名規則は → 【生成されるファイル名 + 連番 +.psd】
  • 生成されたファイルの描画モードは必ずグレースケールモードです
  • 生成されたファイルのレイヤは1枚に結合されてから保存されます
  • 小口は必ず左ページから貼付けされます
  • 使用は自己責任でお願いします

使い方

小口に使用する画像を作成する

小口に使用する画像のサイズを自動計算します

  1. ファイル>スクリプト>参照

  2. DLしたスクリプトCreateKoguchiPct.jsxを選択して読み込む

  3. スクリプトが起動してダイアログが出る

  4. ダイアログの対応している項目(↓は完成原稿だと思って下さい)

  5. 必要事項を入力すると小口装飾に使用するためのイメージ領域が生成される

    ↓説明

    真ん中の部分と塗りたし範囲まで装飾をかいてください

  6. 作成できたらタイトルを半角英数字で保存

作成した小口画像を完成原稿に貼る

  1. ファイル>スクリプト>参照

  2. DLしたスクリプトCreateKoguchiData.jsxを選択して読み込む

  3. スクリプトが起動してダイアログが出る

  4. ダイアログの対応している項目(↓は完成原稿だと思って下さい)

    スクリプト適用フォルダ、作成ファイル保存先、作成ファイル名 のパス及び名称は半角英数字にしてください。
    半角英数字以外が含まれると文字化けします

    ex. C/Document/genko/genko.psd ←OK!
    C/Document/原稿/genko.psd ←NG
    C/Document/原稿/原稿.psd ←NG

  5. OKを押す

  6. あとは待つだけ 作成ファイル保存先フォルダにデータが生成されます

コード

今回は全文載せるのもどうかと思うので、役に立った関数をいくつかのせます
前回同様修正が必要な箇所があればご教示ください

jsxのインクルード

インクルードしたいjsxファイルを宣言するだけでいい
しかもそのままインクルード先の関数にアクセスできる

#include "ominoDialogMaker.jsx"

jsxファイルをクリックするだけでフォトショを自動起動

先頭にかくだけ

#target photoshop

画像解像度を変更する

横幅と縦幅だけでも解像度は変更することができる

//データをリサイズ
    //1番目の引数は横幅
    //2番目の引数は縦幅
    //最低限、横幅と縦幅の引数が必要。
    //3番目の引数は解像度
    //4番目の引数はサンプリング
    activeDocument.resizeImage( width, heitgh, resolution, ResampleMethod.BILINEAR);

レイヤの描画モードを変更する

    var docObj = activeDocument.artLayers;
    docObj[0]. blendMode = BlendMode.NORMAL ;//通常レイヤ
    //docObj[0]. blendMode = BlendMode.MULTIPLY;//乗算レイヤ
    }

docObj[0] ←一番上のレイヤ
レイヤが増えていくたびに1,2,3...と増えていく
レイヤの枚数は lengthで得られる

    var maisu = docObj.length; //枚数

選択範囲にペースト

チャンネル等いじっていたら望む結果がえられなかった
下記だけでもいいみたい(グレスケだったからだろうか)

    activeDocument.selection.select(selReg);
    activeDocument.paste();//選択範囲にペースト

画像結合について

イメージモードが2値化のデータに画像結合命令するとエラーになるよ

activeDocument.mergeVisibleLayers();    //画像を結合
//カラーモードが2値化でなければ結合する
var colMode = activeDocument.mode;  //カラーモードを調べる
if(colMode != DocumentMode.BITMAP){
    activeDocument.mergeVisibleLayers();
}

その他

用紙サイズ(mm)からのピクセル値を求める

解像度と用紙サイズからピクセル値に変換する式

用紙の一辺の長さ[mm] × 解像度[dpi] ÷ 25.4 = 求めたいピクセル[pixel]

感想

  • javascript3日目 ちょっと複雑なものが作れるようになった
  • 一作目にくらべるとコードが綺麗になった嬉しい~
  • ominoDialogMaker.jsx は元のものから少し手を加えてあるので気をつけて下さい(add by~コメントいれました)
  • 上下の小口も作れそうだな(左右反転しなきゃならないのとやっぱり説明めんどくさそう)
  • 今回も設定項目多いけど負けないで欲しい、項目数はできるだけ減らしたのですが・・・
  • jsxファイル作るのとっても面白い

参考サイト

OpenSpace
 他のバージョンやリファレンスへのリンクもありました
Adobe Photoshop CC自動化作戦
  上記サイトOpenSpaceさんのコンテンツのひとつ
Adobe CC バージョンJavaScript リファレンス
 日本語でありがたい
Photoshop CS5 JavaScript Reference(PDF)
 Adobe公式 英語 最終的にはここから検索するしかなかった 他バージョンはこちらから
Adobe Photoshop CS5 Object Library