HyperLPR3车牌识别-Android使用:SDK编译与部署

news2024/11/15 0:22:20

简介

HyperLPR在2023年初已经更新到了v3的版本,该版本与先前的版本一样都是用于识别中文车牌的开源图像算法项目,最新的版本的源码可从github中提取:https://github.com/szad670401/HyperLPR

Android SDK for HyperLPR3说明

HyperLPR3的官方源码已经提供在Android平台下使用该项目SDK的方法。Android SDK for HyperLPR3的组成部分主要为:HyperLPR3的Android工程模块、算法动态链接库、资源文件三个部分组成。

准备工作

目前官方提供的编译方式仅支持在Linux和MacOS下进行交叉编译,在编译库之前需要提前准备好以编译的工作环境,需要依赖如下:

  • CMake(3.10 以上)

  • OpenCV (4.20以上)

  • 编译对应的平台如android、ios、linux都需要采用各自平台支持的OpenCV-SDK

  • MNN (2.0.0以上)

  • C++编译器

  • GCC或Clang皆可 (macOS无需另外安装,Xcode自带)

  • GCC推荐版本4.9以上

  • 在某些发行版上GCC (GNU C编译器)和G++(GNU C++编译器是分开安装的)。

  • 同样以Ubuntu为例,需要分别安装 gcc 和 g++

  • Clang 推荐版本3.9以上

  • Catch2(仅编译TestCase需要)

  • Android NDK(推荐21以上版本)

拉取项目

从github或gitee中拉取最新版的HyperLPR工程到本地

# 从github拉取
git clone https://github.com/szad670401/HyperLPR.git

网络不太稳的同学可以使用gitee拉取项目

# 从gitee拉取
git clone https://gitee.com/tunmx/HyperLPR.git

安装NDK

交叉编译Android版本需要下载并安装NDK,如果你的计算机里已经有NDK版本了也可优先尝试你的版本是否能正常编译和正常使用,如果你没有安装过NDK,那优先推荐使用21版。NDK可从官网发布页面进行下载:NDK下载页面

选择下载支持你宿主机的NDK后,将其解压放置于你硬盘中的某个路径后即可,放好NDK后需要配置系统环境变量ANDROID_NDK:

终端临时配置:

# 临时配置,重启终端会失效
export ANDROID_NDK=/YOUR_PATH/android-ndk-r21e-linux/

Linux用户:

# 打开用户目录下的bashrc
vim ~/.bashrc
# 并写入
ANDROID_NDK=/YOUR_PATH/android-ndk-r21e-linux/

# 也可打开用户目录profile进行配置
vim ~/.profile
# 并写入
ANDROID_NDK=/YOUR_PATH/android-ndk-r21e-linux/

MacOS用户:

# 打开用户目录下的bash_profile
vim ~/.bash_profile
# 并写入
ANDROID_NDK=/YOUR_PATH/android-ndk-r21e-linux/

# 如果使用zsh可直接在zshrc文件下写入
vim ~/.zshrc
# 并写入
ANDROID_NDK=/YOUR_PATH/android-ndk-r21e-linux/

安装依赖库

为了节约编译三方依赖库的时间,这边提供了一份已经编译好的库,提供的库均为功能相对标准的库,如有其他功能的需求,请自行调整参数重新编译。百度网盘 密码:5duf,下载后将其拷贝或链接到HyperLPR根目录下,与CMakeLists.txt同级即可:

HyperLPR/
├── 3rdparty_hyper_inspire_op # 放这里
├── CMakeLists.txt
├── LICENSE
├── Prj-Android
├── Prj-Linux
├── Prj-Python
├── README.md
├── build
├── cmake-build-debug
├── command
├── cpp
├── docs
├── images
└── resource

执行交叉编译

准备好以上工作后,即可执行Android版本动态链接库的交叉编译工作,为了方便各位同学,官方项目已提供快捷编译的脚本,在确保以上步骤均无问题的情况下直接执行脚本即可完成编译:

# 执行编译脚本
sh command/build_release_linux_share.sh

编译完成后产生的文件会放置于根目录下的build/release_android文件夹中,其中包含:

  • arm64-v8a文件夹:Android Armv8版本的动态库

  • armeabi-v7a文件夹:Android Armv7版本的动态库

