JavaFX学习之Web

PopupFeatures 处理新窗口 
   WebHistory 
网页一般都带有历史记录的功能,可以回退,也可以前进,fx用WebHistory处理。

Java代码  

  1. final WebHistory wh = webEngine.getHistory();   //获取webhistory
  2. go(int offset)   //跳到相对应的页,一般-1是后退,1是前进
  3. getCurrentIndex()  //获取当前页索引,开始页索引为0,点击进入下一页此时为1。

WebView WebEngin 
WebView作为一个node用于显示网页内容

Java代码  

  1. WebView webView = new WebView();

WebEngine用于对网页的操作,通过webView获取web引擎

Java代码  

  1. WebEngine webEngine = webView.getEngine();

WebEngine的一些方法

Java代码  

  1. webEngine.load(java.lang.String url);  //加载一个网页
  2. webEngine.executeScript(java.lang.String script)  //执行网页中的脚本语言

看个demo

Java代码  

  1. public void init(Group root){
  2. VBox box = new VBox();
  3. WebView webView = new WebView();
  4. final WebEngine webEngine = webView.getEngine();
  5. webEngine.load("http://forums.oracle.com/forums/");
  6. box.getChildren().add(webView);
  7. Button button = new Button("showAll");
  8. button.setOnAction(new EventHandler<ActionEvent>() {
  9. @Override
  10. public void handle(ActionEvent arg0) {
  11. webEngine.executeScript("showAll()");
  12. }
  13. });
  14. box.getChildren().add(button);
  15. root.getChildren().add(box);
  16. }

这里要注意的是,脚本必须是你网页中存在的。

可以在Application中执行网页中的脚本,那么也可以在网页脚本中执行Application方法

Java代码  

  1. JSObject win = (JSObject) webEngine.executeScript("window");  获取js对象
  2. win.setMember("app", new JavaApp()); 然后把应用程序对象设置成为js对象
  3. private class JavaApp {
  4. public void exit() {
  5. Platform.exit();
  6. }
  7. public void login(){
  8. System.out.println("login...");
  9. }
  10. }

此时在页面可以调用

Java代码  

  1. <a href="about:blank" onclick="app.exit()">Exit the Application</a>

在网页上右键点击的时候,可以选择在新窗口打开,此时你必须自己设定。

Java代码  

  1. setCreatePopupHandler(Callback<PopupFeatures,WebEngine> handler)  //处理弹出窗口。
  2. webEngine.setCreatePopupHandler(
  3. new Callback<PopupFeatures, WebEngine>() {
  4. @Override public WebEngine call(PopupFeatures config) {
  5. return newWebView.getEngine();
  6. }
  7. }
  8. );

网页是通过WebView显示的,所以当你需要一个新窗口时,你必须弄一个新的webView,并为该webview设置好显示的位置,然后在上面的代码中获取该webview的webengine返回。

发现加载web页面需要一段时期,此时application的一些节点显示出来了,若是想让节点显示和web一起显示,则可以监听webEngine的状态属性。

Java代码  

  1. webEngine.getLoadWorker().stateProperty().addListener(
  2. new ChangeListener<State>() {
  3. @Override
  4. public void changed(ObservableValue<? extends State> ov,
  5. State oldState, State newState) {
  6. if (newState == State.SUCCEEDED) {
  7. //添加节点,或者把app注入到网页脚本当中
  8. }
  9. }
  10. }
  11. );

看个demo:

Java代码  

  1. public void init(Group root){
  2. final TabPane tp = new TabPane();
  3. WebView webView = new WebView();
  4. System.out.println(root.getScene());
  5. webView.prefWidthProperty().bind(root.getScene().widthProperty());
  6. webView.prefHeightProperty().bind(root.getScene().heightProperty());
  7. final WebEngine webEngine = webView.getEngine();
  8. webEngine.load("http://forums.oracle.com/forums/");
  9. webEngine.setCreatePopupHandler(new Callback<PopupFeatures, WebEngine>() {
  10. @Override
  11. public WebEngine call(PopupFeatures arg0) {
  12. WebView newWebView = new WebView();
  13. WebEngine newWebEngine = newWebView.getEngine();
  14. Tab tab = new Tab("new Window");
  15. tab.textProperty().bind(newWebEngine.titleProperty());
  16. tab.setContent(newWebView);
  17. tp.getTabs().add(tab);
  18. return newWebEngine;
  19. }
  20. });
  21. final Tab tab = new Tab();
  22. tab.textProperty().bind(webEngine.titleProperty());
  23. tab.setContent(webView);
  24. // process page loading
  25. webEngine.getLoadWorker().stateProperty().addListener(
  26. new ChangeListener<State>() {
  27. @Override
  28. public void changed(ObservableValue<? extends State> ov,
  29. State oldState, State newState) {
  30. if (newState == State.SUCCEEDED) {
  31. tp.getTabs().add(tab);
  32. }
  33. }
  34. }
  35. );
  36. root.getChildren().add(tp);
  37. }

