三步就能在OpenHarmony中实现车牌识别

314 篇文章 8 订阅
249 篇文章 7 订阅

介绍

本车牌识别项目是基于开源项目 EasyPR(Easy to do Plate Recognition)实现。EasyPR 是一个开源的中文车牌识别系统,基于 OpenCV 开源库开发。

本项目使用润和 HiSpark Taurus AI Camera(Hi3516DV300) 摄像头开发板套件(以下简称 Hi3516)实现拍照车牌并显示识别结果。采用的系统是 OpenAtom OpenHarmony (简称“OpenHarmony”) 3.1 Release 小型系统。

首先将 Hi3516 中的摄像头对准车牌,其距离约为 60cm~70cm 如下所示:

运行程序后按下 1 拍照、按 2 输出识别结果如下所示:

开发流程

本车牌识别项目使用 OpenHarmony 中的媒体子系统实现。

代码基于停车场景下的本地车牌识别。进行讲解,其代码结构如下:

三方库移植

EasyPR 实现是基于 OpenCV 实现,因此实现 EasyPR 首先得移植 OpenCV。移植的方式采用 Gn 调用 Shell 脚本,Shell 脚本调用 Makefile 实现。

├── BUILD.gn
├── include 
│   ├── camera.h                                       // 摄像头定义
│   ├── local_net_communication.h          // 设备协同主要功能定义
│   ├── local_net_def.h                             // 设备协同打印日志
│   ├── local_net_dlist.h                            // 设备协同设备列表定义
│   ├── local_net_message.h                    // 设备协同传输消息定义
│   ├── local_net_udp.h                             // 设备协同udp协议定义
│   ├── local_net_utils.h                            // 设备协同通用工具定义
│   ├── log.h                                              // 打印日志定义
│   └── wpa_work.h                                   // wifi设置定义
└── src
    ├── base64.cpp                                     // 图片转base64格式功能代码 
    ├── camera.cpp                                     // 摄像头实现
    ├── local_net_communication.c            // 设备协同主要功能实现
    ├── local_net_dlist.c                              // 设备协同设备列表实现
    ├── local_net_message.c                      // 设备协同传输消息实现
    ├── local_net_udp.c                              // 设备协同udp协议实现
    ├── local_net_utils.c                              // 设备协同通用工具实现
    ├── main.cpp                                         // 主程序
    └── wpa_work.c                                     // wifi设置实现

下面介绍移植的大致流程,具体细节可参考小型系统上运行开源项目车牌识别及移植 opencv 库。

移植OpenCV

下载源码

获取源码将 OpenCV 库源码放在 OpenHarmony 根目录下的 third_party 下:

生成Makefile

在 OpenCV 源码根目录新建 build 目录生成 Makefile 文件:

使用 cmake-gui 来配置编译环境:

cd build
make-gui ..

显示的 UI 界面如下图:

点击 Configure 进行配置,选择第四个选项进行配置,如下图:

配置工具链:

点击 Generate 生成 Makefile。

**创建 Shell 脚本 **

在 OpenCV 源码根目录新增 build_opencv.sh:

touch build_opencv.sh
chmod 777 build_opencv.sh
vim build_opencv.sh
##添加如下内容
#!/bin/sh
processor=`cat /proc/cpuinfo|grep processor | sort -u | wc -l`
cd build
make -j$processor
cp lib/* $1/libs/

创建Gn文件

在 OpenCV 源码根目录新增 BUILD.gn 将 OpenCV 库加入编译构建:

移植EasyPR

下载源码

获取源码 EasyPR 库源码放在源码根目录下的 third_party 下:

生成Makefile

在 EasyPr 源码根目录新建 build 目录:

mkdir build
cd build
cmake-gui ..

显示的 UI 界面如下图:

点击 Configure 进行配置,选择第四个选项进行配置,如下图:

配置工具链:

点击 Generate 生成 Makefile。

创建Shell脚本

在 EasyPR 源码根目录新增 build_easypr.sh:

创建Gn文件

在 EasyPR 源码根目录新增 BUILD.gn 加入至编译构建:

vim BUILD.gn

#BUILD.gn中添加如下内容
import("//build/lite/config/component/lite_component.gni")
import("//build/lite/ndk/ndk.gni")

root_build = rebase_path(root_build_dir)

build_ext_component("easypr_lib") {
    command = "sh build_easypr.sh $root_build"
    exec_path = "$root_build/../../../third_party/EasyPR"
}

lite_component("easypr") {
    deps = [
        "//third_party/opencv:opencv",
        ":easypr_lib"
    ]
    features = []
}

最终 OpenCV 与 EasyPR 在 third_party 目录如下图所示:

在 OpenHarmony 实现 EasyPR 需要主要分为如下三步:

  1. GN 构建,将 EasyPR 加入编译构建;
  2. 拍照,调用 OpenHarmony 拍照接口,拍摄车牌;
  3. EasyPR 本地识别,调用 EasyPR 识别车牌接口并返回识别结果。

GN构建

GN 构建中包含了 EasyPR 的头文件路径 、链接 EasyPR 动态库、编译依赖 EasyPR。如下所示:

拍照

拍照功能是基于官方文档拍照开发指导开发的,其 demo 样例在如下目录:

在停车场景中二维码识别与车牌识别共用同一份拍照代码 ,为提高二维码识别率在拍照初始化时须将分辨率设置为 1280*720。该改动在进行车牌识别时不会影响 ,初始化拍照代码如下图:

设置照片保存路径在文件 camera.h 下:

因为在停车场景中二维码扫码与车牌识别都会调用拍照接口,因此使用 s_runAi 作区分:

int main(int argc,char **argv)
{
    int ret;
    char licensePlate[32] = {0};
    char input;
    InitCamera();
    PlateInit();
    while(cin >> input) {
        switch (input) {
            case '1':
                RunAICamera();                                                  // 拍照
                break;
            case '2':
                memset(licensePlate, 0, sizeof(licensePlate));
                ret = GetPlateString(IMG_PATH, licensePlate);   // 识别车牌
                SAMPLE_INFO("ret -> %d, licensePlate->%s", ret, licensePlate);
                break;
            case 's':
                PlateDeinit();
                ExitCamera();
                return 0;
            default:
                SAMPLE_ERROR("input Error");
                break;
        }
    }
    return 0;
}

进行拍照后会进入拍照数据处理,当 s_runAi 为 false 说明是二维码识别,直接调用二维码识别接口即可。当 s_runAi 为 true 时须将拍照的数据保存为图片:

将拍照数据以图片保存路径为“/sdcard/CaptureAi.jpg” 。

EasyPR本地识别

编写主程序 main.cpp 设置程序功能为按 1 拍照、按 2 显示结果 :

编译烧录

前文大致概括了 OpenCV 和 EasyPR 的移植步骤,更详细的关于环境搭建、烧录以及项目源码构建的步骤,请查看参考文章本地车牌识别。

为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:https://qr21.cn/FV7h05

《鸿蒙开发学习手册》:

如何快速入门:https://qr21.cn/FV7h05

  1. 基本概念
  2. 构建第一个ArkTS应用
  3. ……

开发基础知识:https://qr21.cn/FV7h05

  1. 应用基础知识
  2. 配置文件
  3. 应用数据管理
  4. 应用安全管理
  5. 应用隐私保护
  6. 三方应用调用管控机制
  7. 资源分类与访问
  8. 学习ArkTS语言
  9. ……

基于ArkTS 开发:https://qr21.cn/FV7h05

  1. Ability开发
  2. UI开发
  3. 公共事件与通知
  4. 窗口管理
  5. 媒体
  6. 安全
  7. 网络与链接
  8. 电话服务
  9. 数据管理
  10. 后台任务(Background Task)管理
  11. 设备管理
  12. 设备使用信息统计
  13. DFX
  14. 国际化开发
  15. 折叠屏系列
  16. ……

鸿蒙开发面试真题(含参考答案):https://qr18.cn/F781PH

鸿蒙开发面试大盘集篇(共计319页):https://qr18.cn/F781PH

1.项目开发必备面试题
2.性能优化方向
3.架构方向
4.鸿蒙开发系统底层方向
5.鸿蒙音视频开发方向
6.鸿蒙车载开发方向
7.鸿蒙南向开发方向

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值