【opencv】教程代码 —features2D(5)旋转相机的基本全景拼接

2024-03-31 08:44

本文主要是介绍【opencv】教程代码 —features2D(5)旋转相机的基本全景拼接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

b630e920a95ed92ad6d01ecc7080cc84.png

c60f6b22c247e79b4a18c7df5b57965a.png

05e0c430515a7c35a2d038bc89e0217d.png

基本全景拼接

panorama_stitching_rotating_camera.cpp 将第二张图像进行透视变换后与第一张图像拼接

4f0c4c179bfe2fca60ea95ab50692254.png

#include <iostream>  // 包含了一些用于输入输出的函数
#include <opencv2/core.hpp>  // 包含了OpenCV核心库的一些常用类和函数
#include <opencv2/imgproc.hpp>  // 包含了图像处理的一些类和函数,如图像直方图、滤波、颜色变换等
#include <opencv2/highgui.hpp>  // 包含了GUI绘制函数和一些文件输入输出函数与图片展示函数。using namespace std;  // 使用标准库命名空间
using namespace cv;  // 使用OpenCV库命名空间namespace  // 匿名命名空间
{
void basicPanoramaStitching(const string &img1Path, const string &img2Path)  // 定义一个基本全景图拼接的函数
{Mat img1 = imread( samples::findFile( img1Path ) );  // 读取第一张图片,并进行文件路径查找Mat img2 = imread( samples::findFile( img2Path ) );  // 读取第二张图片,并进行文件路径查找// 定义第一张图片的摄像头位置信息Mat c1Mo = (Mat_<double>(4,4) << 0.9659258723258972, 0.2588190734386444, 0.0, 1.5529145002365112,0.08852133899927139, -0.3303661346435547, -0.9396926164627075, -0.10281121730804443,-0.24321036040782928, 0.9076734185218811, -0.342020183801651, 6.130080699920654,0, 0, 0, 1);// 定义第二张图片的摄像头位置信息Mat c2Mo = (Mat_<double>(4,4) << 0.9659258723258972, -0.2588190734386444, 0.0, -1.5529145002365112,-0.08852133899927139, -0.3303661346435547, -0.9396926164627075, -0.10281121730804443,0.24321036040782928, 0.9076734185218811, -0.342020183801651, 6.130080699920654,0, 0, 0, 1);// 定义相机的内参信息Mat cameraMatrix = (Mat_<double>(3,3) << 700.0, 0.0, 320.0,0.0, 700.0, 240.0,0, 0, 1);// 提取旋转矩阵Mat R1 = c1Mo(Range(0,3), Range(0,3));Mat R2 = c2Mo(Range(0,3), Range(0,3));// 计算旋转位移Mat R_2to1 = R1*R2.t();// 计算单应性矩阵Mat H = cameraMatrix * R_2to1 * cameraMatrix.inv();H /= H.at<double>(2,2);cout << "H:\n" << H << endl;// 进行全景图像拼接Mat img_stitch;warpPerspective(img2, img_stitch, H, Size(img2.cols*2, img2.rows));imshow("warp_image2", img_stitch);// 中间输出Mat half = img_stitch(Rect(0, 0, img1.cols, img1.rows));img1.copyTo(half);// 显示经过拼接的全景图像和原图对比Mat img_compare;Mat img_space = Mat::zeros(Size(50, img1.rows), CV_8UC3);hconcat(img1, img_space, img_compare);hconcat(img_compare, img2, img_compare);imshow("Compare images", img_compare);imshow("Panorama stitching", img_stitch);  // 显示拼接的全景图waitKey();  // 等待用户响应
}// 参数描述信息
const char* params= "{ help h   |                      | print usage }""{ image1   | Blender_Suzanne1.jpg | path to the first Blender image }""{ image2   | Blender_Suzanne2.jpg | path to the second Blender image }";
}int main(int argc, char *argv[])  // 主函数,程序从此处开始运行
{CommandLineParser parser(argc, argv, params);  // 命令行参数解析器if (parser.has("help"))  // 如果有输入'help'参数{parser.about( "Code for homography tutorial.\n""Example 5: basic panorama stitching from a rotating camera.\n" );  // 显示关于该程序的简介parser.printMessage();  // 打印所有参数的说明return 0;  // 程序正常退出}basicPanoramaStitching(parser.get<String>("image1"), parser.get<String>("image2"));  // 运行全景图像拼接函数return 0;  // 程序正常退出
}

这段代码是使用OpenCV来实现全景图像拼接的一个基础示例,通过计算两张來自同一旋转摄像头拍摄的图像的单应性矩阵,然后将第二张图像进行透视变换后与第一张图像拼接,得到一张全景图。

541d734d81ec8992977cc3332299227c.png

这篇关于【opencv】教程代码 —features2D(5)旋转相机的基本全景拼接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

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

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

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

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

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

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