opencv的球面投影

2024-09-05 09:20
文章标签 opencv 投影 球面

本文主要是介绍opencv的球面投影,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

cv::detail::SphericalProjector

在全景图像拼接任务中,可能需要对多个图像进行球面投影以实现无缝拼接。每个cv::detail::SphericalProjector可以负责一个图像的球面投影操作。通过将多个这样的投影器存储在std::vector中,可以对一组图像依次进行投影处理,为后续的图像融合和拼接做准备。
例如,当拼接一组由不同角度拍摄的照片以创建全景图时,这个容器可以存储针对每个照片的投影器,确保每个图像都能正确地投影到球面坐标系统中,从而使得拼接过程更加准确和自然。

std::vectorcv::detail::SphericalProjector

图像变换和校正:
在某些计算机视觉应用中,需要对图像进行特定的球面变换以校正图像的畸变或实现特定的视觉效果。std::vectorcv::detail::SphericalProjector可以存储不同参数设置的投影器,用于对不同的图像区域或不同的图像集进行不同程度的球面变换。
比如在虚拟现实(VR)或增强现实(AR)应用中,可能需要对不同视角的图像进行球面校正,以提供沉浸式的视觉体验。这个容器可以存储多个投影器,每个投影器对应不同的视角或场景,方便在运行时快速切换和应用不同的投影变换。

在 OpenCV 中,cv::detail::SphericalProjector的mapForward函数主要用于进行球面投影的正向映射。

变换

一、坐标变换
从原始图像坐标到球面坐标的转换:
该函数将输入图像中的像素坐标转换为对应的球面坐标。这在全景图像拼接、360 度图像渲染以及一些涉及球面投影的计算机视觉任务中非常关键。
例如,在全景图像拼接中,不同视角拍摄的图像需要转换到统一的球面坐标系统下,以便进行准确的融合。mapForward函数可以将每个像素在原始图像中的位置映射到球面坐标上,使得不同图像的对应位置能够在球面空间中进行匹配和拼接。
二、投影变换
确定像素在新空间中的位置:
它根据特定的投影模型和参数,计算出输入像素在球面投影后的新位置。这个过程涉及到复杂的数学计算,包括三角函数和矩阵运算等。
比如,在虚拟现实(VR)应用中,为了呈现沉浸式的 360 度场景,需要将平面图像投影到球面空间中。mapForward函数可以确定每个像素在球面空间中的具体位置,从而实现正确的投影效果。
三、支持后续处理
为图像融合和处理提供基础:
输出的映射结果可以被其他图像处理函数使用,以实现图像的融合、插值和校正等操作。通过知道每个像素在球面空间中的新位置,可以进行准确的插值计算,以填充由于投影变换而产生的空白区域,或者进行图像融合时确定不同图像中对应像素的权重。
例如,在全景图像拼接后,可能需要对拼接处进行平滑处理,这就需要根据像素在球面坐标下的位置进行插值和混合操作。mapForward函数提供的映射结果为这些后续处理提供了必要的信息。

例子