准备SDK模块

HyperLPR3项目中已经有官方提供的Android版的SDK以及使用Demo工程,放置于根目录下的Prj-Android中。执行完上面的交叉编译后,我们需要将编译后的动态库拷贝到Android-Demo工程下的SDK模块库目录下:

# 创建安卓工程中SDK模块的libs目录
mkdir Prj-Android/hyperlpr3/libs/
# 拷贝动态库到libs文件夹中
cp -r build/release_android/arm* Prj-Android/hyperlpr3/libs

拷贝完成后即完成SDK模块的准备工作

构建Android-Demo工程

使用Android Studio打开Prj-Android工程,使用gradle进行项目构建。工程中的hyperlpr模块为车牌识别的SDK,如需在其他工程中使用,拷贝并设置依赖即可。

点击Run即可构建工程并编译后部署到测试机上进行运行。

Demo有两种测试方式:实测后置相机采集与相册图片测试

SDK代码快速使用

在导入SDK模块后,即可在其他工程使用SDK代码,接口相对简单:

/**
 * Initialize the license plate recognition algorithm SDK
 *
 * @param context context
 * @param parameter Initialization parameter
 * */
void init(Context context, HyperLPRParameter parameter);

/**
 * License plate recognition interface.
 *
 * @param buf Image data buffer.
 * @param height Height of the image
 * @param width Width of the image
 * @param rotation Original data buffer rotation Angle
 * @param format Buffer data coded format
 * @return Resulting object array
 */
Plate[] plateRecognition(byte[] buf, int height, int width, int rotation, int format);

/**
 * License plate recognition interface.
 *
 * @param image Bitmap image
 * @param rotation Original data buffer rotation Angle
 * @param format Buffer data coded format
 * @return Resulting object array
 */
Plate[] plateRecognition(Bitmap image, int rotation, int format);

调用仅需实例化HyperLPR3对象即可,需要导入包

import com.hyperai.hyperlpr3.HyperLPR3;
import com.hyperai.hyperlpr3.bean.Parameter;
import com.hyperai.hyperlpr3.bean.Plate;

实例化对象与检测

// 车牌识别算法配置参数
HyperLPRParameter parameter = newHyperLPRParameter()
        .setDetLevel(HyperLPR3.DETECT_LEVEL_LOW)
        .setMaxNum(1)
        .setRecConfidenceThreshold(0.85f);
// 初始化(仅执行一次生效)
HyperLPR3.getInstance().init(this, parameter);

SDK定义类型说明

在提供的SDK中,官方提供了一些类型以便于开发者进行二次开发调用:

/** 四种情况的转角 */
public static final int CAMERA_ROTATION_0 = 0;
public static final int CAMERA_ROTATION_90 = 1;
public static final int CAMERA_ROTATION_180 = 2;
public static final int CAMERA_ROTATION_270 = 3;

/** 低开销检测模式 */
public static final int DETECT_LEVEL_LOW = 0;
/** 高开销检测模式 */
public static final int DETECT_LEVEL_HIGH = 1;

/** Image in RGB format - RGB排列格式的图像 */
public static final int STREAM_RGB = 0;
/** Image in BGR format (Opencv Mat default) - BGR排列格式的图像(OpenCV的Mat默认) */
public static final int STREAM_BGR = 1;
/** Image in RGB with alpha channel format -带alpha通道的RGB排列格式的图像 */
public static final int STREAM_RGBA = 2;
/** Image in BGR with alpha channel format -带alpha通道的BGR排列格式的图像 */
public static final int STREAM_BGRA = 3;
/** Image in YUV NV12 format - YUV NV12排列的图像格式 */
public static final int STREAM_YUV_NV12 = 4;
/** Image in YUV NV21 format - YUV NV21排列的图像格式 */
public static final int STREAM_YUV_NV21 = 5;


/** 未知车牌 */
public static final int PLATE_TYPE_UNKNOWN = -1;
/** 蓝牌 */
public static final int PLATE_TYPE_BLUE = 0;
/** 黄牌单层 */
public static final int PLATE_TYPE_YELLOW_SINGLE = 1;
/** 白牌单层 */
public static final int PLATE_TYPE_WHILE_SINGLE = 2;
/** 绿牌新能源 */
public static final int PLATE_TYPE_GREEN = 3;
/** 黑牌港澳 */
public static final int PLATE_TYPE_BLACK_HK_MACAO = 4;
/** 香港单层 */
public static final int PLATE_TYPE_HK_SINGLE = 5;
/** 香港双层 */
public static final int PLATE_TYPE_HK_DOUBLE = 6;
/** 澳门单层 */
public static final int PLATE_TYPE_MACAO_SINGLE = 7;
/** 澳门双层 */
public static final int PLATE_TYPE_MACAO_DOUBLE = 8;
/** 黄牌双层 */
public static final int PLATE_TYPE_YELLOW_DOUBLE = 9;

public static final String[] PLATE_TYPE_MAPS = {"蓝牌", "黄牌单层", "白牌单层", "绿牌新能源", "黑牌港澳", "香港单层", "香港双层", "澳门单层", "澳门双层", "黄牌双层"};

帮助

以上为HyperLPR3的AndroidSDK快速上手,需要获取其他的帮助,请移步到项目地址:https://github.com/szad670401/HyperLPR

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/392071.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

最深情的告白——郁金香(Python实现)

目录 1 最深情的告白 2 即兴赞之 2.1 李小白言郁金香 2.2 郁金香般的姑娘 2.3 荷兰的郁金香 3 Python代码实现 3.1 郁金香的芬芳 3.2 我俩绚丽多姿的风景 1 最深情的告白 曾经以为,她爱玫瑰,然后我画了好几种: 花仙子——玫瑰&a…

钉钉、企业微信和飞书向“钱”看

在急剧变革的时候,不管黑猫白猫,要抓到老鼠才算好猫。如今,各互联网企业早已进入降本增效的新阶段。勒紧裤腰带过日子之下,能不能盈利、商业化空间有多大,就成为各个业务极为重要的考核指标。在各业务板块中&#xff0…

【JavaSE】逻辑控制语句

文章目录一. 顺序结构二. 分支结构1. if 语句2. switch 语句3、循环结构3.1 while 循环3.2 do while 循环3.3 for 循环3.4 break 和 continue三. 输入输出1. 输出到控制台2. 从键盘输入一. 顺序结构 顺序结构比较简单,即程序按照代码书写的顺序一行一行执行下去。 …

[数据结构]:11-冒泡排序(顺序表指针实现形式)(C语言实现)

目录 前言 已完成内容 冒泡排序实现 01-开发环境 02-文件布局 03-代码 01-主函数 02-头文件 03-PSeqListFunction.cpp 04-SortCommon.cpp 05-SortFunction.cpp 结语 前言 此专栏包含408考研数据结构全部内容,除其中使用到C引用外,全为C语言代…

滑模控制(Sliding mode control)快速入门

0. 简介 最近作者受到邀请,让我帮忙给刚入门的学弟讲讲滑模控制。可是作者也不知道怎么向未入门的学弟讲解这些基础知识,所以作者翻了翻近几年写的很好的文章以及视频。综合起来,来总结出一套比较基础,且适用于初学者的文章吧。这…

Node.js的简单学习一-----未完待续

文章目录前言学习目标一、初识Node.js1.1 回顾与思考1.1.1 需要掌握那些技术1.1.2 浏览器中的JavaScript的组成部分1.2 Node.js简介1 什么是Node.js2 Node.js中的JavaScript运行环境3 Node.js 可以做什么1.3 Node.js环境的安装1.4 在Node.js环境中执行JavaScript 代码终端中的快…

掌握好Framework 才是王道~

现在面试对Android开发者的要求越来越高了!从最开始的阿里、头条、腾讯等大厂,到现在的互联网车企,面试总喜欢问道 Framework底层原理的相关问题 Android Framework的三大核心功能: 1、View.java:View工作原理,实现包…

海尔三翼鸟:生态聚拢的密度,决定场景落地速度

最近学到一个新词,叫做涌现能力。 怎么理解呢?我们以当下最火的ChatGPT为例,GPT1模型是1.17亿参数,GPT2有15亿参数,GPT3有1750亿个参数。研究人员在放大模型规模的进程中发现一个惊人的现象,模型参数达到一…

Vue基础学习 -- Vue数据与方法 v-指令补充 vue生命周期

