技术专栏
OpenCV实现多张图像拼接
图像拼接Stitch模块算法流程与代码使用介绍
拼接算法
OpenCV从2.4.x版本之后多出来一个新的模型 图像拼接,该模块通过简单的高级API设置,可以获得比较好的图像拼接效果,OpenCV官方提供了一个高度集成的API函数 Stitcher,只要两行代码就可以得到一个很好的拼接图像。
Ptr<Stitcher> stitcher = Stitcher::create(mode);
Stitcher::Status status = stitcher->stitch(imgs, pano);
其中第一行代码是创建拼接Stitcher的指针,第二行代码是调用拼接算法
- imgs表示的输入参数,是一系列Mat对象的vector。
- pano表示的输出结果,是拼接之后的Mat对象
官方的例子得到效果是非常的好,输入的images如下:
拼接结果如下:
但是很多人按照官方的例子开始拼接自己的图像,就是各种掉坑,各种拼接都不出结果,想跟跟上面一样简单的调用两句代码完成几乎是个梦,其实这个API里面有很多参数设置,这个在官方的演示当中都没有详细交代,stitching拼接算法 流程图示如下:
可见图像拼接是一个很复杂的算法,是由一系列的基础算法构成,这些基础算法如果你不是很了解,其实很难实现自己的图像拼接,这其中影响拼接算法stitch工作最常见几个算法子模块为:
- 特征发现与描述子
常见的特征可以选择SIFT、SURF、AKAZE、ORB等特征算子进行匹配- 相机参数
不同的相机参数与设置会导致不同的结果- 融合方式(blender)
不同的融合方式,也会导致不同结果- 各种阈值设置,特别是config threshold,如果无法特征匹配,记得把这个阈值调小点
其它参数可以如何设置可以参考OpenCV的官方文档,总之无法拼接就去调参数,一般最后都会拼接成功,此外该算法速度比较慢,但是支持GPU执行,所以想要实时的可以尝试如何GPU下执行,我这里没有尝试 ,谁尝试过的可以留言分享,我负责置顶。
代码演示
另外在拼接的时候可以设置不同warper,这样会对拼接之后的图像生成不同效果,常见的效果包括
- 鱼眼相机
- 环视(平面曲翘)
- 默认
图示分别如下:
演示代码如下:
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main(int argc, char** argv) {
vector<string> files;
glob("D:/images/zsxq/1", files);
vector<Mat> images;
for (int i = 0; i < files.size(); i++) {
printf("image file : %s \n", files[i].c_str());
images.push_back(imread(files[i]));
}
// 设置拼接模式与参数
Mat result1, result2, result3;
Stitcher::Mode mode = Stitcher::PANORAMA;
Ptr<Stitcher> stitcher = Stitcher::create(mode);
// 拼接方式-多通道融合
auto blender = detail::Blender::createDefault(detail::Blender::MULTI_BAND);
stitcher->setBlender(blender);
// 拼接
Stitcher::Status status = stitcher->stitch(images, result1);
// 平面曲翘拼接
auto plane_warper = makePtr<cv::PlaneWarper>();
stitcher->setWarper(plane_warper);
status = stitcher->stitch(images, result2);
// 鱼眼拼接
auto fisheye_warper = makePtr<cv::FisheyeWarper>();
stitcher->setWarper(fisheye_warper);
status = stitcher->stitch(images, result3);
// 检查返回
if (status != Stitcher::OK)
{
cout << "Can't stitch images, error code = " << int(status) << endl;
return EXIT_FAILURE;
}
imwrite("D:/result1.png", result1);
imwrite("D:/result2.png", result2);
imwrite("D:/result3.png", result3);
waitKey(0);
return 0;
}
注意:一起运行速度比较慢!是真的比较慢!
声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
红包
点赞
收藏
评论
打赏
- 分享
- 举报
评论
0个
手气红包
暂无数据
相关专栏
-
浏览量:1101次2023-12-20 16:40:32
-
浏览量:4681次2021-01-21 14:02:11
-
浏览量:671次2023-11-09 13:58:15
-
浏览量:608次2023-09-11 18:04:33
-
浏览量:4440次2021-01-12 18:43:19
-
浏览量:1521次2023-07-14 14:36:03
-
浏览量:779次2023-11-09 13:45:46
-
浏览量:1108次2024-03-01 16:56:38
-
浏览量:977次2023-07-17 13:57:30
-
浏览量:5532次2021-02-09 14:27:57
-
浏览量:1162次2024-03-04 14:48:01
-
浏览量:699次2024-03-04 15:03:25
-
浏览量:905次2023-07-05 11:03:52
-
浏览量:3318次2020-09-28 10:35:46
-
浏览量:869次2024-03-14 18:20:47
-
浏览量:7200次2020-12-04 10:03:47
-
浏览量:891次2024-03-14 17:53:46
-
浏览量:627次2024-01-12 11:39:24
-
浏览量:1292次2024-03-04 14:11:09
置顶时间设置
结束时间
删除原因
-
广告/SPAM
-
恶意灌水
-
违规内容
-
文不对题
-
重复发帖
打赏作者
程序员小贾
您的支持将鼓励我继续创作!
打赏金额:
¥1
¥5
¥10
¥50
¥100
支付方式:
微信支付
打赏成功!
感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
审核成功
发布时间设置
发布时间:
请选择发布时间设置
是否关联周任务-专栏模块
审核失败
失败原因
请选择失败原因
备注
请输入备注