RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

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

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

嵌入式Qt-實(shí)現(xiàn)兩個(gè)窗口的切換

碼農(nóng)愛(ài)學(xué)習(xí) ? 來(lái)源:碼農(nóng)愛(ài)學(xué)習(xí) ? 作者:碼農(nóng)愛(ài)學(xué)習(xí) ? 2022-09-09 09:03 ? 次閱讀

之前的文章,分別有介紹過(guò)使用Qt程序?qū)崿F(xiàn)一個(gè)時(shí)鐘和一個(gè)秒表,本篇,來(lái)將這兩個(gè)功能整合在一起,實(shí)現(xiàn)兩個(gè)頁(yè)面的隨意切換,并且兩個(gè)頁(yè)面能獨(dú)立運(yùn)行,互不影響。

先來(lái)看下最終的效果,通過(guò)左側(cè)的兩個(gè)按鈕,實(shí)現(xiàn)兩個(gè)頁(yè)面的切換。

pYYBAGMZ9UWATgCbAACkkXYpMHA477.png

1 Qt堆棧窗口

本篇的頁(yè)面切換功能,是利用Qt的QStackedWidget實(shí)現(xiàn)的。

1.1QStackedWidget

QStackedWidget 類提供了多頁(yè)面切換的布局,一次只能顯示一個(gè)界面。

1.2 基礎(chǔ)模板

對(duì)于QStackedWidget的使用,可以先參考下面這個(gè)模板,配合QLabel來(lái)控制頁(yè)面的切換:

#include "stackdlg.h"
#include 

StackDlg::StackDlg(QWidget *parent)
    : QDialog(parent)
{
    setWindowTitle(tr("StackedWidget"));

    list = new QListWidget(this); //創(chuàng)建ListWidge
    list->insertItem(0, tr("Window1")); //ListWidge中添加Item
    list->insertItem(1, tr("Window2")); //ListWidge中添加Item
    list->insertItem(2, tr("Window3")); //ListWidge中添加Item

    stack = new QStackedWidget(this); //創(chuàng)建StackedWidget
    label1 = new QLabel(tr("WindowTest1"));
    label2 = new QLabel(tr("WindowTest2"));
    label3 = new QLabel(tr("WindowTest3"));
    stack->addWidget(label1); //StackedWidget中添加窗口1
    stack->addWidget(label2); //StackedWidget中添加窗口2
    stack->addWidget(label3); //StackedWidget中添加窗口3

    QHBoxLayout *mainLayout = new QHBoxLayout(this); //創(chuàng)建豎直布局器
    mainLayout->setMargin(5);
    mainLayout->setSpacing(5);
    mainLayout->addWidget(list);                      //放入ListWidge
    mainLayout->addWidget(stack,0, Qt::AlignHCenter); //放入StackedWidget
    mainLayout->setStretchFactor(list, 1);  //ListWidge的伸縮尺度是1
    mainLayout->setStretchFactor(stack, 3); //StackedWidget的伸縮尺度是3

    // ListWidge的行狀態(tài)變化時(shí),切換對(duì)應(yīng)的StackedWidget顯示
    connect(list, SIGNAL(currentRowChanged(int)), stack, SLOT(setCurrentIndex(int)));
}

該代碼的運(yùn)行效果如下:

poYBAGMZ9YSAfe_DAAANjE8O4O0194.png

本篇就在這個(gè)模板的基礎(chǔ)上,將Qt時(shí)鐘程序和Qt秒表程序移植過(guò)來(lái)。

2 移植時(shí)鐘與秒表程序

2.1 時(shí)鐘程序移植

將之前這篇中的程序作為一個(gè)獨(dú)立的窗口移植到本篇的程序中:嵌入式Qt-動(dòng)手編寫并運(yùn)行自己的第1個(gè)ARM-Qt程序

移植步驟:

Qt Creator中,堆棧窗口基礎(chǔ)工程的基礎(chǔ)上,點(diǎn)文件菜單,再點(diǎn)新建文件或項(xiàng)目,新建一個(gè)C++類,名字可取clockwidget

pYYBAGMZ9ZCAQS_jAAA6p17FOZs671.png

將Qt時(shí)鐘的程序復(fù)制過(guò)來(lái),代碼基本不需要修改,只需要把類名換成ClockWidget即可

例如其構(gòu)造函數(shù)如下:

ClockWidget::ClockWidget(QWidget *parent) : QWidget(parent)
{
    QTimer *timer = new QTimer(this);
    connect(timer, SIGNAL(timeout()), this, SLOT(update()));
    timer->start(1000);

    setWindowTitle(tr("Clock"));
    setMinimumSize(200, 200); //設(shè)置最小尺寸
}

2.2 秒表程序移植

將之前這篇中的程序作為一個(gè)獨(dú)立的窗口移植到本篇的程序中:嵌入式Qt-做一個(gè)秒表