原文:http://lujin55.iteye.com/blog/1747187

官方文档:http://docs.oracle.com/javafx/2/api/index.html

JavaFX学习之Web

时间: 2024-11-08 12:14:29

JavaFX学习之Web的相关文章

JavaFx学习之道:JavaFx初步了解

因为项目的需要,实在是没有办法了,试了很多种方案(RCP,SWT,Flex,Smartinvoke...),最终还是决定开始研究JavaFx...为了给用户更好地体验我们的"智能家居"! 以下是最近搜索得到的一些资料: 1.Oracle 上 JavaFx的下载页面:http://www.oracle.com/technetwork/java/javafx/overview/index.html 目前最新版本的SDK是2.1 JavaFX 2.1 Developer Preview -

JavaFX学习之道:FXML入门

FXML是JavaFX 2.0提供的新技术.你可能会问"什么是FXML?","对我来说有什么用?". FXML是一种在JavaFX应用程序中定义用户界面的,基于XML的声明性标记语言.FXML非常适合用来静态布局,如表单.控件和表格.使用FXML,您还可以通过脚本动态地构建布局. FXML的优势之一是基于XML,是大多数开发人员所熟悉的,尤其是Web开发人员和使用其他RIA平台的开发人员.另一个优点是,FXML是不是编译语言,你不需要重新编译代码就可看到您所做的更改

JavaFX学习之道:详解JavaFX架构与框架

JavaFX 2.0平台是基于Java技术的富客户端平台.它使应用程序开发者更加容易的开发和部署跨平台的富互联网应用(RIA).JavaFX 2.0文档包含了JavaFX 2.0所提供的功能的概述. 图1描述了JavaFX 2.0平台的架构组件.后面的部分将对每一个组件进行逐一的描述.在JavaFX通用API的下面是用来运行JavaFX代码的引擎.这个引擎包括以下子组件:JavaFX高性能图形引擎(Prism);新的更小但更有效率的窗体系统(Glass);媒体引擎和Web引擎.虽然这些组件不是包

JavaFX学习之道:文本Text及其特效

原文地址http://download.oracle.com/javafx/2.0/text/jfxpub-text.htm 文本讲述如何在JavaFX2.0应用中加入文本和如何为文本提供花俏的效果. 引子 JavaFX 2.0应用的图形内容包含一些对象,它们被组织在一个成为场景图的类树结构中.场景图中的每个元素成为一个结点,结点可以管理很多不同种类的内容,包括文本.结点可以转换和移动,也可以应用多种效果.为所有结点类型使用共同特点使得可以提供复杂的文本内容来满足现在的富网络应用(RIAs).

JavaFX学习之道:JavaFX之TableView

TableView表 TableColumn列 构建一个表主要有TableView,TableColumn,ObservableList,Bean. 添加列table.getColumns().addAll(firstNameCol, lastNameCol, emailCol); ObservableList里面是存放的数据 table.setItems(observableList);添加数据 observableList里面一般是存放的Bean,列与Bean之间建立联系,从而获取值. 列与

Gradle学习(四) web工程构建

Gradle为应用开发提供了两个相关的插件:war plugin以及jetty plugin war plugin继承了java plugin为你的工程构建war包,jetty pugin继承了war plugin可以让的工程构建在嵌入式容器jetty中 构建War文件 首先在你的build.gradle中添加如下一行 apply plugin: 'war' 由于war plugin继承了java plugin,所有java plugin也会被默认的加入配置文件中 运行gradle build命

HTML学习之Web存储(五)

本地数据库功能大大增强了Web应用对于本地存储数据的方式和功能.Web时代真正进入了:“客户端为重,服务端为轻的时代”. <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <

(asp.net MVC学习)System.Web.Mvc.HtmlHelper学习及使用

在ASP.NET MVC框架中没有了自己的控件,页面显示完全就回到了写html代码的年代.还好在asp.net mvc框架中也有自带的HtmlHelper和UrlHelper两个帮助类.另外在MvcContrib扩展项目中也有扩展一些帮助类,这样我们就不光 只能使用完整的html来编写了需要显示的页面了,就可以使用这些帮助类来完成,但最后运行时都还是要生成html代码的. 先来看看HtmlHelper能帮我们生成一些什么样的html呢.直接看效果吧. <div>          1.使用Ht

零基础如何系统学习Java Web

零基础如何系统学习Java Web? 我来给你说一说 你要下决心,我要转行做开发,这样你才能学成. 你要会打字,我公司原来有一个程序员,打字都是两个手一指禅,身为程序员你一指禅怎么写出的代码,半个月后被辞退了,当然我们还是朋友. 前两个条件都符合了你就可以学了,首先要了解web是什么,一般呢,java web开发无外乎就这么两大类,第一,互联网公司,第二,软件公司.对于互联网公司和软件公司还有一些差别,互联公司是面向广大网民的,会有专门的ui设计,前台开发,后台代码开发,ios开发,androi