Android OpenCv4 图像透视变换之图片矫正

2024-04-13 10:58

本文主要是介绍Android OpenCv4 图像透视变换之图片矫正,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


实现效果

相机拍照,对图片进行倾斜矫正

在这里插入图片描述

图片矫正实现步骤
  1. 读取图片到内存。
  2. 为两张图检测ORB特征点
  3. 特征匹配:找到两图中匹配的特征点,并按照匹配度排列,保留最匹配的一小部分。然后把匹配的特征点画出来并保存图片。
  4. 计算单应性矩阵:由于上一步产生的匹配的特征点不是100%正确的,需要调用findHomography 函数来计算多个二维点对之间的最优单应性变换矩阵。
  5. 透视变换:有了精确的单应性矩阵,就可以把一张图片的所有像素映射到另一个图片。使用透视变换 来完成图片矫正。
透视变换

透视变换(Perspective Transformation)是指利用透视中心、像点、目标点三点共线的条件,按透视旋转定律使承影面(透视面)绕迹线(透视轴)旋转某一角度,破坏原有的投影光线束,仍能保持承影面上投影几何图形不变的变换。透视变换是按照物体成像投影规律进行变换,即将物体重新投影到新的成像平面。透视变换常用于机器人视觉导航研究中,由于相机视场与地面存在倾斜角使得物体成像产生畸变,通常通过透视变换实现对物体图像的校正。

/**src  原图dst  透视变换后输出图像,与src数据类型相同,但是尺寸与dsize相同M  3*3变换矩阵dsize  输出图像的尺寸flags  插值方法标志borderMode  像素边界外推方法的标志。BORDER_CONSTANT 或者BORDER_REPLICATEborderValue  填充边界使用的数值,默认情况下为0
**/public static void warpPerspective(Mat src, Mat dst, Mat M, Size dsize, int flags, int borderMode, Scalar borderValue)
实现拍照图片矫正代码带注释
    /*** 图片纠正* @param context* @param bitmap* @param iv* @return* @throws IOException*/public static Point alignImages(Context context, Bitmap bitmap, ImageView iv) throws IOException {//读取的原图Mat real = new Mat();Mat grayReal = Utils.loadResource(context, R.drawable.shujiattl1);Imgproc.cvtColor(grayReal, real, Imgproc.COLOR_BGR2GRAY);//拍照图Mat mSource = new Mat();Utils.bitmapToMat(bitmap, mSource);Mat sourceMat = new Mat();Imgproc.cvtColor(mSource,sourceMat,Imgproc.COLOR_BGR2GRAY);//原图特征点MatOfKeyPoint real_point = new MatOfKeyPoint();//拍照图特征点MatOfKeyPoint source_point = new MatOfKeyPoint();Mat real1 = new Mat();Mat source1 = new Mat();//为两张图检测ORB特征点orbFeatures(sourceMat,source_point,source1);orbFeatures(real,real_point,real1);//特征点匹配MatOfDMatch matches = new MatOfDMatch();BFMatcher matcher = BFMatcher.create(Core.NORM_HAMMING);matcher.match(source1, real1, matches);List<DMatch> list = matches.toList();Collections.sort(list,new Comparator<DMatch>() {@Overridepublic int compare(DMatch o1, DMatch o2) {return Double.compare(o1.distance,o2.distance);}});
//        float min = list.get(0).distance;List<DMatch> goodMatchers = new ArrayList<>();for (int i = 0; i < list.size()*0.15; i++) {goodMatchers.add(list.get(i));}Log.e("dbj", " goodMatchers size = "+goodMatchers.size());Mat result =new Mat();MatOfDMatch matOfDMatch = new MatOfDMatch();matOfDMatch.fromList(goodMatchers);//绘制特征点drawMatches(sourceMat, source_point, real, real_point, matOfDMatch, result);List<Point> matOfPoint2fList_source = new ArrayList<>();List<Point> matOfPoint2fList_real = new ArrayList<>();MatOfPoint2f sourcePoints = new MatOfPoint2f();MatOfPoint2f realPoints = new MatOfPoint2f();for (int i = 0; i < goodMatchers.size(); i++) {matOfPoint2fList_source.add(source_point.toArray()[goodMatchers.get(i).queryIdx].pt);matOfPoint2fList_real.add(real_point.toArray()[goodMatchers.get(i).trainIdx].pt);}sourcePoints.fromList(matOfPoint2fList_source);realPoints.fromList(matOfPoint2fList_real);//计算单应性矩阵Mat homography = findHomography(sourcePoints, realPoints, RANSAC);//图片矫正Mat img = new Mat();Imgproc.warpPerspective(mSource,img,homography,new Size(real.width(), real.height()));//以下是求点操作,可以不用管List<Point> points = getPoint(context,img,iv);if (points==null){return null;}//这是我求的左上角的点return points.get(0);}private static void orbFeatures(Mat source, MatOfKeyPoint keyPoints,Mat descriptor) {ORB orbDetector = ORB.create(1000,1.2f);orbDetector.detect(source, keyPoints);orbDetector.compute(source, keyPoints, descriptor);}

这篇关于Android OpenCv4 图像透视变换之图片矫正的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/899946

相关文章

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y