2

该网页使用了我的 PC 上未安装的自定义字体。在这种情况下,WebView 似乎使用操作系统的默认字体。

但我有字体文件“xx.ttf”。如何将字体嵌入到我的应用程序中并告诉 WebView 使用它来识别页面上的字体?

4

1 回答 1

9

加载字体:

Font.loadFont(
  CustomFontWebView.class.getResource("TRON.TTF").toExternalForm(), 
  10
);

在 WebView 中使用它之前:

style='font-family:"TRON"';

这是一个完整的例子。该示例依赖于您可以从 dafont 下载的 TRON.TTF字体。下载 TRON.TTF 字体后,将其放在与 CustomFontWebView.java 相同的目录中,并确保您的构建系统将 TRON.TTF 文件复制到类输出目录。

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.text.Font;
import javafx.scene.web.WebView;
import javafx.stage.Stage;

// demonstrates the use of a custom font in a WebView.
public class CustomFontWebView extends Application {
  public static void main(String[] args) { launch(args); }
  @Override public void start(Stage stage) {
    stage.setTitle("TRON Synopsis");

    // load the tron font.
    Font.loadFont(
      CustomFontWebView.class.getResource("TRON.TTF").toExternalForm(), 
      10
    );

    // use the tron font in a WebView.
    WebView webView = new WebView();
    webView.getEngine().loadContent(
      "<body bgcolor='silver'>" +   
        "<div align='center'>" +   
          "<p style='font-family:'TRON'; font-size:20;'>" +                 "TRON" + 
          "</p>" +
          "<img src='http://ia.media-imdb.com/images/M/MV5BMTY5NjM2MjAwOV5BMl5BanBnXkFtZTYwMTgyMzA5.V1.SY317.jpg' width='259' height='457'/>" + 
          "<p style='font-family:'TRON'; font-size:10;'>" + 
            "A sci-fi flick set in an alternate reality." + 
          "</p>" +
        "</div>" +   
      "</body>"
    );

    // layout the scene.
    final Scene scene = new Scene(webView, 400, 575);
    stage.setScene(scene);
    stage.show();
  }
}

创

关于微软雅黑字体的具体使用

Microsoft YaHei 适合我(Windows 7)。我的 Win7 安装附带字体(并且无法删除),因此不需要显式加载 - 只需从您的 html 中引用正确的字体系列,它就适用于这样的 Win7 安装。我有一个标准的美版Win7 Pro,不是中文版。我确实将 msyh.ttf 文件从我的 windows/fonts 目录复制到我的项目中并通过 JavaFX 加载它只是为了确保通过 JavaFX 加载工作并且也工作正常。我用来设置 html 样式 css 字体系列说明符的字体系列是“Microsoft YaHei”(而不是上面答案示例中使用的 TRON)。我为了测试它而显示的文本是微软雅黑,我将 JavaFX 应用程序呈现的文本与选择 Microsoft YaHei 的写字板中呈现的相同文本进行了比较,字形相同。


请注意,使用 JavaFX 3.0,您似乎可以使用css @font-face机制,这意味着您可以在网页的 css 中声明字体引用,而不是像我在上面的示例中那样在 Java 代码中声明。这是相关 jira 问题的链接,用于跟踪此功能的实施进度。

于 2012-07-06T00:00:26.237 回答