qt-C++笔记之使用QLabel和QPushButton实现一个bool状态的指示灯

qt-C++笔记之使用QLabel和QPushButton实现一个bool状态的指示灯

code review!

文章目录

  • qt-C++笔记之使用QLabel和QPushButton实现一个bool状态的指示灯
    • 1.QPushButton实现
    • 2.QLabel实现
    • 2.QLabel实现-对错符号

1.QPushButton实现

运行
在这里插入图片描述

在这里插入图片描述

代码

#include <QtWidgets>

class IndicatorLight : public QPushButton
{
public:
    IndicatorLight(QWidget *parent = nullptr) : QPushButton(parent)
    {
        setCheckable(true);
        setFixedSize(30, 30);

        updateButtonStyle();
    }

    void setState(bool state)
    {
        setChecked(state);
        updateButtonStyle();
    }

private:
    void updateButtonStyle()
    {
        if (isChecked())
        {
            setStyleSheet("QPushButton { background-color: green; }");
            setText("ON");
        }
        else
        {
            setStyleSheet("QPushButton { background-color: red; }");
            setText("OFF");
        }
    }
};

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);

    QWidget window;
    QVBoxLayout layout(&window);

    IndicatorLight indicatorLight;
    layout.addWidget(&indicatorLight);

    QPushButton controlButton("Toggle");
    QObject::connect(&controlButton, &QPushButton::clicked, [&indicatorLight]() {
        indicatorLight.setState(!indicatorLight.isChecked());
    });
    layout.addWidget(&controlButton);

    window.show();

    return app.exec();
}

2.QLabel实现

运行
在这里插入图片描述

在这里插入图片描述

代码

#include <QApplication>
#include <QWidget>
#include <QLabel>
#include <QPushButton>

class IndicatorLight : public QWidget {
public:
    IndicatorLight(QWidget *parent = nullptr) : QWidget(parent) {
        setFixedSize(100, 100);
        setWindowTitle("Indicator Light");

        // 创建标签用于显示指示灯状态
        label = new QLabel(this);
        label->setGeometry(40, 40, 20, 20);
        updateLabel();

        // 创建按钮用于切换指示灯状态
        button = new QPushButton("Toggle", this);
        button->setGeometry(10, 70, 80, 20);
        connect(button, &QPushButton::clicked, this, &IndicatorLight::toggleState);
    }

    void toggleState() {
        // 切换状态
        state = !state;
        updateLabel();
    }

    void updateLabel() {
        // 根据状态设置标签的背景颜色
        if (state) {
            label->setStyleSheet("background-color: green; border-radius: 10px");
        } else {
            label->setStyleSheet("background-color: red; border-radius: 10px");
        }
    }

private:
    QLabel *label;
    QPushButton *button;
    bool state = false;
};

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);

    IndicatorLight indicatorLight;
    indicatorLight.show();

    return app.exec();
}

2.QLabel实现-对错符号

运行
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

代码

#include <QApplication>
#include <QWidget>
#include <QLabel>
#include <QPushButton>
#include <QVBoxLayout>
#include <QIcon>

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);

    // 创建一个QWidget作为主窗口
    QWidget *window = new QWidget();

    // 创建一个布局管理器
    QVBoxLayout *layout = new QVBoxLayout(window);

    // 创建一个QLabel对象
    QLabel *indicatorLabel = new QLabel();

    // 设置初始状态为关闭
    bool isOn = false;
    if (isOn) {
        indicatorLabel->setPixmap(QIcon::fromTheme("dialog-ok").pixmap(32, 32));
    } else {
        indicatorLabel->setPixmap(QIcon::fromTheme("dialog-cancel").pixmap(32, 32));
    }

    // 将QLabel添加到布局管理器中
    layout->addWidget(indicatorLabel);

    // 创建一个QPushButton对象
    QPushButton *toggleButton = new QPushButton("Toggle");

    // 将按钮与槽函数连接
    QObject::connect(toggleButton, &QPushButton::clicked, [&]() {
        isOn = !isOn;
        if (isOn) {
            indicatorLabel->setPixmap(QIcon::fromTheme("dialog-ok").pixmap(32, 32));
        } else {
            indicatorLabel->setPixmap(QIcon::fromTheme("dialog-cancel").pixmap(32, 32));
        }
    });

    // 将按钮添加到布局管理器中
    layout->addWidget(toggleButton);

    // 设置主窗口的布局管理器
    window->setLayout(layout);

    // 显示主窗口
    window->show();

    return app.exec();
}

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/259847.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

