HTML с формулами TeX для изображений

Как возможно с помощью MathJax или другой библиотеки JavaScript выполнить синтаксический анализ входного файла HTML с помощью некоторых математических формул TeX и создать выходной файл с формулами, замененными изображениями (gif, png, jpeg, ..)? (Конечная цель - экспортировать выходной HTML-файл в PDF-файл с помощью html-pdf ).

Например:

Входной файл:

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

MathJax:

               |
               |
            Convert
               |
               ↓

Выходной файл:

<html>
    <head></head>
    <body>
        <img src=""/>
    </body>
</html>

person user6178502    schedule 10.04.2016    source источник
comment
Если вам нужен HTML или SVG вместо двоичных изображений, проверьте mathjax-node github.com/mathjax/MathJax- узел.   -  person Peter Krautzberger    schedule 10.04.2016
comment
Спасибо, MathJax-node также может создавать изображения PNG, но я предпочитаю решение на чистом JavaScript.   -  person user6178502    schedule 10.04.2016
comment
Не существует чистого JS-решения для преобразования TeX в двоичные изображения (и html-pdf также не является чистым JS, поскольку он основан на phantomjs). FWIW, mathjax-node - это чистый JS для HTML и SVG, который даст лучшие результаты в pdf.   -  person Peter Krautzberger    schedule 10.04.2016
comment
Да, это правда, но я предпочитаю более кроссплатформенное решение. Я уже пробовал MathJax-node раньше, но даже с кодом примера, который не работает на моем компьютере, поэтому я предпочитаю другое решение, но спасибо.   -  person user6178502    schedule 10.04.2016


Ответы (1)


<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>

вы можете сначала получить svg с помощью mathjax, а затем преобразовать svg в изображение (base64)

person 戚锦秀    schedule 04.12.2018