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

相关文章

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使