经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » 编程经验 » 查看文章
Qt-qrencode开发-生成、显示二维码📀
来源:cnblogs  作者:mahuifa  时间:2024/5/31 9:17:54  对本文有异议

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文件中添加下列代码;

    1. CONFIG(debug, debug|release): {
    2. LIBS += -L$$PWD/QRencode/lib/ -lqrencoded
    3. }else{
    4. LIBS += -L$$PWD/QRencode/lib/ -lqrencode
    5. }
    6. INCLUDEPATH += $$PWD/QRencode/include
    7. 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

    1. DEFINES += HAVE_CONFIG_H
    2. 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
    3. 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

  • 实现代码

    1. #include "qrcodeview.h"
    2. #include "qrencode.h"
    3. #include <QDebug>
    4. #include <QDir>
    5. #include <QFileInfo>
    6. #include <QPainter>
    7. QrCodeView::QrCodeView(QWidget* parent)
    8. : QWidget{parent}
    9. {}
    10. void QrCodeView::setString(const QString& str)
    11. {
    12. if (str.isEmpty())
    13. return;
    14. if (m_str == str)
    15. return;
    16. m_str = str;
    17. QRcode* qrcode = QRcode_encodeString(str.toStdString().data(), 2, QR_ECLEVEL_Q, QR_MODE_8, 1);
    18. if (!qrcode) // 错误返回null
    19. {
    20. qInfo() << errno; // 打印错误码
    21. return;
    22. }
    23. int w = qMin(this->width(), this->height()); // 控件长宽的最小值,保证绘制完整正方形
    24. int qrcodeW = qMax(qrcode->width, 1);
    25. qreal size = w / qreal(qrcodeW); // 二维码小格子的长宽
    26. m_img = QImage(w, w, QImage::Format_ARGB32);
    27. QPainter painter(&m_img);
    28. painter.setBrush(Qt::white); // 设置白色笔刷
    29. painter.setPen(Qt::NoPen);
    30. painter.drawRect(0, 0, w, w); // 绘制w x w的白色背景
    31. painter.setBrush(Qt::black); // 设置黑色笔刷用于绘制方块
    32. for (qint32 y = 0; y < qrcodeW; y++)
    33. {
    34. for (qint32 x = 0; x < qrcodeW; x++)
    35. {
    36. unsigned char b = qrcode->data[(y * qrcodeW) + x];
    37. if (b & 0x01) // 1=黑、0=白
    38. {
    39. QRectF rect(x * size, y * size, size, size);
    40. painter.drawRect(rect); // 绘制黑色格子
    41. }
    42. }
    43. }
    44. delete qrcode;
    45. qrcode = nullptr;
    46. this->update(); // 绘制图片
    47. }
    48. /**
    49. * @brief 保存生成的二维码图片到指定路径
    50. * @param path 保存路径 + 名称.jpg
    51. * @return true 保存成功
    52. */
    53. bool QrCodeView::save(const QString& path)
    54. {
    55. if (path.isEmpty() || m_img.isNull())
    56. return false;
    57. QFileInfo info(path);
    58. if (info.suffix() == "jpg" || info.suffix() == "JPG") // 只支持保存为jpg格式
    59. {
    60. QDir().mkpath(info.path()); // 创建路径,防止路径不存在
    61. return m_img.save(path);
    62. }
    63. else
    64. {
    65. return false;
    66. }
    67. }
    68. /**
    69. * @brief 返回生成的二维码图片
    70. * @return
    71. */
    72. QImage QrCodeView::getImage()
    73. {
    74. return m_img;
    75. }
    76. /**
    77. * @brief 在控件中显示二维码
    78. * @param event
    79. */
    80. void QrCodeView::paintEvent(QPaintEvent* event)
    81. {
    82. QWidget::paintEvent(event);
    83. QPainter painter(this);
    84. int x = (this->width() - m_img.width()) / 2;
    85. int y = (this->height() - m_img.height()) / 2;
    86. painter.drawImage(x, y, m_img);
    87. }

7、完整源代码??

 ??????? ?????????
 ????? ????????
???????????????
 ??????????????
 ??????????????
 ????????? |/
 ????????? ???????
 ??????????????

????????????_????????

原文链接:https://www.cnblogs.com/IntelligencePointer/p/18223383

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号