0
votes

How is it possible, with MathJax or another JavaScript lib, to parse an input HTML file with some TeX math formulas and produce an output file with the formulas replaced with images (gif, png, jpeg, ..)? (The final goal is to export the output HTML file to a PDF file using html-pdf).

For example:

The input file:

<html>
    <head></head>
    <body>
        <p><span class="math-tex">\(x = {-b \pm \sqrt{b^2-4ac} \over 2a}\)</span></p>
    </body>
</html>

MathJax:

               |
               |
            Convert
               |
               ↓

The output file:

<html>
    <head></head>
    <body>
        <img src=""/>
    </body>
</html>
1
If you want HTML or SVG instead of binary images, check out mathjax-node github.com/mathjax/MathJax-node.Peter Krautzberger
Thank you, MathJax-node can also produce PNG images but I prefer a pure JavaScript solution.user6178502
There is no "pure" JS solution for converting TeX to binary images (and html-pdf is not "pure" JS either since it's based on phantomjs). FWIW, mathjax-node is pure JS for HTML and SVG which will produce better results in a pdf.Peter Krautzberger
Yes it's true but I 'prefer' a more cross-platform solution. I already tried MathJax-node before but even with the 'example' code that doesn't work on my computer so I prefer another solution but thank you.user6178502

1 Answers

3
votes

<html>
<head></head>
<script src="https://cdn.mathjax.org/mathjax/latest/MathJax.js"></script>
<script>
    window.MathJax = {
        jax: ["input/TeX", "output/SVG"],
        extensions: ["tex2jax.js"],
        SVG: {
            useGlobalCache: false
        }
    }
</script>
<body onload="render()">
<span id="math-tex">\(x = {-b \pm \sqrt{b^2-4ac} \over 2a}\)</span>
</body>
<script>

    function tex2img(formula, callback) {
        MathJax.Hub.Queue(function () {
            var wrapper = MathJax.HTML.Element("span", {}, formula);
            MathJax.Hub.Typeset(wrapper, function () {
                var svg = wrapper.getElementsByTagName("svg")[0];
                svg.setAttribute("xmlns", "http://www.w3.org/2000/svg");
                var image = new Image();
                image.src = 'data:image/svg+xml;base64,' + window.btoa(unescape(encodeURIComponent(svg.outerHTML)));
                image.onload = function () {
                    var canvas = document.createElement('canvas');
                    canvas.width = image.width;
                    canvas.height = image.height;
                    var context = canvas.getContext('2d');
                    context.drawImage(image, 0, 0);
                    var img = '<img src="' + canvas.toDataURL('image/png') + '"/>';
                    callback(img);
                };
            });
        })
    }

    function render() {
        var dom = document.getElementById("math-tex");
        tex2img(dom.innerText, function (output) {
            dom.innerHTML = output
        });
    }

</script>
</html>

you can get svg by mathjax first, then convert the svg to image(base64)