OpenCV使用Stitcher类生成全景图像

一,原图片

 

二,源代码

#include <fstream>
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/stitching/stitcher.hpp"
#include <iostream>

using namespace cv;
using namespace std;

vector<Mat> imgs; //保存拼接的原始图像向量

//导入所有原始拼接图像函数
void parseCmdArgs()
{
	//导入拼接图像
	CString C_str;
	CString C_readImgPath;
	C_readImgPath = "D:\\opencv全景拼接图";
	int imgNum = 5;
	for (int i = 1; i < 6; i++)
	{
		C_str.Format(_T("%s\\%d.jpg"), C_readImgPath, i);   //读取图像路径
		string strImgPath = (CW2A(C_str.GetString()));
		Mat img = imread(strImgPath);//读取图片
		if (img.empty())
		{
			cout << "Can't read image '" << strImgPath << "'\n";
		}
		imgs.push_back(img);
	}

	Mat pano;
	Stitcher stitcher = Stitcher::createDefault(false);
	Stitcher::Status status = stitcher.stitch(imgs, pano);//拼接
	if (status != Stitcher::OK) //判断拼接是否成功
	{
		cout << "Can't stitch images, error code = " << int(status) << endl;
		return;
	}
	namedWindow("全景拼接", 0);
	imshow("全景拼接", pano);
	imwrite("D:\\全景拼接.jpg", pano);
	waitKey();
	return;
}

三,运行结果

原文地址:https://blog.csdn.net/dcrmg/article/details/52653366

欢迎扫码关注我的微信公众号

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值