Java开发GUI的未来?

考虑到这一点

  • Sun / Oracle决定在他们“发明”JavaFX之后不再开发Swing
  • JavaFX并没有真正起作用, 有些人认为它已经失败了
  • SWT并不是真正与平台无关的特性,处理GUI元素的手动任务以及捆绑特定于平台的库的必要性

还有另一条出路吗?

如果我想在JVM上进行GUI开发

  • 有一个很好的API(Swing和SWT也不错,但它们也不是很好。)
  • 哪种“感觉”响应(尽管声称这已经解决了,但今天Swing和SWT仍然存在问题。)
  • 在几年内不会过时的,我应该做出什么决定?

是否有可用的第三种选择或未来可能有一种选择?

一个选项

  • 快速响应(Not Swing的意识形态“如果它不快,那就是开发人员的错”)
  • 具有原生外观和感觉
  • 使用在所有平台上运行的单个库

这是现实的吗?

谢谢!

=========

澄清一下:如果我必须在JVM上启动一个新的软件项目,有几个现有的选项,比如使用SWT或Swing,使用Swing与第三方库如SwingX,JIDE,JGoodies,Flamingo或使用像Netbeans Platform这样的应用程序框架或Eclipse RCP。 是否有支持/建议的方法可以减轻通常与Java GUI开发相关的痛苦?

你不会找到这个问题的客观答案,只有个人喜好和选择。

SWT

我个人的偏好是SWT。 我开始使用它,当Swing不好选择时。 SWT在本机窗口API之上“只是”一层,因此使用SWT编写的应用程序就像本机编写的应用程序一样。 那些也可以搞砸了。 对于糟糕的开发人员来说,没有API是安全的。 性能和我的经验一样快。 如果不是,那么还有另一种方法可以实现它。

SWT的API非常低,这使得实现基本的东西出乎意料地乏味,但幸运的是,大多数典型的用例都可以通过JFace解决,这可以改善这种情况。 当您使用API​​一段时间后,您将累积自己的util类。 您可以快速实现SWT工具。

由于SWT只为您提供基础知识,因此您需要MigLayout和Nebula小部件才能生存。 你可能会喜欢Glazed Lists 。

Qt Jambi

实际上我希望除了SWT和Swing之外还包括另一个选项: Qt Jambi 。 但诺基亚放弃了这一点,现在它“由一个开源社区维护”。 所以我不知道“几年后不会过时”。

然而,我对这一持续的讨论感到兴奋。 有些人使用Qt Jambi编写了一个SWT实现作为“本机”API。 他们正试图弄清楚如何贡献它。 让Qt作为一个选项可能会在一天内为SWT启用“在所有平台上运行的单个库”,尽管我不会很快指望它。

但对我来说,你对“单一图书馆”的要求并不是一个大问题。 使用maven进行构建,添加几行配置,你很快就会忘记这一点。

摇摆

我无法将SWT与Swing进行比较,因为我对Swing的体验受到限制。 作为一个用户,我不喜欢大多数Swing应用程序,但我确实看到了一些美丽的应用程序。

如今,Swing应用程序的原生外观和感觉非常好,但你不会欺骗高级用户。 在新的和做得好的Swing应用程序中,性能似乎也非常好,但同样,这只是作为用户的限制视图。

显然,Swing的第三方扩展比SWT更多 – 只需进行谷歌搜索。 (但话说回来,如果你忍受学习Eclipse RCP的痛苦,你也会得到一个庞大而有趣的基础设施。虽然这不是关于小部件,就像EMF或RAP这样的东西。我不是Eclipse RCP人 – 我从来没有过足够的耐心……)

如果你喜欢这些东西,Swing的一个非常大的优势就是Netbeans的GUI构建者Matisse。 顺便说一句,Qt还有一个做得很好的GUI构建器。

概要

如果您计划长期,我在Java中看不到比SWT或Swing更多的选项用于GUI开发。 如果你花了足够的时间,两者都足以满足大多数需求。 但它们并不完美。 你总是羡慕那些使用其他语言的人为他们的小部件,实现速度,工具,……如果你不受Java的约束,你甚至可能更喜欢Flash或Qt。

我认为答案更倾向于摇摆

  • 自1.4以来在awt上有很大的进步(sun do that that因为java fx需要awt,幸运的是)
  • 自1.5在线程管理方面取得重大进展(SwingWorker和concurrents事物)
  • swing非常好,反应灵敏(开发者有什么问题?),本地l&f等等
  • 有优秀的图书馆,如swingx,三叉戟等,以及平台,如netbeans。

当然这是一项成熟的技术(有点旧),但我什么都不知道。 这将是GUI开发的cobol 🙂