开源 C++ QT Widget 开发(二)基本控件应用

文章的目的为了记录使用C++ 进行QT Widget 开发学习的经历。临时学习,完成app的开发。开发流程和要点有些记忆模糊,赶紧记录,防止忘记。

相关链接:

开源 C++ QT Widget 开发(一)工程文件结构-CSDN博客

开源 C++ QT Widget 开发(二)基本控件应用-CSDN博客

推荐链接:

开源 java android app 开发(一)开发环境的搭建-CSDN博客

开源 java android app 开发(二)工程文件结构-CSDN博客

开源 java android app 开发(三)GUI界面布局和常用组件-CSDN博客

开源 java android app 开发(四)GUI界面重要组件-CSDN博客

开源 java android app 开发(五)文件和数据库存储-CSDN博客

开源 java android app 开发(六)多媒体使用-CSDN博客

开源 java android app 开发(七)通讯之Tcp和Http-CSDN博客

开源 java android app 开发(八)通讯之Mqtt和Ble-CSDN博客

开源 java android app 开发(九)后台之线程和服务-CSDN博客

开源 java android app 开发(十)广播机制-CSDN博客

开源 java android app 开发(十一)调试、发布-CSDN博客

开源 java android app 开发(十二)封库.aar-CSDN博客

推荐链接:

开源C# .net mvc 开发(一)WEB搭建_c#部署web程序-CSDN博客

开源 C# .net mvc 开发(二)网站快速搭建_c#网站开发-CSDN博客

开源 C# .net mvc 开发(三)WEB内外网访问(VS发布、IIS配置网站、花生壳外网穿刺访问)_c# mvc 域名下不可訪問內網,內網下可以訪問域名-CSDN博客

开源 C# .net mvc 开发(四)工程结构、页面提交以及显示_c#工程结构-CSDN博客

开源 C# .net mvc 开发(五)常用代码快速开发_c# mvc开发-CSDN博客

本章主要内容:演示使用了全局变量和过时的信号槽语法。实现了多种UI控件的交互功能,特别是定时器驱动的进度条更新功能。

1.基本介绍

2.源码分析

3.所有源码

4.演示效果

一、基本介绍

Qt Widgets 是一个强大的框架,用于创建图形用户界面(GUI)应用程序。Qt Widgets 提供了一系列预定义的控件和布局管理器,使得开发者可以轻松地设计出美观且功能丰富的用户界面。这些控件包括按钮、文本框、滑块、列表、菜单等,几乎可以满足所有常见的GUI设计需求。

QT是使用的5.14.2,安装程序很简单,不再详述。

工程功能分析

  1. 定时器功能

自动启动:程序启动时定时器自动开始,每秒触发一次

进度条更新:每次定时器超时,进度条值增加1

问题:进度条会一直增加到255(uint8_t最大值)然后溢出

  1. UI控件交互

pushButton:点击时计数器增加并在lineEdit中显示

radioButton:显示"选中/取消"状态

checkBox:同样显示"选中/取消"状态

comboBox:将选择项显示在lineEdit中

listWidget:点击项时在textEdit中显示内容

  1. 界面组件推断

基于代码可以推断UI包含:

lineEdit:文本框,显示各种状态

textEdit:多行文本框,显示列表选择

progressBar:进度条,由定时器驱动

pushButton、radioButton、checkBox、comboBox、listWidget

二、源码分析

2.1 控制值得设置,使用ui 输入 -> 连接符 会出现 界面的控件,选择控件后,调用setText方法,就可以设置控件的显示值。

2.2 槽函数有多种连接形式

1)选中控件,右键选中 "转到槽"

mainwindow.h会自动生成槽函数

在on_pushButton_clicked()中,进行函数处理即可,其中pushButton为控件的名称,自动生成槽函数都是按这个规则 on + 控件名 + 动作

2)更新信号槽

在mainwindow.h中先进行定时器信号槽的声明

把定时器的时间到的信号,与event_tmr函数连接

最后填入event_tmr槽函数的处理

