Qt學習之 Qss筆記

2021-10-10 16:54:23 字數 4190 閱讀 8043

在此之前說乙個幫助文件的特別用法,絕不僅僅是搜單詞,qt的文件非常強大的,比如你要搜尋怎麼使用qss,可以這樣搜尋:how to use stylesheet

三 通過qt4.2樣式表定製程式外觀

目錄何為qt樣式表

樣式表語法基礎

方箱模型

前景與背景

建立可縮放樣式

控制大小

處理偽狀態

使用子部件定義微觀樣式

8.1. 相對定位

8.2. 絕對定位

摘要由於qt樣式表的引入,定製qt部件的外觀樣式變得非常簡單。 無論你是想僅僅修改乙個現有部件的外觀,還是想從零開始設計一套全新的介面風格, 現在都有了一種新的方法而不必再去繼承並實現乙個qstyle的子類。

何為qt樣式表

樣式表是通過qstyle的乙個叫做qstylesheetstyle的特殊子類來實現的。 這個特殊的子類實際上是其他的系統特定風格類的包裹類, 它會把通過樣式表指定的自定義外觀風格應用在底層的系統特定風格之上。

qt 4.2包含了乙個叫做stylesheet的例子來幫助你學習樣式表, 這個例子自帶了兩個樣式:coffee和pagefold。

上面的coffee風格自定義了push button、frames和tooltip,但使用了下層的風格 (例如這裡是windows xp風格)來繪製checkbox,combobox和radio button。

pagefold風格完全重新定義了對話方塊中使用的所有控制項的外觀,從而實現了一種獨特的,平台無關的外觀。

樣式表語法基礎

qt樣式表與css的語法規則幾乎完全相同,如果你已經了解了css,完全可以跳過本節。

乙個樣式表由一系列的樣式規則構成。每個樣式規則都有著下面的形式:

selector

選擇器(selector)部分通常是乙個類名(例如qcombobox),當然也還有其他的語法形式。

屬性(attribute)部分是乙個樣式表屬性的名字,值(value)部分是賦給該屬性的值。

為了使用方便,我們還可以使用一種簡化形式:

selector1, selector2, …, selectorm

這種簡化形式可以同時為與m個選擇器相匹配的部件設定n種屬性。例如:

qcheckbox, qcombobox, qspinbox

同時,我們也可以分別指定margin-top、margin-right、margin-bottom、margin-left四個屬性。

qframe

雖然目前我們僅僅使用了qframe作為例子,但是我們也可以同樣的將這些屬性應用於任何乙個支援方箱模型的qt部件,例如:qcheckbox、 qlabel、qlineedit、qlistview、qmenu、qpushbutton、qtextedit、和qtooltip。

建立可縮放樣式

在預設情況下,通過background-image指定的背景會自動重複平鋪,以覆蓋部件的整個填充矩形(即邊框裡面的那個區域)。如果我們想建立能夠隨著部件大小自動縮放而不是平鋪的背景,我們需要設定一種稱之為「邊框」的東東。

「邊框」可以通過border-image屬性指定,它同時提供了部件的背景和邊框。乙個「邊框」被分為九個部分(九宮格),有點向tic-tac-toe遊戲的棋盤。

當乙個部件的邊框被填充時,四角的格仔通常不會發生變化,而其餘的五個格仔則可能被拉伸或平鋪以填充可用空間。

當指定乙個「邊框」時,除了本身,我們還必須指定用來分割九宮格的四條分割線。同時我們還必須指定非邊角的格仔是應該平鋪還是拉伸,以及邊框的寬度(用來確定邊角格仔的大小,防止邊角被縮放變形)。

例如,下面的樣式表定義了上圖中的button:

qpushbutton

另外,「邊框」還應該含有alpha通道,以使背景能夠在邊角處露出來。

控制大小

min-width和min-height兩個屬性可以用來指定乙個部件的內容區域的最小大小。這兩個值將影響部件的minimumsizehint(),並在布局時被考慮。

例如:qpushbutton

如果該屬性沒有被指定,最小大小將從部件的內容區域和當前樣式中繼承。

處理偽狀態

