JavaFX UI控件教程(二)之JavaFX UI控件

翻译自  JavaFX UI控件 

本章概述了通过API提供的JavaFX UI控件。

JavaFX UI控件是使用场景图中的节点构建的。因此,控件可以使用JavaFX平台的视觉丰富功能。由于JavaFX API完全用Java实现,因此您可以轻松地将JavaFX UI控件集成到现有的Java应用程序中。

图1-1显示了您可以在Ensemble示例应用程序中找到的典型UI控件。尝试使用此应用程序来评估各种控件,它们的行为和可用样式。

图1-1 JavaFX UI控件

 

JavaFX 2中支持的UI控件

构造UI控件的类驻留在javafx.scene.controlAPI 的包中。

UI控件列表包括您可能从之前使用Java开发的客户端应用程序中识别的典型UI组件。然而,JavaFX的2 SDK引入了新的Java UI控件,如TitledPaneColorPicker,Pagination

图1-2显示了三个TitledPane元素的屏幕截图,其中包含社交网络应用程序的设置列表。列表可以滑入(缩进)和滑出(扩展)。

图1-2标题窗格

有关UI控件的完整列表,请参阅API文档。

UI控件类提供了除类之外的其他变量和方法Control,以直观的方式支持典型的用户交互。您可以通过应用层叠样式表(CSS)为UI组件指定特定样式。对于某些异常任务,您可能需要扩展Control类以创建自定义UI组件,或使用该Skin界面为现有控件定义新外观。

特点和效果

由于javafx.scene.control包中的UI控件都是Node类的扩展,因此可以将它们与场景图渲染,动画,转换和动画过渡集成在一起。

考虑创建按钮,对其应用反射以及通过将其不透明度从其最大值更改为其最小值来设置动画的任务。

图1-3显示了通过动画时间轴的按钮的三种状态。左侧图像显示不透明度设置为时的按钮1.0,中央图像显示不透明度设置为0.8,右侧图像显示不透明度设置为0.5

图1-3动画按钮

通过使用JavaFX API,您只需几行代码即可实现此任务。

示例1-1创建并启动一个不确定的时间轴,其中在600毫秒的关键帧内,按钮的不透明度从其默认值(1.0)变为0.0。该setAutoReverse方法启用相反的顺序。

示例1-1创建动画按钮

import javafx.animation.KeyFrame;
import javafx.animation.KeyValue;
import javafx.animation.Timeline;
import javafx.util.Duration;
import javafx.scene.control.Button;
import javafx.scene.text.Font;
import javafx.scene.effect.Reflection;...
Button button = new Button();button.setText("OK");button.setFont(new Font("Tahoma", 24));button.setEffect(new Reflection());final Timeline timeline = new Timeline();
timeline.setCycleCount(Timeline.INDEFINITE);
timeline.setAutoReverse(true);
final KeyValue kv = new KeyValue(button.opacityProperty(), 0);
final KeyFrame kf = new KeyFrame(Duration.millis(600), kv);
timeline.getKeyFrames().add(kf);
timeline.play();
...

您还可以应用javafx.scene.effect包中可用的其他视觉效果,例如阴影,光照或运动模糊。

使用CSS设置UI控件样式

您可以通过定义自己的层叠样式表(CSS)来自定义内置UI控件的外观。在JavaFX应用程序中使用CSS与在HTML中使用CSS非常相似,因为每种情况都基于相同的CSS规范。控件的可视状态由.css文件定义,如例1-2所示。

示例1-2在CSS文件中定义UI控件的样式

/*controlStyle.css */.scene{-fx-font: 14pt "Cambria Bold";-fx-color: #e79423;-fx-background: #67644e;
}.button{-fx-text-fill: #006464;-fx-background-color: #e79423;-fx-border-radius: 20;-fx-background-radius: 20;-fx-padding: 5;
}

您可以通过类的getStylesheets方法在应用程序中启用样式Scene,如例1-3所示。

示例1-3应用CSS

Scene scene = new Scene();
scene.getStylesheets().add("uicontrolssample/controlStyle.css");

此外,您可以使用该setStyle方法直接在应用程序的代码中定义控件的样式。-fx-base为示例1-4中的切换按钮定义的属性将覆盖.css文件中为添加到场景的所有控件定义的相应属性。

