MathJax渲染Android

时间:2013-02-25 22:39:09

标签: javascript android webview mathjax

现在我为Android编写程序。此应用程序必须使用 MathJax库将formule呈现为 WebView 。但我有问题......有时它不起作用(形式不时)... 现在来源:

// This function calls everytime before output

public static void clearWebView()
{
    w.loadDataWithBaseURL("http://bar", "<!DOCTYPE html><html><head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0,maximum-scale=1.0, user-scalable=no\"> <script type='text/x-mathjax-config'>"
            +"MathJax.Hub.Config({ " 
                +"showMathMenu: false, "
                +"jax: ['input/TeX','output/HTML-CSS'], "
                +"extensions: ['tex2jax.js'], " 
                +"TeX: { extensions: ['AMSmath.js','AMSsymbols.js',"
                  +"'noErrors.js','noUndefined.js', 'MathZoom.js'" +
                "] } "
              +"});</script>"
            +"<script type='text/javascript' "
              +"src=\"file:///android_asset/MathJax/MathJax.js\""
              +"></script></head><body><span id='solve'></span></body></html>" ,"text/html","utf-8", "");
    }

两个呈现功能:

public static void RenderHTML(String html)
{       
        w.loadUrl("javascript:document.getElementById('solve').innerHTML += '" + html + "';");

}

public static void RenderMath(String tex)
{
    RenderHTML("\\\\[" + doubleEscapeTeX(tex) + "\\\\]");

    w.loadUrl("javascript:MathJax.Hub.Queue(['Typeset',MathJax.Hub]);");

}

1 个答案:

答案 0 :(得分:0)

这是4.4的完美解决方案:

  wq.getSettings().setJavaScriptEnabled(true);
            wq.getSettings().setBuiltInZoomControls(true);
            wq.getSettings().setLoadWithOverviewMode(true);
            wq.loadDataWithBaseURL("http://bar/", "<script type='text/x-mathjax-config'>"
                    +"MathJax.Hub.Config({ "
                    +"showMathMenu: false, "
                    +"jax: ['input/MathML','output/HTML-CSS'], " // output/SVG
                    +"extensions: ['mml2jax.js'], "
                    +"TeX: { extensions: ['noErrors.js','noUndefined.js'] }, "
                    //+"'SVG' : { blacker: 30, "
                    // +"styles: { path: { 'shape-rendering': 'crispEdges' } } } "
                    +"});</script>"
                    +"<script type='text/javascript' "
                    +"src='file:///android_asset/MathJax/MathJax.js'"
                    +"></script><span id='text'> </span> <span id='math'></span>", "text/html", "utf-8", "");





    if (android.os.Build.VERSION.SDK_INT < 19)
            {
                wq.loadUrl("javascript:document.getElementById('math').innerHTML='"
                    + "<math xmlns=\"http://www.w3.org/1998/Math/MathML\">"
                    + "<mstyle displaystyle=\"true\">"
                    + doubleEscapeTeX(questn+ans)
                    + "</mstyle></math>';");
                wq.loadUrl("javascript:MathJax.Hub.Queue(['Typeset',MathJax.Hub]);");
            }
            else
            {
                wq.evaluateJavascript("javascript:document.getElementById('math').innerHTML='<font color=\"#000000\">`"+doubleEscapeTeX(questn+ans)+"`</font>';",null);
                wq.loadUrl("javascript:MathJax.Hub.Queue(['Typeset',MathJax.Hub]);");
            }
相关问题