部件的外觀可以按照使用者介面元素狀態的不同來分別定義,這在樣式表中被稱為「偽狀態」。例如,如果我們想在乙個push button在被按下的時候具有sunken的外觀,我們可以指定乙個叫做 :pressed 的偽狀態。

qpushbutton

qpushbutton:pressed

下面是可用的偽狀態列表:

表 1. 偽狀態列表

偽狀態 描述

:checked button部件被選中

:disabled 部件被禁用

:enabled 部件被啟用

:focus 部件獲得焦點

:hover 滑鼠位於部件上

:indeterminate checkbox或radiobutton被部分選中

:off 部件可以切換,且處於off狀態

:on 部件可以切換,且處於on狀態

:pressed 部件被滑鼠按下

:unchecked button部件未被選中

使用子部件定義微觀樣式

許多部件都包含有子元素,這些元素可以稱為「子部件」。spin box的上下箭頭就是子部件最好的例子。

子部件可以通過::來指定,例如qdatetimeedit::up-button。定義子部件的樣式與定義部件非常相似,它們遵循前面提到的方箱模型(即它們可以擁有自己的邊框、背景等),並且也可以和偽狀態聯合使用(例如qspinbox::up-button:hover)。

下表列出了可用的子部件型別:

表 2. 子部件列表

子部件 描述

::down-arrow combo box或spin box的下拉箭頭

::down-button spin box的向下按鈕

::drop-down combo box的下拉箭頭

::indicator checkbox、radio button或可選擇group box的指示器

::item menu、menu bar或status bar的子專案

::menu-indicator push button的選單指示器

::title group box的標題

::up-arrow spin box的向上箭頭

::up-button spin box的向上按鈕

通過指定subcontrol-position和subcontrol-origin屬性,子部件可以被放置在部件箱體內的任何位置。並且,子部件的位置還可以使用相對或絕對的方式進一步的調整。具體選擇何種調整方式取決於子部件具有固定的大小,還是會隨著父部件而變化。

8.1. 相對定位

相對定位適合於子部件具有固定大小的情形(通過width和height指定子部件大小)。使用這種方式,子部件可以以相對於subcontrol-position和 subcontrol-origin屬性定義的原始位置進行移動調整。使用left屬性可以把子部件向右移,top屬性可以把子部件向左移。

例如:qpushbutton::menu-indicator

8.2. 絕對定位

絕對定位適合於子部件的位置隨父部件的變化而變的情形。與前面的例子相同,subcontrol-origin定義了父部件箱體的參考矩形。子部件的矩形區域則可以隨後通過相對於這個參考矩形四邊的偏移量來定義。

qpushbutton::menu-indicator {

border: 2px solid red;

subcontrol-origin: padding;

position: absolute;

top: 2px;

right: 2px;

bottom: 2px;

left: 40px;

對於寬度或高度固定的子部件,subcontrol-position被用來說明其在subcontrol-origin指定矩形內的對其方式:

qpushbutton::menu-indicator {

image: url(menu_indicator.png);

width: 13px;

subcontrol-origin: padding;

subcontrol-position: bottom right;

position: absolute;

top: 2px;

bottom: 2px;

right: 2px;

五 樣式表使用

Qt筆記 qss定製QCalendarWidget

由於qcalendarwidget是qt的一種複雜控制項,故除了qss外,還需要進行一些 編寫以達到定製效果 if p inherits qcalendarwidget 更改當前的語言顯示 csq pcalendarwidget setlocale qlocale english 將週日放到前面 p...

Qt之QSS(動態屬性)

qss可以定製應用程式的外觀,無需關注qt樣式背後的魔力。從非常輕微到極其複雜的調整,樣式表都可以做到。對於乙個完全定製和獨特的使用者體驗,qtquick和qgraphicsview是更好的選擇。更多參考 為了使用者介面外觀的動態變化,屬性選擇器可以與動態屬性組合使用。動態屬性在qt4.2中引入,允...

QT開發之QSS控制項

1 多選按鈕 ui checkbox setstylesheet qcheckbox qcheckbox indicator 未選中時正常狀態 qcheckbox indicator unchecked 未選中時,滑鼠懸停時的狀態 qcheckbox indicator unchecked hove...