做了个 IntelliJ 主题,让我再也不想用 JetBrains 的 IDE 了

查看 184|回复 8
作者:anson0370   
大家好,前不久分享了下我们的 HardHacker 的主题,有些朋友表示想要 JetBrains 的版本。讲道理我也是写了十几年 Java 的,那还有什么好说的,整💪。
目前已经整了一个算是可用的版本了,大家可以在 Marketplace 里搜索 HardHacker 找到。
这里也丢个图:

只能说真的是无知者无畏,下次谁再让我给 IntelliJ 做主题,我谢谢他🙏。以下都是吐槽,也算是我踩到的坑,分享出来给也想要做 IntelliJ 主题的勇士参考一下,不感兴趣的朋友就可以直接略过了。
出师不利,官方教程跑不通
首先我们打开官方文档,找到 Theme 的部分。IntelliJ 的 Theme 也是 plugin 的一种,JetBrains 专门为 Theme 做了一个简化的工程和创建流程。看起来很简单,next 、next 、run ,喜提 ClassNotFoundException 。经过亿点点研究之后,我发现是 IDEA 在 run Theme plugin 的时候 classpath 里少了个 IDEA 自己的 jar ,但是没找到办法自定义 run Theme plugin 的时候的 classpath 。
于是又经过亿点点搜索之后,我找到了这个:

