解説らしい解説がないので、機能2と3は抱き合わせました。
さっそく以下からどうぞ。
2.[黒]スウォッチだけでなく,色成分がK100のみの場合もすべてオーバープリントにする
var myDoc = app.activeDocument; var myTxf = myDoc.textFrames; for (var i=0; i<myTxf.length; i++){ var myTab = myTxf[i].tables; for (var k=0; k<myTab.length; k++){ var myCel = myTab[k].cells; for (var m=0; m<myCel.length; m++){ if (!myCel[m].diagonalLineStrokeOverprint && myCel[m].diagonalLineStrokeColor.colorValue.join(',') == "0,0,0,100"){ myCel[m].diagonalLineStrokeOverprint = true; } if (!myCel[m].diagonalLineStrokeGapOverprint && myCel[m].diagonalLineStrokeGapColor.colorValue.join(',') == "0,0,0,100"){ myCel[m].diagonalLineStrokeGapOverprint = true; } } } }
元のコードと比較してもらうと、3行目のtgtBlack
という変数を削除し、if文の条件を変更しています。
if (!myCel[m].diagonalLineStrokeOverprint && myCel[m].diagonalLineStrokeColor.colorValue.join(',') == "0,0,0,100"){
それがこの部分の2つめの条件です。
「線の色がK100(他は0なら)」という条件ですが、もともとcolorValue
は4つの要素を持った配列です(順にC、M、Y、Kの値が入っています)。したがって、正攻法では下記のようにします。
if (!myCel[m].diagonalLineStrokeOverprint && myCel[m].diagonalLineStrokeColor.colorValue[0] === 0 && myCel[m].diagonalLineStrokeColor.colorValue[1] === 0 && myCel[m].diagonalLineStrokeColor.colorValue[2] === 0 && myCel[m].diagonalLineStrokeColor.colorValue[3] === 100 &&){
ただこれだと冗長で面倒くさい(と僕は思いました)。
そこでjoin
メソッドを使ってひとつづきのStringにして、それを文字列として比較させました。この辺は書き方の好みでもあるので、どちらの方法を採ってもらっても構いません。あくまでも後者の方がベーシックな書き方ですが、前者のように書くこともできて、同じ結果が得られます、という例です。
3.スクリプトで修正した個数をカウントして表示
var myDoc = app.activeDocument; var myTxf = myDoc.textFrames; var tgtBlack = myDoc.swatches.item('Black'); var resultCount = {'strokes': 0, 'gaps': 0} for (var i=0; i<myTxf.length; i++){ var myTab = myTxf[i].tables; for (var k=0; k<myTab.length; k++){ var myCel = myTab[k].cells; for (var m=0; m<myCel.length; m++){ if (!myCel[m].diagonalLineStrokeOverprint && myCel[m].diagonalLineStrokeColor == tgtBlack){ myCel[m].diagonalLineStrokeOverprint = true; resultCount.strokes ++; } if (!myCel[m].diagonalLineStrokeGapOverprint && myCel[m].diagonalLineStrokeGapColor == tgtBlack){ myCel[m].diagonalLineStrokeGapOverprint = true; resultCount.gaps ++; } } } } alert ("結果は以下の通りです\n斜線のノセ変更:"+resultCount.strokes+"\n斜線の間隔のノセ変更:"+resultCount.gaps);
結果を表示させるため、処理した数をカウントして代入するresultCount
という変数を用意しました。JSON*1で記述してひとつの変数(というかオブジェクトに2つの変数を用意)としましたが、わかりにくければ2つの変数を別々に作ってOKです。
//var resultCount = {'strokes': 0, 'gaps': 0} var result_strokes = 0; var result_gaps = 0;
もしこうやって変数を2つに分ける場合は、後に出てくる2箇所のインクリメント*2で変数を参照しているのでそこを書き換えます。
//resultCount.strokes ++;
result_strokes ++;
//resultCount.gaps ++;
result_gaps ++;
という感じですね。
最後に、結果を表示するalert
メソッド内でも参照するので、そこを書き換えたら変数の書き換えは完了です。
//alert ("結果は以下の通りです\n斜線のノセ変更:"+resultCount.strokes+"\n斜線の間隔のノセ変更:"+resultCount.gaps); alert ("結果は以下の通りです\n斜線のノセ変更:"+result_strokes+"\n斜線の間隔のノセ変更:"+result_gaps);
以上です。機能2、機能3については知ってさえいればそんなに難しくなかったと思いますが、どうだったでしょうか。
また、他所からもらってきたスクリプトに手を加える場合は、どこに手を加えたのかが後から分かるように、こうやってコメントアウトしながら書き換えていくのがいいと思います。