最終更新日 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

編集中のテキストを上から1行ずつレンダリングペインに

応用例をみてみましょう

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

js {

const fontName = fontname();

renderpanecommand({
    target: "MyMessagePanel",
    place: "top",
    size: 100,
    show: 1
});

// javascriptでdocumentに div タグの作成
const textDiv = document.createElement('div');

// レンダリングペインへの送信。
function sendRenderPane(ix, lineFormat) {
    // HTMLとして扱えるように、タグ内部テキストとして...
    textDiv.innerText = lineFormat;
    
    // HTMLタグごとレンダリング枠へと送信。フォントも編集エリアのものを採用しておこう。
    renderpanecommand({
        target: "MyMessagePanel",
        url: `data: text/html;charset=utf-8,<title>${ix} 行目</title><font face="${fontName}" size="4">${textDiv.outerHTML}</font>`
    });
}

// レンダリングペインは見えてるの?
function isRenderPaneShow() {
    const isShow = renderpanecommand({
        target: "MyMessagePanel",
        get: "show"
    });
    
    return +isShow == 1;
}


// 該当の行を「行番|文面」に加工。
function getFormattedLineText(ix, lineText) {
    const lineCount = linecount();
    const lineDigits = String(lineCount).length;
    let lineFormatNumber = ix.toString().padStart(lineDigits, "0");
    let lineFormat = `${lineFormatNumber}|${lineText}`;
    return lineFormat;
}

// マクロを再実行した時には、前のをキャンセルする。
var timeoutHandler;
hidemaru.clearTimeout(timeoutHandler); // 再実行した時に前のを停止


function processLine(ix) {
    // 最後まで行ったら終わり
    if (ix > linecount()) {
        hidemaru.clearTimeout(timeoutHandler);
        outputAlert("全行終了しました。");
        return;
    }

    // レンダリング枠閉じたら終わり
    if (ix > 1 && !isRenderPaneShow()) {
        hidemaru.clearTimeout(timeoutHandler);
        outputAlert("ウィンドウ枠が閉じられました。");
        return;
    }

    // 該当行のテキストを加工し、レンダリング枠へと転送
    let lineText = getlinetext(ix);
    let lineFormat = getFormattedLineText(ix, lineText);
    sendRenderPane(ix, lineFormat);

    // 次の行を2秒後に
    timeoutHandler = hidemaru.setTimeout(processLine, 2000, ix+1);
}

function main() {
    timeoutHandler = hidemaru.setTimeout(processLine, 0, 1); // 最後の「1」は1行目からのスタート
}

// 警告等、アウトプット枠
function outputAlert(msg) {
    var dll = loaddll("HmOutputPane.dll");
    dll.dllFuncW.OutputW(hidemaru.getCurrentWindowHandle(), msg + "\r\n");
}

main();

}