opencv图片全景拼接详解
来源:互联网 发布:博弈树算法c语言 编辑:程序博客网 时间:2024/05/07 11:33
简介
基本的拼接方式参见: 《opencv实现图像的拼接功能》
本博文基于取景模式讲解图像拼接。API全面基本的介绍介绍参见:
opencv官网:http://docs.opencv.org/modules/stitching/doc/stitching.html
在opencv源代码中stitching.cpp 是简单版图像拼接实例,参见《opencv实现图像的拼接功能》。
stitching_detailed.cpp 复杂全面版图像拼接实例。
简单实例(stitching.cpp)
首先看下,opencv实现图像拼接的最简单实例,这是将stitching.cpp裁剪到最简单的代码
#include <iostream>
#include <fstream>
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/stitching/stitcher.hpp"
using namespace std;
using namespace cv;
bool try_use_gpu = true; //false;
vector<Mat> imgs;
string result_name = "result.jpg";
int parseCmdArgs(int argc, char** argv)
{
for (int i = 1; i < argc; ++i){
Mat img = imread(argv[i]);
if (img.empty()){
cout << "Can't read image '" << argv[i] << "'\n";
return -1;
}
imgs.push_back(img);
imshow(argv[i], img);
}
return 0;
}
int main(int argc, char* argv[])
{
int retval = parseCmdArgs(argc, argv);
if (retval) return -1;
Mat pano;
Stitcher stitcher = Stitcher::createDefault(try_use_gpu);
Stitcher::Status status = stitcher.stitch(imgs, pano);
if (status != Stitcher::OK)
{
cout << "Can't stitch images, error code = " << int(status) << endl;
return -1;
}
imwrite(result_name, pano);
imshow("show", pano);
cv::waitKey(0);
return 0;
}
效果演示
基于不同模式的全景拼接(stitching_detailed.cpp精简版)
代码具体代码如下:
#include <iostream>
#include <fstream>
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/stitching/stitcher.hpp"
using namespace std;
using namespace cv;
bool try_use_gpu = false;
vector<Mat> imgs;
string result_name = "result.jpg";
int parseCmdArgs(int argc, char** argv)
{ //输入的图片全部填充到容器imgs中,并将输入的图片显示出来。
for (int i = 1; i < argc-1; ++i)
{
Mat img = imread(argv[i]);
if (img.empty()){
cout << "Can't read image '" << argv[i] << "'\n";
return -1;
}
imgs.push_back(img);
imshow(argv[i], img);
}
return 0;
}
int main(int argc, char* argv[])
{
int retval = parseCmdArgs(argc, argv);
if (retval) return -1;
Mat pano;
Stitcher stitcher = Stitcher::createDefault(try_use_gpu); //创建一个stitcher对象。
if(argv[4][0] == '1')
{ //1:平面拼接
PlaneWarper* cw = new PlaneWarper();
stitcher.setWarper(cw);
}
else if(argv[4][0] == '2')
{//2:柱面 拼接
SphericalWarper* cw = new SphericalWarper();
stitcher.setWarper(cw);
}
else if(argv[4][0] == '3')
{//3:立体画面拼接
StereographicWarper *cw = new cv::StereographicWarper();
stitcher.setWarper(cw);
}
//使用Surf算法来寻找特征点,支持Surf和Orb两种方式
detail::SurfFeaturesFinder *featureFinder = new detail::SurfFeaturesFinder();
stitcher.setFeaturesFinder(featureFinder);
/*匹配给定的图像和估计相机的旋转*/
Stitcher::Status status = stitcher.estimateTransform(imgs); //另一种方式来实现拼接
if (status != Stitcher::OK)
{
cout << "Can't stitch images, error code = " << int(status) << endl;
return -1;
}
/*生成全景图像*/
status = stitcher.composePanorama(pano);
if (status != Stitcher::OK)
{
cout << "Can't stitch images, error code = " << int(status) << endl;
return -1;
}
imwrite(result_name, pano);
imshow("show", pano);
cv::waitKey(0);
return 0;
}
代码中设置生成结果图为:1:平面, 2:柱面, 3:立体画面。在它提供的复杂版实例:stitching_detailed.cpp,
有如下种类可以选择:
plane|cylindrical|spherical|fisheye|stereographic|compressedPlaneA2B1|
compressedPlaneA1.5B1|compressedPlanePortraitA2B1|compressedPlanePortraitA1.5B1|paniniA2B1|
paniniA1.5B1|paniniPortraitA2B1|paniniPortraitA1.5B1|mercator|transverseMercator
本例中结果展示:
1:平面
2:柱面
3:立体画面
- opencv图片全景拼接详解
- opencv全景拼接例子
- opencv图像全景拼接
- opencv全景拼接
- opencv全景图拼接
- opencv 基于sift的多张图片全景图拼接
- 全景图片拼接
- 基于OpenCV全景图像拼接
- 全景视频拼接(二)--OpenCV源码解析
- opencv全景拼接源码解读与修改。
- OpenCV图片拼接
- OpenCV图片拼接
- 全景拼接
- 全景拼接
- 全景视频拼接(四):循环将两幅图像拼接为全景图片
- C#图片拼接(全景图片的实现)
- Opencv 使用Stitcher类图像拼接生成全景图像
- 【OpenCV学习笔记 024】Stitcher类实现全景图像拼接
- SpringMVC中使用Interceptor拦截器
- gulp教程之gulp中文API
- 界面跳转异常记录
- windows7远程桌面ubuntu14.04
- Spring3 MVC请求参数获取的几种方法
- opencv图片全景拼接详解
- 苏宁的手机号如何充值
- Spring IoC Service Provicer 管理对象间的依赖关系的三种方式
- 关于伪类覆盖指定类相的问题
- GDI与GDI+的区别
- 移动端地图技术分享 百度高德SDK
- JSONObject put,accumulate,element的区别
- Android4.4 xposed安装失败(the xposed framework is not installed)
- js中几种实用的跨域方法原理详解