秒表這個(gè)Qt程序,用到了Qt Creator的圖形頁(yè)面設(shè)計(jì),因此要主要移植的不同之處。

移植步驟:

Qt Creator中,堆棧窗口基礎(chǔ)工程的基礎(chǔ)上,點(diǎn)文件菜單,再點(diǎn)新建文件或項(xiàng)目,新建一個(gè)C++類,名字可取TimerWidget

將ui文件也拷貝過(guò)來(lái),在工程中,通過(guò)添加現(xiàn)有文件的方式,將ui文件添加進(jìn)工程

另外,可以將移植過(guò)來(lái)的ui文件,更名為TimerWidget.ui。需注意的是,修改了文件名后,還需要將ui文件以文本的形式打開(kāi),修改對(duì)應(yīng)的類名為TimerWidget,要包含的頭文件也改名為ui_TimerWidget.h

pYYBAGMZ9ZmAGs21AADp1aIedfk134.png

移植后的構(gòu)造函數(shù)如下:

#include "timerwidget.h"
#include "ui_TimerWidget.h"
#include
#pragma execution_character_set("utf-8")

TimerWidget::TimerWidget(QWidget *parent) : QWidget(parent), ui(new Ui::TimerWidget)
{
    ui->setupUi(this);
    connect(&timer, SIGNAL(timeout()), this, SLOT(timeout_slot()));
    connect(&timer, SIGNAL(timeout()), this, SLOT(update()));
    connect(ui->Btn_Reset, SIGNAL(clicked()), this, SLOT(update()));

    time.setHMS(0,0,0,0);
    ui->Txt_ShowTime->setText("00:00:00");

    ui->Btn_Start->setChecked(false);
    ui->Btn_Reset->setEnabled(false);
    ui->Btn_Hit->setEnabled(false);
}

?

注意頭文件包含的是ui_TimerWidget.h,構(gòu)造函數(shù)繼承的ui也是Ui::TimerWidget

2.3 主程序框架

移植好Qt時(shí)鐘程序和Qt秒表程序后,就可以將這兩個(gè)功能加入到堆棧窗口中了。

注意,下面的頁(yè)面切換,我改用兩個(gè)QPushButton來(lái)實(shí)現(xiàn)Qt時(shí)鐘和Qt秒表的頁(yè)面切換,并使用QGridLayout進(jìn)行布局,使得兩個(gè)按鈕位于整個(gè)界面的左側(cè)。

StackDlg::StackDlg(QWidget *parent)
    : QDialog(parent)
{
    setWindowTitle(tr("StackedWidget"));
    setMinimumSize(800, 480);
    qDebug("Hello");

    QPushButton *pClockButton = new QPushButton("時(shí)\n鐘", this);
    QPushButton *pTimerButton = new QPushButton("秒\n表", this);
    pClockButton->setFixedSize(QSize(80,200));
    pClockButton->setFont(QFont("Times", 20));
    pTimerButton->setFixedSize(QSize(80,200));
    pTimerButton->setFont(QFont("Times", 20));

    pStack = new QStackedWidget(this);
    ClockWidget *pClockWidget = new ClockWidget();
    TimerWidget *pTimerWidget = new TimerWidget();
    pStack->addWidget(pClockWidget);
    pStack->addWidget(pTimerWidget);

    QGridLayout *mainLayout = new QGridLayout(this);
    mainLayout->addWidget(pClockButton, 0, 0, Qt::AlignCenter);
    mainLayout->addWidget(pTimerButton, 1, 0, Qt::AlignCenter);
    mainLayout->addWidget(pStack, 0, 1, 2, 1);

    mainLayout->setContentsMargins(10,10,1,1);
    mainLayout->setColumnStretch(1, 10);
    mainLayout->setRowStretch(1, 1);

    connect(pClockButton, SIGNAL(clicked()), this, SLOT(showClock()));
    connect(pTimerButton, SIGNAL(clicked()), this, SLOT(showTimer()));
}

void StackDlg::showClock()
{
    qDebug("%s", __func__);
    pStack->setCurrentIndex(0);
}
void StackDlg::showTimer()
{
    qDebug("%s", __func__);
    pStack->setCurrentIndex(1);
}

另外需要注意的是,Qt的信號(hào)和槽機(jī)制,需要信號(hào)和槽函數(shù)的參數(shù)一致或信號(hào)的參數(shù)多于槽的參數(shù),而按鈕按下沒(méi)有參數(shù),但切換堆棧頁(yè)面需要一個(gè)參數(shù)(索引號(hào),指示要展示第幾個(gè)頁(yè)面),因此不能直接使用pStack的setCurrentIndex作為槽函數(shù),需要自己再封裝一層,分別寫兩個(gè)按鈕按下時(shí)的槽函數(shù)。

3 測(cè)試

