linux終端字體
1. linux系統終端代碼用的是哪一種字體
默認為等寬字體。
再給你推薦幾款ubuntu linux字體及安裝方法
1. Inconsolata
安裝命令:
sudo apt-get install ttf-inconsolata
2. Envy Code R
Download
3. Droid Sans Mono
安裝命令:
sudo apt-get install ttf-droid
4. Anonymous Pro
Download
5. DejaVu Sans Mono
安裝命令:
sudo apt-get install ttf-dejavu
6. Liberation Mono
安裝命令:
sudo apt-get install ttf-liberation
7. Terminus
安裝命令:
sudo apt-get install xfonts-terminus
推薦你看一本書《linux就該這么學》書中內容非常豐富,LINUX基本問題都可以在書中解決。望採納!
2. Linux系統終端字體亂碼(非管理員賬戶操作指南)
問題:使用一台Linux系統的機器,終端總是顯示有亂碼,不是中文亂碼,看起來像是英文亂碼,我這強迫症又受不了了
解決方案:
Linux字元編碼默認為UTF-8,如果出現英文亂碼有可能是系統設置的編碼方式為GBK。
設置locale的根本就是設置一組總共12個LC開頭的變數,不包括LANG和LC_ALL。
優先 級:LC_ALL > LC_* > LANG
可以看出原系統設置的為中文字體顯示和運行的語言環境,所有的設置都是使用的 zh_CN.gbk ,因中英文字元編碼方式不同,可能造成英文字元或者空格顯示有亂碼。
5.退出後再次查看locale(再次登錄才生效)
亂碼的字元消失了。locale轉變為:
3. 如何改造 Linux 虛擬終端顯示文字
必須使用 UTF-8 模式 ( 默認 vc->utf=1 即可 )
虛擬控制台的 vc_screenbuf 必須修改以為 glyph 提供至少 16bit 的空間。
圖形控制台需要 vc_font包含更多的字元,不只是 255 個,並提供代碼繪制雙倍寬度的中文字形,字體中的字元按照 UNICODE
排列,這樣 glyph 就是字元的 UNICODE 編碼。
修改虛擬控制台
一開始,我的打算是 vc_screenbuf 修改為 unsigned long long* 類型,32bit 給字元屬性,分別表示 16bit
終端前景色和背景色。glyph 則擁有 31bit 的空間 , 因為漢字的寬度為雙倍的英文字母 ,其中 1 bit 用來表示雙字元寬度。比如 '我' 會表達為
兩個 '我',第二個'我'的最高位為 1:繪制任何字形的時候,只繪制字形的左半部分;如果發現最高位為 1
則繪制字體點陣圖中的右半部分。這樣同樣的繪制代碼可以適應英文字母和漢字。寫入 vc_screenbuf 的時候,
如果是雙倍寬度的字元,需要同時寫入兩份,第二份的最高位置 1 就可以。但是 vc_screenbuf
的格式已經被到處假定為每字元兩個位元組。如此修改導致牽一發動全身。許多艱澀難懂的代碼都依賴 vc_screenbuf 是
每字元兩個位元組的設定,直接修改定義後,光是編譯器能直接檢測出來的就有百餘個地方需要修改,還有更多的邏輯並不能被編譯器檢測出來。如此修改的後果就是會出現許多隱晦的錯誤,非常難於調式。掙扎後,為最終選擇了另一條道路
:
為漢字重新分配一塊 vc_unicode_screenbuf
vc_unicode_screenbuf 緊挨著 vc_screenbuf , 事實上 vc_screenbuf
在分配空間的時候,多分配了一倍的空間,多分配的空間充作 vc_unicode_screenbuf,因此 struct vc_data 里並沒有添加
vc_unicode_screenbuf 成員。 vc_unicode_screenbuf 同樣為每字元 2 個位元組,並不包含字元屬性,所以 2
個位元組如數用來保存 glyph。vc_screenbuf 格式未變,所以 vgacon 不需要修改,這就減少了大量的工作量。向 vc_screenbuf
寫入字元的時候,同時寫入一份到 vc_unicode_screenbuf 。如果是漢字,由於其 glyph 大於 254 , 所以 vc_screenbuf
的那兩個字元 ( 漢字雙倍寬度 ) 實際寫入的是 0xff 和 0xfe ( 故而上文提到是 glyph 大於 254 的字元 ,0xfe 被保留它用了
)。0xff 表示該字元的 glyph 要到 vc_unicode_screenbuf 提取,然後繪制左半部分;0xfe 表示該字元的 glyph 要到
vc_unicode_screenbuf 提取,然後繪制右半部分。對於 glyph 大於 254 但是又不是雙倍寬度的字元,就不需要 0xfe
作陪了。比如屏幕上顯示的文字是黑底白字的 「牛 B」 , vc_screenbuf 的內容就是 「0x00ff, 0x0ffe, 0x0f42 」 ,
vc_unicode_screenbuf 的內容則是 「牛 , 牛 ,b」
。這是因為一個漢字為兩倍的英文字母寬度。在屏幕文字緩沖區上也必須佔用兩個字元的位置。並且必須有一種機制能知道應該繪制左半部分和右半部分,我使用的就是 0xff
和 0xfe。
修改圖形控制台繪制代碼
要修改的地方只有 3 個。
struct console_font 添加 charcount 成員。將主線內核的字體設置為 charcount = 255。 主線內核帶的字體都是
255 個 glyph 的,所以沒有添加字元個數的必要。不過我們即將要添加的字體會有數萬字元。
添加一個新的字體,復蓋 UNICODE BMP 基本區域的所有符號。
修改字元繪制代碼,添加 vc_unicode_screenbuf 的支持。
字元繪制代碼的修改比較繁瑣,代碼分布在 drivers/video/console/ 下的多個文件中。fbcon_putc(s) 由由
vc->vc_sw->con_putc(s) 調用, fbcon_putc(s) 轉而調用分散於 drivers/video/console/
的多個 puts 實現。因為終端要支持 console_rotate , decoration , timing , 故而每種模式下的繪制實現都是不同的。我拿
drivers/video/console/bitblt.c 最常用的不傾斜、不加裝飾等的終端模式為例來講解繪圖部分的修改。由於中文字體為 16x16
點陣,是對齊的字體,故而其繪制代碼為 bit_putcs_aligned() 原先的代碼以 glyph 為下標到 vc->vc_font->data
獲得字體數據,然後調用 fb_pad_aligned_buffer 執行塊拷貝操作。我的修改很簡單,原來獲得字體數據的代碼修改後放入 font_bits()
輔助函數。 在 font_bits 里,要判斷 glyph 是否為 0xff 或者 0xfe, 如果不是,使用 glyph 為下標獲得字體的左半部分後並返回。
如果是,則從 vc_unicode_screenbuf 獲得真正的 glyph 數值,然後再依據現有的 glyph 是 0xff 還是 0xfe
去獲得字體的右半部分還是左半部分返回。font_bits 獲得字體數據後執行 fb_pad_aligned_buffer 塊拷貝。需要修改的地方還有
drivers/video/console/fbcon_ccw.c fbcon_cw.c fbcon_ub.c 。依原理進行修改即可。
虛擬終端的不足之處
雖然費盡心機添加了中文支持,那隻是一個 workaround ,
並不能算真正的支持。要真正的支持必須徹底重寫虛擬終端和控制台。而要支持中文,就需要更進一步,全面支持 UNICODE ,
包括支持從右向左的書寫習慣。在內核里實現一個全面支持 UNICODE
的控制台並不是一件容易的事情,何況內核的政策也不允許將如此龐大的字型檔裝入內核。於是乎,這里出現了死胡同。KMS 和 Wayland
的出現讓這死胡同似乎有了個完美的解。
System Compositor?
System Compositor 是一個 wayland compositor,只是運行於系統全局范圍。
為了懶人我這里稍微講解一下 wayland compositor 吧。 Wayland 不同於 X , 在 wayland 的世界裡,只有
compositor 和 client。Client 利用各種 API (wayland 給出的示例使用的是 OpenGL ES, 但其實 wayland
並不限制使用的繪圖 API 類型 ) 進行窗口繪圖,然後將窗口的繪制結果直接提交給 compositor 合成到屏幕上。這樣 wayland 本身就不包含繪圖
API 而大大簡化了 wayland 的設計。Wayland compositor 可以同 X 一樣操作顯卡向屏幕輸出合成後的結果,也可以作為另一個
wayland compositor 的 client。
對於多賬戶同時登錄的實現,固然可以讓每一個本地 GUI 會話開啟一個 wayland compositor,但是存在更好的辦法就是固定開啟一個
system compositor。而讓所有用戶會話的 wayland compositor 再作為 system compositor 的 client.
藉由 system compositor 的合成效果,進行快速用戶切換也可以進行一些視覺效果。而且 Xorg 本身也已經支持作為 wayland client
運行,這樣可以使用傳統的 X 提供桌面,而讓 wayland system compositor 實現終端切換。這還有一個好處,只有 wayland
system compositor 是以 root 運行的,而用戶會話的 compositor 或 X 就不必以 root 許可權運行。因為 Wayland
非常輕量,所以 system compositor 可以作為系統級服務常駐內存運行。而因為有了 system compositor ,
內核也不再需要實現虛擬終端了:只需要實現終端模擬器作為 system compositor 的 client
。由於是在用戶空間實現的,所有可以加入 UNICODE,矢量字體,國際化的書寫習慣等等的支持,再也不用受限於內核啦。 Wayland
還是一個非常年輕的項目,Wayland system compositor 目前還只是設想中的概念,需要更多的人關注參與。筆者相信不久的將來 wayland
4. 怎樣調整Linux超級終端中字體大小
linux修改終端字體的設置方法,通過console-tools設置控制台字體:
1.選用並測試合適的字體和字型檔文件:
#ls/usr/share/consolefonts/
2.測試選用喜愛的字型檔文件:
#consolechars-f/usr/share/consolefonts/lat9w-16.psf.gz
#consolechars-f/usr/share/consolefonts/lat2-16.psf.gz
3.保存控制台默認字體配置:
#vi/etc/console-tools/config
註:將合適的字型檔文件設置為默認,如果選擇lat2-16.psf.gz 字型檔文件,可將SCREEN_FONT設成:SCREEN_FONT=lat2-16
5. 怎麼才可以弄成很漂亮的linux終端背景,和字體顏色
你說的是Linux終端字體顏色設置吧
教程:http://blog.csdn.net/yanghao23/article/details/6249291
個人建議:先分步寫,最後合成,避免出錯。
方括弧顏色:[e[0;37;40m]
顯示方括弧:[
用戶名顏色:[e[1;32;40m]
顯示用戶名:u
冒號顏色:[e[1;32;40m]
顯示冒號::
當前目錄顏色:[e[1;36;40m]
顯示當前目錄:w
方括弧顏色:[e[0;37;40m]
顯示方括弧:]
$符號顏色:[e[1;35;40m]
顯示一個:$
最後空一格:
命令的顏色:[e[1;33;40m]
#寫好後在.bashrc文件中添加PS1變數:
PS1="[e[0;37;40m][[e[1;32;40m]u:[e[1;36;40m]w[e[0;37;40m]][e[1;35;40m]$[e[1;33;40m]"
效果如圖: