LoginSignup
0
1

More than 5 years have passed since last update.

Illustratorから文字と属性を取得しHTMLタグとCSSに変換する。

Posted at

ドキュメント上の文字ツールで選択された文字とフォント、サイズ、カラーを取得しHTMLタグを付与しCSSを生成するツールを作ってみました。
06.JPG

※HTML5のタグは108つありますが、とりあえずh1とpタグだけにしてみました。。。

実行すると以下が表示されます。
01.JPG

要素が未選択だとエラー以下のアラートが表示され選択するまでループします。
02.JPG

属性名の選択はプルダウンになっています。
idセレクタ、classセレクタを選択すると、下部の属性値の入力欄に任意のセレクタ名が入力できます。
03.JPG

プルダウン最下部の空白を選択すると属性値は入力できない仕様にしました。
04.JPG

要素、属性名を選択はしているが、属性値は未入力という状態では、仮入力という想定で「○○○○●」を出力するようにしてみました。
05.JPG

コードは以下。

Illustrator2HTMLTag.jsx
var myDocument = app.activeDocument;
var mySelection = myDocument.selection;

var outPutHTML = getContents();
//▼タグ、セレクタ取得関数定義
function getContents() {
    //▼選択している文字を取得
    if (mySelection.typename == "TextRange") {
        var myContents = mySelection.contents;
    } else if (mySelection.length != 0) {
        alert("フレームが選択されています。" + "\r\n" + "文字を選択してください。");
        return;
    } else {
        alert("文字が選択されていません。" + "\r\n" + "文字を選択してください。");
        return;
    }

    //▼タグ付与のダイアログ表示
    var tagFlag = false; //フラグの初期化
    var textFlag = true;
    while (tagFlag == false) { //タグが未選択の場合繰り返す
        var myWindow = new Window('dialog', '要素・属性の設定', [800, 500, 1025, 730]);
        myWindow.elementText = myWindow.add("statictext", [10, 10, 450, 30], "要素を選択してください。"); //固定テキスト
        myWindow.h1Bottom = myWindow.add("radiobutton", [10, 35, 85, 65], "h1 タグ");
        myWindow.pBottom = myWindow.add("radiobutton", [105, 35, 205, 65], "p タグ");
        myWindow.attributeText = myWindow.add("statictext", [10, 70, 275, 100], "属性名を選択してください"); //固定テキスト
        myWindow.dropdownList = myWindow.add("dropdownlist", [10, 100, 200, 120], ["id セレクタ", "class セレクタ", ""]);
        myWindow.dropdownList.selection = 0; //デフォルト表示は一番上のもの
        myWindow.attributeValueText = myWindow.add("statictext", [10, 150, 275, 170], "属性値を入力してください"); //固定テキスト

        myWindow.editText = myWindow.add("edittext", [10, 170, 200, 190], "", {
            readonly: false
        }); //id、classセレクタだったら入力できる
        myWindow.dropdownList.onChange = function () {
            if (myWindow.dropdownList.selection == 2) {
                myWindow.editText = myWindow.add("edittext", [10, 170, 200, 190], "※属性名空欄時は入力不可", {
                    readonly: true
                }); //入力できなくする
                textFlag = false; //フラグ
            } else {
                myWindow.editText = myWindow.add("edittext", [10, 170, 200, 190], "", {
                    readonly: false
                }); //id、classセレクタだったら入力できる
            }
        }

        myWindow.okBottom = myWindow.add("button", [20, 200, 100, 220], "OK", {
            name: "ok"
        });
        myWindow.cancelBottom = myWindow.add("button", [120, 200, 200, 220], "キャンセル", {
            name: "cancel"
        });

        var bottomFlag = myWindow.show(); //ダイアログを表示し、OK、キャンセルボタンの結果を取得

        if (bottomFlag == 2) { //キャンセルの場合処理を抜ける
            return;
        }
        var h1BottomResult = myWindow.h1Bottom.value; //h1タグ押下時true
        var pBottomResult = myWindow.pBottom.value; //pタグ押下時true
        var dropDownListResult = myWindow.dropdownList.selection.text; //ドロップダウンリストから選択したセレクタ名が返る

        var mySelectorName = myWindow.editText.text; //入力したテキストが返る

        //▼セレクタ名の取得
        if (textFlag == false) {
            var selectorNameReault = "";
        } else if (mySelectorName == "") {
            var selectorNameReault = '="○○○○●"';
            var mySelectorName = '○○○○●';
        } else {
            var selectorNameReault = '="' + mySelectorName + '"';
        }

        //▼セレクタの選択
        if (dropDownListResult == "id セレクタ") {
            var selectorResult = "id";
            var chiceSelector = "#" + mySelectorName;
        } else if (dropDownListResult == "class セレクタ") {
            var selectorResult = "class";
            var chiceSelector = "." + mySelectorName;

        } else {
            var selectorResult = "";
        }

        //▼タグの選択
        if (h1BottomResult == true) {
            var getTag = "h1";
            var tagResult = "<h1" + " " + selectorResult + selectorNameReault + ">" + myContents + "</h1>";
            var tagFlag = true; //フラグ
        } else if (pBottomResult == true) {
            var tagResult = "<p" + " " + selectorResult + selectorNameReault + ">" + myContents + "</p>";
            var getTag = "p";
            var tagFlag = true; //フラグ
        } else if (h1BottomResult == false && pBottomResult == false) {
            alert("タグが選択されていません。");
            var tagFlag = false; //フラグ
        }
    }

    //▼セレクタに書き出す
    var myContents = mySelection.contents; //選択している文字
    var myFontName = mySelection.textFont.name; //フォント名
    var myFontStyle = mySelection.textFont.style; //スタイル名
    //▼RGB値を取得する関数
    function getColorValue() {
        var myFontColorRed = mySelection.fillColor.red; //red値を取得
        var myFontColorGreen = mySelection.fillColor.green; //green値を取得
        var myFontColorBlue = mySelection.fillColor.blue; //blue値を取得
        var myColor = myFontColorRed + ',' + myFontColorGreen + ',' + myFontColorBlue;
        return myColor;
    }
    var myFontSize = mySelection.size + 'px'; //サイズ
    //▼CSSに書き出す
    if (textFlag == false) {
        //▼セレクタがない場合
        var selectorResult = getTag + '{' + '\r\n' + 'font-family: "' + myFontName + '";' + '\r\n' + 'font-size: ' + myFontSize + ';' + '\r\n' + 'color:rgb(' + getColorValue() + ');' + '\r\n' + '}';
    } else {
        //▼セレクタがある場合       
        var selectorResult = chiceSelector + '{' + '\r\n' + 'font-family: "' + myFontName + '";' + '\r\n' + 'font-size: ' + myFontSize + ';' + '\r\n' + 'color:rgb(' + getColorValue() + ');' + '\r\n' + '}';
    }
    var htmlTag = '<!DOCTYPE html><html lang="ja"><head><meta charset="UTF-8"><title>Document</title><style>' + selectorResult + '</style></head><body>' + tagResult + '</body></html>';
    return htmlTag;
}


