Skip to main content

A Python package for fast and robust Image Stitching

Project description

stitching

A Python package for fast and robust Image Stitching.

Based on opencv's stitching module and inspired by the stitching_detailed.py python command line tool.

inputs

result

Installation

use the docker image

or pip to install stitching from PyPI.

pip install stitching

Usage

Python CLI

The command line interface (cli) is available after installation

stitch -h show the help

stitch *.jpg stitches all jpg files in the current directory

stitch img_dir/IMG*.jpg stitches all files in the img_dir directory starting with "IMG" and ending with ".jpg"

stitch img1.jpg img2.jpg img3.jpg stitches the 3 explicit files of the current directory

Enable verbose mode with stitch *.jpg -v. This will create a folder where all intermediate results are stored so that you can find out where there are problems with your images, if any

Docker CLI

If you are familiar with Docker and don't feel like setting up Python and an environment, you can also use the openstitching/stitch Docker image

docker container run --rm -v /path/to/data:/data openstitching/stitch:{version} -h

You can use the Python CLI as described above (read "current directory" as "/data directory").

Python Script

You can also use the Stitcher class in your script

from stitching import Stitcher
stitcher = Stitcher()

Specify your custom settings as

stitcher = Stitcher(detector="sift", confidence_threshold=0.2)

or

settings = {"detector": "sift", "confidence_threshold": 0.2}
stitcher = Stitcher(**settings)

Create a Panorama from your Images:

  • from a list of filenames
panorama = stitcher.stitch(["img1.jpg", "img2.jpg", "img3.jpg"])
  • from a single item list with a wildcard
panorama = stitcher.stitch(["img?.jpg"])
  • from a list of already loaded images
panorama = stitcher.stitch([cv.imread("img1.jpg"), cv.imread("img2.jpg")])

The equivalent of the --affine cli parameter within the script is

from stitching import AffineStitcher
stitcher = AffineStitcher()
panorama = stitcher.stitch(...)

The equivalent of the -v/--verbose cli parameter within the script is

panorama = stitcher.stitch_verbose(...)

Questions

For questions please use our discussions. Please do not use our issue section for questions.

Contribute

Read through how to contribute for information on topics like finding and fixing bugs and improving / maintaining this package.

Tutorial

This package provides utility functions to deeply analyse what's happening behind the stitching. A tutorial was created as Jupyter Notebook. The preview is here.

You can e.g. visualize the RANSAC matches between the images or the seam lines where the images are blended:

matches1 matches2 seams1 seams2

Literature

This package was developed and used for our paper Automatic stitching of fragmented construction plans of hydraulic structures

License

Apache License 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stitching_headless-0.6.1.tar.gz (30.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stitching_headless-0.6.1-py3-none-any.whl (30.5 kB view details)

Uploaded Python 3

File details

Details for the file stitching_headless-0.6.1.tar.gz.

File metadata

  • Download URL: stitching_headless-0.6.1.tar.gz
  • Upload date:
  • Size: 30.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for stitching_headless-0.6.1.tar.gz
Algorithm Hash digest
SHA256 ad3fb2084b044f340b2786e8ec82778d89101aeebf76b2ea48388f820bd76c6e
MD5 21bfca1faf444146be0945ced1cc0a25
BLAKE2b-256 34164972565542c8adf859ae475a6ad14c9290ce725b4ed883ece9c609dbfdaa

See more details on using hashes here.

Provenance

The following attestation bundles were made for stitching_headless-0.6.1.tar.gz:

Publisher: python-publish-headless.yml on OpenStitching/stitching

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file stitching_headless-0.6.1-py3-none-any.whl.

File metadata

File hashes

Hashes for stitching_headless-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a2ee76c150be79af5b0b55d5ee71fc00d9e6f5d16a565d5b72f457604318b4c1
MD5 d367828cd64199610b0073b11b147235
BLAKE2b-256 60ce4e4684ab79b0c2d5ebe029f2eccbcc99b321313d2f75e616adab78845431

See more details on using hashes here.

Provenance

The following attestation bundles were made for stitching_headless-0.6.1-py3-none-any.whl:

Publisher: python-publish-headless.yml on OpenStitching/stitching

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page