一、導(dǎo)讀
本質(zhì)上,Qt Designer的ui文件是一個(gè)以XML格式書(shū)寫(xiě)的文件,文件中內(nèi)容描述了一個(gè)界面的widget關(guān)系樹(shù)。這個(gè)文件在以下兩種情況中會(huì)使用到:
(1)在編譯的時(shí)候,這意味著ui文件將被轉(zhuǎn)換為可編譯的C++代碼,這個(gè)過(guò)程由uic完成。
(2)在應(yīng)用程序運(yùn)行的時(shí)候,ui文件將由QUiLoader類(lèi)處理,該類(lèi)用于解析XML文件并動(dòng)態(tài)構(gòu)造widget樹(shù)。
本文描述第一種情況:在編譯的時(shí)候使用ui文件。描述ui文件背后的機(jī)制,以及如何在應(yīng)用程序中使用設(shè)計(jì)好的ui文件。
二、編譯過(guò)程中對(duì)ui文件的處理
在實(shí)際項(xiàng)目開(kāi)發(fā)中,使用Qt Designer創(chuàng)建用戶(hù)界面組件(當(dāng)然也完全可以使用代碼描述),并使用Qt的集成構(gòu)建工具qmake和uic在構(gòu)建應(yīng)用程序時(shí)生成中間代碼,這個(gè)過(guò)程是由集成開(kāi)發(fā)環(huán)境完成的。生成的代碼包含了ui文件中描述的用戶(hù)界面對(duì)象,它是一個(gè)C++結(jié)構(gòu)體,包含以下內(nèi)容:
(1)指向窗體小部件、布局、布局項(xiàng)、按鈕組和操作的指針。
(2)名為setupUi()的成員函數(shù),用于在父部件上構(gòu)建部件樹(shù)。
(3)名為retranslateUi()的成員函數(shù),用于處理ui文件字符串屬性的轉(zhuǎn)換。
生成的代碼可以在應(yīng)用程序中包含,并可以直接使用。除此之外,還可以用于擴(kuò)展標(biāo)準(zhǔn)小部件的子類(lèi)。
了解了QtCreator對(duì)ui文件背后的處理機(jī)制,下文將來(lái)看看如何在編譯構(gòu)建過(guò)程中使用ui文件。
三、在編譯過(guò)程中如何使用ui文件
主要有三種方法在編譯過(guò)程中使用ui文件:1、直接附加、2、單繼承方式、3、多繼承方式。
1、直接附加:構(gòu)造一個(gè)小部件作為組件的占位符,并在其中設(shè)置用戶(hù)界面。
2、單繼承方式:子類(lèi)化Qt標(biāo)準(zhǔn)界面元素的基類(lèi)(例如QWidget或QDialog),并包含ui用戶(hù)界面對(duì)象的私有實(shí)例。
3、多繼承方式:將ui文件的基類(lèi)和ui文件的用戶(hù)接口對(duì)象都子類(lèi)化。因此這可以在從子類(lèi)的范圍內(nèi)直接使用ui文件中定義的小部件。
(3-1)直接附加方式
本文中,筆者創(chuàng)建一個(gè)名為widget.ui的ui文件:
為了使用直接附加的方法使用ui文件,直接在main.cpp中包含ui_widget.h文件:
#include"ui_widget.h"
然后在主函數(shù)中構(gòu)造一個(gè)標(biāo)準(zhǔn)的QWidget,用于創(chuàng)建widget小部件,接著我們則使用這個(gè)QWidget來(lái)托管由widget描述的用戶(hù)界面ui文件,完整代碼如下:
#include"ui_widget.h" intmain(intargc,char*argv[]) { QApplicationapp(argc,argv); QWidget*w=newQWidget; Ui::Widgetui; ui.setupUi(w); w->show(); returnapp.exec(); }
直接附加方法是一種在應(yīng)用程序中快速使用組件的簡(jiǎn)單方法。但是在實(shí)際開(kāi)發(fā)中,使用Qt Designer創(chuàng)建的組件通常需要與應(yīng)用程序的其余代碼進(jìn)行緊密的集成。例如,上面提供的widget代碼將編譯并運(yùn)行,但是界面中的對(duì)象之間不會(huì)進(jìn)行交互。為了實(shí)現(xiàn)界面中對(duì)象之間的交互,則需要使用單繼承方式。
(3-2)單繼承方式
使用單繼承方式,需要子類(lèi)化一個(gè)標(biāo)準(zhǔn)的Qt小部件,并在其中包括ui用戶(hù)界面對(duì)象的私有實(shí)例。可以采取以下兩種方式的任意一種:
(1)成員變量方式
(2)指向成員變量的指針
『成員變量方式』
在這種方法中,子類(lèi)化一個(gè)Qt小部件,并在構(gòu)造函數(shù)中setupUi()用戶(hù)界面。以這種方式使用的組件會(huì)將ui文件中使用的小部件和布局公開(kāi)給Qt小部件子類(lèi),并提供一個(gè)標(biāo)準(zhǔn)系統(tǒng),用于在用戶(hù)界面和應(yīng)用程序中的其他對(duì)象之間建立信號(hào)和槽函數(shù)連接。
為了確保可以正常使用用戶(hù)界面,需要在子類(lèi)化的Qt小部件描述文件中包含uic生成的頭文件,然后引用Ui::Widget(本文是Widget.ui界面文件):
子類(lèi)化一個(gè)Qt小部件子類(lèi)的構(gòu)造函數(shù)通過(guò)調(diào)用ui對(duì)象的setupUi()函數(shù)來(lái)構(gòu)造和配置界面中的所有小部件和布局:
這種方法的優(yōu)點(diǎn)是:簡(jiǎn)單使用繼承來(lái)提供基于QWidget的接口,并將用戶(hù)界面小部件變量封裝在ui數(shù)據(jù)成員中。我們可以使用這個(gè)方式在同一個(gè)小部件中定義多個(gè)用戶(hù)界面,每個(gè)界面都包含在自己的名稱(chēng)空間中,并可以覆蓋(或組合)它們。
『指向成員變量的指針』
采用這種方式,在ui用戶(hù)界面對(duì)象的寫(xiě)法上就變成了指向Ui::Widget的指針,且在名稱(chēng)空間中對(duì)界面對(duì)象進(jìn)行了提前聲明:
對(duì)應(yīng)的源文件則是:
這種方法的優(yōu)點(diǎn)是:用戶(hù)界面對(duì)象可以預(yù)先聲明,這意味著不必在頭文件中包含生成的ui_Widget.h文件,然后可以在不重新編譯相關(guān)源文件的情況下更改ui文件。
可見(jiàn),這兩種方法都能使用ui文件,但推薦使用指向成員變量的指針的方式使用ui文件,這也是庫(kù)和大型應(yīng)用程序開(kāi)發(fā)的方法,況且使用QtCreator新文件創(chuàng)建向?qū)砑拥膗i界面類(lèi)則是以這種方式生成的代碼。
(3-3)多繼承方式
使用Qt Designer創(chuàng)建的ui文件可以與標(biāo)準(zhǔn)的基于QWidget的類(lèi)一起子類(lèi)化。通過(guò)這種方式,則可以在子類(lèi)的范圍內(nèi)直接訪問(wèn)ui文件中定義的所有用戶(hù)界面組件,并能夠使用connect()函數(shù)建立界面對(duì)象之間的信號(hào)和槽函數(shù)連接。
本文創(chuàng)建了Widget.ui界面描述文件,首先則需要在子類(lèi)中包含使用uic生成的頭文件:
#include"ui_widget.h"
接著在這個(gè)類(lèi)的定義中需繼承QWidget和Ui::Widget,可以私有的繼承Ui::Widget,以確保用戶(hù)界面對(duì)象在子類(lèi)中是私有的。當(dāng)然還可以使用public或protected關(guān)鍵字,就像在前面的例子中可以設(shè)置ui為public或protected一樣。如下所示:
對(duì)應(yīng)的源碼文件則是:
在多繼承方式中,用戶(hù)界面中使用的小部件的訪問(wèn)方式與手工在代碼中創(chuàng)建的小部件的一樣。除此之外,我們不再需要ui前綴來(lái)訪問(wèn)這些小部件了。
四、總結(jié)
以上三種在應(yīng)用程序編譯時(shí)使用ui文件的方法,其目的都是以如何在應(yīng)用程序設(shè)計(jì)和編寫(xiě)中使用UI文件為目的展開(kāi)的。直接附加方法較為簡(jiǎn)單,在開(kāi)發(fā)中幾乎不使用。單繼承方式較為常用,其次是多繼承方式。
審核編輯:湯梓紅
-
XML
+關(guān)注
關(guān)注
0文章
188瀏覽量
33563 -
文件
+關(guān)注
關(guān)注
1文章
578瀏覽量
25206 -
函數(shù)
+關(guān)注
關(guān)注
3文章
4371瀏覽量
64202 -
C++
+關(guān)注
關(guān)注
22文章
2117瀏覽量
74780 -
Qt
+關(guān)注
關(guān)注
1文章
313瀏覽量
38801
原文標(biāo)題:玩Qt,這三種使用ui文件的方式不得不知!
文章出處:【微信號(hào):嵌入式小生,微信公眾號(hào):嵌入式小生】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
伺服電機(jī)的三種控制方式
debugInRam,與debuginflash,reinflash這三種燒寫(xiě)方式有什么區(qū)別?
stm32的三種編程下載方式
請(qǐng)問(wèn)stm32啟動(dòng)的三種方式是什么意思?
在main函數(shù)運(yùn)行之前,你不得不知的那些事
STM32支持三種啟動(dòng)方式
如何使用三種方式進(jìn)行文件的創(chuàng)建
伺服電機(jī)的三種控制方式該如何應(yīng)用
如何應(yīng)用伺服電機(jī)的三種控制方式

8051單片機(jī)的這三種數(shù)據(jù)傳輸方式,你了解多少?

評(píng)論