【qt计算器】

ops/2025/2/26 13:15:26/

qt计算器

  • 目录
      • 注释部分
      • 模块配置
      • 目标配置
      • 模板配置
      • 源文件配置
      • 头文件配置
      • UI 文件配置
      • 1. 头文件保护宏
      • 2. 包含必要的头文件
      • 3. 命名空间声明
      • 4. 类的定义
      • 5. 构造函数和析构函数
      • 6. 私有槽函数
      • 7. 私有成员变量
      • 8. 头文件保护宏结束
      • 1. 包含头文件
      • 2. 构造函数 `MainWindow::MainWindow(QWidget *parent)`
      • 3. 析构函数 `MainWindow::~MainWindow()`
      • 4. 按钮点击事件处理函数 `MainWindow::on_pushButton_clicked()`
      • 5. 文本编辑框 1 文本编辑事件处理函数 `MainWindow::on_lineEdit_1_textEdited(const QString &arg1)`
      • 6. 文本编辑框 2 文本编辑事件处理函数 `MainWindow::on_lineEdit_2_textEdited(const QString &arg1)`
      • 7. 下拉框当前文本改变事件处理函数 `MainWindow::on_comboBox_currentTextChanged(const QString &arg1)`
      • 总结

目录

注释部分

#-------------------------------------------------
#
# Project created by QtCreator 2025-02-19T14:23:43
#
#-------------------------------------------------

这是一段注释内容,表明该项目是由 Qt Creator 在 2025 年 2 月 19 日 14 时 23 分 43 秒创建的。注释在 .pro 文件中不影响实际的项目配置,主要用于提供一些说明信息。

模块配置

QT       += core gui
  • QT:是一个用于指定项目所需 Qt 模块的配置项。
  • +=:表示在原有模块的基础上追加新的模块。
  • core:是 Qt 的核心模块,提供了 Qt 框架的基础功能,如对象系统、事件循环、文件操作、字符串处理等。
  • gui:是 Qt 的图形用户界面模块,包含了创建图形界面所需的各种类和功能,像窗口、按钮、文本框等控件的相关类都在这个模块中。
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
  • greaterThan(QT_MAJOR_VERSION, 4):这是一个条件判断表达式。QT_MAJOR_VERSION 代表当前使用的 Qt 版本的主版本号,该表达式判断主版本号是否大于 4。
  • ::如果前面的条件成立,就执行后面的语句。
  • QT += widgets:如果 Qt 主版本号大于 4,就追加 widgets 模块。widgets 模块是 Qt 5 及更高版本引入的,提供了更多高级的图形界面组件和功能。

目标配置

TARGET = prj
  • TARGET:用于指定生成的可执行文件或库的名称。这里表示最终生成的可执行文件名为 prj

模板配置

TEMPLATE = app
  • TEMPLATE:指定项目的模板类型。app 表示这是一个应用程序项目,最终会生成一个可执行文件。除了 app,常见的模板类型还有 lib(用于创建库项目)等。

源文件配置

SOURCES += main.cpp\mainwindow.cpp
  • SOURCES:指定项目中包含的源文件列表。
  • +=:表示追加源文件。
  • main.cpp:通常是程序的入口文件,包含 main 函数,程序从这里开始执行。
  • mainwindow.cpp:是自定义主窗口类的实现文件,包含该类成员函数的具体实现代码。
  • \:是换行符,用于将较长的列表拆分成多行,方便阅读和编辑,表明下一行的内容也是该配置项的一部分。

头文件配置

HEADERS  += mainwindow.h
  • HEADERS:指定项目中包含的头文件列表。
  • +=:表示追加头文件。
  • mainwindow.h:是自定义主窗口类的头文件,包含该类的声明,如类的成员变量、成员函数的声明等。

UI 文件配置

FORMS    += mainwindow.ui
  • FORMS:指定项目中包含的 UI 文件列表。
  • +=:表示追加 UI 文件。
  • mainwindow.ui:是使用 Qt Designer 可视化设计的主窗口界面文件,通过该文件可以方便地设计窗口的布局和控件。

综上所述,这个 .pro 文件配置了一个名为 prj 的 Qt 应用程序项目,使用了 coregui
widgets 模块,包含 main.cppmainwindow.cpp 源文件、mainwindow.h 头文件以及
mainwindow.ui UI 文件。

这段代码是一个 Qt 项目中 MainWindow 类的头文件 mainwindow.h,下面为你逐行解释其含义。

