活动介绍

JavaFX在Web开发中的应用实践

立即解锁
发布时间: 2025-08-18 02:24:40 阅读量: 3 订阅数: 14
### JavaFX在Web开发中的应用实践 #### 1. 基于Yahoo天气服务的JavaFX应用 在开发JavaFX应用以获取Yahoo天气服务的XML信息时,我们可以按照以下步骤进行: 1. **获取本地天气的RSS URL**: - 打开浏览器,访问http://weather.yahoo.com/。 - 输入城市名或邮政编码,然后点击“Go”按钮。 - 点击网页右侧(“Add weather to your website”下方)橙色的小RSS按钮。 - 复制浏览器地址栏中的URL,用于天气应用代码中。例如:http://weather.yahooapis.com/forecastrss?p=USMD0033&u=f。 2. **创建JavaFX应用**: - **定义实例变量**:创建`ManipulatingHtmlContent`类时,需要两个实例变量`url`和`refreshCountdown`。`url`赋值为步骤4中获取的RSS URL,`refreshCountdown`类型为`int`,赋值为60,表示刷新或再次获取天气信息的时间间隔(秒)。 - **创建场景和WebEngine**:在`start()`方法中,首先创建`Scene`对象作为初始主内容区域,然后通过传入`url`创建`javafx.scene.web.WebEngine`实例,该对象将异步加载Yahoo天气服务的网页内容。 ```java final WebEngine webEngine = new WebEngine(url); ``` - **创建HTML模板**:使用`StringBuilder`创建HTML文档模板,用于后续网页内容的组装。 ```java StringBuilder template = new StringBuilder(); template.append("<head>\n") .append("<style type=\"text/css\">body {background-color:#b4c8ee;}</style>\n") .append("</head>\n") .append("<body id='weather_background'>"); ``` - **创建WebView对象**:创建`WebView`对象实例,用于渲染网页。`WebView`会有自己的`WebEngine`实例,我们使用`WebView`节点来渲染组装好的HTML网页,而通过`WebEngine`对象从Yahoo天气服务获取XML信息进行解析,再将解析结果传递给`WebView`显示为HTML。 ```java final WebView webView = new WebView(); ``` - **创建倒计时定时器**: - 实例化`IntegerProperty`变量`countdown`,用于保存到下一次刷新的剩余秒数。 - 添加`ChangeListener`,使用JavaFX执行JavaScript的能力动态更新HTML内容,并在倒计时为0时调用`webEngine`的`reload()`方法刷新天气信息。 ```java IntegerProperty countDown = new SimpleIntegerProperty(refreshCountdown); countDown.addListener(new ChangeListener<Number>() { @Override public void changed(ObservableValue<? extends Number> observable, Number oldValue, Number newValue){ webView.getEngine().executeScript("document.getElementById('countdown').innerHTML = 'Seconds till refresh: " + newValue + "'"); if (newValue.intValue() == 0) { webEngine.reload(); } } }); ``` - **更新倒计时**:使用`Timeline`对象更新`countDown`变量,触发`ChangeListener`更新HTML中显示的倒计时文本。 ```java final Timeline timeToRefresh = new Timeline(); timeToRefresh.getKeyFrames().addAll( new KeyFrame(Duration.ZERO, new KeyValue(countDown, refreshCountdown)), new KeyFrame(Duration.seconds(refreshCountdown), new KeyValue(countDown, 0)) ); ``` - **解析和显示天气数据**:当`webEngine`完成XML信息的获取后,使用`ChangeListener`解析并将组装好的网页内容渲染到`webView`节点中。 ```java if (newValue != State.SUCCEEDED) { return; } Weather weather = parse(webEngine.getDocument()); String countdownText = "<b id=\"countdown\"></b><br />\n"; webView.getEngine().loadContent(fullHtml + location.toString() + timeOfWeatherTextDiv + countdownText + weather.htmlDescription); ``` - **解析XML数据**:通过`webEngine`的`getDocument()`方法返回的`org.w3c.dom.Document`对象,使用`parse()`方法遍历DOM树获取天气数据,并返回`Weather`对象。 #### 2. 响应HTML事件 为天气应用添加额外功能,响应用户操作: 1. **问题描述**:担心同事忽略即将到来的风暴,想通过天气应用提醒他们带伞。 2. **解决方案**:在天气应用中添加“Panic Button”和“Calm Down”按钮,分别模拟邮件通知和撤销警告消息。 ```java @Override public void start(Stage stage) { // ... 模板构建代码 template.append("<body id='weather_background'>"); template.append("<form>\n"); template.append(" <input type=\"button\" onclick=\"alert('warning')\" value=\"Panic Button\" />\n"); template.append(" <input type=\"button\" onclick=\"alert('unwarning')\" value=\"Calm down\" />\n"); template.append("</form>\n"); // 创建警告消息,初始透明度为0,使其不可见 final Text warningMessage = createMessage(Color.RED, "warning: "); warningMessage.setOpacity(0); // ... 倒计时代码 // 当天气信息成功获取后,更新警告消息 webEngine.getLoadWorker().stateProperty().addListener(new ChangeListener<State>() { public void changed(ObservableValue<? extends State> observable, State oldValue, State newValue){ System.out.println("done!" + newValue.toString()); if (newValue != State.SUCCEEDED) { return; } Weather weather = parse(webEngine.getDocument()); warningMessage.setText("Warning: " + weather.currentWeatherText + "\nTemp: " + weather.temperature + "\n E-mailed others"); // ... 其余changed()方法代码 } }); // 设置OnAlert属性,处理按钮点击事件 webView.getEngine().setOnAlert(new EventHandler<WebEvent<String>>(){ public void handle(WebEvent<String> evt) { warningMessage.setOpacity("warning".equalsIgnoreCase(evt.getData()) ? 1d : 0d); } }); root.getChildren().addAll(webView, warningMessage); stage.setScene(scene); stage.show(); } private Text createMessage(Color color, String message) { DropShadow dShadow = DropShadowBuilder.create() .offsetX(3.5f) .offsetY(3.5f) .build(); Text textMessage = TextBuilder.create() .text(message) .x(100) .y(50) .strokeWidth(2) .stroke(Color.WHITE) .effect(dShadow) .fill(color) .font(Font.font(null, FontWeight.BOLD, 35)) .translateY(50) .build(); return textMessage; } ``` 其工作原理如下:使用`<input type=”button”>`标签添加按钮,并设置`onclick`属性调用JavaScript的`alert()`函数。当按钮被点击时,`alert()`函数会触发,通过`WebEngine`的`OnAlert`属性通知JavaFX,我们添加事件处理程序`EventHandler`来响应`WebEvent`对象,根据事件数据切换警告消息节点的透明度,从而显示或隐藏警告消息。 #### 3. 数据库内容显示(JavaFX RSS阅读器) 为了及时了解本地立法和科学新闻,我们可以创建一个JavaFX RSS阅读器,将RSS源URL存储在数据库中,后续进行检索。 1. **准备工作**:使用Apache的嵌入式数据库Derby,需要从http://db.apache.org/derby/derby_downloads.html 下载最新版本的软件,解压到指定目录。编译和运行代码时,需要更新IDE的类路径或环境变量,指向Derby库文件(derby.jar和derbytools.jar)。 2. **实现RSS阅读器**:以下是JavaFX实现RSS阅读器的代码: ```java package org.java7recipes.chapter20.recipe20_05; import java.util.*; import javafx.application.Application; import javafx.beans.value.*; import javafx.collections.ObservableList; import javafx.concurrent.Worker.State; import javafx.event.*; import javafx.geometry.*; import javafx.scene.*; import javafx.scene.control.*; import javafx.scene.input.*; import javafx.scene.layout.*; import javafx.scene.paint.Color; import javafx.scene.w ```
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

