前一段時間需要從本地SSH到某臺云服務器查看配置文件,BOSS在我邊上跟我一起找文件。找畢,BOSS說:“你這顏色看著不難受么?辨識度太低了”當時我的屏幕是這樣的:
其實我也是這么認為的,這顏色太慘了。漆黑的背景,深深藍色的標識符,實在是看不清楚。說搞就搞,網上找各種配色方案,先來一打iTerm2的配色方案,再把其中的背景圖片也設置一下,先不說遠端服務器的效果(因為有坑,后說),本機已經是這樣的了:
一不做而不休,把本機的oh-my-zsh也在自己CentOS的騰訊云主機里搞一套,當然vim的配色也不能少,都要搞的漂漂亮亮的:
這些配色都還沒什么,基本上隨便選個zsh主題,選個vim主題,選個iTerm2主題,基本都可以看起來比較舒服了。(主要是自己舒服)
但是,但是!
在選iTerm2主題的時候出現了問題:有時候我選擇不同的主題,為什么感覺zsh的條沒有變化呢?
這簡直就**尷尬了。。那豈不是意味著,那些惡心的藍色,還會是一如即往的惡心?可這到底是為什么呢?明明用戶名都是變色龍一樣的了,為啥有些字死活就不動呢?百度不到靠譜的答案,只能google了。在StackOverflow上找到了一個鏈接,答主熱心的解答了其中的原理:
There are two layers of settings/themes at work here:The terminal or terminal emulator, in your case iTerm2
Depending on the terminal only a limited color palette is supported. "Traditionally" there have been 16 colors: 8 Normal and 8 Light/Bright. They are assigned the code 0 to 7 and 8 to 15, respectively. They also have names, with the codes n and n+8 sharing the same name…
由于不是英語課,我就不在這里全文引用了。感興趣的同學可以通過上面的鏈接進去看到原文。
我在這里簡單介紹下答主的中心思想:
- 終端顯示總共經歷了兩(三)層:
- 應用(如:vim)/ shell:決定了顯示成什么樣的顏色
- 用戶終端(如:iTerm2): 決定了怎么顯示
- 你看到了顏色
這么說畢竟太抽象了,不妨換個說法:
- 你上課的時候通過后桌的男生傳話給最后面的女生也經歷了兩(三)個步驟:
-
你說:我愛你,
-
結果后桌也喜歡最后面的小女生,他知道你是在表白,就把你的表白變成了表黑,但他看不懂函數,于是他和小女生說:**說他可煩你了,還給了個公式
- 于是小女生看到了你后桌傳過來的信息,就是這樣的:***說他可煩你了,還有
看到這一定更糊涂了吧!哈哈!其實后面的故事主要是想表示,各種各樣的終端會將應用傳過來的信息展示給最終用戶看,但是有些終端軟件已知的一組預定義顏色是可以被它替換成特定顏色的。而它本身讀不懂的顏色(其實是沒有替換策略的顏色)就會原封不動的傳給坐在顯示器前的你的。這樣就可以知道,為什么有些顏色可以跟著securtCRT/iTerm2的配色而變,有些不可以了吧?
接下來再具體的展示下如何實現,以及怎么調整配色使配色萬年不變或者隨著終端千變萬化。先看這樣一條命令
print -P '%F{yellow}yellow %F{2}green %1Fred %F{117}light blue'
把這條命令通過你的linux終端執行一下,就可以看到如下結果
-
再輸入一條命令:
for a in {0..255}; printf "\x1b[48;2;255;${a};0m \x1b[0m"
可以看到如下結果:
現在可以開始我們的實驗了,打開iTerm2的Colors配置頁,調整當前頁面的配色(選了個Batman)
可以看到結果:在蝙蝠俠的配色下,紅的綠的文字被變成了不同的黃色,但是RGB顏色調出來的彩虹是沒有變化的。按照這個思路,找到zsh的主題配置頁,路徑如下:
\~/.oh-my-zsh/themes
對其中一個固定顏色的片段進行調整,用iTerm2所能調整的顏色之一Blue定義這個片段(變化在光標處)(fn)
用source命令生效.zshrc后看看效果:
這樣就可以讓zsh的配色隨著iTerm2的不同主題發生變化了!
同理,大家可以看下vim的主題描述中,大量的使用了非RGB的方式來對配色進行描述。這樣帶來的好處是,心情變化的時候換配色很容易!
最后附上 ANSI escape code在[wiki上的鏈接][wiki]以及這些可以隨終端配色變化而變化的顏色名稱列表,:
[wiki]:https://en.wikipedia.org/wiki/ANSI_escape_code#Colors