最終更新日 2025-04-26

「data: ***」の例

ブラウザ枠やレンダリング枠を利用した例には、

などがありますが、もうひとつ、「data: ***」を渡すことが出来ます。 通常のブラウザに対して利用されることは、ほぼありませんが、プログラムとブラウザのURLという関係においては使い勝手があるものになっています。

data: ****

ファイルとしての実態が存在しないものを、レンダリング枠に手軽に表示するのに利用できるのが data :*** です

HTMLの例

test.mac
jsmode "JScript\\" + currentmacrofilename;
 
js {
    renderpanecommand({
         target: "mytest_01",
         url: 'data:text/html;charset=utf-8;,<title>test</title><font color="red" size="5">あい</font>うえお',
         place: "right",
         size: 300,
         show: 1
    });
}
    

画像を表示する際は、下記のようにHTMLの中にbase64として埋め込むのが自然

画像自体の file:/// パスをそのまま url: プロパティに渡した場合は、レンダリング枠の中央に配置されるような形となります。
それだとやや見苦しいため、下記のように html の imgタグ として構築するのが良いでしょう。

test.mac
jsmode "JScript\\" + currentmacrofilename;
 
js {
     
    renderpanecommand({
         target: "mytest_02",
         url: 'data:text/html;charset=utf-8;,<title>test</title><img src="">',
         place: "right",
         size: 300,
         show: 1
    });
}
    

ただし、画像の解像度が非常に大きく、base64にするのに負担が大きい場合は、
下記のように画像の file:/// パスを、そのまま url: プロパティに渡すのが良いでしょう

ただし、この場合には、レンダリング枠の中央に表示されることになります。

test.mac
jsmode "JScript\\" + currentmacrofilename;
 
js {
    renderpanecommand({
         target: "mytest_02",
         url: "C:\\Users\\master\\Pictures\\64x80_dark.png",
         place: "right",
         size: 300,
         show: 1
    });
}
    

これらは URL の一般的な仕様

秀丸専用の機能ではなく、一般的なURLの機能ですので、
「data:」「URL」などとして検索するなり、会話AIなどで調べてください。

ローカルに存在するファイルをbase64のテキストにする例

ローカルのファイルをマクロ内でbase64にするには、下記のような方法となるでしょう。

test.mac
jsmode "JScript\\" + currentmacrofilename;

js {

debuginfo(2);

function imageToBase64(imagePath) {
    if (!existfile(imagePath)) {
        return null;
    }

    try {
        // JScript
        var stream = createobject("ADODB.Stream");

        // ストリーム設定
        stream.Type = 1; // バイナリ
        stream.Open();
        stream.LoadFromFile(imagePath);
        stream.Position = 0;

        // バイナリをBase64に変換
        var domDocument = new createobject("MSXML2.DOMDocument");
        var base64 = domDocument.createElement("b64");
        base64.dataType = "bin.base64";
        base64.nodeTypedValue = stream.Read();

        // Base64文字列取得
        var base64String = base64.text;

        // ストリームを閉じる
        stream.Close();

        return base64String;

    } catch (e) {
        console.log("エラーが発生しました: " + e);
        return null; // エラーの場合はnullを返すなど適切な処理を行う
    }
}

var base64 = imageToBase64("C:\\Users\\master\\Pictures\\64x80_dark.png");
console.log(base64);

} // js