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

相关文章

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class