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

相关文章

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Python利用PIL进行图片压缩

《Python利用PIL进行图片压缩》有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所以本文为大家介绍了Python中图片压缩的方法,需要的可以参考下... 有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所有可以对文件中的图

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将