Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexwlchan/dominant_colours
A CLI tool to find the dominant colours in an image 🎨
https://github.com/alexwlchan/dominant_colours
dominant-colors kmeans kmeans-colors rust
Last synced: 2 months ago
JSON representation
A CLI tool to find the dominant colours in an image 🎨
- Host: GitHub
- URL: https://github.com/alexwlchan/dominant_colours
- Owner: alexwlchan
- License: mit
- Created: 2021-11-26T08:58:04.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-20T20:08:57.000Z (3 months ago)
- Last Synced: 2024-10-21T00:39:41.678Z (3 months ago)
- Topics: dominant-colors, kmeans, kmeans-colors, rust
- Language: Rust
- Homepage: https://dominant-colours.glitch.me
- Size: 10.3 MB
- Stars: 89
- Watchers: 6
- Forks: 4
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- stars - alexwlchan/dominant_colours - A CLI tool to find the dominant colours in an image 🎨 \[*MIT License*\] (⭐️92) (Rust)
- stars - alexwlchan/dominant_colours - A CLI tool to find the dominant colours in an image 🎨 \[*MIT License*\] (⭐️92) (Rust)
README
# dominant_colours
This is a tool for finding the dominant colours of an image.
It prints their hex codes to the terminal, along with a preview of the colour (in terminals that support ANSI escape codes):![Left: a photo of a red and white lighthouse set against a blue sky. Right: the terminal output of three invocations of 'dominant_colours' against 'lighthouse.jpg', with hex colours printed to the terminal.](screenshot.png)
It's available both as a command-line tool and [as a web app](./webapp).
## Installation
You can download compiled binaries from the [GitHub releases](https://github.com/alexwlchan/dominant_colours/releases).
Alternatively, you can install from source.
You need Rust installed; I recommend using [Rustup].
Then clone this repository and compile the code:```console
$ git clone "https://github.com/alexwlchan/dominant_colours.git"
$ cd dominant_colours
$ cargo install --path .
```[Rustup]: https://rustup.rs/
## Usage examples
Pass the path of an image you want to look at:
```console
$ dominant_colours /path/to/cats.jpg
▇ #d0c6b2
▇ #3f3336
▇ #f3f2ee
▇ #786356
▇ #aa9781
```By default, it finds (up to) five dominant colours.
If you want more or less, pass the `--max-colours` flag.
For example:```console
$ dominant_colours /path/to/corgis.jpg --max-colours=3
▇ #7c8442
▇ #ccbe8f
▇ #2d320e
```The colours are printed as hex codes, with colour previews in your terminal.
If you just want the hex codes and no colour preview, pass the `--no-palette` flag:```console
$ dominant_colours /path/to/crustaceans.png --no-palette
#e6401b
#be5e36
#734f48
#d6c0bd
#b1948f
```This is useful if your terminal doesn't support ANSI escape codes, or you're passing the output to another tool.
It currently supports JPEGs, PNGs, and GIFs (including animated GIFs).
## Wrapper functions in other languages
One of the reasons I wrote `dominant_colours` as a standalone binary was to allow me to write all the fiddly colour logic once, and then I can call it with thin wrapper functions from other languages.
So far I've only done this from Python, but the option is there!
I'll put any of these wrapper functions I write below (or add your own in a PR):Python
```python
import subprocessdef dominant_colours(path, *, max_colours=5):
"""
Get the dominant colours of an image.
Returns the colours as RGB tuples of 0-255 values,
e.g. red is (255, 0, 0).
"""
cmd = ["dominant_colours", path, f"--max-colours={max_colours}", "--no-palette"]
output = subprocess.check_output(cmd)colours = []
for line in output.splitlines():
colours.append((
int(line[1:3], 16),
int(line[3:5], 16),
int(line[5:7], 16),
))return colours
```## Further reading
- I've written [an accompanying blog post](https://alexwlchan.net/2021/11/dominant-colours/) that talks more about the motivation behind the tool, a high-level overview of how it works, and why I chose to write it in Rust.
- [Getting a tint colour from an image with Python and k-means](https://alexwlchan.net/2019/08/finding-tint-colours-with-k-means/) – a blog post I wrote in August 2019 explaining how to find dominant colours.
My original implementation was in Python.
I've replaced it with a standalone Rust tool so I can easily share it across multiple projects, and because Rust is noticeably faster for this sort of thing.- [Collyn O'Kane's kmeans-colors project](https://github.com/okaneco/kmeans-colors) – a Rust command-line tool and library for finding the average colours in an image using k-means.
The command-line tool has a lot of features, more than I need.
I wanted a very simple tool that does one thing, so I wrote dominant_colours as a wrapper around the library.- [Drawing coloured squares/text in my terminal with Python](https://alexwlchan.net/2021/04/coloured-squares/) – a blog post I wrote in April 2021 explaining how to use ANSI escape codes to print arbitrary colours in a terminal.
I used the same escape codes to get the coloured output in this tool.
## License
MIT.