1. 头文件保护宏

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

这是头文件保护机制,也称为预处理器守卫。其作用是防止头文件被重复包含,避免因重复定义导致的编译错误。当第一次包含该头文件时,MAINWINDOW_H 未被定义,因此会执行 #define MAINWINDOW_H 定义该宏,后续再次包含该头文件时,由于 MAINWINDOW_H 已被定义,#ifndef 条件不成立,头文件内容将被跳过。

2. 包含必要的头文件

#include <QMainWindow>

包含了 QMainWindow 类的头文件。QMainWindow 是 Qt 中用于创建主窗口的基类,它提供了菜单栏、工具栏、状态栏等常见主窗口元素的支持。

3. 命名空间声明

namespace Ui {
class MainWindow;
}

声明了一个名为 Ui 的命名空间,并在其中声明了 MainWindow 类。这个 Ui::MainWindow 类是由 Qt Designer 自动生成的,用于管理 mainwindow.ui 文件中设计的界面元素。

4. 类的定义

class MainWindow : public QMainWindow
{Q_OBJECT

定义了一个名为 MainWindow 的类,它继承自 QMainWindowQ_OBJECT 是一个宏,它是 Qt 元对象系统的核心部分,用于支持信号与槽机制、动态属性系统等高级特性。任何使用信号与槽机制的类都必须包含这个宏。

5. 构造函数和析构函数

public:explicit MainWindow(QWidget *parent = 0);~MainWindow();
  • explicit MainWindow(QWidget *parent = 0);:这是 MainWindow 类的构造函数。explicit 关键字用于防止隐式类型转换。parent 是一个指向父窗口的指针,默认值为 0(即 nullptr),表示该窗口没有父窗口。
  • ~MainWindow();:这是 MainWindow 类的析构函数,用于在对象销毁时进行资源清理工作。

6. 私有槽函数

private slots:void on_pushButton_clicked();void on_lineEdit_1_textEdited(const QString &arg1);void on_lineEdit_2_textEdited(const QString &arg1);void on_comboBox_currentTextChanged(const QString &arg1);
  • private slots:这是 Qt 中槽函数的声明区域。槽函数是一种特殊的成员函数,用于响应信号。
  • on_pushButton_clicked():当名为 pushButton 的按钮被点击时,该槽函数会被调用。
  • on_lineEdit_1_textEdited(const QString &arg1):当名为 lineEdit_1 的文本编辑框中的文本被编辑时,该槽函数会被调用,arg1 是编辑后的文本内容。
  • on_lineEdit_2_textEdited(const QString &arg1):当名为 lineEdit_2 的文本编辑框中的文本被编辑时,该槽函数会被调用,arg1 是编辑后的文本内容。
  • on_comboBox_currentTextChanged(const QString &arg1):当名为 comboBox 的下拉框中当前选中的文本发生变化时,该槽函数会被调用,arg1 是新选中的文本内容。

7. 私有成员变量

private:Ui::MainWindow *ui;

定义了一个私有成员变量 ui,它是一个指向 Ui::MainWindow 类对象的指针。这个指针用于访问 mainwindow.ui 文件中设计的界面元素,通过它可以在代码中操作界面上的各种控件。

8. 头文件保护宏结束

#endif // MAINWINDOW_H

结束头文件保护宏,与开头的 #ifndef MAINWINDOW_H#define MAINWINDOW_H 相对应。

综上所述,这个头文件定义了一个 MainWindow 类,它继承自
QMainWindow,包含构造函数、析构函数和一些用于处理界面元素事件的槽函数,同时使用 Ui::MainWindow
指针来管理界面元素。

这段代码是 mainwindow.cpp 文件,它实现了 MainWindow 类中声明的函数,主要功能是创建一个简单的计算器界面,处理界面上控件的交互事件并进行相应的计算。下面为你逐行详细解释:

1. 包含头文件

#include "mainwindow.h"
#include "ui_mainwindow.h"
  • #include "mainwindow.h":包含自定义的 MainWindow 类的头文件,其中声明了 MainWindow 类的成员函数和成员变量。
  • #include "ui_mainwindow.h":包含由 Qt Designer 自动生成的界面类的头文件,该文件中定义了 Ui::MainWindow 类,用于管理 mainwindow.ui 文件中设计的界面元素。

2. 构造函数 MainWindow::MainWindow(QWidget *parent)

MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{ui->setupUi(this);
}
  • MainWindow::MainWindow(QWidget *parent):这是 MainWindow 类的构造函数定义。
  • QMainWindow(parent):调用基类 QMainWindow 的构造函数,将传入的父窗口指针 parent 传递给它。
  • ui(new Ui::MainWindow):使用 new 运算符动态创建一个 Ui::MainWindow 对象,并将其地址赋值给成员变量 ui
  • ui->setupUi(this):调用 Ui::MainWindow 对象的 setupUi 方法,将当前 MainWindow 对象 this 作为参数传入,该方法会将 mainwindow.ui 文件中设计的界面元素设置到当前窗口中。

3. 析构函数 MainWindow::~MainWindow()

MainWindow::~MainWindow()
{delete ui;
}
  • MainWindow::~MainWindow():这是 MainWindow 类的析构函数定义。
  • delete ui:释放之前在构造函数中动态分配的 Ui::MainWindow 对象的内存,防止内存泄漏。

4. 按钮点击事件处理函数 MainWindow::on_pushButton_clicked()

void MainWindow::on_pushButton_clicked()
{int line1 = ui->lineEdit_1->text().toInt();int line2 = ui->lineEdit_2->text().toInt();int line3;QString sFlag = ui->comboBox->currentText();if (sFlag == "+"){line3 = line1 + line2;}else if(sFlag == "-"){line3 = line1 - line2;}else if(sFlag == "*"){line3 = line1 * line2;}else if(sFlag == "/"){line3 = line1 / line2;}else{ui->lineEdit_3->setText("error");return;}QString str = QString::number(line3);ui->lineEdit_3->setText(str);
}
  • 当界面上的 pushButton 被点击时,该函数会被调用。
  • int line1 = ui->lineEdit_1->text().toInt();int line2 = ui->lineEdit_2->text().toInt();:从 lineEdit_1lineEdit_2 文本编辑框中获取用户输入的文本,并将其转换为整数类型。
  • QString sFlag = ui->comboBox->currentText();:从 comboBox 下拉框中获取当前选中的运算符。
  • 根据运算符进行相应的计算,并将结果存储在 line3 中。
  • 如果运算符不是 +-*/ 中的任何一个,则在 lineEdit_3 中显示 error
  • QString str = QString::number(line3);:将计算结果 line3 转换为字符串类型。
  • ui->lineEdit_3->setText(str);:将计算结果显示在 lineEdit_3 文本编辑框中。

5. 文本编辑框 1 文本编辑事件处理函数 MainWindow::on_lineEdit_1_textEdited(const QString &arg1)

void MainWindow::on_lineEdit_1_textEdited(const QString &arg1)
{int line1 = arg1.toInt();int line2 = ui->lineEdit_2->text().toInt();int line3 = line1 + line2;QString str = QString::number(line3);ui->lineEdit_3->setText(str);
}
  • lineEdit_1 文本编辑框中的文本被编辑时,该函数会被调用。
  • int line1 = arg1.toInt();:将编辑后的文本 arg1 转换为整数类型。
  • int line2 = ui->lineEdit_2->text().toInt();:从 lineEdit_2 文本编辑框中获取用户输入的文本,并将其转换为整数类型。
  • 计算 line1line2 的和,并将结果存储在 line3 中。
  • 将计算结果转换为字符串类型,并显示在 lineEdit_3 文本编辑框中。

6. 文本编辑框 2 文本编辑事件处理函数 MainWindow::on_lineEdit_2_textEdited(const QString &arg1)

void MainWindow::on_lineEdit_2_textEdited(const QString &arg1)
{int line1 = ui->lineEdit_1->text().toInt();int line2 = arg1.toInt();int line3 = line1 + line2;QString str = QString::number(line3);ui->lineEdit_3->setText(str);
}
  • lineEdit_2 文本编辑框中的文本被编辑时,该函数会被调用。
  • lineEdit_1 文本编辑框中获取用户输入的文本,并将其转换为整数类型。
  • 将编辑后的文本 arg1 转换为整数类型。
  • 计算 line1line2 的和,并将结果存储在 line3 中。
  • 将计算结果转换为字符串类型,并显示在 lineEdit_3 文本编辑框中。

7. 下拉框当前文本改变事件处理函数 MainWindow::on_comboBox_currentTextChanged(const QString &arg1)

void MainWindow::on_comboBox_currentTextChanged(const QString &arg1)
{int line1 = ui->lineEdit_1->text().toInt();int line2 = ui->lineEdit_2->text().toInt();int line3;QString sFlag = ui->comboBox->currentText();if (sFlag == "+"){line3 = line1 + line2;}else if(sFlag == "-"){line3 = line1 - line2;}else if(sFlag == "*"){line3 = line1 * line2;}else if(sFlag == "/"){line3 = line1 / line2;}else{ui->lineEdit_3->setText("error");return;}QString str = QString::number(line3);ui->lineEdit_3->setText(str);
}
  • comboBox 下拉框中当前选中的文本发生变化时,该函数会被调用。
  • lineEdit_1lineEdit_2 文本编辑框中获取用户输入的文本,并将其转换为整数类型。
  • 根据当前选中的运算符进行相应的计算,并将结果存储在 line3 中。
  • 如果运算符不是 +-*/ 中的任何一个,则在 lineEdit_3 中显示 error
  • 将计算结果转换为字符串类型,并显示在 lineEdit_3 文本编辑框中。

总结

这段代码实现了一个简单的计算器界面的交互逻辑,通过处理按钮点击、文本编辑和下拉框选择等事件,根据用户输入的数字和运算符进行相应的计算,并将结果显示在界面上。

在这里插入图片描述


http://www.ppmy.cn/ops/161417.html

相关文章

python爬虫学习第十一篇爬取指定类型数据

最近在学习Python爬虫的过程中&#xff0c;尝试用爬虫获取指定类型的数据。今天&#xff0c;我想和大家分享一下我的实践过程和遇到的问题。 一、实现目标 目标是从一个网站的API接口获取不同类型的食品数据。 比如&#xff0c;第一步我想获取汉堡、小食、甜品等不同类型的数…

R Excel 文件:高效数据处理的利器

R Excel 文件:高效数据处理的利器 在数据分析领域,R语言因其强大的统计分析和可视化功能而备受推崇。而R Excel文件,作为R语言与Excel的桥梁,使得数据在R和Excel之间的高效转换成为可能。本文将详细介绍R Excel文件的概念、应用场景以及操作方法。 一、R Excel文件的概念…

Spring源码分析の循环依赖

文章目录 前言一、循环依赖问题二、循环依赖的解决三、整体流程分析 前言 常见的可能存在循环依赖的情况如下&#xff1a; 两个bean中互相持有对方作为自己的属性。   类似于&#xff1a; 两个bean中互相持有对方作为自己的属性&#xff0c;且在构造时就需要传入&#xff1a…

百度首页上线 DeepSeek 入口,免费使用

大家好&#xff0c;我是小悟。 百度首页正式上线了 DeepSeek 入口&#xff0c;这一重磅消息瞬间在技术圈掀起了惊涛骇浪&#xff0c;各大平台都被刷爆了屏。 百度这次可太给力了&#xff0c;PC 端开放仅 1 小时&#xff0c;就有超千万人涌入体验。这速度&#xff0c;简直比火…

MobSF(Mobile Security Framework) 的详细介绍、安装指南、配置说明

MobSF&#xff1a;移动应用安全分析的全能框架 一、MobSF 简介 MobSF 是一款开源的 移动应用安全测试框架&#xff0c;专为 Android 和 iOS 应用设计。它集成了静态代码分析、动态调试、恶意软件检测、网络流量分析等功能&#xff0c;适用于渗透测试、漏洞挖掘和安全合规审计…

大数据新视界 -- Hive 事务与 ACID 特性的实现(2 - 16 - 7)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

老游戏回顾:B2RE

里昂线 里昂斯科特肯尼迪几日来都没有听到关于他新岗位的消息&#xff0c;于是他决定驾车前往浣熊市一探究竟。不过他不知道的是&#xff0c;在前方等待他的是一场恶梦…… 克莱尔线 克莱尔雷德菲尔德即将面对另一场噩梦&#xff0c;她还不知道自己平凡的生活将迎来多么剧烈…

八、Spring Boot:RESTful API 应用

创建第一个 Spring Boot RESTful API 应用 在现代 Web 开发中&#xff0c;RESTful API 是一种非常流行的设计风格&#xff0c;它基于 HTTP 协议&#xff0c;提供了简单、灵活的方式来构建网络应用。Spring Boot 作为一款强大的微服务框架&#xff0c;提供了丰富的工具和支持&a…