OpenCV相机标定与3D重建(6)将3D物体点投影到2D图像平面上函数projectPoints()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

cv::fisheye::projectPoints 是 OpenCV 库中用于鱼眼镜头模型的函数,它将3D物体点投影到2D图像平面上。这个函数对于模拟或者理解鱼眼镜头如何将三维空间中的点映射到二维图像上非常有用

函数原型

cpp 复制代码
void cv::fisheye::projectPoints	
(
	InputArray 	objectPoints,
	OutputArray 	imagePoints,
	const Affine3d & 	affine,
	InputArray 	K,
	InputArray 	D,
	double 	alpha = 0,
	OutputArray 	jacobian = noArray() 
)	

函数说明

  • 该函数根据相机的内参和外参计算3D点到图像平面的投影。
  • 可选地,该函数计算雅可比矩阵------图像点坐标(作为所有输入参数的函数)相对于特定参数(内参和/或外参)的部分导数矩阵。

参数

  • 参数objectPoints: 物体点数组,1xN/Nx1 的 3 通道(或 vector),其中 N 是视图中的点数。
  • 参数imagePoints: 输出的图像点数组,2xN/Nx2 的 1 通道或 1xN/Nx1 的 2 通道,或 vector。
  • 参数affine: 仿射变换。
  • 参数K: 相机内参矩阵 cameramatrixK。
  • 参数D: 输入的畸变系数向量 (k1, k2, k3, k4)。
  • 参数alpha: 偏斜系数。
  • 参数jacobian: 可选输出的 2Nx15 雅可比矩阵,表示图像点相对于焦距分量、主点坐标、畸变系数、旋转向量、平移向量和偏斜的导数。在旧接口中,雅可比的不同分量通过不同的输出参数返回。

代码示例

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
    // 定义3D物体点
    std::vector<cv::Point3f> objectPoints;
    objectPoints.push_back(cv::Point3f(0.0f, 0.0f, 1.0f));
    objectPoints.push_back(cv::Point3f(1.0f, 0.0f, 1.0f));
    objectPoints.push_back(cv::Point3f(0.0f, 1.0f, 1.0f));

    // 相机内参矩阵 K 和畸变系数 D
    cv::Mat K = (cv::Mat_<double>(3, 3) << 458.654, 0, 367.215, 0, 457.296, 248.375, 0, 0, 1);
    cv::Mat D = (cv::Mat_<double>(1, 4) << 0.0695303, -0.160713, -0.00480225, 0.000911994);

    // 创建一个单位矩阵作为仿射变换
    cv::Affine3d affine = cv::Affine3d::Identity();

    // 输出的2D图像点
    cv::Mat imagePoints;
    cv::fisheye::projectPoints(objectPoints, imagePoints, affine, K, D);

    // 打印结果
    for (int i = 0; i < imagePoints.rows; ++i) {
        std::cout << "Image Point: (" << imagePoints.at<float>(i, 0) << ", " << imagePoints.at<float>(i, 1) << ")" << std::endl;
    }

    return 0;
}

运行结果

bash 复制代码
Image Point: (367.215, 248.375)
相关推荐
esmap5 小时前
ESMAP 智慧消防解决方案:以数字孪生技术构建全域感知消防体系,赋能消防安全管理智能化升级
人工智能·物联网·3d·编辑器·智慧城市
zhooyu6 小时前
C++和OpenGL手搓3D游戏编程(20160207进展和效果)
开发语言·c++·游戏·3d·opengl
Dfreedom.10 小时前
图像直方图完全解析:从原理到实战应用
图像处理·python·opencv·直方图·直方图均衡化
Dfreedom.11 小时前
图像处理中的对比度增强与锐化
图像处理·人工智能·opencv·锐化·对比度增强
听麟13 小时前
HarmonyOS 6.0+ PC端虚拟仿真训练系统开发实战:3D引擎集成与交互联动落地
笔记·深度学习·3d·华为·交互·harmonyos
新缸中之脑13 小时前
30个最好的3D相关AI代理技能
人工智能·3d
Pyeako13 小时前
opencv计算机视觉--LBPH&EigenFace&FisherFace人脸识别
人工智能·python·opencv·计算机视觉·lbph·eigenface·fisherface
多恩Stone13 小时前
【3D AICG 系列-9】Trellis2 推理流程图超详细介绍
人工智能·python·算法·3d·aigc·流程图
格林威14 小时前
Baumer相机水果表皮瘀伤识别:实现无损品质分级的 7 个核心方法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·计算机视觉·视觉检测·工业相机·sdk开发·堡盟相机
爱打代码的小林15 小时前
基于 OpenCV 与 Dlib 的人脸替换
人工智能·opencv·计算机视觉