示例1-4在JavaFX应用程序中定义切换按钮的样式

ToggleButton tb3 = new ToggleButton ("I don't know");
tb3.setStyle("-fx-base: #ed1c24;");

图1-4显示了样式化切换按钮在添加到应用程序时的外观。

图1-4将CSS样式应用于切换按钮

图表

除了用户界面的典型元素之外,JavaFX SDK还在javafx.scene.chart包中提供预制图表。目前支持以下类型的图表:面积图,条形图,气泡图,折线图,饼图和散点图。图表可能包含几个系列的数据。

图1-5显示了导入水果的饼图。

图1-5饼图

与其他Java客户端工具包不同,使用JavaFX SDK,您可以通过添加几行代码在应用程序中构建这样的图表。您还可以定义各种颜色方案和样式,应用视觉效果,处理鼠标事件以及创建动画。

有关图表功能的更多信息,请参阅使用JavaFX图表。

在Swing中集成JavaFX 2 UI控件

您可以将JavaFX UI控件集成到基于Swing工具包构建的现有Java客户端应用程序中。

要将JavaFX内容集成到Swing应用程序中,请使用以下步骤: 

  1. 将所有JavaFX UI控件javafx.scene.Scene逐个添加到对象中,在布局容器中或作为一个组添加。

  2. Scene对象添加到Swing应用程序的内容中。

如果需要在现有Swing代码中放置单个JavaFX 2控件,则必须执行上述两个步骤。

即使将它们集成到Swing应用程序中,JavaFX 2 UI控件仍然使用Prism图形库进行渲染,并充分利用其高级渲染功能。

有关JavaFX和Swing互操作性的更多信息,请参阅Swing教程中的JavaFX。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325136.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaFX UI控件教程(三)之Label

翻译自 Label 本章介绍如何使用Label驻留在javafx.scene.controlJavaFX API包中的类来显示文本元素。了解如何包装文本元素以适合特定空间,添加图形图像或应用视觉效果。 图2-1显示了三种常见的标签用法。左侧的标签是带有图像的文本元素,中间的标签表…

asp.net core中负载均衡场景下http重定向https的问题

上周欣喜地发现,微软官方终于针对 asp.net core 在使用负载均衡的情况下从 http 强制重定向至 https 的问题提供了解决方法。 app.UseForwardedHeaders(new ForwardedHeadersOptions {ForwardedHeaders ForwardedHeaders.XForwardedProto });var options new Rew…

JavaFX UI控件教程(四)之Button

翻译自 Button Button通过JavaFX API提供的类使开发人员能够在用户单击按钮时处理操作。该Button班是的扩展Labeled类。它可以显示文本,图像或两者。图3-1显示了具有各种效果的按钮。在本章中,您将学习如何创建这些按钮类型。 图3-1按钮类型 创建一个按…

.Net Core应用搭建的分布式邮件系统设计

本篇分享的是由NetCore搭建的分布式邮件系统,主要采用NetCore的Api和控制台应用程序,由于此系统属于公司的所以这里只能分享设计图和一些单纯不设计业务的类或方法; 为什么要在公司中首例采用NetCore做开发 为什么要在公司中首例采用NetCore…

JavaFX UI控件教程(五)之Radio Button

翻译自 Radio Button 本章讨论单选按钮控件和RadioButton类,该类的一个专门实现ToggleButton。 可以选择或取消选择单选按钮控件。通常,单选按钮组合成一个组,其中一次只能选择一个按钮。此行为将它们与切换按钮区分开来,因为组…

.NET开源MSSQL、Redis监控产品Opserver之Redis配置

Redis监控数据实例的加载可以查看Opserver.Core项目data/Redis文件夹下的RedisModule.cs,我加了点注释 /// <summary>/// 加载Redis连接 /// </summary>/// <returns></returns>private static List<RedisConnectionInfo> LoadRedisConn…

使用变量注意事项

Java中每个变量必须先声明&#xff0c;后使用(否则会编译失败) 使用变量名来访问这块区域的数据 变量的作用域&#xff1a;其定义所在的一对{ }内 变量只有在其作用域内才有效 同一个作用域内&#xff0c;不能定义重名的变量

