使用getResource获取本地图片资源的位置。
editor.setHtmlText(
"<img src=\"" +
getClass().getResource("categoryButton.fw.png") +
"\" width=\"32\" height=\"32\" >"
);
它的工作方式与将内容加载到WebView中的方式相同,如下所示:
如何从 javafx.scene.web.WebEngine#loadContent 加载的 html 页面访问 css 和图像文件?
这是一个屏幕截图:
还有一个可执行示例:
import javafx.application.*;
import javafx.scene.Scene;
import javafx.scene.web.HTMLEditor;
import javafx.stage.Stage;
public class HTMLEditorWithImage extends Application {
@Override public void start(Stage stage) {
HTMLEditor editor = new HTMLEditor();
editor.setHtmlText(
"<img src=\"" +
getClass().getResource("Blue-Fish-icon.png") +
"\" width=\"32\" height=\"32\" >"
);
stage.setScene(new Scene(editor));
stage.show();
}
public static void main(String[] args) { launch(args); }
}
我只是好奇这是否是将图像放入某种文本区域的唯一方法?
- 使用 JavaFX 2,您可以将与文本混合的图像嵌入到FlowPane中,如Javafx Text multi-word colorization 中所述。
- Java 8 添加了一个TextFlow组件,它允许您将图像嵌入到文本区域中。
以上两种技术仅用于数据显示。两者都不允许编辑插入图像和其他节点的多样式文本。目前,JavaFX 平台为此功能提供的唯一控件是HTMLEditor或具有contenteditable true的WebView或用 JavaScript 编写的嵌入式3rd 方编辑器。
已经有一些第 3 方努力使用不依赖于 WebView 或 HTMLEditor 的本机 JavaFX 构造创建样式化文本编辑器,但截至今天,我认为还没有准备好广泛使用。