c – OpenCV Equirectangular旋转

由于我对投影和旋转矩阵的数学理解(几乎为零),我目前仍坚持使用OpenCV在360°图像上实现等角旋转.

这种旋转的结果正如你在这里看到的那样:https://www.youtube.com/watch?v=l1N0lEKIeLA

在这里找到了一些代码https://github.com/FoxelSA/libgnomonic/wiki/Equirectangular-rotation_v0.1但我没有成功将它应用于opencv

如果有人知道如何将它应用于OpenCV Mat和Pitch,Yaw,Roll角度,我们将非常感激!

谢谢!

解决方法

而不是谈论偏航,俯仰和滚动,我将在这里谈论欧拉角x,y和z.

要执行equirectangular映射的旋转,可以按照以下过程操作:

>考虑结果图像中的坐标(i2,j2).我们将尝试找到放在这里的颜色.这些坐标对应于球体上的点,纬度为纬度lat2 = 180 * i2 / image.height和经度lon2 = 360 * j2 / image.width.计算相应的3D矢量v2.
>使用角度x,y和z计算旋转矩阵R(查看公式here).进行该矩阵的转置以获得从新图像到旧图像的反向旋转.我们将这个反向旋转矩阵Rt命名为.
>计算v1 = Rt * v2.然后计算v1的纬度lat1和经度lon1.
>在坐标i1 = image.height * lat1 / 180和j1 = image.width * lon1 / 360处查找原始图像中的颜色.这可能不是整数坐标.您可能需要在几个像素之间进行插值才能获得值.这是新图像中位置(i2,j2)处像素的颜色.

您需要了解如何在球体上的3D矢量与其纬度和经度角度之间进行转换,但这不应该太难找到.这里描述的算法应该是相当简单的实现.

如果我犯了任何错误,请告诉我,因为我自己没有测试过.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...