Skip to content

A command-line information tool written in Python 3.x to display matplotlib colors.

License

Notifications You must be signed in to change notification settings

AstroBarker/mplcolors

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mplcolors

A command-line information tool written in Python 3.x

Tired of searching "matplotlib colors" every week/day/hour? mplcolors is a command-line information tool written in Python 3.x which can display matplotlib colors, colorbars, and has a few other useful functions. This uses matplotlib.colors to get color names and RGB values and prints with ANSI escape sequences. Finally, given a matplotlib color or hex value, mplcolors can return the RGB color complement, color triad, tetrad, and split color complements. It can be installed and imported as a package to manipulate colors in-situ.

It can also print all of the built-in colorbars.

matplotlib colors

Compatibility

The command line interface requires a terminal with true color support. Notably, Mac's Terminal.app does not have this and so the colors cannot be properly displayed. I'm not sure that that is a workaround for this. On Mac I suggest switching to a different terminal emulator with more modern support such as kitty, alacritty, or iTerm.

Requirements

You just need a Python distribution (3.x) with matplotlib and a true color compatible terminal emulator.

Installation

Direct Installation

  1. Clone this repository git clone https://github.com/AstroBarker/mplcolors.git.
  2. For the package: run python -m pip install --user .
  3. For the CLI: run make install inside the top level directory.
  • MacOS make PREFIX=/usr/local install

OS Packages

mplcolors is hosted on the Arch User Repository. On an Arch-based system, you can do, e.g.,

yay -S mplcolors

which gives access to the CLI.

Alternatively, you may create an alias in your shell's rc file (e.g., ~/.bashrc) such as

alias mplcolors='python /path/to/dir/mplcolors.py'

although this will not install the man file.

Usage (CLI)

After installation, you may run

mplcolors

to print the default matplotlib colors.

You may display all of the available xkcd colors by passing the option -a or flag --all.

To search for the RGB complement to a given color, use the -c or --complement flags followed by either a matplotlib color or hex. If using a hex value, the "#" can be given or withheld.

mplcolors -c "12ab84"

To search for colors containing a given string (e.g., "red"), then you can run:

mplcolors -s "red"

To display all of the built-in colormaps, use the -b flag ("b" for "bars") or the --colorbars option

mplcolors -b

You can display color triads, tetrads, and split complements

mplcolors -t teal # or --triad
mplcolors -r teal # or --tetrad
mplcolors -sc teal # or --split

Usage (package)

mplcolors can be imported and used as a package to support your plotting needs. To enable this, it must be in your $PYTHONPATH environment variable. Currently, mplcolors may support you by finding:

  • RGB color complement (GetComplement)
  • color triads (GetTriad)
  • color tetrads (GetTetrad)
  • color split complement(GetSplitComplement)

Once installed, simply

from mplcolors import mplcolors
my_color = "teal"
triad = mplcolors.GetTriad(my_color)

Note that most functions of relevance here will take either an mpl color name (e.g., "cornflowerblue") or a hex value. RGB and HSV values are used internally for manipulation. Return types for these functions are always hex values.

Code Style

Code linting and formatting is done with ruff. Rules are listed in ruff.toml.

TODO

  • Invert color
  • Some functionality to determine how many columns to print based on temrinal size, namely for the color bars, needs logic updates.
  • Better order printed colors ( they are "row major," we want "column major" )

About

A command-line information tool written in Python 3.x to display matplotlib colors.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •