Qt-qrencode开发-生成、显示二维码

qt,qrencode · 浏览次数 : 0

小编点评

该代码主要用于生成QR编码的图片,并将其嵌入到Qt中。代码首先包含了QR编码相关的头文件,然后定义了QRCodeView类,该类负责生成和绘制QR编码图片。 1. **qrencode.h**定义了QR编码相关类型和函数,例如`QRcode_encodeString()`用于编码字符串到QR编码格式。 2. **qrinput.h**定义了用于处理用户输入的变量,例如`m_str`,以及用于绘制QR编码图片的`m_img`和`m_imgWidth`。 3. **qrspec.h**定义了用于设置QR编码参数的变量,例如`QR_ECLEVEL_Q`,`QR_MODE_8`等。 4. **rsecc.h**定义了用于设置RGB颜色值的变量,例如`Qt::white`等。 5. **split.h**定义了用于绘制QR编码图片的变量,例如`m_img`、`m_imgWidth`等。 6. **widget.h**定义了QRCodeView的基类,并包含了`setString()`方法,用于设置QR编码字符串。 7. **widget.cpp**实现了`QrCodeView`类的构造函数,其中调用了`QRcode_encodeString()`将字符串编码为QR编码格式,并绘制该编码后的QR编码图片。 8. **qrcode_inner.h**定义了QR编码内部的类型和函数,例如`QRcode`用于存储QR编码数据,`QRcode_encodeString()`等用于编码字符串到QR编码格式。 9. **qrinput.cpp**实现了`QRCodeView`的`setString()`方法,其中调用了`QRcode_encodeString()`将字符串编码为QR编码格式,并绘制该编码后的QR编码图片。 10. **qrspec.cpp**实现了`QRCodeView`的`setParam()`方法,用于设置QR编码参数。 11. **rsecc.cpp**实现了`QRCodeView`的`setColor()`方法,用于设置QR编码图片的颜色。 12. **split.cpp**实现了`QRCodeView`的`drawGrid()`方法,用于绘制QR编码图片的表格结构。 13. **widget.cpp**包含了其他与QR编码相关的类和函数,例如`QDir`、`QFileInfo`等,用于处理文件操作。

正文

Qt-qrencode开发-生成二维码📀

1、概述📸

qrencode是一个用于生成QR码(二维码)的库,它支持多种编程语言的接口,包括C、C++、Python等。QR码是一种矩阵式二维码,常用于存储网址、联系信息、文字信息等,广泛应用于各种场景,如产品追踪、广告宣传、文档管理等。

qrencode的设计简洁高效,提供了易于使用的API接口,使得开发者能够轻松地在应用程序中集成QR码生成和处理功能

库的基本特性

  1. 生成能力qrencode库能够生成不同版本和纠错级别的QR码,支持从最小的版本1(21x21的模块)到最高的版本40(177x177的模块),并且可以根据需要调整纠错等级(L、M、Q、H)。
  2. 输出格式:库支持生成多种格式的输出,包括PNG图片、SVG矢量图、ASCII文本形式的二维码等,这取决于库的具体实现和使用的接口。
  3. 编码内容:支持多种数据类型编码,如数字、字母、二进制数据、UTF-8文本、电子邮件地址、电话号码、URL等。
  4. C++接口:对于C++,qrencode提供了丰富的类和方法来方便地生成二维码。用户可以创建一个QRcode对象,向其中添加数据,然后将其渲染成所需的格式。
  5. C接口:对于C语言使用者,qrencode也提供了函数接口,通过这些函数可以直接操作二维码数据结构,进行编码和输出。
  6. 跨平台qrencode库是跨平台的,可以在多种操作系统上编译和使用,包括Windows、Linux、macOS等。
  7. 依赖:在某些情况下,如生成PNG图片输出时,qrencode可能需要额外的依赖,如libpngzlib库。

开发环境说明

  • 系统:Windows11、Ubuntu20.04
  • Qt版本:V5.14.2
  • 编译器:MSVC2017-64、GCC/G++64
  • qrencode版本:4.1.1

2、实现效果💽

  1. 将qrencode使用Qt封装为一个生成、显示二维码的控件;
  2. 支持使用QPainter绘制显示二维码;
  3. 可通过函数接口返回生成的二维码QImage;
  4. 可通过调用函数将生成的二维码保存到指定路径;
  5. 支持使用源码嵌入工程(更好的跨平台、支持各种编译器);
  6. 支持使用编译好的静态库(MSVC2017-64);

3、编译qrencode🔍

  1. 下载源代码

  2. 将qrencode-4.1.1解压后,创建一个build文件夹;

  3. 打开Cmake,将qrencode-4.1.1文件夹下的CMakeLists.txt文件拖入CMake中;

  4. 点击【Configure】;

  5. 这里我选择了MSVC2017-64编译器,点击【Finish】;

  6. 如下图所示进行配置,配置不正确会由于没有准备依赖而报错;

    1. 设置编译后的安装路径为C:/Users/MHF/Downloads/qrencode-4.1.1/QRencode
    2. 勾选WITHOUT_PNG,表示不支持png;
    3. 取消勾选WITH_TOOLS,否则会报错。

  7. 然后点击【Generate】、【Open Project】打开VS;

  8. 鼠标右键选择【ALL_BUILD】,点击【生成】,然后选择【INSTALL】,点击【生成】;

  9. 就可以在安装路径下生成编译好的文件了;

4、在QT中引入编译为静态库的QRencode

  • 创建一个工程,将编译后的QRencode文件夹复制到工程中;

  • 在工程的pro文件中添加下列代码;

    CONFIG(debug, debug|release): {
    LIBS += -L$$PWD/QRencode/lib/ -lqrencoded
    }else{
    LIBS += -L$$PWD/QRencode/lib/ -lqrencode
    }
    INCLUDEPATH += $$PWD/QRencode/include
    DEPENDPATH += $$PWD/QRencode/include
    

5、在Qt中直接使用QRencode源码

  • 将qrencode-4.1.1文件夹中除了.h、.c、config.h.in外的文件删除,文件夹也删除,qrenc.c也删除;

  • config.h.in重命名为config.h

  • 在pro文件中添加所有.h 、.c文件

  • 注意:还需要添加DEFINES += HAVE_CONFIG_H

    DEFINES += HAVE_CONFIG_H
    SOURCES += \
        main.cpp \
        qrencode/bitstream.c \
        qrencode/mask.c \
        qrencode/mmask.c \
        qrencode/mqrspec.c \
        qrencode/qrencode.c \
        qrencode/qrinput.c \
        qrencode/qrspec.c \
        qrencode/rsecc.c \
        qrencode/split.c \
        widget.cpp
    
    HEADERS += \
        qrencode/bitstream.h \
        qrencode/config.h \
        qrencode/mask.h \
        qrencode/mmask.h \
        qrencode/mqrspec.h \
        qrencode/qrencode.h \
        qrencode/qrencode_inner.h \
        qrencode/qrinput.h \
        qrencode/qrspec.h \
        qrencode/rsecc.h \
        qrencode/split.h \
        widget.h
    
  • 编译后会报错error: C2065: “MAJOR_VERSION”: 未声明的标识符

  • 打开config.h文件,如下图所示;

  • MAJOR_VERSIONMICRO_VERSIONMINOR_VERSIONVERSION四项修改为如下所示,与自己下载的版本号相同;

  • 然后就可以正常编译了;

6、在Qt中使用QRencode生成二维码示例

  • 在ui文件中添加下列控件,并将QWidget提升为QrCodeView

  • 实现代码

    #include "qrcodeview.h"
    #include "qrencode.h"
    #include <QDebug>
    #include <QDir>
    #include <QFileInfo>
    #include <QPainter>
    
    QrCodeView::QrCodeView(QWidget* parent)
        : QWidget{parent}
    {}
    
    void QrCodeView::setString(const QString& str)
    {
        if (str.isEmpty())
            return;
        if (m_str == str)
            return;
        m_str = str;
    
        QRcode* qrcode = QRcode_encodeString(str.toStdString().data(), 2, QR_ECLEVEL_Q, QR_MODE_8, 1);
        if (!qrcode)   // 错误返回null
        {
            qInfo() << errno;   // 打印错误码
            return;
        }
    
        int w = qMin(this->width(), this->height());   // 控件长宽的最小值,保证绘制完整正方形
        int qrcodeW = qMax(qrcode->width, 1);
        qreal size = w / qreal(qrcodeW);   // 二维码小格子的长宽
    
        m_img = QImage(w, w, QImage::Format_ARGB32);
        QPainter painter(&m_img);
        painter.setBrush(Qt::white);   // 设置白色笔刷
        painter.setPen(Qt::NoPen);
        painter.drawRect(0, 0, w, w);   // 绘制w x w的白色背景
        painter.setBrush(Qt::black);    // 设置黑色笔刷用于绘制方块
    
        for (qint32 y = 0; y < qrcodeW; y++)
        {
            for (qint32 x = 0; x < qrcodeW; x++)
            {
                unsigned char b = qrcode->data[(y * qrcodeW) + x];
                if (b & 0x01)   // 1=黑、0=白
                {
                    QRectF rect(x * size, y * size, size, size);
                    painter.drawRect(rect);   // 绘制黑色格子
                }
            }
        }
        delete qrcode;
        qrcode = nullptr;
    
        this->update();   // 绘制图片
    }
    
    /**
     * @brief       保存生成的二维码图片到指定路径
     * @param path  保存路径 + 名称.jpg
     * @return   true 保存成功
     */
    bool QrCodeView::save(const QString& path)
    {
        if (path.isEmpty() || m_img.isNull())
            return false;
    
        QFileInfo info(path);
        if (info.suffix() == "jpg" || info.suffix() == "JPG")   // 只支持保存为jpg格式
        {
            QDir().mkpath(info.path());   // 创建路径,防止路径不存在
            return m_img.save(path);
        }
        else
        {
            return false;
        }
    }
    
    /**
     * @brief   返回生成的二维码图片
     * @return
     */
    QImage QrCodeView::getImage()
    {
        return m_img;
    }
    
    /**
     * @brief          在控件中显示二维码
     * @param event
     */
    void QrCodeView::paintEvent(QPaintEvent* event)
    {
        QWidget::paintEvent(event);
    
        QPainter painter(this);
        int x = (this->width() - m_img.width()) / 2;
        int y = (this->height() - m_img.height()) / 2;
        painter.drawImage(x, y, m_img);
    }
    
    

