linux圖形介面程式設計基本知識(X11, xorg, gdm/gnome)
original url:
https://blogs.gnome.org/raywang/2007/10/11/linux%E5%9B%BE%E5%BD%A2%E7%95%8C%E9%9D%A2%E7%BC%96%E7%A8%8B%E5%9F%BA%E6%9C%AC%E7%9F%A5%E8%AF%86/
以前看過這篇文章,不過當時沒有部落格,現在又一次看到了,記下來:
http://hi.baidu.com/skychen1900/blog/item/9c7b94350a5fae1290ef39fb.html
很多LINUX初學者分不清楚linux和X之間,X和Xfree86之間,X和KDE,GNOME等之間是什麼關係.常常混淆概念,我想以比較易於理 解的方式說明一下X,X11,XFREE,WM,KDE,GNOME等之間的關係.由於本人水平有限可能存在錯誤,請高手指正.
一,linux本身沒有圖形介面,linux現在的圖形介面的實現只是linux下的應用程式實現的.
圖 形介面並不是linux的一部分,linux只是一個基於命令列的作業系統,linux和Xfree的關係就相當於當年的DOS和 WINDOWS3.0一樣,windows3.0不是獨立的作業系統,它只是DOS的擴充,是DOS下的應用程式級別的系統,不是獨立的作業系統,同樣 XFree只是linux下的一個應用程式而已.不是系統的一部分,但是X的存在可以方便使用者使用電腦.WINDOWS95及以後的版本就不一樣了,他們 的圖形介面是作業系統的一部分,圖形介面在系統核心中就實現了,沒有了圖形介面windows就不成為windows了,但linux卻不一樣,沒有圖形 介面linux還是linux,很多裝linux的WEB伺服器就根本不裝X伺服器.這也WINDOWS和linux的重要區別之一.
二,X是協議,不是具體的某個軟體:
X 是協議,就像HTTP協議,IP協議一樣.這個概念很多初學者甚至學習LINUX有一定時間的人都混淆,一個基於X的應用程式需要執行並顯示內容時他就聯 接到X伺服器,開始用X協議和伺服器交談.比如一個X應用程式要在螢幕上輸出一個圓那麼他就用X協議對X伺服器說:喂!我需要在螢幕上畫一個圓.X應用程 序只負責告訴X伺服器在螢幕的什麼地方用什麼顏色畫一個多大的圓,而具體的"畫"的動作,比如這個圓如何生成,用什麼顯示卡的驅動程式去指揮顯示卡完成等等工 作是由X伺服器來完成的.X伺服器還負責捕捉鍵盤和滑鼠的動作,假設X伺服器捕捉到滑鼠的左鍵被按下了,他就告訴X應用程式:親愛的應用程式先生,我發現 滑鼠被按下了,您有什麼指示嗎?如果X應用程式被設計成當按下滑鼠左健後再在螢幕上畫一個正方形的話,X應用程式就對X伺服器說:請再畫一個正方形,當然 他會告訴伺服器在什麼地方用什麼顏色畫多大的正方形,但不關心具體怎麼畫–那是伺服器的事情.
那麼協議是需要具體的軟體來實現的,這就是下面我要講的:
三,X和XFree86的關係.
有 了協議就需要具體的軟體來實現這個協議.就好比我們有了交通法規就需要交警去根據法規維護交通秩序一樣.Xfree86就是這樣一個去根據法規實現協議的 "交警".他按照X協議的規定來完成X應用程式提交的在螢幕上顯示的任務.當然不僅僅是某個特定的交警才可以去維護和實現這個法規,比如還可以由交通協管 員來實現交通法規,必要的時候警察也可以介入,當然前提是他們都要懂得交通法規,也就是要懂得協議.所以實現X協議的軟體也並不只有 XFree86,XFree86只是實現X協議的一個免費X伺服器軟體.商業上常用MOTIF,現在還有XORG,還有很多很小的由愛好者寫的小的X服務 器軟體.甚至可以在WINDOWS上有X伺服器執行,這樣你可以在linux系統上執行一個X應用程式然後在另一臺windows系統上顯示.多麼神奇. 你可以用google找到這樣的X伺服器軟體.只不過在LINUX上最常用的是XFree86.(現在的linux發行版都用Xorg了)順便說一句,蘋 果電腦的圖形介面用的也是X協議,而且被認為是做的最好的X協議圖形介面,並且他對X協議的實施是做在系統核心裡的,所以效能明顯好很多,這就是為什麼很 多大型三維圖形設計軟體都是在蘋果平臺上的原因.
為了便於理解拿HTTP協議來比較:
協議是HTTP (hyper text transmission protocol)
實現這個協議的常用伺服器有:apache IIS 等
請求這些伺服器傳輸檔案的客戶有:IE ,MOZILLA ,NETSCAPE等.
協議是X
實現這個協議的常用伺服器有Xfree86 ,Xorg ,Xnest等
請求這些伺服器來完成顯示任務的客戶:所有的X應用程式.
只 不過HTTP協議的伺服器和客戶端通常都在兩臺不同的電腦(伺服器和客戶機)之間來實現,所以一般人對這個比較容易理解.而X協議的伺服器和客戶端程式通 常在同一臺電腦上,因此很多使用者都感到對此很難理解.既然是協議,那麼肯定和平臺無關的,因此可以讓X應用程式顯示在任何裝有X伺服器的遠端計算機上.甚 至顯示在裝有Xnest伺服器的windows系統上.只不過在大多數情況下,X應用程式都用本機的X伺服器,然後X伺服器將顯示結果輸出到本機的顯示 器.這也是很多人不理解X是一種協議的原因.
四,X和X11R6又是什麼關係?
不知道初學者有沒有注意到/usr/X11R6這個目錄,這是XFree的預設安裝目錄
X11R6 實際上是 X Protocol version 11 Release 6
(X協議第11版第六次發行)的意思,就是說目前用的X協議是第11版的,然後經過了6次小的修正.不同版本的X協議是不能通訊的.就象我們現在IPV4和IPV6不能通訊一樣,不過不用擔心,現在的X伺服器軟體和X應用程式都遵循X11R6.
另外XFree86 3.3.6 XFree86 4.3.6 等這些版本是實現X協議的軟體XFree86的版本號.這是初學者經常高混淆的概念.
協議版本和實現協議的軟體的版本–這兩個概念的區別你分清楚了嗎?
五,X伺服器和WM(window manager 視窗管理器)之間是什麼關係.
平時大家起動圖形介面是怎麼啟動的呢?
如果你是一開己就進入圖形介面那就太遺憾了.應為你錯過了瞭解X伺服器起動過程的好時機.不過沒關係.你開啟一個XTERM輸入:
init 3
就可以安全的回到字元介面.
好了,等做完以下實驗你就完全明白X和WM(window manager 視窗管理器)之間是什麼關係了.
先輸入以下命令:
#startx
起動圖形介面,你看到的是一個和平時使用一樣的完整的圖形介面操作環境.
你可以最大化,最小化,移動,關閉視窗等.
按ctrl+alt+backspace反回字符介面.
輸入:
#xinit
再次啟動圖形介面,你看到了什麼,你看到一個XTERM.而且不能移動.但是你可以在這個XTERM中輸入命令開啟X應用程式,如果我輸入:
#mozilla
開啟瀏覽器,你看到的瀏覽器和平時有什麼不同嗎?他在螢幕中間,不能移動,不能最小化,不能最大化,沒有邊框.
為什麼同樣一個X應用程式會有這樣的不同呢?因為我們用startx起動圖形介面的時候同時也啟動了一個WM(即視窗管理器),如果你用KDE就起動了KDE,如果你用GNOME就起動了GNOME.但是你用xinit起動圖形介面的時候卻沒有起動WM.
現在你明白視窗管理器的作用了嗎?他的作用就是最大化,最小化,移動,關閉視窗等.而這些不是X伺服器來負責完成的.
如果你用xinit起動圖形介面並在xterm中輸入twm,看看會有什麼?
xterm被加上了一個邊框,你可以通過這個邊框移動,最大化,最小化這個xterm,twm就是XFree86中自帶的視窗管理器,是一個比較簡陋的最簡單的視窗管理器,但是他具有視窗管理器的全部特徵.
如果你不輸入twm而輸入gnome-session就可以起動GNOME
或者輸入startkde起動KDE.
通過以上的實驗你就可以清楚的明白他們之間的關係.
六,關於KDE和GNOME
KDE 和GNOME是LINUX裡最常用的圖形介面操作環境,他們不僅僅是一個視窗管理器那麼簡單, KDE是K Desktop Environment 的縮寫.他不僅是一個視窗管理器,還有很多配套的應用軟體和方便使用的桌面環境,比如工作列,開始選單,桌面圖示等等.
GNOME是GNU Network Object Model Environment 的縮寫.和KDE一樣,也是一個功能強大的綜合環境.
另外在其它UNIX系統中,常常使用CDE作為這樣一個環境.
其它的小型視窗管理器有:
window maker,after step,blackbox,fvwm,fvwm2,等等都是常用的優秀視窗管理器.REDHAT9中有 window maker 但是預設不安裝,大家可以裝來試試.只要xinit再wmaker&就可以用windowmaker了.
七,linux圖形介面層次關係總結
linux本身–>X伺服器<-[通過X協議交談]->視窗管理器(綜合桌面環境)–>X應用程式.
Xfree86伺服器的實現包括兩個部分,一部分是和顯示卡直接打交道的低層,一部分是和X應用程式打交道的上層.上層負責接收應用程式的請求和滑鼠鍵盤 的動作.而和顯示卡直接打交道的底層負責指揮顯示卡生成圖形,其實就是顯示卡驅動.上層接收到應用程式的請求後,將請求內容做適當處理,然後交給顯示卡驅動來指揮 顯示卡完成畫圖的動作.另外,上層的捕捉鍵盤和滑鼠動作的部分會嚮應用程式提供滑鼠和鍵盤的狀態資訊,應用程式接收到這些資訊後決定是否再有相應的動作.
平時說的VESA,VGA ,fbdev等其實就是針對不同模式顯示卡的驅動程式.
VESA(Video Electronics Standards Association)
VGA (Video Graphics Array)
fbdev (FrameBuffer Device)
等
都是不同的顯示卡標準,不過這些標準都已經很老了.現在的顯示卡都相容這幾種模式.
framebuffer模式的顯示卡本身不具有任何運算資料的能力,他好比是一個暫時存放水的水池.CPU將運算後的結果放到這個水池,水池再將結果流到顯示器.中間不會對資料做處理.在這中情況下,所有顯示任務都有CPU完成,CPU負擔很重.
從frambuffer這個名字我們就能猜測到他的功能了(資料偵緩衝).
在linux核心中有有framebuffer機制,摹仿framebuffer顯示卡的這種功能.他的好處是把顯示卡的硬體結構抽象掉,把所有的顯示卡都當做一個"水池"來用.應用程式也可以直接讀取這個水池的內容.framebuffer的裝置名是 /dev/fb
可以用命令:
#dd if=/dev/zero of=/dev/fb
清空螢幕.如果你的X用的是framebuffer的驅動,螢幕將全變黑.通過移動滑鼠,切換視窗等動作可以讓原先的內容重新顯示.
如果你不用framebuffer驅動,可以在字元模式下做這個試驗.螢幕將全部被清空.
以下的命令:
#dd if=/dev/fb of=fbfile
可以將fb中的內容儲存下來,以後可以重新寫回螢幕:
#dd if=fbfile of=/dev/fb
作用類似於螢幕截圖,但是截下的圖不能用普通圖片瀏覽器看.
現在知道linux中framebuffer裝置的神奇了吧.
linux字元介面在高解析度下,啟動時會有一個小企鵝logo,這個logo就是用framebuffer功能寫上螢幕的.
VESA和VGA比FB要好很多,但是他的顯示能力也很有限.CPU仍舊要處理大部分的顯示任務.
現 在的顯示卡就不一樣了,CPU幾乎不引數顯示任務,而專注於運算工作.我們平時在linux下裝顯示卡驅動,其實就是替換掉XFree86中底層的那一部分. 使他有更強的顯示能力.比如你的顯示卡是nvidia的,XFree預設的驅動是"nv",他是一個nvidia顯示卡的通用驅動,但是他不能發揮 nvidia顯示卡的效能.這個"nv"驅動模組可以在:
/usr/X11R6/lib/modules/drivers
目錄下找到,檔名是:nv_drv.o
這個目錄下還有很多顯示卡驅動模組.
apm_drv.o dummy_drv.o nsc_drv.o sis_drv.o
ark_drv.o fbdev_drv.o nv_drv.o tdfx_drv.o
ati_drv.o glint_drv.o r128_drv.o tga_drv.o
atimisc_drv.o i128_drv.o radeon_drv.o trident_drv.o
chips_drv.o i740_drv.o rendition_drv.o tseng_drv.o
cirrus_alpine.o i810_drv.o s3_drv.o vesa_drv.o
cirrus_drv.o linux s3virge_drv.o vga_drv.o
cirrus_laguna.o mga_drv.o savage_drv.o
cyrix_drv.o neomagic_drv.o siliconmotion_drv.o
fbdev vga evsa 等都在其中.
只要在XF86Conf檔案中的Section module段中指定了什麼驅動,X就用哪個驅動.
程式碼:
Section "Module"
Load "dbe"
Load "extmod"
Load "fbdevhw" #這裡用的是fbdev
Load "glx"
Load "record"
Load "freetype"
Load "type1"
Load "dri"
EndSection
這是XFree86 4.0以上版本的方法.即X主程式和驅動模組是分開的.
主程式是/usr/X11R6/bin/XFree86 (即上層部分)
然後主程式啟動的時候根據配置檔案決定用哪一個驅動.
但是,在XFree86以前的版本(3.3.6)中, X主程式和驅動模組是合在一起的,因此,以前的Xfree86 3.3.6 有很多針對不同顯示卡的版本.
另外其他的X伺服器如KDrive 也是驅動也主程式整合的,因此同樣是KDrive X伺服器會有 VESA ,SVGA ,和 fbdev的版本之分.因為這些都是輕量級的X伺服器,為了簡化結構他做成這樣.
Xfree86 4 做成驅動和主程式分離的好處是使用者可以自己添加升級驅動.