Vue数据与方法 实例化Vue对象时,需要在data中定义数据,data选项是一个函数,它应该返回一个对象,然后Vue通过响应性系统将其包裹起来,并以$data形式储存在实例中。为了方便起见,该归降的任何顶级property可…

【蓝桥杯刷题】盗版Huybery系列之手抓饼赛马

【蓝桥杯刷题】—— 盗版Huybery系列之手抓饼赛马😎😎😎 目录 💡前言🌞: 💛盗版Huybery系列之手抓饼赛马题目💛 💪 解题思路的分享💪 😊题…

计算机SCI期刊投稿,除了投稿信,还要做什么准备? - 易智编译EaseEditing

投稿信的准备 期刊的编辑往往需要一些有关作者及其论文的信息。 而作者也希望给编辑提供一些有助于其全文送审及决策的信息。 这些信息都应该包括在投稿信中。 投稿信应包括以下几方面的内容: 文题和所有作者的姓名;稿件适宜的栏目; 为什么此论文适合于在该刊而…

大数据框架之Hive:第2章 Hive安装

第2章 Hive安装 2.1 Hive安装地址 1)Hive官网地址 http://hive.apache.org/ 2)文档查看地址 https://cwiki.apache.org/confluence/display/Hive/GettingStarted 3)下载地址 http://archive.apache.org/dist/hive/ 4)gith…

OpenCV入门(四)快速学会OpenCV3画基本图形

OpenCV入门(四)快速学会OpenCV3画基本图形 1.画点 在OpenCV中,点分为2D平面中的点和3D平面中的点,区别就是3D中点多了一个z坐标。我们首先介绍2D中的点,坐标为整数的点可以直接用(x, y)代替,其中x是横坐标…

快速幂----快速求解底数的n次幂

目录 一.快速幂 1.问题的引入 2.快速幂的介绍 3.核心思想 4.代码实现 2.猴子碰撞的方法数 1.题目描述 2.问题分析 3.代码实现 一.快速幂 1.问题的引入 问题:求解num的n次幂,结果需要求余7 对于这个问题我们可能就是直接调用函数pow(a,b)来直接求解a的b次幂问题,但是如果…

灵巧手抓持<分类><仿真>

获取灵巧手抓取物体时的抓持类型,需要考虑:手本身的结构、被抓取物体的形状尺寸、抓持操作任务的条件。 研究方法:基于模型的方法、基于数据驱动的方法 基于模型的方法:建立灵巧手抓持相关的运动学和动力学模型建立目标函数求解…

【操作系统】进程和线程的区别

文章目录1. 概述2. 进程3. 线程4. 协程5. 进程与线程区别1. 概述 进程和线程这两个名词天天听,但是对于它们的含义和关系其实还有点懵的,其实除了进程和线程,还存在一个协程,它们的关系如下: 首先,我们需要…

C++基础——Ubuntu下编写C++环境配置总结(C++基本简介、Ubuntu环境配置、编写简单C++例程)

【系列专栏】:博主结合工作实践输出的,解决实际问题的专栏,朋友们看过来! 《QT开发实战》 《嵌入式通用开发实战》 《从0到1学习嵌入式Linux开发》 《Android开发实战》 《实用硬件方案设计》 长期持续带来更多案例与技术文章分享…

优思学院|质量管理简史:从质检到质控,到六西格玛管理

在现代的工业化生产中,质量管理已成为企业生产运营的不可或缺的一部分。经过长时间的探索和实践,质量管理的理论和实践已经逐步成熟,并形成了完整的体系。下面,我将简要介绍一下质量管理学的发展历程。 质量管理的萌芽期&#xff…

socket聊天室--socket的建立

socket聊天室–socket实现 文章目录 socket聊天室--socket实现socket()bind()listen()accept()connect()发送接收read()函数recv()函数write()函数send()函数close()关闭套接字IP 地址格式转换函数socket() #include <sys/types

web餐饮开源程序

简介 一款专门针对餐饮行业而开发桌面应用程序 技术 借助Panuon.UI.Silver控件库&#xff0c;开发的一款餐饮软件。 运行环境&#xff1a;.NETFramework,Versionv4.8。 运行数据库&#xff1a;MySql。 ORM框架&#xff1a;SqlSugar。 第三方插件&#xff1a;Panuon.UI.Silv…