李_涛

知名公司架构师
拥有多年在大型科技公司的工作经验,曾在多个大厂担任技术主管和架构师一职。擅长设计和开发高效稳定的后端系统,熟练掌握多种后端开发语言和框架,包括Java、Python、Spring、Django等。精通关系型数据库和NoSQL数据库的设计和优化,能够有效地处理海量数据和复杂查询。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

机械臂三维模型的材料选择与应用:材质决定命运,选对材料赢未来

![机械臂三维模型的材料选择与应用:材质决定命运,选对材料赢未来](https://blogs.sw.siemens.com/wp-content/uploads/sites/2/2023/12/Inverse-Kinematics-1024x466.png) # 摘要 机械臂作为先进制造和自动化系统的重要组成部分,其三维模型设计和材料选择对提高机械臂性能与降低成本至关重要。本文从基础理论出发,探讨了机械臂三维模型设计的基本原则,以及材料选择对于机械臂功能和耐久性的关键作用。通过对聚合物、金属和复合材料在实际机械臂应用案例的分析,本文阐述了不同材料的特性和应用实例。同时,提出了针对机械臂材料

在线票务系统解析:功能、流程与架构

### 在线票务系统解析:功能、流程与架构 在当今数字化时代,在线票务系统为观众提供了便捷的购票途径。本文将详细解析一个在线票务系统的各项特性,包括系统假设、范围限制、交付计划、用户界面等方面的内容。 #### 系统假设与范围限制 - **系统假设** - **Cookie 接受情况**:互联网用户不强制接受 Cookie,但预计大多数用户会接受。 - **座位类型与价格**:每场演出的座位分为一种或多种类型,如高级预留座。座位类型划分与演出相关,而非个别场次。同一演出同一类型的座位价格相同,但不同场次的价格结构可能不同,例如日场可能比晚场便宜以吸引家庭观众。 -

响应式Spring开发:从错误处理到路由配置

### 响应式Spring开发:从错误处理到路由配置 #### 1. Reactor错误处理方法 在响应式编程中,错误处理是至关重要的。Project Reactor为其响应式类型(Mono<T> 和 Flux<T>)提供了六种错误处理方法,下面为你详细介绍: | 方法 | 描述 | 版本 | | --- | --- | --- | | onErrorReturn(..) | 声明一个默认值,当处理器中抛出异常时发出该值,不影响数据流,异常元素用默认值代替,后续元素正常处理。 | 1. 接收要返回的值作为参数<br>2. 接收要返回的值和应返回默认值的异常类型作为参数<br>3. 接收要返回

【电路设计揭秘】:5个技巧彻底理解电路图的奥秘

![【电路设计揭秘】:5个技巧彻底理解电路图的奥秘](https://electronics.koncon.nl/wp-content/uploads/2020/09/all_components-1-1024x506.jpg) # 摘要 电路图与电路设计是电子工程领域的基石,本文全面概述了电路图的基础知识、核心理论以及设计实践技巧。从电路图基础知识开始,逐步深入到电路设计的核心理论,包括基本电路元件特性、电路理论基础和仿真软件应用。在实践技巧方面,本文介绍了电路图绘制、测试与调试、PCB设计与制造的关键点。进一步探讨了模拟电路与数字电路的区别及应用、电源电路设计优化、微控制器的电路设计应用

【Nokia 5G核心网运维自动化】:提升效率与降低错误率的6大策略

![5g核心网和关键技术和功能介绍-nokia.rar](https://www.viavisolutions.com/sites/default/files/images/diagram-sba.png) # 摘要 随着5G技术的快速发展,其核心网运维面临一系列新的挑战。本文首先概述了5G核心网运维自动化的必要性,然后详细分析了Nokia 5G核心网架构及其运维挑战,包括组件功能、架构演变以及传统运维的局限性。接着,文章探讨了自动化策略的基础理论与技术,包括自动化工具的选择和策略驱动的自动化设计。重点介绍了Nokia 5G核心网运维自动化策略实践,涵盖网络部署、故障诊断与性能优化的自动化实

并发编程:多语言实践与策略选择

### 并发编程:多语言实践与策略选择 #### 1. 文件大小计算的并发实现 在并发计算文件大小的场景中,我们可以采用数据流式方法。具体操作如下: - 创建两个 `DataFlowQueue` 实例,一个用于记录活跃的文件访问,另一个用于接收文件和子目录的大小。 - 创建一个 `DefaultPGroup` 来在线程池中运行任务。 ```plaintext graph LR A[创建 DataFlowQueue 实例] --> B[创建 DefaultPGroup] B --> C[执行 findSize 方法] C --> D[执行 findTotalFileS

AWSLambda冷启动问题全解析

### AWS Lambda 冷启动问题全解析 #### 1. 冷启动概述 在 AWS Lambda 中,冷启动是指函数实例首次创建时所经历的一系列初始化步骤。一旦函数实例创建完成,在其生命周期内不会再次经历冷启动。如果在代码中添加构造函数或静态初始化器,它们仅会在函数冷启动时被调用。可以在处理程序类的构造函数中添加显式日志,以便在函数日志中查看冷启动的发生情况。此外,还可以使用 X-Ray 和一些第三方 Lambda 监控工具来识别冷启动。 #### 2. 冷启动的影响 冷启动通常会导致事件处理出现延迟峰值,这也是人们关注冷启动的主要原因。一般情况下,小型 Lambda 函数的端到端延迟

ApacheThrift在脚本语言中的应用

### Apache Thrift在脚本语言中的应用 #### 1. Apache Thrift与PHP 在使用Apache Thrift和PHP时,首先要构建I/O栈。以下是构建I/O栈并调用服务的基本步骤: 1. 将传输缓冲区包装在二进制协议中,然后传递给服务客户端的构造函数。 2. 构建好I/O栈后,打开套接字连接,调用服务,最后关闭连接。 示例代码中的异常捕获块仅捕获Apache Thrift异常,并将其显示在Web服务器的错误日志中。 PHP错误通常在Web服务器的上下文中在服务器端表现出来。调试PHP程序的基本方法是检查Web服务器的错误日志。在Ubuntu 16.04系统中

Clojure多方法:定义、应用与使用场景

### Clojure 多方法:定义、应用与使用场景 #### 1. 定义多方法 在 Clojure 中,定义多方法可以使用 `defmulti` 函数,其基本语法如下: ```clojure (defmulti name dispatch-fn) ``` 其中,`name` 是新多方法的名称,Clojure 会将 `dispatch-fn` 应用于方法参数,以选择多方法的特定实现。 以 `my-print` 为例,它接受一个参数,即要打印的内容,我们希望根据该参数的类型选择特定的实现。因此,`dispatch-fn` 需要是一个接受一个参数并返回该参数类型的函数。Clojure 内置的

编程中的数组应用与实践

### 编程中的数组应用与实践 在编程领域,数组是一种非常重要的数据结构,它可以帮助我们高效地存储和处理大量数据。本文将通过几个具体的示例,详细介绍数组在编程中的应用,包括图形绘制、随机数填充以及用户输入处理等方面。 #### 1. 绘制数组图形 首先,我们来创建一个程序,用于绘制存储在 `temperatures` 数组中的值的图形。具体操作步骤如下: 1. **创建新程序**:选择 `File > New` 开始一个新程序,并将其保存为 `GraphTemps`。 2. **定义数组和画布大小**:定义一个 `temperatures` 数组,并设置画布大小为 250 像素×250 像