用了好幾年Xfce桌面了,但是從來沒有仔細研究過Xfce底下相關的運行邏輯,最近才對相關的底層概念感興趣並去嘗試瞭解了一下,但是它的體系架構以及複雜的依賴關係令初來乍到者望而卻步。沒辦法,寫點什麼方便理解吧。 這一系列文章主要是探討Xfce底層實現的,不會過多聚焦於美化之類的話題。我的環境是Arch ...
用了好幾年Xfce桌面了,但是從來沒有仔細研究過Xfce底下相關的運行邏輯,最近才對相關的底層概念感興趣並去嘗試瞭解了一下,但是它的體系架構以及複雜的依賴關係令初來乍到者望而卻步。沒辦法,寫點什麼方便理解吧。
這一系列文章主要是探討Xfce底層實現的,不會過多聚焦於美化之類的話題。我的環境是Arch Linux+Xfce,不同發行版的命令可能不同。
XFCE桌面環境
Xfce是桌面環境,用於Unix與Unix-like操作系統,如Linux與FreeBSD。Xfce建基在GTK+之上,它同時為程式設計者提供開發框架。Xfce使用Xfwm作為預設的視窗管理器,亦可搭配Openbox等其他視窗管理器協作。Xfce由許多彼此獨立的組件所構成,除了本身,還有第三方的程式使用Xfce的程式庫,如文本編輯器Mousepad、多媒體播放程式Parole與終端模擬器。(摘自xfce-維基百科)
為了將討論最簡化,下麵列出Xfce桌面最為核心的部件(按Xfce預設會話,已按載入順序排序):
xfce4-session
: Xfce的會話(session)管理器,同時也負責與D-Bus交流xfwm4
: Xfce的視窗管理器,負責與顯示混成器(compositor)進行交流以管理其中顯示的視窗xfsettingsd
: Xfce的設置管理器守護進程(用於Xfconf)xfce4-panel
: Xfce的面板thunar --daemon
: Xfce的文件管理器。這裡只是啟動守護進程xfdesktop
: Xfce桌面本身,負責顯示牆紙和桌面內容;藉助thunar在桌面顯示~/Desktop文件夾內的文件
這些應該是組成桌面環境至少需要的部分。此外還有一些自啟動程式如xfce4-notifyd
等,由於不在最小化session的範圍內,暫時不做討論。
上面出現的不少程式都與Dbus連接或者作為一個用戶級別的systemd單元;同時也有負責與Compositor交流的程式。此外,Xfce是基於GTK3(目前如此)開發的,為了理解xfce的實現必須先對GTK有一定瞭解。還有一點需要補充的是,Xfce遵循著XDG標準,這個又是由freedesktop.org組織提出和維護的。總而言之,為了瞭解Xfce的運行……一步步來吧。
GTK+
一個GUI工具包,在功能上可以認為是對標Qt,負責處理底層渲染以及為上層應用程式提供介面。和Qt不同的是,GTK+中不同的組件都單獨分出了不同的庫文件,主要有:
- Glib: G家最基本的庫,提供了各種數據結構、容器、事件迴圈機制等等…… 這個庫是通用化的,除了GTK之外的程式也可使用它(其實Qt也在使用這個庫)
- GObject: Glib的一部分。提供面向對象功能(畢竟都是用C語言實現的)
- Gio: Glib的一部分。提供IO相關功能(文件流、VFS交互、網路、與D-bus交互等等)
- GDK: 繪圖工具箱。負責基本圖形繪製,與底下的渲染器(cairo、pango等)、Compositor以及Glib進行交流,並向上層的GTK提供服務。
- GTK: 應用程式程式員直接交互的圖形庫。雖然其實程式員也需要直接和Glib打交道。
真是複雜啊,下圖或許能說明GTK中各個組件的關係。話說我直接去調查基於Qt的桌面環境不就不需要掌握一整個全新的圖形工具包了嗎。