跳到內容

主題

選擇內建主題或定義您自己的主題。

透過 Vikasit Code,您可以從多個內建主題中進行選擇,使用能自動適配終端機主題的主題,或者定義您自己的自訂主題。

預設情況下,Vikasit Code 使用我們自己的 vikasit 主題。


終端機要求

為了使主題能夠正確顯示完整的調色盤,您的終端機必須支援真彩色(24 位元色)。大多數現代終端機預設支援此功能,但您可能需要手動啟用:

  • 檢查支援情況:執行 echo $COLORTERM — 輸出應為 truecolor24bit
  • 啟用真彩色:在您的 shell 設定檔中設定環境變數 COLORTERM=truecolor
  • 終端機相容性:確保您的終端機模擬器支援 24 位元色(大多數現代終端機如 iTerm2、Alacritty、Kitty、Windows Terminal 以及較新版本的 GNOME Terminal 均已支援)

如果沒有真彩色支援,主題可能會出現色彩精度下降的情況,或者回退到最接近的 256 色近似值。


內建主題

Vikasit Code 自帶多個內建主題。

名稱描述
system自動適配終端機的背景顏色
tokyonight基於 Tokyonight 主題
everforest基於 Everforest 主題
ayu基於 Ayu 暗色主題
catppuccin基於 Catppuccin 主題
catppuccin-macchiato基於 Catppuccin 主題
gruvbox基於 Gruvbox 主題
kanagawa基於 Kanagawa 主題
nord基於 Nord 主題
matrix駭客風格的黑底綠字主題
one-dark基於 Atom One Dark 主題

我們還在不斷新增更多主題。


系統主題

system 主題旨在自動適配您終端機的配色方案。與使用固定顏色的傳統主題不同,system 主題具有以下特點:

  • 產生灰階色階:根據終端機的背景顏色建立自訂灰階色階,確保最佳對比度。
  • 使用 ANSI 顏色:利用標準 ANSI 顏色(0-15)進行語法高亮和 UI 元素渲染,遵循終端機的調色盤設定。
  • 保留終端機預設值:將文字和背景顏色設為 none,以保持終端機的原生外觀。

系統主題適合以下使用者:

  • 希望 Vikasit Code 與終端機的外觀保持一致
  • 使用了自訂終端機配色方案
  • 偏好所有終端機應用程式擁有統一的視覺風格

使用主題

您可以透過 /theme 指令調出主題選擇介面來選擇主題,也可以在 tui.json 中直接指定。

tui.json
{
"$schema": "https://opencode.ai/tui.json",
"theme": "tokyonight"
}

自訂主題

Vikasit Code 支援靈活的基於 JSON 的主題系統,讓使用者可以輕鬆建立和自訂主題。


層級優先順序

