[Qt QML] 如何呼叫C++ class functions

在開發Qt應用程式時,不論其目標執行環境是Desktop (Windows/macOS/Linux) 或 embedded,我都建議採用QML來開發GUI的部分。其主要的原因之一是,在程式架構上可以很容易地把畫面跟商業邏輯的部分拆開。如此一來,在UI改版的情況下,幾乎不需要修改到商業邏輯的部分,這提高了在開發及維護上的彈性和效率。

這邊提供一個簡單的範例程式,來示範一下如何從以QML撰寫的GUI來呼叫C++層所定義的class function。先講解一下畫面的部分(如下圖),視窗中間有一個按鈕,當按鈕被點擊時,等待三秒後將應用程式關閉。這邊提到的「等待三秒將應用程式關閉」,其實使用QML撰寫就可以很快速的實作出來,但因為這一篇文章主要是要示範如何呼叫C++的class function,所以我們用C++來實作這個功能。

Qt C++部分

首先,依據MVC的設計概念,我習慣會在C++這邊定義一個class名為Controller,它就是負責實作上面提到的商業邏輯部分,而UI跟商業邏輯間的溝通和交互,主要都是透過這個類別來進行。我們在Controller裡定義了一個public function,名為quitApp(),其input參數為一個int資料型態,表示在seconds秒後,將應用程式關閉。

要讓QML可以呼叫C++類別function的話,有兩種方式,第一種是我比較建議的方式,在宣告function時標記Q_INVOKABLE這個marco。

Q_INVOKABLE void quitApp(int seconds);

或是,將該function歸類為public slot

public slots:
    void quitApp(int seconds);

要讓QML操作C++ class function,概念上很容易懂,就是讓其class所產生的instance作為QML裡的一個property,在UI層就可以操作這個instance。

QQmlApplicationEngine engine;
Controller *pController = new Controller();
QQmlContext *pRootContext = engine.rootContext();
pRootContext->setContextProperty("ctrl", pController);

以上面這段程式碼為例,在QML裡就可以把ctrl視為一個可操作的物件。

Qt QML部分

QML的部分就很單純,在Button click事件發生時,呼叫ctrl的quitApp(),帶入值設定為整數3。

    Button {
        id: btnQuitApp
        anchors.centerIn: parent
        text: qsTr("Quit app after 3 seconds")
        onClicked: {
            ctrl.quitApp(3);
        }
    }

以上就是一個簡單了範例介紹如何從QML端呼叫C++的function,下一篇我再介紹反過來如何從C++呼叫QML的function。

Read more

聽說 AI 都能寫程式了,那我還需要學程式語言嗎?

自從ChatGPT橫空問世,人們在獲取知識的方式,發生很大的改變。很多既有的知識或疑問,可以不用在透過Google等搜尋引擎,搭配正確的關鍵字,從中找到相符的結果。 有了ChatGPT,只要用聊天的方式,用人類自然語言詢問,就能在短時間統整出邏輯清晰且條理分明的結果。不論是知識的學習、文章的統整、甚至程式的撰寫,都能透過AI工具快速產生具有一定水準的成品。 那,既然AI都能幫忙寫程式,而且也寫得不錯,我還需要學習程式語言嗎?答案是「肯定」的。 AI是輔助工具,不是程式設計師 沒錯!AI能寫出不錯的程式碼,但如果你本身不懂程式設計,你如何判斷它寫出的結果,是否符合你所想要的?對懂程式的人來說,他會比較清楚該如何對AI工具「下指令」,程式設計師可以利用AI工具的輔助,節省掉實際開發與除錯的時間。 再者,要寫出一個可以應用的程式,並非如此簡單。從一開始的需求分析,到架構設計、模組化元件、單元測試等等,絕對不是透過跟AI工具講三兩句話就能產出的。 AI是透過背後龐大資料與分析模型取產生我們想要的結果,意即,它做不到「無中生有」。相較於AI,人類的優勢在於「創造」。AI工具的出現與

By 三寶爸工程師

[程式教育] 該學哪一種程式語言才好?你必須先了解程式語言的7個應用領域

之前一再強調,學習程式語言不完全是為了將來當工程師而學的。但對初學者來說,在這麼多種程式語言中,究竟要選哪一種程式語言做學習呢? 在這之前,我們要先了解,程式語言的應用,大概有哪些領域。先看看自己對哪一個領域有興趣,不妨從該領域下手,學習一種該領域會用到的程式語言,並透過學習去完成一個小作品。 以下是依照應用領域的分類,列出該領域的幾個主要採用的程式語言。 一、網頁開發 (Web Development) 網頁(網站)開發是最普遍的一種應用,幾乎每個人每天會接觸到的,都脫離不了網頁開發的相關產品。在這裡我要特別說明,「開發」網站跟「架設」網站是兩回事,如果只是要「架設」網站,那是可以不需要學會寫程式就能做到的,因為有太多現成工具就可以達到「架設」網站這件事。關於「架設」網站的工具,我們有機會再另外寫一篇文章說明。但不論如何,網頁(網站)的基本運作原理還是要懂的。 網頁開發的部分,一般來說還區分「前端」和「後端」的開發與維護。

By 三寶爸工程師

[程式教育] 我未來不想當程式設計師,那還需要學程式語言嗎?

這個問題,最中肯又八股的答案當然是「不一定,但有學比較好」。如果問我,我肯定是建議你「最好要學」。 我換個問題,我未來不想當英文老師,那我需要學英文嗎?答案應該很清楚了! 你可能會說「不一樣啊!」請你仔細想想,學習「語言」跟「程式語言」的目的,我在 [程式教育] 學習程式語言的Why and How 這篇文章內有提到,兩者的目的一樣都在「溝通」,只是對象不同。 以目前AI發展的速度,也許不久的將來,「語言」也不需要學習了也說不定。屆時,「程式語言」的角色可能反而更吃重。並不是說你要學會用程式語言來開發軟體,而是透過學習程式語言吸取基本知識和延伸的能力。以下我列出五點,學習程式語言所能帶來的價值。 一、提升問題解決能力與創造力 學習程式設計可以培養邏輯思維和系統化解決問題的能力。這些技能在各種職業中都是非常寶貴的,無論是管理、行銷、工程還是醫療領域,遇到複雜問題時,能夠分解問題並系統地找到解決方案是非常重要的。 程式設計是一種創造性的活動,讓你能夠實現自己的想法和項目。

By 三寶爸工程師