# Collage **Create a collage of an image using smaller images** ![demo](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/demo_1.png) [Full resolution output](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/lenna_full.jpg) (4000x4000px) ## Create your own ### Prerequisites 1. Install the `pip` package manager for Python 3. ``` sudo apt-get install python3-pip ``` 2. Install dependencies from `requirements.txt`. ``` python3 -m pip install -r requirements.txt ``` ### Create a collage 1. Add JPG images to use as samples to the `samples/` folder. [9999 free sample images](#download-sample-images). Sample sets containing images with a mix of different colors and light intensity will in general produce better results. 2. Run `create.py` from `~/collage` with Python 3. ``` python3 create.py ``` 3. Provide an input and output file path when prompted. You can also pass the input and output file paths as arguments when running `create.py`. ``` python3 create.py [path_to_input] [path_to_output] ``` ## Download sample images 9999 free 612x612px sample images (~1GB when inflated). *Note that 9999 images are probably overkill if the samples are random enough (which these are). 2000-4000 samples should be enough for most use cases.* Set|Size|Download| --|--|-- 1-2000|193.5 MB|[Download](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/samples/1-2000.zip) 2001-4000|192.2 MB|[Download](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/samples/2001-4000.zip) 4001-6000|191.2 MB|[Download](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/samples/4001-6000.zip) 6001-8000|380.5 MB|[Download](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/samples/6001-8000.zip) 8001-10000|191.4 MB|[Download](https://storage.googleapis.com/public.victorwesterlund.com/github/VictorWesterlund/collage/samples/8001-10000.zip) ## Increase / Decrease the output resolution Resizing the output doesn't require any modification to the underlying code. It does however require that you instance each class manually. 1. Import the required modules. ```python from classes.Samples import Samples from classes.Collage import Collage ``` 2. Loading the samples with `Sample`. Nothing exciting here. ```python samples = Samples("samples",False) ``` 3. Initialize `Collage` and define your own `self.size` tuple. ```python collage = Collage("path/to/input.jpg",samples) collage.size = (100,50) # (width,height) of each sample in the collage. collage.put("path/to/write/output.jpg") ``` # License [This repo is licensed under the MIT License](https://github.com/VictorWesterlund/collage/blob/master/LICENSE) # Issues & Contribute Report bugs and suggest features by creating an [Issue](https://github.com/VictorWesterlund/collage/issues). Pull Requests to this repo are very appreciated.