相关 issue 在这:https://youtrack.jetbrains.com/issue/IDEA-302414 。好嘛,7 months ago 。不过 JB 家 bug 常年不修也是传统了🤷🏻‍♂️,只要有 workaround 那也行。
Schema 困惑之旅
把我的 theme 切换成 gradle 工程之后,总算可以跑起来了。
众所周知,IntelliJ 的样式分成 theme 和 schema 两部分,theme 控制 UI ,而 schema 则控制 editor 的内容。(这里就要给 vscode 磕一个了,它就不分,开发 theme 的体验非常舒爽)
由于我之前在 Github 上找到一个 JB 官方的 schema converter:JetBrains/colorSchemeTool (github.com) 。用它可以把 vscode 的 theme 转换成 IntelliJ 的 schema ,我决定从它的转换结果开始。然后困惑之旅就开始了。
不知道 key 值是什么
IntelliJ 的 schema 是个 XML 文件,大概长这样:
  
   
       
       
   
      
        
        
        
      
   
  
看起来挺清晰的,但问题是这个 option 的 name 是完全没有文档的。官方的意思是你看着我们内置的主题文件自己猜吧:intellij-community/highContrastScheme.xml at idea/231.8109.175 · JetBrains/intellij-community · GitHub 。
这些 name 命名毫无规律,比如:
  • HYPERLINK_ATTRIBUTES:这有个 _ATTRIBUTES 后缀。
  • RUNTIME_ERROR:这就没有。
  • DEFAULT_LABEL:这是 default scope 下的,有个 DEFAULT_ 前缀。
  • BAD_CHARACTER:这也是 default scope 下的,没前缀。
  • TODO_DEFAULT_ATTRIBUTES:这也是 default scope 下的,跑中间去了,而且为什么你又有 _ATTRIBUTES 后缀了?
  • ANNOTATION_NAME_ATTRIBUTES:这是 Java scope 下的,从命名上根本看不出是 Java 。
  • Class:这是 Groovy 的,好家伙原来是用大小写来区分 Java 和 Grovvy 的吗?
  • KOTLIN_DYNAMIC_PROPERTY_CALL:这个能看出来了,是 kotlin 的。
  • REGEXP.CHAR_CLASS:等等,为什么你不是下划线?为什么你特别?
  • Clojure Keyword:好嘛……

    你想从中找到规律?主打的就是一个没有规律。✌️🤬
    那么怎么才能准确找到你想改的 option 呢?特别是上面提到的那个 JB 官方转换工具的转换结果还缺斤少两的情况下?就此事我和 ChatGPT 探讨了一下,它给了我一个建议:你直接在 IDE 的 settings 里改,然后导出,再查找。你别说还真管用……我只需要找到那个配置,然后把颜色改成比如 334554 ,123456 ,然后导出来打开,cmd + f 即可……
    默认值逻辑乱七八糟
    IntelliJ 的 schema 里,不同 scope 之间是有继承关系的。比如 Java 的 keyword 会继承 default 的 keyword 。这很方便,但同样的,这部分也没规律。简单来说就是有时候你直接不管,它自动就继承了,而有时候你又必须显式声明,否则它就会有一个默认的💩一样的配色:
    魔法数字
    注意看我刚才贴的 schema 文件的内容第一行:
    version 是 142 ,但别问我为什么是 142 ,我只知道我改成 143 不行,但我改成 143 再改回 142 似乎可以刷新某种 cache 🧙‍♂️!因为你会发现当你在 devkit 的 IDEA 中改了 schema 并保存后,有一定概率你再改 schema 文件它不生效!此时就可以用这个 143/142 大法。
    然后这个 parent_scheme 是 Darcula ( IntelliJ 自己有个 Darcula 主题,并不是那个 Dracula themes ),你改成别的比如 Dark 也是没用的。还有这 Darcula 拼错了吧喂?
    不能 hotreload
    这就不得不再提一下 vscode 了,保存实时生效,简直太方便了🧎🏻‍♂️。但 IntelliJ 这个你要么重新手动 import 一下,要么直接 rerun plugin ,然后等它重新启动一个 devkit 的 IDEA 。
    搞了几次之后我就学乖了,我在 notion 里列了一个 TODO list ,一次改一批然后列进去。重启一次之后对着这个 TODO list 再一个一个检查……
    不支持透明度
    都 2023 年了。唯一支持透明度的是 editor 里的滚动条。
    困惑加倍,快乐归零
    说完 schema ,我们来看看 theme 部分。基本上 schema 部分的槽点,theme 部分都占了。比如找不到 key (官方给了一个 LaF 工具,但也只能看到 key 值,并不知道具体对应哪里,得不断修改来尝试);比如不能 hotreload 等等。此外因为 2023 的 New UI 还在 beta 阶段,所以有些 UI 样式改不了,所以如果你安装了主题之后发现有些地方不协调,那很可能就是因为……改不了。
    但最让我抓狂的是 code suggestion 的弹出框,就是这个东西:

    为了调这个东西,花了我大半天时间。因为……这东西别的都归 theme 管,唯独背景色归 schema 管!我 TM 带着无比的困惑在 LaF 和别人的主题文件里找它的背景色找了两个小时!两个小时!🤬🤬🤬
    经过两天的折腾,我算是知道为什么 IntelliJ 的主题这么少了,就这开发体验没点共产主义吃苦耐劳的优良品质都坚持不下去。
    写到这里的时候我突然想起来自己以前在 youtrack 上 star 过的一些 issues ,我就去翻了一下。好家伙 9 years ago 的 issue 还开着呢,7 months 简直不值一提。
    说实话就 schema 里那些 attribute names 的混乱情况,让我很难相信 IntelliJ 里面的代码不是一坨💩⛰️……
    年年更新大版本,就不能解决一下这些历史遗留问题吗?突出一个能跑就行。这么想想好像拿 Fleet 来彻底解决一下是个合理的思路,虽然 JB 说的挺好听的 Fleet 和 IntelliJ 不存在竞争关系,但这不是明摆着前浪后浪的事?
    想想自己从 09 年开始用 IntelliJ IDEA ,到今天 IDEA 也显出老态了。Anyway ,欢迎大家试用主题。

    IntelliJ, schema, theme, option

  • encro   
    IntelliJ 每位员工收入约 35 万美元。
    ohmycorolla   
    已下载,配色非常喜欢,这个粉红色很骚
    Doracis   
    IDEA 感觉确实就像廉颇老矣, 尚能饭否, 未来真的可能被 vscode 取代了
    anson0370
    OP
      
    老哥 我知道这么说确实很过分,但是能不能再出一个白天版的,重度散光程序员看不清黑啊 TAT
    anson0370
    OP
      
    @ohmycorolla 感谢喜欢,也欢迎使用该配色的 VSCode 、VIM 、emacs 、iTerm2 等等版本 🤣
    anson0370
    OP
      
    @Doracis 我有在考虑这个问题,虽说亮色版的有点不太符合我们 HardHacker 的定位,但确实对散光比较友好。关键得把配色定一下,做一下倒是不麻烦,因为我未雨绸缪都写了脚本来生成。回头弄好了我来 at 你。
    anson0370
    OP
      
    @encro 这就是他们 9 年前的 bug 也不修的底气吗 😂
    ohmycorolla   
    @fiveStarLaoliang 实际上我前几年已经在用 VSCode 写 Java 了。
    您需要登录后才可以回帖 登录 | 立即注册

    返回顶部