Android使用OpenCV 4.5.0实现扑克牌识别(源码分享)

ops/2024/9/24 4:23:24/

一、显示效果展示

二、OpenCV 4.5.0

OpenCV 4.5.0是OpenCV(Open Source Computer Vision Library,开源计算机视觉库)的一个重要更新版本,该版本在多个方面进行了优化和新增了多项功能。

三、ONNX模型

ONNX(Open Neural Network Exchange)模型是一种针对机器学习所设计的开放式的文件格式,用于存储训练好的模型。它允许不同的深度学习框架(如PyTorch、TensorFlow、MXNet等)之间交换和共享模型,使得模型可以在不同平台和工具上进行部署和推理。

四、OpenCV加载onnx模型进行前向推理实现识别扑克牌识别

//统计预测的结果private int[] number_class=new int[54];public Bitmap detection(Bitmap bp){Canvas can=new Canvas();Paint p=new Paint();android.graphics.Bitmap.Config bitmapConfig = bp.getConfig();bp = bp.copy(bitmapConfig, true);can=new Canvas(bp);p.setAntiAlias(true);//不填充,默认填充p.setStyle(Paint.Style.STROKE);//设置线条宽度p.setStrokeWidth(5);//设置颜色p.setColor(0xFF33FFFF);p.setTextAlign(Paint.Align.LEFT);p.setTextSize(50);Mat blob = Dnn.blobFromImage(src, IN_SCALE_FACTOR,new Size(IN_WIDTH, IN_HEIGHT),new Scalar(MEAN_VAL, MEAN_VAL, MEAN_VAL), false);net.setInput(blob);blob.release();//获取输出层的名字List<String> outnames=net.getUnconnectedOutLayersNames();
//        Log.i("aa",String.valueOf(outnames));//创建输出矩阵集合List<Mat> detections = new ArrayList<Mat>();net.forward(detections,outnames);//获取输出的盒子和置信度Mat scores=detections.get(0);Mat boxes= detections.get(1);scores= scores.reshape(1,3000).colRange(1,55);boxes= boxes.reshape(1,3000);Size ss=scores.size();
//        Log.i("aa",String.valueOf(scores));
//        Log.i("aa",String.valueOf(boxes));List<Rect2d> rect2dList=new ArrayList<>();//box信息List<Float> confList=new ArrayList<>();//置信度List<Integer> objIndexList=new ArrayList<>();//对象类别索引for(int i=0; i<scores.rows();i++){Mat one_row=scores.rowRange(i,i+1);Core.MinMaxLocResult max_index=Core.minMaxLoc(one_row);double max_value=max_index.maxVal;Point location=max_index.maxLoc;if(max_value>0.4){confList.add((float) max_value);objIndexList.add((int)location.x);Mat box_one=boxes.rowRange(i,i+1);float[] aa=new float[4];box_one.get(0,0,aa);double x1=aa[0];double y1=aa[1];double x2=aa[2];double y2=aa[3];rect2dList.add(new Rect2d(x1,y1,x2,y2));}}//去重//去重后的索引值MatOfInt index=new MatOfInt();//转换box的结果集MatOfRect2d boxe=new MatOfRect2d(rect2dList.toArray(new Rect2d[0]));//转换置信度结果集float[] confArr=new float[confList.size()];for(int j=0;j<confList.size();j++){confArr[j]=confList.get(j);}MatOfFloat con=new MatOfFloat(confArr);//使用nms去重Dnn.NMSBoxes(boxe,con,0.4f,0.45f,index);if (index.empty()){return bp;}//画框int[] ints=index.toArray();for(int x:ints){
//            Log.i("aa",String.valueOf(x));double[] aa=new double[4];boxe.get(x,0,aa);//Log.i("aa",String.valueOf(aa[0]));//Imgproc.rectangle(src,new Point(aa[0]*src.width(),aa[1]*src.height()-70),new Point(aa[2]*src.width()+200,aa[1]*src.height()),new Scalar(255,255,255),-1);//Imgproc.rectangle(src,new Point(aa[0]*src.width(),aa[1]*src.height()),new Point(aa[2]*src.width(),aa[3]*src.height()),new Scalar(255,255,0),10);//Imgproc.putText(src,""+classNames[objIndexList.get(x)]+":"+confList.get(x),new Point(aa[0]*src.width(),aa[1]*src.height()),Imgproc.FONT_HERSHEY_SIMPLEX, 3, new Scalar(0, 0, 0));//画框can.drawRect((float) aa[0]*src.width(),(float) aa[1]*src.height(),(float)aa[2]*src.width(),(float)aa[3]*src.height(),p);//绘制填充框p.setStyle(Paint.Style.FILL);p.setColor(0xFFFFCC00);can.drawRect((float) aa[0]*src.width(),(float) aa[1]*src.height()-60,(float)aa[2]*src.width()+150,(float)aa[1]*src.height(),p);//写字p.setColor(0xFFFF0000);can.drawText(classNames[objIndexList.get(x)]+": "+String.format("%.3f", confList.get(x)),(float)aa[0]*src.width(),(float) aa[1]*src.height()-10,p);p.setStyle(Paint.Style.STROKE);p.setColor(0xFF33FFFF);//统计类别信息number_class[objIndexList.get(x)]+=1;}

