Spectra is a Python library that makes color math, color scales, and color-space conversion easy. Support for:
- Color scales
- Color ranges
- Color blending
- Brightening/darkening colors
- Saturating/desaturating colors
- Conversion to/from multiple color spaces
Spectra is built on colormath and grapefruit. Spectra is enormously inspired by chroma.js and d3's scales.
pip install spectra
See this walkthrough to see what Spectra can do.
E.g., spectra.html("papayawhip")
, spectra.html("#BAABAA")
spectra.html("#FFF")
Specifically: sRGB
Specifically: CIELAB
Also known elsewhere as "hcl"
Instances of spectra.Color
have four main properties:
.values
: An array representation of the color's values in its own color space, e.g.(L, a, b)
for anlab
color..hexcode
: The hex encoding of this color, e.g.#ffffff
forrgb(255, 255, 255)
/html(\"white\")
..rgb
: The(r, g, b)
values for this color in thergb
color space; these are allowed to go out of gamut..clamped_rgb
: The "clamped"(r, g, b)
values for this color in thergb
color space.
Note on .rgb
and .rgb_clamped
: Spectra follows colormath's convention:
RGB spaces tend to have a smaller gamut than some of the CIE color spaces. When converting to RGB, this can cause some of the coordinates to end up being out of the acceptable range (0.0-1.0 or 1-255, depending on whether your RGB color is upscaled). [...] Rather than clamp these for you, we leave them as-is.
Convert this color to another color space.
teal_lab = spectra.html("teal").to("lab")
print(teal_lab.values)
>>> (48.25453959565715, -28.843707890081394, -8.48135382506432)
Blend this color with another color, using ratio
of that other color.
yellow, red = spectra.html("red"), spectra.html("yellow")
orange = yellow.blend(red)
print(orange.hexcode)
>>> '#ff8000'
Brighten this color by amount
luminance. (Converts this color to the LCH color space, and then increases the L
parameter by amount
.)
teal = spectra.html("teal")
light_teal = light_teal.brighten(30)
print(light_teal.hexcode)
>>> '#75d1d0'
The opposite of color.brighten
; reduces color by amount
luminance.
Saturate this color by amount
chroma. (Converts this color to the LCH color space, and then increases the C
parameter by amount
.)
The opposite of color.saturate
; reduces color by amount
chroma.
colors
should be a list of two or more colors (created by any of the methods above), web-color names, or hexcodes.
Returns a spectra.Scale
object, which translates numbers to their corresponding colors:
my_scale = spectra.scale([ "gray", "red" ])
halfway = my_scale(0.5)
print(halfway.hexcode)
>>> '#c04040'
By default, a scale's domain is [ 0, 1 ]. But you can change it to be anything else, e.g.:
my_scale = spectra.scale([ "gray", "red" ]).domain([ 10, 20 ])
halfway = my_scale(15)
print(halfway.hexcode)
>>> '#c04040'
This function returns a list of spectra.Color
objects evenly spaced between a scale's colors
. For example:
my_scale = spectra.scale([ "gray", "red" ])
my_range = my_scale.range(5)
print(my_range)
>>> [<spectra.core.Color object at 0x10f4759d0>, <spectra.core.Color object at 0x10f475a90>,
<spectra.core.Color object at 0x10f475b50>, <spectra.core.Color object at 0x10f475cd0>,
<spectra.core.Color object at 0x10f475d50>]
print([ c.hexcode for c in my_range ])
>>> ['#808080', '#a06060', '#c04040', '#df2020', '#ff0000']
Alternatively, as a shortcut, you can use spectra.range(colors, count)
.
Issues and pull requests very much appreciated.