//▼ファイル保存
if (outPutHTML !== undefined) {
    saveFile();
}

function saveFile() {
    var inputFileName = File.saveDialog("保存先とファイル名を指定してください。");
    if (inputFileName == null) {
        //alert("キャンセルしました。");
        return;
    }

    var inputFileName = inputFileName.toString();
    var myNewText = inputFileName.match(/.html/);
    if (myNewText) {
        var myNewText = inputFileName;
    } else {
        var inputFileName = inputFileName + ".html";
    }

    var fileObj = new File(inputFileName);
    var inputFileName = fileObj.open("w");
    if (inputFileName == true) {
        fileObj.encoding = "UTF-8";
        fileObj.writeln(outPutHTML);
        fileObj.close;
        alert("処理が終わりました。");
    }
}

htmlとして保存するのでBracketsなどで開いて編集します。

HTML
<!DOCTYPE html>
<html lang="ja">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        ._text {
            font-family: "Meiryo";
            font-size: 15px;
            color: rgb(204, 144, 42);
        }
    </style>
</head>

<body>
    <p class="_text">吾輩は猫である。</p>
</body>

</html>

タグ選択もプルダウンにしたり、カラーをhex値で取ってきたり、改行を含む文章からタグやCSSを振り分ける機能を搭載したりなどなど、まだまだ改善の余地有りですね。。。
※動作確認はWindows10とIllustrator CC 2017のみ。

リファレンスは古籏一浩様のサイトを参考にさせていただきました。
Adobe CC バージョン JavaScript リファレンス

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1