三、所有源码

3.1 mainwindow.h

复制代码
#ifndef MAINWINDOW_H
#define MAINWINDOW_H


#include <QListWidget>
#include <QMainWindow>


namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();
    QTimer *myTmr;
private slots:
    void on_pushButton_clicked();

    void on_radioButton_clicked();

    void on_checkBox_clicked();

    void on_comboBox_activated(const QString &arg1);

    void on_btnTmrStart_clicked();

    void event_tmr();
    void on_listWidget_itemClicked(QListWidgetItem *item);

private:
    Ui::MainWindow *ui;
};

#endif // MAINWINDOW_H

3.2 mainwindow.cpp

复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <string.h>
#include "QTimer"
uint8_t ucCnt=0;
uint8_t ucCntTmr=0;
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    /*******定时器设置***************/
    myTmr =new QTimer(this);
    connect(myTmr, &QTimer::timeout, this, &MainWindow::event_tmr);
    myTmr->start(1000);
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_pushButton_clicked()
{
    QString a;

    ucCnt++;
    a=QString::number(ucCnt);
    ui->lineEdit->setText(a);



}

void MainWindow::on_radioButton_clicked()
{
    bool BFlg = ui->radioButton->isChecked();
    if(BFlg ==true)
    {
        ui->lineEdit->setText("选中");
    }
    else
    {
        ui->lineEdit->setText("取消");
    }
}

void MainWindow::on_checkBox_clicked()
{
    bool BFlg = ui->checkBox->isChecked();
    if(BFlg ==true)
    {
        ui->lineEdit->setText("选中");
    }
    else
    {
        ui->lineEdit->setText("取消");
    }
}

void MainWindow::on_comboBox_activated(const QString &arg1)
{
    ui->lineEdit->setText(arg1);
}


void MainWindow::on_btnTmrStart_clicked()
{


}
void MainWindow::event_tmr()
{


    ucCntTmr++;
    if(ucCntTmr>90)ucCntTmr=0;

    ui->progressBar->setValue(ucCntTmr);
}


void MainWindow::on_listWidget_itemClicked(QListWidgetItem *item)
{
    if (item) {
            QString text = item->text();



            // 方法2:在lineEdit中显示
            ui->textEdit->setText("选中: " + text);

            // 方法3:显示消息框(可选)
            // QMessageBox::information(this, "选中项", "您选择了: " + text);
        }
}

四、显示效果

相关推荐
FIT2CLOUD飞致云14 小时前
喜报丨MaxKB开源智能体平台入选2025年浙江省“数智优品”名单
人工智能·开源
说私域16 小时前
开源AI大模型、AI智能名片与S2B2C商城系统:个体IP打造与价值赋能的新范式
人工智能·tcp/ip·开源
说私域18 小时前
从工具理性到价值共生:开源链动2+1模式、AI智能名片与S2B2C商城系统的社会连接重构研究
人工智能·重构·开源
Yann-企业信息化1 天前
AI 开发工具对比:Dify 与 Coze Studio(开源版)差异对比
人工智能·开源
IvorySQL1 天前
在一台机器上搭建一体化 Ceph 存储集群
postgresql·开源
云雾J视界1 天前
开源协作2.0:GitHub Discussions+AI重构开发者社区的知识共创生态
人工智能·开源·github·discussions·知识共创·社区知识·ai重构
兆龙电子单片机设计1 天前
【STM32项目开源】STM32单片机智能家居控制系统
stm32·单片机·物联网·开源·毕业设计·智能家居
一路阳光8511 天前
开源鸿蒙5.0正式发布 底座及配套能力快速稳定成熟
华为·开源·harmonyos
IvorySQL1 天前
PostgreSQL 18 中国贡献者经验分享:开源参与的四点建议
数据库·postgresql·开源
云创智城-yuncitys1 天前
城市级充电项目高性价比落地方案:源码级交付 + 设备直供,全文档 + 永久保障(已开源)
开源·城市级充电系统·充电桩二开