linux系统中利用QT实现车牌识别的方法

简介: linux系统中利用QT实现车牌识别的方法

     大家好,今天主要和大家分享一下,如何利用QT实现车牌识别的方法。



 

第一:车牌识别基本简介

     很多车牌方案商都有成熟的车牌识别技术,他们是靠这个吃饭的,不开源。当然网上也有一些开 源的车牌识别算法可以参考,但是我们 Qt 教程里不是讲车牌识别算法,因为过于复杂,内容多。 所以本教程也是使用方案商提供的接口来做车牌识别,例程比较简单,百度 AI 接口车牌识别 率非常高,毕竟能让别人花钱的东西是不一样的。下面就让我们使用 Qt 来调用百度 AI 车牌识 别的接口来做个例子吧

     车牌识别基本操作如下:

1、介绍百度车牌识别功能申请,及简单介绍调用流程。

2、用 Qt 编写示例程序。流程如下,将本地车牌照片(JPG),发送到百度车牌识别服务 器,然后由百度服务器返回车牌识别结果。

第二:车牌识别产品申请

    在浏览器输入“百度车牌识别”搜索,击进去。

     点击“技术文档”,其中您需要参阅下图的“技术文档”来查看使用手册。它里面会介绍 API 相关使用方法和领取免费的测试资源方法。

我们只需要领取车牌识别功能资源,根据百度提供的“技术文档”可以知道,在文字识别》 购买指南》免费测试资源,可以看到未实名认证的用户免费领取车牌识别功能为 200 次/月,实 名认证是 1000 次/月。根据自己所需,勺情实名认证。在快速入门》新手操作指引处,我们在 领取资源页面找到车牌识别,勾选“车牌识别”,然后点 0 元领取即可。

      点击上图的文字识别控制台(蓝色字体)就可以看跳转到创建文字识别的应用了。如下图。 点击创建应用后。在文字识别应用列表中,默认会把文字识别的应用全部勾选了,如下图。接 着填上相关信息,完成创建即可。

创建完成后,查看应用的 API Key 和 Secret Key。因为下面的程序需要用到。

第三:百度车牌识别API接口

     ocr 是笔者编写的车牌识别功能 demo,(ocr 原意光学字符识别即 Optical Character Recognition)。使用此程序需要修改自己应用的 client_id (API Key)和 client_secret( Secret Key)。

1 #ifndef OCR_H
2 #define OCR_H
3
4 #include <QNetworkAccessManager>
5 #include <QNetworkReply>
6
7 #include <QJsonDocument>
8 #include <QJsonParseError>
9 #include <QJsonObject>
10 #include <QJsonArray>
11 #include <QHostInfo>
12
13 #include <QFile>
14 #include <QImage>
15
16 class Ocr : public QObject
17 {
18 Q_OBJECT
19
20 public:
21 Ocr(QObject *parent = nullptr);
22 ~Ocr();
23
24 /* 请求网络 */
25 void requestNetwork(QString, QByteArray);
26
27 /* 获取识别结果 */
28 void getTheResult(QString fileName);
29 void getTheResult(QImage image);
30
31 private:
32 /* 存储获取 tokenUrl 地址 */
33 QString tokenUrl;
34
35 /* 存储 serverapi 地址 */
36 QString serverApiUrl;
37
38 /* 最终需要访问 token 的地址 */
39 QString accessToken;
40
41 /* 获取 token 的接口*/
42 const QString token_org =
"https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials
&client_id=%1&client_secret=%2&";
43
44 /* 填写网页上申请的 appkey 如 api_key ="g8eBUMSokVB1BHGmgxxxxxx" */
45 const QString api_key = "填写自己的 APP KEY";
46
47 /* 填写网页上申请的 APP SECRET 如
secret_key="94dc99566550d87f8fa8ece112xxxxx" */
48 const QString secret_key = "填写自己的 APP SECRET";
49
50 /* 百度服务器 API 接口,发送图片可返回识别结果 */
51 const QString server_api =
"https://aip.baidubce.com/rest/2.0/ocr/v1/license_plate?access_token=%1
";
52
53 /* 网络管理 */
54 QNetworkAccessManager *networkAccessManager;
55
56 /* 处理 Json 数据 */
57 QString getJsonValue(QByteArray ba, QString key);
58
59 /* 处理 Json 数据 */
60 QString getJsonValue(QByteArray ba, QString key1, QString key2);
61
62 public slots:
63
64 /* 准备读取响应返回来的数据 */
65 void readyReadData();
66
67 /* 响应完成处理 */
68 void replyFinished();
69
70 /* 开始识别 */
71 void readyToDetection(QString);
72 void readyToDetection(QImage);
73
74 signals:
75 /* 识别到车牌,发送信号 */
76 void ocrReadyData(QString);
77
78 };
79 #endif // OCR_H

分析:第 45 行,请填写读者自己在网页上申请的 API Key。本例不提供开放的 API Key,请填写 自已个人申请的! 第 48 行,请填写读者在网页上申请的 Secret Key。本例不提供开放的 Secret Key,请填写 自已个人申请的! 其他地址由来在百度车牌识别的帮助文档,它已经解释的很详细,我们只要阅读它的帮助 文档可知,这里就不详细说了。发送要识别的图片到服务器,就可以返回识别的结果了。

第四:车牌识别综合测试

     1、ocr 文件夹为车牌识别的应用程序,主要发送本地图片到百度车牌识别服务器上,然后返 回识别结果。

     2、 Headers 文件夹为界面的头文件。

     3、 Sources 文件夹为界面的源文件。

 我们直接构建工程,注意:运行之前需要把项目下的 image 文件夹拷贝到可执行程序的同 级目录下。此 image 文件夹目录存放的是要识别的车牌图片,若想替换自己的图片,需要把要 识别的图片替换到 image 文件夹下的 carlpr.jpg,名字要相同。

总结,我们使用了百度车牌识别的接口来完成这个车牌识别的过程,在这里我们虽然我们 不能学到车牌识别的算法,但是我们也学会了怎么根据百度 ai 的帮助文档去调用。并不是所有 的车牌识别算法都开源,毕竟也是别人的成果,别人的成果也是要付出的。此例程仅供参考使 用。实际用到项目上请购买相关的车牌识别产品。

目录
相关文章
|
10月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
874 3
Linux系统禁用swap
|
10月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
1450 3
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
945 3
Linux系统初始化脚本
|
11月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
676 18
|
10月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
1087 1
|
10月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
1375 1
|
11月前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
2558 10
|
数据安全/隐私保护 C++ 计算机视觉
Qt(C++)开发一款图片防盗用水印制作小工具
文本水印是一种常用的防盗用手段,可以将文本信息嵌入到图片、视频等文件中,用于识别和证明文件的版权归属。在数字化和网络化的时代,大量的原创作品容易被不法分子盗用或侵犯版权,因此加入文本水印成为了保护原创作品和维护知识产权的必要手段。 通常情况下,文本水印可以包含版权声明、制作者姓名、日期、网址等信息,以帮助识别文件的来源和版权归属。同时,为了增强防盗用效果,文本水印通常会采用字体、颜色、角度等多种组合方式,使得水印难以被删除或篡改,有效地降低了盗用意愿和风险。 开发人员可以使用图像处理技术和编程语言实现文本水印的功能,例如使用Qt的QPainter类进行文本绘制操作,将文本信息嵌入到图片中,
679 1
Qt(C++)开发一款图片防盗用水印制作小工具
|
监控 C++ 容器
【qt】MDI多文档界面开发
【qt】MDI多文档界面开发
936 0