msvcp120.dll丢失的多种详细有效解决方法

在计算机使用过程中&#xff0c;我们可能会遇到一些错误提示&#xff0c;其中之一就是“msvcp120.dll丢失”。那么&#xff0c;msvcp120.dll到底是什么&#xff1f;为什么会出现丢失的情况&#xff1f;丢失后会对电脑产生什么影响&#xff1f;本文将为您详细解答这些问题&#…

计算机网络 运输层下 | TCP概述 可靠传输 流量控制 拥塞控制 连接管理

文章目录 3 运输层主要协议 TCP 概述3.1 TCP概述 特点3.2 TCP连接RSVP资源预留协议 4 TCP可靠传输4.1 可靠传输工作原理4.1.1 停止等待协议4.1.2 连续ARQ协议 4.2 TCP可靠通信的具体实现4.2.1 以字节为单位的滑动窗口4.2.2 超时重传时间的选择4.2.3 选择确认SACK 5 TCP的流量控…

MAC苹果笔记本电脑如何彻底清理垃圾文件软件?

苹果电脑以其流畅的操作系统和卓越的性能而备受用户喜爱。然而&#xff0c;随着时间的推移&#xff0c;系统可能会积累大量垃圾文件&#xff0c;影响性能。本文将介绍苹果电脑怎么清理垃圾文件的各种方法&#xff0c;以提升系统运行效率。 CleanMyMac X是一款专业的Mac清理软件…

C#中HttpWebRequest的用法

前言 HttpWebRequest是一个常用的类&#xff0c;用于发送和接收HTTP请求。在C#中使用HttpWebRequest可以实现各种功能&#xff0c;包括发送GET和POST请求、处理Cookie、设置请求头、添加参数等。本文将深入介绍HttpWebRequest的用法&#xff0c;并给出一些常见的示例。 目录 前…

01AVue入门(持续学习中)

1.使用AVue开发简单的前端页面直接简单到起飞,他是Element PlusVueVite开发的,不需要向元素的前端代码一样一个组件要传很多参数,他可以使用Json文本来控制我们要传入的数据结构来决定显示什么 //我使用的比较新,我们也可以使用cdn直接使用script标签直接引入 2.开发中遇到的坑…

macOS制作dmg包

macOS制作dmg包 准备&#xff1a;磁盘工具、以及要制作的软件&#xff0c;这里以Firefox为例 图片素材 背景图&#xff1a; 找到Firefox&#xff0c;点击显示简介&#xff0c;查看包的大小 打开磁盘工具 文件–>新建映像–>空白映像 填写信息&#xff0c;大小…

MySQL,使用Union组合查询

1、基本使用 Union可将多条select语句组合成一个结果集&#xff0c;常见的使用场景有2种&#xff1a; 在单个查询中&#xff0c;从不同的表返回类似结构的数据&#xff1b;对单个表执行多个查询&#xff0c;按单个查询返回数据。 例&#xff1a;检索出所有价格<50的产品&…

.Net Attribute 什么是特性、预定义特性使用(一)

什么是特性&#xff1f; 特性&#xff08;Attribute&#xff09;是用于在运行时传递程序中各种元素&#xff08;比如类、方法、结构、枚举、组件等&#xff09;的行为信息的声明性标签。您可以通过使用特性向程序添加声明性信息。一个声明性标签是通过放置在它所应用的元素前面…

实时化与 Serverless 是开源大数据 3.0 时代的必然选择

近日在 2023 云栖大会上&#xff0c;阿里云开源大数据产品进行了年度发布&#xff1a;E-MapReduce、Elasticsearch 等开源大数据产品全面 Serverless 化&#xff1b;创新性推出 Flink 与 Paimon 搭档的新一代流式湖仓&#xff1b;拥抱 AI&#xff0c;推出 Milvus 全托管服务&am…

