javafx 项目

因此, Java 9可能会破坏您的代码 ……

如果您的项目使用JavaFX,则这尤其可能,因为许多自定义和自制控件都需要使用内部API。 借助Project Jigsaw,这些内容将无法在Java 9中访问。幸运的是, Oracle在几天前宣布了 JEP 253 。 其目标:

为JavaFX UI控件和CSS功能定义公共API,这些公共API当前仅可通过内部API使用,因此由于模块化而变得不可访问。

JEP 253 – 2015年5月14日

让我们看一下JavaFX,Jigsaw项目和JEP 253是如何交互的。

总览

为了更好地了解内部API在JavaFX中的作用,了解其控制体系结构将很有帮助,因此我们将从此开始。 然后,我们将研究为什么在使用JavaFX时经常使用内部API。 这将有助于将新的JEP置于上下文中。

因为我熟悉它,所以我经常以ControlsFX为例。 我假设类似的库(例如JFXtras )以及其他自定义JavaFX的项目都处于相同的情况。

JavaFX控制架构

模型视图控制器

JavaFX控件是根据model-view-controller实现的 。 无需赘述,让我们快速了解一下如何完成。 (有关详细信息,请参见GuiGarage 。)

所有正式控件都扩展了抽象类Control 。 这是MVC的模型。

该控件定义一个skinProperty ,其中包含一个Skin实现。 它可视化控件的当前状态,即它是MVC的视图。 默认情况下,它还负责捕获和执行用户交互,这在MVC中是控制器的任务。

皮肤通常是通过扩展BehaviorSkinBase实现的。 它创建了BehaviorBase的实现,将所有用户交互委托给该BehaviorBase的实现,并相应地更新了模型。 因此,这里有MVC的控制器。

按键绑定

还值得注意的是控件如何解决用户输入。 为了将动作链接到输入(例如,“ CTRL +鼠标单击”中的“在后台打开新选项卡”),它们创建了KeyBindings列表。 然后将输入事件与所有创建的绑定进行比较,并调用正确的操作。

由Flosweb在CC-BY-SA下发布 -我添加了拼图效果。

JavaFX中的内部API

使用JavaFX时,通常依赖于内部API。 这样做是为了创建新控件,调整现有控件或修复错误。

创建新控件

虽然ControlSkin甚至SkinBase都是公共API,但经常使用的BehaviorSkinBaseBehaviorBase不是。 使用拼图项目,将无法访问它们。

不过,该API的使用率很高。 ControlsFX包含大约二十个控件,其中大约一半需要这些类之一的实现。

同样,键KeyBindings没有发布,因此创建键KeyBindings来管理用户交互会增加另一个有问题的依赖性。

调整现有控件

自定义现有控件通常会更改可视化效果或调整某些用户交互的行为。

对于前者,简单地扩展和修改现有的外观通常是最容易的。 不幸的是,现有控件的所有外观都位于com.sun.javafx.scene.control.skin 。 当它们变得不可访问时,许多自定义控件将不再编译。

要更改控件对用户交互的React,必须干预BehaviorBase定义的BehaviorBase 。 这类似于创建新控件,通常通过扩展BehaviorSkinBaseBehaviorBase并创建新的KeyBindings

通过CSS设置控件的样式

在JavaFX中,可以实现控件,以便可以通过CSS设置样式。 所有官方控件都具有此功能,其他一些控件也由其他项目提供。

设置控件样式的中心步骤是将属性的文本表示形式从CSS文件转换为NumberPaint ,enum…的实例,以便可以将它们分配给属性。 为了确保统一,高质量的转换,JavaFX为此提供了一个API。 不幸的是,它位于com.sun.javafx.css.converters

高级样式要求必须在StyleManager帮助下实现,您猜想它也没有发布。

解决错误

JavaFX相对来说还很年轻,但仍然包含一些很难接触的错误。 通常,唯一的解决方法是侵入控件的内部工作原理,从而使用私有API。 (此类情况的示例可以在OpenJFX邮件列表中找到,例如RobertKrüger , Stefan Fuchs和Tom Schindl在这些邮件中。)