JavaFX UI控件教程(六)之Toggle Button

翻译自 Toggle Button 在本章中&#xff0c;您将了解ToggleButton该类&#xff0c;这是通过JavaFX API提供的另一种类型的按钮。 可以将两个或多个切换按钮组合成一个组&#xff0c;其中一次只能选择一个按钮&#xff0c;或者不需要选择。图5-1是组合了三个切换按钮的应用程…

窥探ASP.Net MVC底层原理 实现跨越Session的分布式TempData

Hi,guys!Long time no see! 1、问题的引出 我相信大家在项目中都使用过TempData&#xff0c;TempData是一个字典集合&#xff0c;一般用于两个请求之间临时缓存数据或者页面之间传递消息。也都知道TempData是用Session来实现的&#xff0c;既然是用Session来实现的&#xff0…

某同学正为自己安装不上sqlserver数据库而愁眉苦脸,使用朋友给的方法顿时喜笑颜开,那么朋友到底出了个什么样的方法呢?...

小故事引入&#xff1a;张同学下一节课就要开始学习使用jdbc访问Sql Server数据库了&#xff0c;部分同学由于刚换电脑&#xff0c;导致没有安装数据库&#xff0c;于是同学们按照老师给的方法&#xff08;文末提供老师的方法&#xff09;&#xff0c;将5G多的Sqlserver的安装包…

JavaFX UI控件教程(七)之Checkbox

翻译自 Checkbox 本章教授如何向JavaFX应用程序添加复选框。 虽然复选框看起来类似于单选按钮&#xff0c;但它们不能组合到切换组中以便一次选择多个选项。有关详细信息&#xff0c;请参阅单选按钮和切换按钮章节。 图6-1显示了一个应用程序的屏幕截图&#xff0c;其中三…

.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结(一)

我们知道Kafka支持Consumer Group的功能&#xff0c;但是最近在应用Consumer Group时发现了一个Topic 的Partition不能100%覆盖的问题。 程序部署后&#xff0c;发现Kafka在pdb组的consumer消费topic时存在问题&#xff0c;consumer无法完全覆盖Topic的各个partition。如下图&…

JavaFX UI控件教程(八)之Choice Box

翻译自 Choice Box 本章介绍了选项框&#xff0c;这些UI控件提供了在几个选项之间快速选择的支持。 使用ChoiceBox该类将选择框添加到JavaFX应用程序。其简单的实现如图7-1所示。 图7-1创建包含三个项目的选择框 创建一个选择框 例7-1创建了一个包含三个项目的选择框。 例…

View Components as Tag Helpers,离在线模板编辑又进一步

在asp.net core mvc中增加了ViewComponent&#xff08;视图组件&#xff09;的概念&#xff0c;视图组件有点类似部分视图&#xff0c;但是比部分视图功能更加强大&#xff0c;它更有点像一个控制器。 使用方法 1&#xff0c;定义类派生自ViewComponent类 2&#xff0c;增加…

JavaFX UI控件教程(九)之Text Field

翻译自 Text Field 本章讨论文本字段控件的功能。 的TextField类实现接受并显示文本输入的UI控制。它提供了从用户接收文本输入的功能。与另一个文本输入控件一起&#xff0c;PasswordField此类扩展了TextInput类&#xff0c;它是通过JavaFX API提供的所有文本控件的超类。…

VS

&—逻辑与 | —逻辑或 &#xff01;—逻辑非 && —短路与 || —短路或 ^ —逻辑异或

ssl1643-最小乘车费用【dp练习】

最小乘车费用 题目 假设某条街上每一公里就有一个公共汽车站&#xff0c;并且乘车费用如下表&#xff1a;      而任意一辆汽车从不行驶超过10公里。某人想行驶n公里&#xff0c;假设他可以任意次换车&#xff0c;请你帮他找到一种乘车方案&#xff0c;使得总费用最小 …

JavaFX UI控件教程(十)之Scroll Bar

翻译自 Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格。 本ScrollBar类可以在应用程序中创建滚动窗格和意见。图9-1显示了滚动条的三个区域&#xff1a;拇指&#xff0c;右侧和左侧按钮&#xff08;或向下和向上按钮&#xff09;以及轨道。 图9-1滚动条的元素 创建…