【Qt菜鸟笔记】QLCDNumber控件

1.QLCDNumber控件简介(Qt6.5.3版)

      QLCDNumber控件显示带有类似 LCD 数字的数字。它可以显示十进制、十六进制、八进制或二进制数。

头文件引入#include<QLCDNumber>
CMake配置:find_package(Qt6 REQUIRED COMPONENTS Widgets)
target_link_libraries(mytarget PRIVATE Qt6::Widgets
qmake配置QT += widgets
继承于QFrame控件

2.QLCDNumber基本使用(Qt6.5.3版-Mingw)

2.1使用纯代码写法

在这里插入图片描述
main.cpp文件

#include <QApplication>
#include <QWidget>
#include <QLCDNumber>                         
#include <QVBoxLayout>
#include <QLabel>
#include <QFormLayout>

// 创建并配置QLCDNumber控件的函数
QLCDNumber* createLCDNumber(int digits, const QString &value, QLCDNumber::SegmentStyle style, QSize maxSize, const QString &stylesheet) {
    QLCDNumber *lcd = new QLCDNumber();
    lcd->setDigitCount(digits); // 设置显示的数字位数
    lcd->display(value);        // 设置显示值
    lcd->setSegmentStyle(style); // 设置显示样式
    lcd->setMaximumSize(maxSize); // 设置最大尺寸
    lcd->setStyleSheet(stylesheet); // 设置样式表
    return lcd;
}

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

    QWidget window;
    window.setWindowTitle("QLCDNumber Example");
    window.setMinimumSize(800, 600);

    // 使用封装的函数创建不同样式的QLCDNumber控件
    QLCDNumber *lcdFlat = createLCDNumber(8, "11.111", QLCDNumber::Flat, QSize(200, 80),
                                          "QLCDNumber { background-color: black; color: green; }");

    QLCDNumber *lcdFilled = createLCDNumber(6, "22.22", QLCDNumber::Filled, QSize(200, 80),
                                            "QLCDNumber { background-color: black; color: green; }");

    QLCDNumber *lcdOutline = createLCDNumber(6, "33.33", QLCDNumber::Outline, QSize(200, 80),
                                             "QLCDNumber { background-color: black; color: green; }");
    QLCDNumber *lcdFont = createLCDNumber(12, "44.4444", QLCDNumber::Flat, QSize(150, 80),
                                             "QLCDNumber { background-color: black; color: green; }");

    // 创建布局并将控件添加到窗口中
    QVBoxLayout *layout = new QVBoxLayout(&window);
    QFormLayout *formLayout = new QFormLayout();
    formLayout->addRow("Flat平面形式显示:", lcdFlat);
    formLayout->addRow("Filled填充形式显示,qss样式不起效果:", lcdFilled);
    formLayout->addRow("Outline平面形式显示,qss样式不起效果:", lcdOutline);
     formLayout->addRow("lcd的字体大小受控件尺寸和显示位数影响,qss样式不起效果:", lcdFont);

    layout->addLayout(formLayout);
    window.setLayout(layout);

    window.show();
    return app.exec();
}

2.2 使用designerUI进行设计

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

竹林海灵

谢谢义父

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值