This program is intended to create a panorama from a set of images by stitching them together using OpenCV library stitching.hpp and the implementation for the same is done in C++. The program saves the resultant stitched image in the same directory as the program file. If the set of images are not stitched then it exits the program with an error. This error comes due to the fact that the input images don’t have common areas or they don’t share a common patch of pixels.
Steps to implement the code:
1) Make sure OpenCV is installed on the local machine
2) Place the input images in the same directory as the program.
3) Compile the code from the command prompt as usual.
4) While running the code give all the input images as arguments.
5) Check the resultant image by the name “result.jpg”
Stitching Pipeline:
This image shows the basic architecture of how the stitching algorithm works.It is based on the research paper with title “Automatic Panoramic Image Stitching using Invariant Features” by M. Brown and D. Lowe. Refer to the second link in references.
Please refer this opencv.org image for details.
Implementation
// CPP program to Stitch // input images (panorama) using OpenCV #include <iostream> #include <fstream> // Include header files from OpenCV directory // required to stitch images. #include "opencv2/imgcodecs.hpp" #include "opencv2/highgui.hpp" #include "opencv2/stitching.hpp" using namespace std;
using namespace cv;
// Define mode for stitching as panorama // (One out of many functions of Stitcher) Stitcher::Mode mode = Stitcher::PANORAMA; // Array for pictures vector<Mat> imgs; int main( int argc, char * argv[])
{ // Get all the images that need to be
// stitched as arguments from command line
for ( int i = 1; i < argc; ++i)
{
// Read the ith argument or image
// and push into the image array
Mat img = imread(argv[i]);
if (img.empty())
{
// Exit if image is not present
cout << "Can 't read image ' " << argv[i] << "'\n";
return -1;
}
imgs.push_back(img);
}
// Define object to store the stitched image
Mat pano;
// Create a Stitcher class object with mode panoroma
Ptr<Stitcher> stitcher = Stitcher::create(mode, false );
// Command to stitch all the images present in the image array
Stitcher::Status status = stitcher->stitch(imgs, pano);
if (status != Stitcher::OK)
{
// Check if images could not be stitched
// status is OK if images are stitched successfully
cout << "Can't stitch images\n";
return -1;
}
// Store a new image stitched from the given
//set of images as "result.jpg"
imwrite("result.jpg", pano);
// Show the result
imshow("Result", pano);
waitKey(0);
return 0;
} |
Input Images:
Output:
References:
1) http://docs.opencv.org/2.4/modules/stitching/doc/stitching.html
2) http://docs.opencv.org/2.4/modules/stitching/doc/introduction.html