MathML标记在JavaFX WebView中无法正确呈现

问题描述 投票:2回答:1

MathML标记在JavaFX WebView中无法正确呈现

JDK版本:1.8.0_192

例如,

<math xmlns="http://www.w3.org/1998/Math/MathML"> 
   <msub> 
    <mi>
      S 
    </mi> 
    <mi>
      n 
    </mi> 
   </msub> 
   <mo>
     &lt; 
   </mo> 
   <mstyle displaystyle="true" scriptlevel="0"> 
    <mfrac> 
     <mi>
       π 
     </mi> 
     <mrow> 
      <mn>
        3 
      </mn>     
      <msqrt> 
       <mn>
         3 
       </mn> 
      </msqrt> 
     </mrow> 
    </mfrac> 
   </mstyle> 
 </math>

上面的代码呈现为:

Chrome rendering

在谷歌浏览器中,它呈现为:

WebView version

在JavaFX WebView中。

如何解决这个问题?

javafx java-8 javafx-8 mathml javafx-webengine
1个回答
3
投票

我的计算机上的结果与您发布的代码? ?

Screenshot CaptainIRS MathML Code

首先,请确保您至少使用Java / JavaFX 8 192 build 04或JavaFX 11(MathML支持已损坏,在Java / JavaFX 9和10中,并且不会在这些版本中修复)。

其次,验证您的字体列表。可能是您计算机上的字体配置问题?

必须至少安装其中一种字体(按优先顺序排列):

  • Latin Modern Math
  • STIX Two Math
  • XITS Math
  • STIX Math
  • Libertinus Math
  • TeX Gyre Termes Math
  • TeX Gyre Bonum Math
  • TeX Gyre Schola
  • DejaVu Math TeX Gyre
  • TeX Gyre Pagella Math
  • Asana Math
  • Cambria Math
  • Lucida Bright Math
  • Minion Math
  • Times New Roman

结果在我的电脑上,但在Latin Modern Math字体安装后:

enter image description here

代码示例:你使用这样的代码吗?

import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.StackPane;
import javafx.scene.web.WebView;
import javafx.stage.Stage;

public class NavigateurTest extends Application {

    final StackPane root = new StackPane();
    final WebView webView =  new WebView();
    String ContentStackOverFlow = ""
            + "<math xmlns=\"http://www.w3.org/1998/Math/MathML\">"
            + "   <msub>"
            + "      <mi>S</mi>"
            + "      <mi>n</mi>"
            + "   </msub>"
            + "   <mo>&lt;</mo>"
            + "   <mstyle displaystyle=\"true\" scriptlevel=\"0\">"
            + "      <mfrac>"
            + "         <mi>π</mi>"
            + "         <mrow>"
            + "            <mn>3</mn>"
            + "            <msqrt>"
            + "               <mn>3</mn>"
            + "            </msqrt>"
            + "         </mrow>"
            + "      </mfrac>"
            + "   </mstyle>"
            + "</math>";

    public void init() {    
        root.getChildren().add(webView);
    }

    @Override
    public void start(Stage primaryStage) {

        //webView.getEngine().load("https://www.qwant.com");
        webView.getEngine().loadContent(ContentStackOverFlow);

        primaryStage.setTitle("OpenJFX MathML Rendering WebBrowser Test");
        primaryStage.setScene(new Scene(root));
        primaryStage.show();

    }

}
© www.soinside.com 2019 - 2024. All rights reserved.