这些变通办法将在Java 9中失败。由于似乎所有错误均已修复,因此它们不必要变得不必要,因此可以理解以下问题:

当然,从理论上讲,如果所有[那些bug]都已在[Java] 9中得到了修复,那我很好,但是如果有一段时间将其中的一半修复在9中,而另一半只能在8,我该如何处理我的产品?

罗伯特·克鲁格– 2015年4月9日

杰普253

我们已经了解了为什么在使用JavaFX时普遍使用内部API。 那么, JEP 253如何解决这个问题?

(除非另有说明,否则本节中的所有引号均取自JEP。)

目标,非目标和成功指标

该提案恰好解决了到目前为止所描述的问题。 而且它认识到“在很多情况下,要获得理想的结果,开发人员别无选择,只能使用这些内部API”。 因此,“此JEP的目标是为内部API当前提供的功能定义公共API”。

(请注意,当开发人员将其代码从内部移动并且现在无法访问新的公共API时,这仍然会带来编译错误。)

同时,该JEP既不计划对现有已发布的代码进行任何更改,也不进行任何改进:“不受模块化影响的所有其他现有API都将保持不变。”

定义了两个成功指标:

  • “依赖JavaFX内部API的项目,尤其是Scene Builder,ControlsFX和JFXtras,在更新到新的API之后仍可以继续工作,而不会失去功能。”
  • “最终,如果所有工作都按计划进行,那么第三方控件应该是可构建的,而不依赖于内部API。”

三个项目

JEP分为三个项目:

项目一:使UI控件外观成为公共API

现有控件的外观将从com.sun.javafx.scene.control.skin移至
javafx.scene.control.skin 。 这将使它们成为已发布的API。 (请注意,这不包括行为类。)

项目二:改进对输入映射的支持

行为将通过输入映射来定义。 这允许在运行时更改控件的行为,而无需扩展任何特定(且未发布)的类。

项目三:审查并公开相关CSS API

com.sun.*软件包中当前可用CSS API将进行审查和发布。 该提案将更加详细,并描述每个项目的当前状态以及一些风险和假设。

这些项目解决了上述四个用例中的三个。 可以合理地假设可以满足这些要求,并且在Java 9中,即使无法访问内部API,也可以正确地创建,调整和皮肤控件。

如何解决错误? 至少其中一些似乎可以用相同的工具解决(例如,扩展现有的皮肤)。 但是我不能说这是否对所有人都适用,以及没有解决方法留下来的重要性有多重要。

时间表

如果您想试用新的API,则必须耐心等待一段时间。 JFX 253的所有者,JavaFX UI控件团队的Oracle技术负责人乔纳森·吉尔斯(Jonathan Giles)在推文中说,“他可能在几个月内不会合并到存储库中……”。

另一方面,由于Java 9的功能完整性计划于12月发布 ,因此它必须在接下来的七个月内可用。

反射

我们已经看到,使用JavaFX常常需要使用私有API。 这发生在三个截然不同的区域:

  • 根据控件体系结构(MVC)创建新控件。
  • 通过扩展其外观或更改键绑定来调整现有控件。
  • 通过CSS设置控件的样式。
  • 解决错误。

JEP 253分为三个项目,分别针对前三个领域。 (对于我来说)尚不清楚它们是否足以仅使用公共API来解决错误。

翻译自: https://www.javacodegeeks.com/2015/05/javafx-project-jigsaw-and-jep-253.html

javafx 项目