#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2/stitching/detail/blenders.hpp>
#include <opencv2/stitching/detail/matchers.hpp>
#include <opencv2/stitching/detail/motion_estimators.hpp>
#include <opencv2/stitching/detail/seam_finders.hpp>
#include <opencv2/stitching/detail/warpers.hpp>int main() {// 读取两张图像cv::Mat image1 = cv::imread("image1.jpg");cv::Mat image2 = cv::imread("image2.jpg");// 创建图像拼接器cv::Ptr<cv::detail::Stitcher> stitcher = cv::Stitcher::create();// 特征点匹配和图像拼接准备std::vector<cv::Mat> images = {image1, image2};std::vector<cv::detail::ImageFeatures> features(2);std::vector<cv::detail::MatchesInfo> pairwise_matches;cv::Ptr<cv::detail::FeaturesFinder> finder = cv::makePtr<cv::detail::OrbFeaturesFinder>();finder->compute(images, features);cv::Ptr<cv::detail::BestOf2NearestMatcher> matcher = cv::makePtr<cv::detail::BestOf2NearestMatcher>(false, 0.3f);matcher->match(features, pairwise_matches);std::vector<cv::detail::CameraParams> cameras;cv::Ptr<cv::detail::HomographyBasedEstimator> estimator = cv::makePtr<cv::detail::HomographyBasedEstimator>();estimator->estimate(features, pairwise_matches, cameras);cv::Ptr<cv::detail::BundleAdjusterBase> adjuster = cv::makePtr<cv::detail::BundleAdjusterRay>();adjuster->setConfThresh(1.0);adjuster->optimize(cameras, features, pairwise_matches);cv::detail::SphericalWarper warper;std::vector<cv::Point> corners(2);std::vector<cv::UMat> masks_warped(2);std::vector<cv::UMat> images_warped(2);warper.warp(images, images_warped, cameras);warper.warp(masks, masks_warped, cameras);cv::Rect roi;std::vector<cv::Point> corners2;int result_width = 0, result_height = 0;warper.composePanorama(masks_warped, corners, roi, result_width, result_height);cv::Mat result(result_height, result_width, CV_8UC3, cv::Scalar::all(0));cv::Mat mask(result_height, result_width, CV_8U, cv::Scalar::all(0));std::vector<cv::detail::SphericalProjector> projectors;for (size_t i = 0; i < cameras.size(); ++i) {projectors.push_back(cv::detail::SphericalProjector(cameras[i]));}// 使用 mapForward 函数示例cv::Point2f originalPoint(100, 150); // 假设这是图像中的一个点cv::Point2f sphericalPoint;projectors[0].mapForward(originalPoint, sphericalPoint);std::cout << "Original Point: (" << originalPoint.x << ", " << originalPoint.y << ")" << std::endl;std::cout << "Spherical Point: (" << sphericalPoint.x << ", " << sphericalPoint.y << ")" << std::endl;return 0;
}

在这个例子中,首先读取两张图像,进行特征点匹配和图像拼接的准备工作。然后创建了cv::detail::SphericalProjector对象,并使用mapForward函数将一个原始图像中的点转换为球面坐标中的点。请注意,运行这个示例代码需要有合适的图像文件(image1.jpg和image2.jpg)

这篇关于opencv的球面投影的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

opencv 滚动条

参数介绍:createTrackbar( trackbarname , "hello" , &alpha_slider ,alpha_max ,  on_trackbar )  ;在标签中显示的文字(提示滑动条的用途) TrackbarName创建的滑动条要放置窗体的名字 “hello”滑动条的取值范围从 0 到 alpha_max (最小值只能为 zero).滑动后的值存放在

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

树莓派5_opencv笔记27:Opencv录制视频(无声音)

今日继续学习树莓派5 8G:(Raspberry Pi,简称RPi或RasPi)  本人所用树莓派5 装载的系统与版本如下:  版本可用命令 (lsb_release -a) 查询: Opencv 与 python 版本如下: 今天就水一篇文章,用树莓派摄像头,Opencv录制一段视频保存在指定目录... 文章提供测试代码讲解,整体代码贴出、测试效果图 目录 阶段一:录制一段

Verybot之OpenCV应用三:色标跟踪

下面的这个应用主要完成的是Verybot跟踪色标的功能,识别部分还是居于OpenCV编写,色标跟踪一般需要将图像的颜色模式进行转换,将RGB转换为HSV,因为对HSV格式下的图像进行识别时受光线的影响比较小,但是也有采用RGB模式来进行识别的情况,这种情况一般光线条件比较固定,背景跟识别物在颜色上很容易区分出来。         下面这个程序的流程大致是这样的:

Verybot之OpenCV应用二:霍夫变换查找圆

其实我是想通过这个程序来测试一下,OpenCV在Verybot上跑得怎么样,霍夫变换的原理就不多说了,下面是程序: #include "cv.h"#include "highgui.h"#include "stdio.h"int main(int argc, char** argv){cvNamedWindow("vedio",0);CvCapture* capture;i

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

虚拟机ubuntu配置opencv和opencv_contrib

前期准备  1.下载opencv和opencv_contrib源码 opencv-4.6.0:https://opencv.org/releases/ opencv_contrib-4.6.0:https://github.com/opencv/opencv_contrib 在ubuntu直接下载或者在window上下好传到虚拟机里都可以 自己找个地方把他们解压,个人习惯在home下新建一

Windows下使用cmake编译OpenCV

Windows下使用cmake编译OpenCV cmake下载OpenCV下载编译OpenCV cmake下载 下载地址:https://cmake.org/download/ 下载完成,点击选择路径安装即可 OpenCV下载 下载地址:https://github.com/opencv/opencv/releases/tag/4.8.1因为我们是编译OpenCV,下图选择