前提#
某一天点开掘金的写作界面的时候,发现了内置Markdown
编辑器有一个Github
的图标,点进去就是一个开源的Markdown
编辑器项目bytemd
(https://github.com/bytedance/bytemd
):
这是一个NodeJs
项目,由字节跳动提供。联想到之前业余的时候做过一些Swing
或者JavaFx
的Demo
,记得JavaFx
中有一个组件WebView
已经支持Html5
、CSS3
和ES5
,这个组件作为一个嵌入式浏览器,可以轻松地渲染一个URL
里面的文本内容或者直接渲染一个原始的Html
字符串。另外,由于原生的JavaFx
的视觉效果比较丑,可以考虑引入Swing
配合IntelliJ IDEA
的主题提供更好的视觉效果。本文的代码基于JDK11
开发。
引入依赖#
很多人吐槽过Swing
组件的视觉效果比较差,原因有几个:
- 技术小众,现在有更好的组件进行混合开发和跨平台开发
- 基于上一点原因,导致很少人会去开发
Swing
组件的UI
,其实Swing
的每个组件都可以重新实现UI
的表现效果 compose-jb
(JetBrains
)组件很晚才发布出来,刚好碰上Swing
官方停止维护,后面应该更加少人会使用Swing
做GUI
开发
使用Swing
并且成功了的方案最知名的就是JetBrains
全家桶。目前来看,为了解决这个"丑"的问题,现在有比较简单的处理方案:
- 方案一:使用
compose-jb
(名字有点不好听,官方仓库为https://github.com/JetBrains/compose-jb
)开发,这个是JetBrains
系列的通用组件,基于Swing
做二次封装,不过必须使用语言Kotlin
,有点强买强卖的嫌疑,这列贴两个官方的图参考一下:
小伙伴们有兴趣想了解内容和更多相关学习资料