Open In App
Related Articles

Stitching input images (panorama) using OpenCV with C++

Improve Article
Save Article
Like Article

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 image for details. 



// 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;
    // 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);
    return 0;

Input Images:





This article is contributed by Shashwat Jain. If you like GeeksforGeeks and would like to contribute, you can also write an article using or mail your article to See your article appearing on the GeeksforGeeks main page and help other Geeks. Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.

Last Updated : 26 Apr, 2022
Like Article
Save Article
Similar Reads