0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

玩Qt,這三種使用ui文件的方式不得不知!

嵌入式小生 ? 來源:嵌入式小生 ? 2023-01-31 13:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、導(dǎo)讀

本質(zhì)上,Qt Designer的ui文件是一個以XML格式書寫的文件,文件中內(nèi)容描述了一個界面的widget關(guān)系樹。這個文件在以下兩種情況中會使用到:

(1)在編譯的時候,這意味著ui文件將被轉(zhuǎn)換為可編譯的C++代碼,這個過程由uic完成。

(2)在應(yīng)用程序運行的時候,ui文件將由QUiLoader類處理,該類用于解析XML文件并動態(tài)構(gòu)造widget樹。

本文描述第一種情況:在編譯的時候使用ui文件。描述ui文件背后的機制,以及如何在應(yīng)用程序中使用設(shè)計好的ui文件。

二、編譯過程中對ui文件的處理

在實際項目開發(fā)中,使用Qt Designer創(chuàng)建用戶界面組件(當(dāng)然也完全可以使用代碼描述),并使用Qt的集成構(gòu)建工具qmake和uic在構(gòu)建應(yīng)用程序時生成中間代碼,這個過程是由集成開發(fā)環(huán)境完成的。生成的代碼包含了ui文件中描述的用戶界面對象,它是一個C++結(jié)構(gòu)體,包含以下內(nèi)容:

(1)指向窗體小部件、布局、布局項、按鈕組和操作的指針。

(2)名為setupUi()的成員函數(shù),用于在父部件上構(gòu)建部件樹。

(3)名為retranslateUi()的成員函數(shù),用于處理ui文件字符串屬性的轉(zhuǎn)換。

生成的代碼可以在應(yīng)用程序中包含,并可以直接使用。除此之外,還可以用于擴展標(biāo)準(zhǔn)小部件的子類。

了解了QtCreator對ui文件背后的處理機制,下文將來看看如何在編譯構(gòu)建過程中使用ui文件。

三、在編譯過程中如何使用ui文件

主要有三種方法在編譯過程中使用ui文件:1、直接附加、2、單繼承方式、3、多繼承方式。

1、直接附加:構(gòu)造一個小部件作為組件的占位符,并在其中設(shè)置用戶界面。

2、單繼承方式:子類化Qt標(biāo)準(zhǔn)界面元素的基類(例如QWidget或QDialog),并包含ui用戶界面對象的私有實例。

3、多繼承方式:將ui文件的基類和ui文件的用戶接口對象都子類化。因此這可以在從子類的范圍內(nèi)直接使用ui文件中定義的小部件。

(3-1)直接附加方式

本文中,筆者創(chuàng)建一個名為widget.ui的ui文件:

7580f59e-a121-11ed-bfe3-dac502259ad0.png


為了使用直接附加的方法使用ui文件,直接在main.cpp中包含ui_widget.h文件:

#include"ui_widget.h"

然后在主函數(shù)中構(gòu)造一個標(biāo)準(zhǔn)的QWidget,用于創(chuàng)建widget小部件,接著我們則使用這個QWidget來托管由widget描述的用戶界面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)用程序中快速使用組件的簡單方法。但是在實際開發(fā)中,使用Qt Designer創(chuàng)建的組件通常需要與應(yīng)用程序的其余代碼進行緊密的集成。例如,上面提供的widget代碼將編譯并運行,但是界面中的對象之間不會進行交互。為了實現(xiàn)界面中對象之間的交互,則需要使用單繼承方式。

(3-2)單繼承方式

使用單繼承方式,需要子類化一個標(biāo)準(zhǔn)的Qt小部件,并在其中包括ui用戶界面對象的私有實例??梢圆扇∫韵聝煞N方式的任意一種:

(1)成員變量方式

(2)指向成員變量的指針

成員變量方式

在這種方法中,子類化一個Qt小部件,并在構(gòu)造函數(shù)中setupUi()用戶界面。以這種方式使用的組件會將ui文件中使用的小部件和布局公開給Qt小部件子類,并提供一個標(biāo)準(zhǔn)系統(tǒng),用于在用戶界面和應(yīng)用程序中的其他對象之間建立信號和槽函數(shù)連接。

