【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

相关文章

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测