五、完整源码下载:

Card.zip: https://url83.ctfile.com/f/45573183-1373015108-43a4dd?p=7526 (访问密码: 7526)
 


http://www.ppmy.cn/ops/115114.html

相关文章

Kubernets基础-包管理工具Helm详解

文章目录 什么是Helm?Helm 的基本概念Helm 的工作原理Helm 的主要功能使用 Helm 的步骤 values.yaml和Chart.yamlvalues.yaml 文件示例Chart.yaml 文件示例 什么是Helm? Helm 是 Kubernetes 的一个非常流行的包管理工具&#xff0c;它使得在 Kubernetes 上部署应用程序变得更…

JAVA同城生活新引擎外卖跑腿团购到店服务多合一高效系统小程序源码

&#x1f680;同城生活新风尚&#xff01;一站式高效系统&#xff0c;让日常更便捷&#x1f6cd;️ &#x1f37d;️【开篇&#xff1a;同城生活&#xff0c;一触即发】&#x1f37d;️ 在这个快节奏的时代&#xff0c;同城生活的便利性与效率成为了我们追求的新风尚。想象一下…

已成功与服务器建立连接,但是在登录过程中发生错误

详细错误&#xff1a;已成功与服务器建立连接&#xff0c;但是在登录过程中发生错误。 (provider: SSL 提供程序, error: 0 - 证书链是由不受信任的颁发机构颁发的。) 原因&#xff1a; SqlSugar.SqlSugarException: 中文提示 : SSL出错&#xff0c;因为升级了驱动,字符串增加…

DPDK 简易应用开发之路 2:UDP数据包发送及实现

本机环境为 Ubuntu20.04 &#xff0c;dpdk-stable-20.11.10 发送数据包的通用步骤 初始化DPDK环境&#xff1a; 调用 rte_eal_init() 来初始化DPDK的EAL&#xff08;环境抽象层&#xff09;&#xff0c;这是所有DPDK应用程序的第一步&#xff0c;用于初始化硬件、内存和逻辑核…

基础算法(4)——前缀和

1. 前缀和 题目描述&#xff1a; 解法一&#xff1a;暴力解法 直接模拟实现题目流程即可 时间复杂度为&#xff0c;根据题目给出的条件&#xff0c;肯定会超时 解法二&#xff1a;前缀和&#xff08;适用题型&#xff1a;快速 求出数组中某一个 连续区间 的 和&#xff09;…

SpringCloud 基于 web 的只会养老平台

摘要 首先,论文一开始便是清楚的论述了系统的研究内容。其次,剖析系统需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确系统的需求。然后在明白了系统的需求基础上需要进一步地设计系统,主要包罗软件架构模式、整体功能模块、数据库设计…

【算法】栈与模拟

【ps】本篇有 5 道 leetcode OJ。 目录 一、算法简介 二、相关例题 1&#xff09;删除字符串中的所有相邻重复项 .1- 题目解析 .2- 代码编写 2&#xff09;比较含退格的字符串 .1- 题目解析 .2- 代码编写 3&#xff09;基本计算器 II .1- 题目解析 .2- 代码编写 4&…

Avatarify——实时面部替换工具,允许用户通过网络摄像头将自己的表情映射到虚拟人物或名人头像上

一、Avatarify介绍 Avatarify 是一款基于深度学习的实时面部动画生成工具&#xff0c;它允许用户使用 AI 技术将自己的面部表情实时映射到虚拟角色、静态图片或视频上&#xff0c;进而使这些角色看起来像是在模仿用户的表情。该工具在娱乐、社交媒体以及虚拟会议等场景中应用广…