7、完整源代码📑

          🎈🎈  ☁️
         🎈🎈🎈
☁️     🎈🎈🎈🎈
       🎈🎈🎈🎈
  ☁️    ⁣🎈🎈🎈
           |/
           🏠   ☁️
  ☁️         ☁️

🌳🌻🏫🌳🏘🏢_🏘🏢🌲🌳

与Qt-qrencode开发-生成、显示二维码相似的内容:

Qt-qrencode开发-生成、显示二维码

将qrencode使用Qt封装为一个生成、显示二维码的控件; 支持使用QPainter绘制显示二维码; 可通过函数接口返回生成的二维码QImage; 可通过调用函数将生成的二维码保存到指定路径; 支持使用源码嵌入工程(更好的跨平台、支持各种编译器); 支持使用编译好的静态库(MSVC2017-64)...

Qt实现汽车仪表盘

在UI界面显示中,仪表盘的应用相对比较广泛,经常用于显示速度值,电压电流值等等,最终实现效果如下动态图片(文末提供给源工程下载): 主要包含以下绘制步骤: 绘制画布 /* * 绘制画布 */ void Widget::initCanvas(QPainter &painter) { //消除锯齿 pa

逆向通达信 x 逆向微信 x 逆向Qt

本篇在博客园地址https://www.cnblogs.com/bbqzsl/p/18252961 本篇内容包括: win32窗口嵌入Qt UI。反斗玩转signal-slot。最后 通达信 x 微信 x Qt 做手术。 Qt Alien Widget是一种广义的DirectUI。 在UI技术中,D

Qt 应用程序中自定义鼠标光标

在 Qt 应用程序中,你可以自定义鼠标光标。你可以使用 `QCursor` 类来设置不同类型的鼠标光标,比如内置样式或者自定义的图片。以下是一些使用示例: 使用内置光标样式 Qt 提供了一些内置的光标样式,你可以使用这些样式来改变光标的外观,例如箭头、手形、等待图标等等。 1 #include

QT中各控件的属性和方法

1.在QT6中,QLabel类具有许多属性和方法,以下是QLabel类的常见属性和调用方法:setText(const QString &text):设置标签的文本内容。setAlignment(Qt::Alignment align):设置文本在标签中的对齐方式。setPixmap(const Q

C++(Qt)-GIS开发-简易瓦片地图下载器

Qt-GIS开发-简易瓦片地图下载器 目录Qt-GIS开发-简易瓦片地图下载器1、概述2、安装openssl3、实现效果4、主要代码4.1 算法函数4.2 瓦片地图下载url拼接4.3 多线程下载5、源码地址6、参考 更多精彩内容 个人内容分类汇总 GIS开发 1、概述 支持单线

[Qt开发]当我们在开发兼容高分辨率和高缩放比、高DPI屏幕的软件时,我们在谈论什么。

前言 最近在开发有关高分辨率屏幕的软件,还是做了不少尝试的,当然我们也去网上查了不少资料,但是网上的资料也很零碎,说不明白,这样的话我就做个简单的总结,希望看到这的你可以一次解决你有关不同分辨率下的所有问题。 分辨率?DPI? 首先我们搞清楚我们现在到底面对的是什么场景。在开发高分屏的时候,实际上不

Qt OPC UA通信

介绍 OPC UA全称Open Platform Unified Architecture,开放平台统一架构,是工业自动化领域通用的数据交换协议,它有两套主要的通信机制:1.客户端-服务器通信;2.发布订阅。Qt对OPC UA通信标准也提供了支持,目前还是第三方库的形式(不过Qt官方貌似有文档了),

Qt开发技术:Q3D图表开发笔记(四):Q3DSurface三维曲面图颜色样式详解、Demo以及代码详解

前言 qt提供了q3d进行三维开发,虽然这个框架没有得到大量运用也不是那么成功,性能上也有很大的欠缺,但是普通的点到为止的应用展示还是可以的。 其中就包括华丽绚烂的三维图表,数据量不大的时候是可以使用的。 前面介绍了基础的q3d散点图、柱状图、三维曲面图,本片深入对三维曲面图支持的颜色表现方式进行探

QtCreator 跨平台开发添加动态库教程(以OpenCV库举例)- Windows篇

Qt具有跨平台的特性,即Qt数据结构与算法库本身跨平台和编译脚本(.pro)跨平台。在同时具有Windows下和Linux开发的需求时,最好的建议是使用QtCreator来开发,虽然也可以使用其他的IDE配合CMake等方式,但使用QtCreator更加方便,并且操作环境完全一致。QtCreator