為了確??梢哉J褂糜脩艚缑?,需要在子類化的Qt小部件描述文件中包含uic生成的頭文件,然后引用Ui::Widget(本文是Widget.ui界面文件):

7591f6dc-a121-11ed-bfe3-dac502259ad0.png


子類化一個Qt小部件子類的構(gòu)造函數(shù)通過調(diào)用ui對象的setupUi()函數(shù)來構(gòu)造和配置界面中的所有小部件和布局:

75a13304-a121-11ed-bfe3-dac502259ad0.png


這種方法的優(yōu)點是:簡單使用繼承來提供基于QWidget的接口,并將用戶界面小部件變量封裝在ui數(shù)據(jù)成員中。我們可以使用這個方式在同一個小部件中定義多個用戶界面,每個界面都包含在自己的名稱空間中,并可以覆蓋(或組合)它們。

指向成員變量的指針

采用這種方式,在ui用戶界面對象的寫法上就變成了指向Ui::Widget的指針,且在名稱空間中對界面對象進行了提前聲明:

75c1abde-a121-11ed-bfe3-dac502259ad0.png


對應(yīng)的源文件則是:

75cf59aa-a121-11ed-bfe3-dac502259ad0.png


這種方法的優(yōu)點是:用戶界面對象可以預(yù)先聲明,這意味著不必在頭文件中包含生成的ui_Widget.h文件,然后可以在不重新編譯相關(guān)源文件的情況下更改ui文件。

可見,這兩種方法都能使用ui文件,但推薦使用指向成員變量的指針的方式使用ui文件,這也是庫和大型應(yīng)用程序開發(fā)的方法,況且使用QtCreator新文件創(chuàng)建向?qū)砑拥膗i界面類則是以這種方式生成的代碼。

(3-3)多繼承方式

使用Qt Designer創(chuàng)建的ui文件可以與標(biāo)準(zhǔn)的基于QWidget的類一起子類化。通過這種方式,則可以在子類的范圍內(nèi)直接訪問ui文件中定義的所有用戶界面組件,并能夠使用connect()函數(shù)建立界面對象之間的信號和槽函數(shù)連接。

本文創(chuàng)建了Widget.ui界面描述文件,首先則需要在子類中包含使用uic生成的頭文件:

#include"ui_widget.h"

接著在這個類的定義中需繼承QWidget和Ui::Widget,可以私有的繼承Ui::Widget,以確保用戶界面對象在子類中是私有的。當(dāng)然還可以使用public或protected關(guān)鍵字,就像在前面的例子中可以設(shè)置ui為public或protected一樣。如下所示:

75db84dc-a121-11ed-bfe3-dac502259ad0.png


對應(yīng)的源碼文件則是:

75ea0746-a121-11ed-bfe3-dac502259ad0.png


在多繼承方式中,用戶界面中使用的小部件的訪問方式與手工在代碼中創(chuàng)建的小部件的一樣。除此之外,我們不再需要ui前綴來訪問這些小部件了。

四、總結(jié)

以上三種在應(yīng)用程序編譯時使用ui文件的方法,其目的都是以如何在應(yīng)用程序設(shè)計和編寫中使用UI文件為目的展開的。直接附加方法較為簡單,在開發(fā)中幾乎不使用。單繼承方式較為常用,其次是多繼承方式。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • XML
    XML
    +關(guān)注

    關(guān)注

    0

    文章

    188

    瀏覽量

    33671
  • 文件
    +關(guān)注

    關(guān)注

    1

    文章

    578

    瀏覽量

    25287
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4377

    瀏覽量

    64553
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2118

    瀏覽量

    74969
  • Qt
    Qt
    +關(guān)注

    關(guān)注

    2

    文章

    314

    瀏覽量

    38961

原文標(biāo)題:玩Qt,這三種使用ui文件的方式不得不知!