將代碼在Windows上編譯運(yùn)行ok后,再將源碼復(fù)制到Ububtu中進(jìn)行交叉編譯,具體的編譯過(guò)程可參考之前的文章:嵌入式Qt-動(dòng)手編寫并運(yùn)行自己的第1個(gè)ARM-Qt程序

然后將編譯后的程序復(fù)制到Linux板子中運(yùn)行,運(yùn)行效果如下:

https://www.bilibili.com/video/BV1RB4y147s7

poYBAGMZ9k2AG4n1AAwEBnPpxDQ594.png

可以看到Qt時(shí)鐘和Qt秒表這兩個(gè)頁(yè)面可以隨意切換,并且兩個(gè)頁(yè)面獨(dú)立運(yùn)行,某個(gè)頁(yè)面被隱藏顯示時(shí),其計(jì)時(shí)功能仍在運(yùn)行,再次將頁(yè)面切換回來(lái),計(jì)時(shí)時(shí)間也是對(duì)的。

4 總結(jié)

本篇介紹了介紹了QStackedWidget的使用,通過(guò)這個(gè)類,實(shí)現(xiàn)了Qt時(shí)鐘和Qt秒表這兩個(gè)頁(yè)面可以隨意切換。

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

    關(guān)注

    5082

    文章

    19104

    瀏覽量

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

    關(guān)注

    1

    文章

    302

    瀏覽量

    37899
  • 秒表
    +關(guān)注

    關(guān)注

    3

    文章

    77

    瀏覽量

    22012
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    【「嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)」閱讀體驗(yàn)】+ 學(xué)習(xí)一個(gè)STM32的案例

    嵌入式系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)——第六屆全國(guó)大學(xué)生嵌入式芯片與系統(tǒng)設(shè)計(jì)競(jìng)賽芯片應(yīng)用賽道優(yōu)秀作品剖析》一書的基本情況。今天來(lái)學(xué)習(xí)一個(gè)具體的案例。 這本書中意法半導(dǎo)體的案例是最多的,尤其是第二部分
    發(fā)表于 12-06 22:22

    什么是嵌入式?一文讀懂嵌入式主板

    在現(xiàn)代科技浪潮中,嵌入式技術(shù)已成為支撐各種智能設(shè)備和系統(tǒng)運(yùn)行的核心力量。那么,究竟什么是嵌入式嵌入式系統(tǒng),顧名思義,是將計(jì)算機(jī)的硬件和軟件嵌入到某種設(shè)備或系統(tǒng)中,以
    的頭像 發(fā)表于 10-16 10:14 ?923次閱讀

    嵌入式系統(tǒng)的原理和應(yīng)用

    嵌入式系統(tǒng)是一種專用的計(jì)算機(jī)系統(tǒng),其設(shè)計(jì)初衷是執(zhí)行特定任務(wù),而非作為通用計(jì)算機(jī)使用。這類系統(tǒng)通常作為更大系統(tǒng)的一部分,起到控制、監(jiān)控或輔助的作用,具有資源受限、實(shí)時(shí)性高、可靠性強(qiáng)等特點(diǎn)。下面將從嵌入式系統(tǒng)的原理、應(yīng)用兩個(gè)方面進(jìn)行
    的頭像 發(fā)表于 10-05 17:03 ?817次閱讀

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統(tǒng)的核心組件,是一種用于控制和數(shù)據(jù)處理的計(jì)算機(jī)硬件,其設(shè)計(jì)旨在嵌入特定設(shè)備中執(zhí)行專門任務(wù)。嵌入式主板如同是設(shè)備的“大腦”,主要功能是根據(jù)需要管理和控制設(shè)備
    的頭像 發(fā)表于 09-30 10:05 ?449次閱讀

    嵌入式環(huán)形隊(duì)列與消息隊(duì)列的實(shí)現(xiàn)原理

    嵌入式環(huán)形隊(duì)列,也稱為環(huán)形緩沖區(qū)或循環(huán)隊(duì)列,是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),用于在固定大小的存儲(chǔ)區(qū)域中高效地存儲(chǔ)和訪問(wèn)數(shù)據(jù)。其主要特點(diǎn)包括固定大小的數(shù)組和兩個(gè)指針(頭指針和尾指針),分別指向隊(duì)列的起始位置和結(jié)束位置。
    的頭像 發(fā)表于 09-02 15:29 ?476次閱讀

    七大嵌入式GUI盤點(diǎn)

    。 MiniGUI 一款國(guó)產(chǎn)GUI,一款面向嵌入式系統(tǒng)的高級(jí)窗口系統(tǒng)和圖形用戶界面(GUI)支持系統(tǒng),由魏永明先生于1998年底開(kāi)始開(kāi)發(fā)。2002年,魏永明先生創(chuàng)建北京飛漫軟件技術(shù)有限公司,為MiniGUI
    發(fā)表于 09-02 10:58

    嵌入式QT常見(jiàn)開(kāi)發(fā)方式有哪些?

    提供的豐富組件如按鈕、文本框、窗口等構(gòu)建傳統(tǒng)的桌面應(yīng)用風(fēng)格界面。對(duì)于嵌入式設(shè)備上的復(fù)雜用戶界面或者需要高性能響應(yīng)的應(yīng)用,Qt Widgets是一個(gè)較為常用的選擇。 2.
    發(fā)表于 08-12 10:05

    PLC與嵌入式的區(qū)別是什么

    在工業(yè)自動(dòng)化和嵌入式系統(tǒng)領(lǐng)域,PLC(Programmable Logic Controller,可編程邏輯控制器)和嵌入式系統(tǒng)是兩個(gè)常被提及的概念。它們各自具有獨(dú)特的特點(diǎn)和應(yīng)用場(chǎng)景,但也常常被誤解
    的頭像 發(fā)表于 05-28 16:22 ?5807次閱讀

    什么是嵌入式SoC

    嵌入式SoC有兩個(gè)顯著的特點(diǎn):一是硬件設(shè)計(jì)難度大;二是軟件比重大,需要進(jìn)行軟 硬件協(xié)同設(shè)計(jì)。舉個(gè)例子,比如城市相比農(nóng)村的優(yōu)勢(shì)很明顯:配套齊全、交通便利、效率高。
    發(fā)表于 05-03 17:30 ?1466次閱讀
    什么是<b class='flag-5'>嵌入式</b>SoC

    嵌入式系統(tǒng)中集成Rust和Qt的實(shí)踐

    Rust 擁有豐富的庫(kù)生態(tài)系統(tǒng),用于序列化和反序列化、異步操作、解析不安全輸入、線程、靜態(tài)分析等,而 Qt 是一個(gè) C++ 工具包,支持跨各種平臺(tái)的豐富的、基于 GUI 的應(yīng)用程序,從 iOS 到嵌入式Linux。
    發(fā)表于 05-03 10:26 ?1785次閱讀
    在<b class='flag-5'>嵌入式</b>系統(tǒng)中集成Rust和<b class='flag-5'>Qt</b>的實(shí)踐

    如何運(yùn)用emwin把顯示屏分為上下兩個(gè)窗口,實(shí)現(xiàn)上下窗口分別可以左右滑動(dòng)?

    怎么運(yùn)用emwin把顯示屏分為上下兩個(gè)窗口,可以實(shí)現(xiàn)上下窗口分別可以左右滑動(dòng)?
    發(fā)表于 04-26 06:03

    fpga和嵌入式應(yīng)該學(xué)哪個(gè)

    FPGA和嵌入式系統(tǒng)是兩個(gè)不同的領(lǐng)域,各有其特點(diǎn)和優(yōu)勢(shì),選擇學(xué)習(xí)哪個(gè)取決于個(gè)人的興趣、職業(yè)目標(biāo)以及市場(chǎng)需求。
    的頭像 發(fā)表于 03-27 14:43 ?771次閱讀

    fpga是嵌入式開(kāi)發(fā)嗎

    FPGA(現(xiàn)場(chǎng)可編程門陣列)與嵌入式開(kāi)發(fā)之間確實(shí)存在一定的關(guān)聯(lián),但它們?cè)诒举|(zhì)上是兩個(gè)不同的領(lǐng)域。
    的頭像 發(fā)表于 03-15 14:18 ?1032次閱讀

    arcgis中如何關(guān)聯(lián)兩個(gè)屬性表

    在ArcGIS中,關(guān)聯(lián)兩個(gè)屬性表是一個(gè)重要的操作,可以通過(guò)此操作將兩個(gè)表中的數(shù)據(jù)關(guān)聯(lián)起來(lái),以便進(jìn)行分析和查詢。下面是詳細(xì)介紹如何在ArcGIS中實(shí)現(xiàn)屬性表的關(guān)聯(lián)。 首先,我們需要明確
    的頭像 發(fā)表于 02-25 11:01 ?4187次閱讀

    嵌入式軟件開(kāi)發(fā)和軟件開(kāi)發(fā)的區(qū)別

    嵌入式軟件開(kāi)發(fā)和軟件開(kāi)發(fā)是兩個(gè)不同的概念,它們?cè)谝恍╆P(guān)鍵方面有著明顯的區(qū)別。嵌入式軟件開(kāi)發(fā)是指開(kāi)發(fā)嵌入在硬件設(shè)備中的軟件,而軟件開(kāi)發(fā)一般指開(kāi)發(fā)運(yùn)行在通用計(jì)算機(jī)上的軟件。本文將從多個(gè)方面
    的頭像 發(fā)表于 01-22 15:27 ?2269次閱讀
    RM新时代网站-首页