/image-gridder

A system for making a grid of images from a group of images

Primary LanguagePython

codecov tests black

Image Gridder

Yes, it's a terrible name. Image gridder it quite a specific tool for organising a group of images in a directory into a grid so they can sit together in one complete image.

Why?

I wanted a system where I could pass any number and size of images to it and it would return one combined image. I kept making this over and over for specific projects so it made sense to wrap it up into it's own repo, so rather than constantly copy and tweak code this can be used.

How does it work?

Instantiation can be seen in the example_runs file, but in essence the system works like this:

  1. First, create a folder of images
  2. Instantiate ImageGrid() passing the directory and any other configurable args (see image_grid.ImageGrid for args)
  3. All the images in the directory are resized to a new image with the dimensions of the largest image size in the original directory.
  4. Given the amount of images, a grid size is worked out
  5. The resized images are then placed left to right on the grid.
  6. A new single image is then created and saved.

Examples

See ./example_runs.py for example code for the below images

An image grid made up from 4 equal sized images

4

An image grid made up of 4 different sized images

4

An image grid made up of 9 images

9

An image grid made up of 100 equal images

100

TODOS

  • Fill mode (images zoomed in to fill area)
  • Testing images with numpy
  • Canvas margins