![見出し画像](https://assets.st-note.com/production/uploads/images/170232295/rectangle_large_type_2_c35b0f3bbe0def880922088bcfad7410.png?width=1200)
アピアランスの線属性をオープンパスにする作業を半自動化する(Illustrator)
しつこく取り上げてきている「線属性をオープンパス化」ですが、スクリプトとKeyboard Maestroのマクロ化でいいところまで自動化できるようになりました。
「線属性をオープンパス化」については、こちらの記事がオリジナルです。
そもそもの手順
樋口さんがワークフローを最適化くださいました。
[形状に変換]効果で長方形化
[変形]効果でぺったんこに
[パスファインダー(アウトライン)]効果を適用()
[変形]効果を[パスファインダー(アウトライン)]効果の上に移動
なお、図形の場合には「1. [形状に変換]効果で長方形化」は省略できます。
#朝までイラレ 鷹野さんのセッションを復習して「パスファインダー/アウトライン」を後追加した後オープンパスに出来ないか色々触ってたらドラッグする位置で対処出来るかも。「アウトライン」は中央に挿入されるので「変形」や「パスの自由変形」を上にドラッグすると先端角丸になる。#イラレ知恵袋 pic.twitter.com/sd3c6WXjoc
— 樋口泰行/イラレおじさん (@higuchidesign) January 4, 2024
1 | [形状に変換]効果で長方形化
次の手順で設定します。
![](https://assets.st-note.com/img/1724304518327-MQCyYoAnTI.png?width=1200)
次の操作をKeyboard Maestroマクロで実行します。
[形状に変換]→[長方形]を選択
「0」を入力
tabキーで[高さを追加]に移動して「0」を入力
returnキーでダイアログボックスを閉じる
![](https://assets.st-note.com/img/1724304361870-7D4gbHGoKT.png?width=1200)
2 | [変形]効果でぺったんこに
![](https://assets.st-note.com/img/1724304660343-RzNbVutuWX.png?width=1200)
次の操作をKeyboard Maestroマクロで実行します。
[パスの変形]→[変形]を選択
tabキーで[高さを追加]に移動して「0」を入力
returnキーでダイアログボックスを閉じる
![](https://assets.st-note.com/img/1724304550964-1315cN36jo.png?width=1200)
3 | [パスファインダー(アウトライン)]効果を適用
[パスファインダー(アウトライン)]効果を適用します。
Keyboard MaestroのSelect or Show Menu a Menu Itemアクションを使ってもよいのですが、JavaScriptで実行できます。
app.executeMenuCommand("Live Pathfinder Outline")
![](https://assets.st-note.com/img/1724304792291-MRBBi6mI6y.png?width=1200)
なお、[分割およびアウトライン適用時に塗りのないアートワークを削除]オプションをOFFにする必要がありますが、これは追って手動で行うしかありません。
![](https://assets.st-note.com/img/1724304764206-tsi8SBNKXe.png?width=1200)
4 | [変形]効果を[パスファインダー(アウトライン)]効果の上に移動
この操作は手動で行います。
![](https://assets.st-note.com/img/1724305299232-7Gq6Wv9oxK.png?width=1200)
5 | 丸型線端に
必要なわけではないのですが、オープンパス化されていることを確認できる指標として丸型線端にする行程を加えます。
パスの場合
次のようなスクリプトで実現できました。
if (app.documents.length === 0 || app.activeDocument.selection.length === 0) {
alert("ドキュメントが開かれていないか、パスアイテムが選択されていません。");
exit();
}
var selectedItems = app.activeDocument.selection; // 選択されたアイテムを取得
for (var i = 0; i < selectedItems.length; i++) {
var currentItem = selectedItems[i]; // 現在処理中のアイテムを取得
if (currentItem.stroked && currentItem.strokeCap !== StrokeCap.ROUNDENDCAP) {
currentItem.strokeCap = StrokeCap.ROUNDENDCAP; // 線端を丸型線端に設定
}
}
テキストの場合
アピアランスの線属性の変更はスクリプトからは不可能です。そこで、アクションを登録します。
![](https://assets.st-note.com/img/1724306378967-EUYxBsXpAa.png?width=1200)
このアクションを強制的にテキストとして開き、[Ai Do Action Text]アクションで組み込みます。
![](https://assets.st-note.com/img/1724306525933-h7gephr8ZZ.png?width=1200)
丸型線端以外の値もついてきてしまうため、アクションを強制的に調整してみたのですが、逆に不要な破線の設定が付加されてしまうようです。
![](https://assets.st-note.com/img/1724306494514-2aZkR4sBiO.png?width=1200)
全体像
手動でやらなければならない箇所はありますが、それでもラクです!
![](https://assets.st-note.com/img/1724307078184-GY1rNlzB3D.png?width=1200)
Keyboard Maestroマクロ
「JavaScriptでフォントをサイズを取得してKeyboard Maestroに受け渡す」ことを前提にして苦労を重ねていましたが、AppleScriptならシンプルでした。
![](https://assets.st-note.com/img/1725906785-nuyM1C56kKE0GOxQRtzawJU7.png?width=1200)
全体像
![](https://assets.st-note.com/img/1725907295-4RYDc9bgQZePXFWoLul5vNfa.png?width=1200)
ここから先は
¥ 100
Amazonギフトカード5,000円分が当たる
定期マガジンを購読されるとサンプルファイルをダウンロードいただけます。 https://note.com/dtp_tranist/m/mebd7eab21ea5