基于SSM+Vue的新闻管理系统

基于SSMVue的新闻管理系统的设计与实现~ 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringSpringMVCMyBatisVue工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 主页 新闻列表 管理员界面 用户界面 摘要 新闻管理系统基于SSM&#xff08;Spr…

C# 使用NUnit进行单元测试

写在前面 NUnit是一个开源的.Net单元测试框架&#xff0c;经常被用来在.Net体系下做白盒测试。 NUnit.org GitHub 本文记录一个简单的使用NUnit进行单元测试的完整流程。 代码实现 新建一个目标类库NUnitTester&#xff0c;添加待测试的类文件&#xff0c;内容如下&#…

GLTF/GLB模型在线预览、编辑、动画查看以及材质修改

在线工具推荐&#xff1a; 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 GLTF在线编辑器提供了一个内置的模型查看器&#xff0c;可以加载和预…

最新国内可用使用GPT4.0,GPT语音对话,Midjourney绘画,DALL-E3文生图

一、前言 ChatGPT3.5、GPT4.0、GPT语音对话、Midjourney绘画&#xff0c;相信对大家应该不感到陌生吧&#xff1f;简单来说&#xff0c;GPT-4技术比之前的GPT-3.5相对来说更加智能&#xff0c;会根据用户的要求生成多种内容甚至也可以和用户进行创作交流。 然而&#xff0c;GP…

使用TikTok云手机轻松拓展全球市场

TikTok作为一款风靡全球的短视频应用&#xff0c;全球影响力不断扩大。越来越多的商家开始借助TikTok分享作品、在海外市场上获取商业机会。要想更好地借助TikTok扩大海外市场&#xff0c;使用TikTok云手机是一个好选择。本文将介绍TikTok云手机的几大作用&#xff0c;以助您更…

LVS+keepalived 高可用负载均衡

目录 工具&#xff1a; keepalived &#xff08;专为LVS和HA设计的一款健康检查工具&#xff09; 协议&#xff1a;VRRP协议 一个合格的集群&#xff0c;应该具备哪些特性&#xff1a; 健康检查&#xff08;探针&#xff09;的方式&#xff1a; 主备切换&#xff1a…

nodejs微信小程序+python+PHP柚子校园影院系统-计算机毕业设计推荐

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

JavaGUI(但期末速成版)之JFrame和JDialog

前言 学到期末发现越来越没时间来细写这些东西了&#xff0c;毕竟蒟蒻博主的发展方向主要需要学的不是Java&#xff0c;但为了期末高分通过&#xff0c;也不得不花一些精力上来&#xff0c;于是有了这样一篇速成GUI&#xff0c;本篇会以十分精简的语言来学习&#xff0c;主打一…

Linux:(登录后/退出后)—自动执行脚本或者命令

系统:centos7 登录后 自动执行脚本或者命令至少有三种 都是把要执行的语句写进文件里 /etc/profile ~/.bash_profile /etc/rc.d/rc.local 登录后自动执行脚本或者命令的方式有很多&#xff0c;网上大多数说的都是在 /etc/rc.d/rc.local 所以我主要讲解一下后两种。需要第…

nodejs+vue+微信小程序+python+PHP柚子校园影院系统-计算机毕业设计推荐

柚子校园影院综合网络空间开发设计要求。目的是将系统传统管理方式转换为在网上管理&#xff0c;完成信息管理的方便快捷、安全性高、交易规范做了保障&#xff0c;目标明确。柚子校园影院可以将功能划分为管理员功能和用户功能。  而开发本系统&#xff0c;又能够提高系统整体…

2024亚洲(春季)户外露营展览会在深圳启幕!共话户外露营生活流行风向

COSP2024深圳进出口户外用品贸易展&#xff0c;将于2024年3月14日至16日在深圳会展中心&#xff08;福田馆&#xff09;盛大举行。作为华南地区户外行业的顶级开年盛会&#xff0c;本次展会将汇聚600多家行业知名企业和60,000多名专业采购观众&#xff0c;共同聚焦户外全产业链…