世界最資訊丨[QML]事無(wú)巨細(xì)開(kāi)始實(shí)踐QML開(kāi)發(fā)(一)什么是QML,為什么學(xué)習(xí)QML,先寫一個(gè)簡(jiǎn)單的頁(yè)面
QML(Qt Meta-Object Language)是Qt提供的一種聲明性語(yǔ)言,用于快速創(chuàng)建用戶界面。相對(duì)而言,Qt Widgets是基于C++的桌面應(yīng)用程序開(kāi)發(fā)框架。
下面是QML和Qt Widgets之間的一些優(yōu)缺點(diǎn)以及為何Qt公司大力推行QML開(kāi)發(fā)的原因:
優(yōu)點(diǎn):可視化設(shè)計(jì):QML是一種基于標(biāo)記的語(yǔ)言,使用了層疊樣式表(CSS)類似的語(yǔ)法,使得界面設(shè)計(jì)變得直觀輕松??缙脚_(tái)支持:QML與其他主流操作系統(tǒng)和設(shè)備無(wú)關(guān),可以在多個(gè)平臺(tái)上運(yùn)行,包括桌面、移動(dòng)和嵌入式設(shè)備。快速迭代:QML具有熱重載功能,可以實(shí)時(shí)編輯和查看界面的更改,加快了開(kāi)發(fā)和調(diào)試的速度。良好的動(dòng)畫和效果支持:QML通過(guò)內(nèi)置的動(dòng)畫和效果組件,使得界面的交互和動(dòng)態(tài)效果實(shí)現(xiàn)變得簡(jiǎn)單。靈活和可維護(hù)性:QML允許將界面元素分解為可重用的組件,使得代碼結(jié)構(gòu)化,易于拓展和維護(hù)。
【資料圖】
學(xué)習(xí)曲線:QML需要學(xué)習(xí)新的語(yǔ)法和概念,相對(duì)于傳統(tǒng)的C++開(kāi)發(fā),可能需要一些時(shí)間來(lái)適應(yīng)和掌握。性能:與原生C++應(yīng)用程序相比,QML在某些情況下可能會(huì)有性能上的損失,尤其是在復(fù)雜界面或需要大量渲染的場(chǎng)景中。Qt公司推行QML開(kāi)發(fā)的原因:
用戶體驗(yàn):QML提供了現(xiàn)代化、用戶友好的界面設(shè)計(jì)能力,可以創(chuàng)建吸引人且交互性強(qiáng)的用戶界面。多平臺(tái)支持:QML通過(guò)跨平臺(tái)的特性,可以將開(kāi)發(fā)的應(yīng)用程序輕松地移植到不同的操作系統(tǒng)和設(shè)備上,提高了開(kāi)發(fā)效率和代碼的重用性。易用性和開(kāi)發(fā)效率:QML的可視化設(shè)計(jì)和聲明性語(yǔ)法使得開(kāi)發(fā)者可以更快速地構(gòu)建和迭代界面,減少了開(kāi)發(fā)周期。
這也是一種真正在Qt上進(jìn)行前后端分離的方案,這倒是挺新穎的。個(gè)人在簡(jiǎn)單體驗(yàn)了一下QML開(kāi)發(fā)之后,感覺(jué)QML是一個(gè)很類似前端CSS的技術(shù),把頁(yè)面變成一個(gè)單獨(dú)的模塊,也算是一種完美貫徹MVC模式的工具吧(畢竟之前還是會(huì)有很多人把業(yè)務(wù)放到界面里面去寫,而且也會(huì)被人瘋狂亂噴)某種意義上來(lái)說(shuō),這也是一種真正在Qt上進(jìn)行前后端分離的方案,這倒是挺新穎的。另外值得一提的點(diǎn),QML作為一種幾乎是描述性語(yǔ)言的存在,其跨平臺(tái)的支持理論上應(yīng)該顯著好于QWidget的,所以新項(xiàng)目的開(kāi)發(fā)(大概率是要兼容多系統(tǒng))盡量在QML的基礎(chǔ)上開(kāi)發(fā)吧!
這就又相當(dāng)于是我學(xué)了一門新的語(yǔ)言了,但既然已經(jīng)有了QWidget的開(kāi)發(fā)經(jīng)驗(yàn),再去開(kāi)發(fā)前端html頁(yè)面想必難度也不會(huì)大到哪里去,那么就來(lái)看看效果吧
開(kāi)發(fā)準(zhǔn)備作為一名高貴的windows開(kāi)發(fā),那自然是要使用宇宙第一IDE:Visual Studio 2022 + Qt 5.14.2
為什么不用Qt 6 ?因?yàn)槲疫@臺(tái)開(kāi)發(fā)電腦上沒(méi)有裝Qt 6 ,不過(guò)具體使用起來(lái)大差不差。
然后比較重要的一點(diǎn)是,QML本身可能對(duì)中文的支持有點(diǎn)問(wèn)題,也就是說(shuō)QML中如果出現(xiàn)了中文,可能就會(huì)出現(xiàn)亂碼。當(dāng)然了不止QML中會(huì)出現(xiàn)亂碼,在QWidget中也會(huì)出現(xiàn)亂碼,不同的是可以在QWidget中使用#pragma characterset("utf8")解決,但是在QML文件中不允許這樣的語(yǔ)法出現(xiàn)(實(shí)際上QML是一套自己的語(yǔ)法),所以只能通過(guò)保存文件為UTF-8 with BOM的方式來(lái)規(guī)避掉這種可能出現(xiàn)的問(wèn)題。
這也是為什么我們說(shuō)QML比較適合新項(xiàng)目----因?yàn)槟阋膊荒鼙WC以前的老項(xiàng)目的代碼文件是以UTF8 with BOM格式保存的,也不可能把以前的老代碼全部轉(zhuǎn)換成UTF8 with BOM,這個(gè)是比較需要注意的。
至于說(shuō)怎么轉(zhuǎn),網(wǎng)上教程一大堆,我只說(shuō)我的做法 : 下載插件 Format on Save for VS2022(當(dāng)然了每個(gè)vs版本肯定都會(huì)有的)
具體方法就是:擴(kuò)展--》管理擴(kuò)展--》聯(lián)機(jī)--》搜索并下載Format on Save for VS2022--》下載完成--》VS上方菜單欄點(diǎn)擊工具--》選項(xiàng)--》Format On Save -->UTF8-->Enable ForceUtf8WithBom 改為True
OK,讓我們開(kāi)啟我們的第一個(gè)項(xiàng)目,怎么創(chuàng)建的就不說(shuō)了,反正就是你在創(chuàng)建項(xiàng)目的時(shí)候直接創(chuàng)建一個(gè)QtQuick項(xiàng)目就可以了,我們來(lái)直接看項(xiàng)目?jī)?nèi)部:
先來(lái)看main函數(shù),這個(gè)
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
先不管,這一段是給整個(gè)程序設(shè)置了一個(gè)支持高DPI的模式,這個(gè)無(wú)所謂
QQmlApplicationEngine engine;engine.load(QUrl(QStringLiteral("qrc:/main.qml")));if (engine.rootObjects().isEmpty())return -1;
在這段代碼中,使用QQmlApplicationEngine來(lái)加載和運(yùn)行一個(gè)QML界面。
首先,創(chuàng)建了一個(gè)QQmlApplicationEngine對(duì)象,該對(duì)象用于加載和管理QML應(yīng)用程序。
然后,使用engine.load(QUrl(QStringLiteral("qrc:/main.qml")))
語(yǔ)句加載名為"main.qml"的QML文件。在這里,使用QUrl::fromLocalFile()
函數(shù)將文件路徑轉(zhuǎn)換為QUrl格式,"qrc:"表示該文件位于Qt資源(qrc)中。
接下來(lái),通過(guò)engine.rootObjects().isEmpty()
判斷加載的QML界面是否成功。engine.rootObjects()
返回根對(duì)象的列表,如果列表為空,則表示加載失敗。
如果加載的QML界面成功,程序繼續(xù)執(zhí)行后續(xù)的邏輯。否則,返回-1,可能表示加載失敗或發(fā)生錯(cuò)誤。
簡(jiǎn)而言之,這段代碼的作用是加載并檢查一個(gè)QML界面是否成功加載,如果加載成功,則繼續(xù)執(zhí)行其他相關(guān)操作。
然后我們雙擊一下這個(gè)main.qml文件,進(jìn)來(lái)看看,內(nèi)容大概如下:
import QtQuick 2.12import QtQuick.Window 2.12import QtQuick.Controls 2.5Window {visible: truewidth: 640height: 480title: qsTr("Hello World")}
沒(méi)錯(cuò),就這么簡(jiǎn)單,就是幾句話就表示了一個(gè)窗口,沒(méi)有那么多規(guī)定復(fù)雜的構(gòu)造函數(shù),信號(hào),Q_OBJECT宏之類的,而是一個(gè)由Qt完全封裝好了的QML文件
讓我們來(lái)編譯執(zhí)行一下,大概效果就是生成了一個(gè)窗口:
讓我們來(lái)寫一個(gè)按鈕,添加代碼如下:
import QtQuick 2.12import QtQuick.Window 2.12import QtQuick.Controls 2.5Window {visible: truewidth: 640height: 480title: qsTr("Hello World") Button{x:100 //設(shè)置按鈕的橫坐標(biāo)y:100 //設(shè)置縱坐標(biāo)text:"我是按鈕" //按鈕標(biāo)題//一個(gè)類似JS風(fēng)格的函數(shù)function slotAnyway(){console.log("slotAnyway")}//信號(hào)槽連接onClicked: {slotAnyway()console.log("點(diǎn)擊")}}}
再編譯執(zhí)行一下:
然后按一下這個(gè)按鈕就會(huì)彈出對(duì)應(yīng)的提示。onClick是點(diǎn)擊函數(shù),至于這個(gè)函數(shù)是什么意思,將會(huì)在之后的文章中著重講一下,這里不講信號(hào)槽這些概念。
預(yù)覽寫到這里,不禁讓我頭皮發(fā)麻,因?yàn)檫@里有一個(gè)非常嚴(yán)重的問(wèn)題就是:我怎么知道現(xiàn)在界面是什么情況的?之前有一幫B開(kāi)發(fā)就是用純代碼寫QWidget,而且不能預(yù)覽,調(diào)試起來(lái)真的麻煩的我想殺人。
當(dāng)然了,Qt肯定也想到了這個(gè)問(wèn)題,不然他們也不會(huì)一開(kāi)始就提供.ui給用戶去編輯了,相對(duì)的,Qt也肯定提供了一套QML的預(yù)覽工具以供開(kāi)發(fā)者調(diào)用,這個(gè)工具就是 :qmlscene.exe,這個(gè)工具的位置在你的Qt安裝目錄的指定版本下的bin目錄,比如D:\DevTools\Qt_5.14.2\5.14.2\msvc2017_64\bin\qmlscene.exe
怎么用呢?其實(shí)也簡(jiǎn)單,就是直接雙擊qmlscene.exe,然后再選擇指定的.qml文件就行了
當(dāng)然了,這肯定有點(diǎn)低能,我們也不可能這么做。正確的做法是右鍵main.qml->..打開(kāi)方式->瀏覽->找到qmlscene.exe
,注意不能設(shè)置為默認(rèn),否則你就不能編輯這個(gè).qml文檔了,只需要每次預(yù)覽的時(shí)候雙擊一下就可以了
之后簡(jiǎn)單說(shuō)一下關(guān)于QML控件、信號(hào)、槽、錨、屬性相關(guān)的內(nèi)容
調(diào)試當(dāng)然了,你肯定會(huì)好奇這種代碼怎么調(diào)試,你會(huì)好奇地在qml字段上打上一個(gè)斷點(diǎn)然后嘗試調(diào)試,結(jié)果你發(fā)現(xiàn)行不通。
當(dāng)然了,Qt也考慮到了這個(gè)問(wèn)題,當(dāng)你需要調(diào)試這個(gè)程序的時(shí)候,請(qǐng)右鍵項(xiàng)目-》屬性-》Qt Project Settings->QML->Enable QMl Debugging->改為是,這樣之后你在qml文件中打上的斷點(diǎn)就可以被命中了,當(dāng)然了這也帶來(lái)一個(gè)問(wèn)題,就是當(dāng)你在之后刪掉這個(gè)斷點(diǎn)后,每次調(diào)試或者啟動(dòng)這個(gè)程序都會(huì)告訴你程序命中了斷點(diǎn)但是找不到這個(gè)斷點(diǎn),不過(guò)這并不是什么首要的問(wèn)題,不是嗎?
關(guān)鍵詞:
相關(guān)閱讀
-
世界最資訊丨[QML]事無(wú)巨細(xì)開(kāi)始實(shí)踐QML...
[QML]從零開(kāi)始QML開(kāi)發(fā)(一)什么是QML,為什么學(xué)習(xí)QML,先寫一個(gè)簡(jiǎn)單 -
世界時(shí)訊:武漢首屆“新中考”落幕 ...
武漢首屆“新中考”落幕試題突出考查學(xué)科核心素養(yǎng)---湖北日?qǐng)?bào)訊(記... -
郭廣盈:6.22黃金如期下行破位,反彈仍...
郭廣盈:黃金如期下行破位,反彈仍是空!黃金呈3浪下行看千八,今日走勢(shì) -
化驗(yàn)員個(gè)人工作總結(jié)與計(jì)劃2023
化驗(yàn)員個(gè)人工作總結(jié)與計(jì)劃2023(精選31篇)化驗(yàn)員個(gè)人工作總結(jié)與計(jì)劃20 -
華為手機(jī)怎么開(kāi)啟定位功能設(shè)置 華為手...
華為手機(jī)自帶定位功能,那么怎么開(kāi)啟定位功能設(shè)置呢?方法如下,快來(lái)看 -
環(huán)球聚焦:每日觀察!感動(dòng)一年級(jí)作文500...
下面就是小編給大家?guī)?lái)的感動(dòng)一年級(jí)作文500字,希望大家喜歡,可以幫 -
當(dāng)前熱議!【美股盤前】三大期指走低,特...
24小時(shí)財(cái)經(jīng)資訊平臺(tái),依托新銳財(cái)經(jīng)日?qǐng)?bào)《每日經(jīng)濟(jì)新聞》(NationalBusin -
生日宴會(huì)家長(zhǎng)答謝詞
生日宴會(huì)家長(zhǎng)答謝詞(精選4篇)生日宴會(huì)家長(zhǎng)答謝詞篇1尊敬的爺爺奶奶、 -
安陽(yáng)擔(dān)保追償糾紛律師費(fèi)用一般怎么計(jì)算
1、按件收費(fèi)收?。?)無(wú)財(cái)產(chǎn)爭(zhēng)議:6000元-20000元之間;(2)法律文書 -
微資訊!命運(yùn)方舟國(guó)服7月20日全面起航 ...
近日,《命運(yùn)方舟》通過(guò)一場(chǎng)聲勢(shì)浩大的定檔發(fā)布會(huì)正式宣布,7月20日國(guó) -
福州市五里亭茶葉批發(fā)市場(chǎng)黨支部成立
海峽網(wǎng)訊19日上午,福建省福州市晉安區(qū)王莊街道在五里亭尚東區(qū)茶城舉行 -
小小CBA嘉年華(全國(guó)總動(dòng)員)端午假期開(kāi)...
(謝妮均)參賽隊(duì)伍覆蓋25個(gè)省區(qū),在120多個(gè)市級(jí)賽區(qū)舉辦,累計(jì)超過(guò)25000 -
最新:寧夏銀川燒烤店爆炸事故9名相關(guān)人...
記者從寧夏回族自治區(qū)黨委獲悉,目前,公安部門已依法對(duì)銀川燒烤店爆炸事 -
端午假期湖南迎強(qiáng)降雨時(shí)段 外出活動(dòng)需...
6月20日,湖南省氣象臺(tái)發(fā)布最新氣象信息,20日至25日強(qiáng)降雨帶在湖南省 -
世界速看:文班亞馬:和法國(guó)球員交手很...
直播吧6月22日訊近日,文班亞馬在《OldManandThree》播客節(jié)目中談到了 -
留念1950年代的美好時(shí)光:手工教程,送...
在制作服裝時(shí),擁有合適的配飾可以塑造或破壞整體印象。以汽水混蛋 -
學(xué)習(xí)貫徹全會(huì)精神|雅安:堅(jiān)定不移做強(qiáng)...
彭華川觀新聞?dòng)浾哐S睿6月21日,雅安市委常委會(huì)召開(kāi)(擴(kuò)大)會(huì)議,傳 -
世界熱門:如何用文學(xué)魔法制作天使般光輝...
如果沒(méi)有可愛(ài)的天使光環(huán),萬(wàn)圣節(jié)天使服裝就不完整,而且自己制作一 -
金市神話:黃金回撤1925-20分別反手多
黃金在1918-19一線仍舊是多頭支撐,我們前面分析說(shuō)過(guò)這里的支撐,但是 -
世界視訊!五塔寺里細(xì)讀端午故事
本報(bào)訊(記者李祺瑤)昨天,伴著悠揚(yáng)的京音樂(lè),“長(zhǎng)河薰風(fēng)古都夏韻...