主題按以下順序從多個目錄載入,後面的目錄會覆蓋前面的目錄:

  1. 內建主題 — 嵌入在二進位檔案中
  2. 使用者設定目錄 — 定義在 ~/.config/opencode/themes/*.json$XDG_CONFIG_HOME/opencode/themes/*.json
  3. 專案根目錄 — 定義在 <project-root>/.vikasit/themes/*.json
  4. 當前工作目錄 — 定義在 ./.vikasit/themes/*.json

如果多個目錄包含同名主題,將使用優先順序較高的目錄中的主題。


建立主題

要建立自訂主題,請在上述任一主題目錄中建立一個 JSON 檔案。

建立使用者級主題:

Terminal window
mkdir -p ~/.config/opencode/themes
vim ~/.config/opencode/themes/my-theme.json

建立專案級主題:

Terminal window
mkdir -p .vikasit/themes
vim .vikasit/themes/my-theme.json

JSON 格式

主題使用靈活的 JSON 格式,支援以下特性:

  • 十六進位顏色"#ffffff"
  • ANSI 顏色3(0-255)
  • 顏色參考"primary" 或自訂定義的顏色名
  • 深色/淺色變體{"dark": "#000", "light": "#fff"}
  • 無顏色"none" — 使用終端機的預設顏色或透明背景

顏色定義

defs 部分是選填的,它允許您定義可在主題中重複引用的可重複使用顏色。


終端機預設值

特殊值 "none" 可用於任何顏色屬性,以繼承終端機的預設顏色。這在建立需要與終端機配色方案無縫融合的主題時特別有用:

  • "text": "none" — 使用終端機的預設前景色
  • "background": "none" — 使用終端機的預設背景色

範例

以下是一個自訂主題的完整範例:

my-theme.json
{
"$schema": "https://opencode.ai/theme.json",
"defs": {
"nord0": "#2E3440",
"nord1": "#3B4252",
"nord2": "#434C5E",
"nord3": "#4C566A",
"nord4": "#D8DEE9",
"nord5": "#E5E9F0",
"nord6": "#ECEFF4",
"nord7": "#8FBCBB",
"nord8": "#88C0D0",
"nord9": "#81A1C1",
"nord10": "#5E81AC",
"nord11": "#BF616A",
"nord12": "#D08770",
"nord13": "#EBCB8B",
"nord14": "#A3BE8C",
"nord15": "#B48EAD"
},
"theme": {
"primary": {
"dark": "nord8",
"light": "nord10"
},
"secondary": {
"dark": "nord9",
"light": "nord9"
},
"accent": {
"dark": "nord7",
"light": "nord7"
},
"error": {
"dark": "nord11",
"light": "nord11"
},
"warning": {
"dark": "nord12",
"light": "nord12"
},
"success": {
"dark": "nord14",
"light": "nord14"
},
"info": {
"dark": "nord8",
"light": "nord10"
},
"text": {
"dark": "nord4",
"light": "nord0"
},
"textMuted": {
"dark": "nord3",
"light": "nord1"
},
"background": {
"dark": "nord0",
"light": "nord6"
},
"backgroundPanel": {
"dark": "nord1",
"light": "nord5"
},
"backgroundElement": {
"dark": "nord1",
"light": "nord4"
},
"border": {
"dark": "nord2",
"light": "nord3"
},
"borderActive": {
"dark": "nord3",
"light": "nord2"
},
"borderSubtle": {
"dark": "nord2",
"light": "nord3"
},
"diffAdded": {
"dark": "nord14",
"light": "nord14"
},
"diffRemoved": {
"dark": "nord11",
"light": "nord11"
},
"diffContext": {
"dark": "nord3",
"light": "nord3"
},
"diffHunkHeader": {
"dark": "nord3",
"light": "nord3"
},
"diffHighlightAdded": {
"dark": "nord14",
"light": "nord14"
},
"diffHighlightRemoved": {
"dark": "nord11",
"light": "nord11"
},
"diffAddedBg": {
"dark": "#3B4252",
"light": "#E5E9F0"
},
"diffRemovedBg": {
"dark": "#3B4252",
"light": "#E5E9F0"
},
"diffContextBg": {
"dark": "nord1",
"light": "nord5"
},
"diffLineNumber": {
"dark": "nord2",
"light": "nord4"
},
"diffAddedLineNumberBg": {
"dark": "#3B4252",
"light": "#E5E9F0"
},
"diffRemovedLineNumberBg": {
"dark": "#3B4252",
"light": "#E5E9F0"
},
"markdownText": {
"dark": "nord4",
"light": "nord0"
},
"markdownHeading": {
"dark": "nord8",
"light": "nord10"
},
"markdownLink": {
"dark": "nord9",
"light": "nord9"
},
"markdownLinkText": {
"dark": "nord7",
"light": "nord7"
},
"markdownCode": {
"dark": "nord14",
"light": "nord14"
},
"markdownBlockQuote": {
"dark": "nord3",
"light": "nord3"
},
"markdownEmph": {
"dark": "nord12",
"light": "nord12"
},
"markdownStrong": {
"dark": "nord13",
"light": "nord13"
},
"markdownHorizontalRule": {
"dark": "nord3",
"light": "nord3"
},
"markdownListItem": {
"dark": "nord8",
"light": "nord10"
},
"markdownListEnumeration": {
"dark": "nord7",
"light": "nord7"
},
"markdownImage": {
"dark": "nord9",
"light": "nord9"
},
"markdownImageText": {
"dark": "nord7",
"light": "nord7"
},
"markdownCodeBlock": {
"dark": "nord4",
"light": "nord0"
},
"syntaxComment": {
"dark": "nord3",
"light": "nord3"
},
"syntaxKeyword": {
"dark": "nord9",
"light": "nord9"
},
"syntaxFunction": {
"dark": "nord8",
"light": "nord8"
},
"syntaxVariable": {
"dark": "nord7",
"light": "nord7"
},
"syntaxString": {
"dark": "nord14",
"light": "nord14"
},
"syntaxNumber": {
"dark": "nord15",
"light": "nord15"
},
"syntaxType": {
"dark": "nord7",
"light": "nord7"
},
"syntaxOperator": {
"dark": "nord9",
"light": "nord9"
},
"syntaxPunctuation": {
"dark": "nord4",
"light": "nord0"
}
}
}