javafx 项目_JavaFX,Jigsaw项目和JEP 253相关推荐

  1. javafx 教程_JavaFX,Jigsaw项目和JEP 253

    javafx 教程 因此, Java 9可能会破坏您的代码-- 如果您的项目使用JavaFX,则这尤其可能,因为许多自定义和自制控件都需要使用内部API. 借助Project Jigsaw,这些内容将 ...

  2. Java 9终于要包含Jigsaw项目了

    当Jigsaw在Java 9中最终发布时,这个项目的历史已经超过八年了.\ 在最初的几年中,它必须要与另外两个类似的Java规范请求(Java Specification Request)进行竞争,这 ...

  3. Java 9 正式发布,终落地 Jigsaw 项目

    9 月 21 日,大家期待已久的 Java 9 终于正式发布了,本文与大家一起快速回顾一下 IntelliJ IDEA 中 Java 9 的支持,并了解 IntelliJ IDEA 2017.3 中针 ...

  4. JavaFX开发桌面,移动端,嵌入式权威指南(一)—— JavaFX桌面入门小项目

    目录 概述 代码 结果 总结 JavaFX应用 舞台和场景 显示图像 显示文字 将文本节点作为组 动画文本向上滚动 概述 JavaFX是用于构建富互联网应用程序的Java库.使用JavaFX开发的应用 ...

  5. jigsaw模块化_Java 9和模块化的未来:Jigsaw项目会成功还是失败?

    jigsaw模块化 Java世界中的烹饪是什么? 当EC 未能批准 JSR 376的公众评审投票时,有些人认为Jigsaw项目注定要失败. 有13票反对,10票赞成 ,尽管JSR 376公众投票的最终 ...

  6. 清华医工结合项目及三创项目与天津市27家重点医院对接

    6月28日,清华医工结合项目及三创项目与重点医院对接应用场景暨集中签约活动在天津武清金泰假日酒店举行.天津市科技局副局长祖延辉.市卫健委副巡视员王增田.武清区副区长曲海富,天津市第一中心医院.天津市环 ...

  7. 将springboot项目和vue项目部署到windows 2016 server(服务器)

    将springboot项目和vue项目部署到服务器 1.服务器环境配置 1.1 服务器需要安装的环境 1.2 服务器需要配置的入站与进站规则 2.springboot项目的打包 2.1 springb ...

  8. TFS 2010 使用手册(二)项目集合与项目

    1.项目集合 1.1 项目集合创建 打开TFS管理控制台,点击"团队项目集合". 图1点击"团队项目集合" 图2 点击"创建集合" 然后按照 ...

  9. 项目集跟进计划_项目延期,项目经理应该如何补救?

    大部分项目经理都面临过项目延期的情况,特别是在软件开发领域,项目延期情况尤为严重.项目管理者的真正挑战,不是发现问题和记录问题,而是预见问题.控制问题和解决问题. 首先项目经理一般受过良好培训,又经历 ...

最新文章

  1. 百度员工吐槽:百度江河日下,不知该何去何从?
  2. USTC English Club Note20171021
  3. IntelliJ IDEA 导入 IntelliJ IDEA 创建好的JavaWeb项目!
  4. 2.安装号mysql后当重启Linux服务器之后发现进入不了的解决方案
  5. python图形绘制含注释
  6. Android ViewModel
  7. 利用WPF创建含多种交互特性的无边框窗体
  8. Atitit 常用二维码对比(QR、PDF417、DM、汉信码 Aztec code maxicode
  9. 职场中,什么样的人最容易升职?
  10. 记录一次keil调试过程:自动识别GPS厂家芯片
  11. java万年历有农历_家庭农民历五行曰历,日历为什么叫“万年历”
  12. 《神经网络与深度学习》-网络优化和正则化
  13. 华为防火墙nat地址转换实现可以访问互联网
  14. SVN常见问题解决方案
  15. 腾讯云函数报错 Invoking task timed out after 3 seconds
  16. 数据不在有用时进行安全销毁
  17. Git学习--分支(branch、merge、rebase)
  18. 劲牌连续两年问鼎全国质量大奖背后的密码
  19. 手机桌面隐藏大师_隐藏大师app下载-隐藏大师安卓版下载-ROM之家
  20. Markdown图片本地化

热门文章

  1. P3295-[SCOI2016]萌萌哒【ST表,并查集】
  2. jzoj4244-yi【贪心】
  3. 小 X 的 AK 计划
  4. SpringCloud Consul自定义服务注册
  5. Nacos(二)之概念
  6. 面试官问:为什么 Java 线程没有 Running 状态?我懵了
  7. JavaFX键盘事件
  8. Java 调用EXE
  9. 关于Icon,Image,ImageIcon的简单的对比参考 上篇
  10. 分布式系统架构常识:CAP理论