文章出處:【微信號:嵌入式小生,微信公眾號:嵌入式小生】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 0人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    伺服電機的三種控制方式

    伺服電機控制方式有脈沖、模擬量和通訊這三種,在不同的應(yīng)用場景下,我們該如何選擇伺服電機的控制方式呢?
    發(fā)表于 08-17 11:01 ?7442次閱讀

    debugInRam,與debuginflash,reinflash這三種燒寫方式有什么區(qū)別?

    我買的是一個lpc2131的arm板子然后總是出現(xiàn)以下情況,我用的是jlink,這樣之后就沒法燒代碼了,然后只有用j-tag燒寫之后才能重新編碼?我用的燒寫方式是debugInRam,另外與debuginflash,reinflash這三種
    發(fā)表于 02-20 18:34

    模電設(shè)計不得不看——模擬電路設(shè)計原則

    模電設(shè)計不得不看——模擬電路設(shè)計原則
    發(fā)表于 08-17 21:26

    不得不看的藍(lán)牙4.0組網(wǎng)實驗教程

    不得不看的藍(lán)牙4.0組網(wǎng)實驗教程
    發(fā)表于 02-26 16:33

    stm32的三種編程下載方式

    J-link幾乎可以調(diào)試所有的arm芯片,不得不說是個好東東。這里記錄三種stm32的下載程序方式:1.J-Flash下載(需要用到J-link)2.MDK配置下載(需要用到J-link)3.ISP
    發(fā)表于 06-24 20:50

    請問stm32啟動的三種方式是什么意思?

    請群主詳細(xì)解釋下這三種啟動方式,看了參考資料不是很明白其意!謝謝!
    發(fā)表于 07-17 04:35

    伺服電機的三種控制方式怎么選

    一般伺服都有三種控制方式:速度控制方式,轉(zhuǎn)矩控制方式,位置控制方式。大多數(shù)人想知道的就是這三種
    發(fā)表于 01-29 07:28

    在main函數(shù)運行之前,你不得不知的那些事

    在main函數(shù)運行之前,不得不知的那些事在c_int00函數(shù)中完成的功能有哪些?
    發(fā)表于 04-20 06:03

    設(shè)計PCB不得不關(guān)注的重點

    設(shè)計PCB不得不關(guān)注的重點
    發(fā)表于 04-21 06:24

    STM32支持三種啟動方式

    正文不得不提的啟動方式STM32支持三種啟動方式 1. FLASH啟動 2. SRAM啟動 3. 系統(tǒng)存儲器啟動這三種啟動順序決定了上電后第
    發(fā)表于 08-23 06:03

    如何使用三種方式進行文件的創(chuàng)建

    ,使用文本編輯器進行創(chuàng)建,使用重定向符號進行創(chuàng)建,接下來就演示如何使用這三種方式進行文件的創(chuàng)建。使用touch命令進行文件創(chuàng)建touch命令最初的作用是對
    發(fā)表于 12-15 08:42

    伺服電機的三種控制方式該如何應(yīng)用

    一般伺服都有三種控制方式:速度控制方式,轉(zhuǎn)矩控制方式,位置控制方式。大多數(shù)人想知道的就是這三種
    的頭像 發(fā)表于 12-14 23:12 ?5846次閱讀

    如何應(yīng)用伺服電機的三種控制方式

    一般伺服都有三種控制方式:速度控制方式,轉(zhuǎn)矩控制方式,位置控制方式。大多數(shù)人想知道的就是這三種
    發(fā)表于 01-22 06:30 ?7次下載
    如何應(yīng)用伺服電機的<b class='flag-5'>三種</b>控制<b class='flag-5'>方式</b>

    不得不收藏的PCB的Checklist!

    不得不收藏的PCB的Checklist
    發(fā)表于 02-09 10:46 ?37次下載
    <b class='flag-5'>不得不</b>收藏的PCB的Checklist!

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

    單片機CPU與外部設(shè)備交換信息通常有如下幾種方式:無條件傳送方式,查詢傳送方式和中斷傳送方式。我們以單片機與微型打印機接口為例講述這三種
    發(fā)表于 02-10 11:00 ?1次下載
    8051單片機的<b class='flag-5'>這三種</b>數(shù)據(jù)傳輸<b class='flag-5'>方式</b>,你了解多少?

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品