colorgrad
data:image/s3,"s3://crabby-images/598bf/598bfc7922ada0b5f7eae26a6f1449c80fb1fb33" alt="go report"
Go (Golang) color scales library for data visualization, charts, games, maps, generative art and others.
Support This Project
data:image/s3,"s3://crabby-images/ab3ea/ab3eaf1ae135747bc566a438f750bae566ba8a3b" alt="Donate"
Index
import "github.com/mazznoer/colorgrad"
Custom Gradient
Basic
grad, err := colorgrad.NewGradient().Build()
data:image/s3,"s3://crabby-images/c0ebd/c0ebd8025fa32b4f27d4b64c45eb35b146983a36" alt="img"
Custom Colors
grad, err := colorgrad.NewGradient().
Colors(
colorgrad.Rgb8(0, 206, 209, 255),
colorgrad.Rgb8(255, 105, 180, 255),
colorgrad.Rgb(0.274, 0.5, 0.7, 1),
colorgrad.Hsv(50, 1, 1, 1),
colorgrad.Hsv(348, 0.9, 0.8, 1),
).
Build()
data:image/s3,"s3://crabby-images/99405/99405a6ec454d93449b9c7202e944c3e91f45331" alt="img"
Using Web Color Format
HtmlColors()
method accepts named colors, hexadecimal (#rgb
, #rgba
, #rrggbb
, #rrggbbaa
), rgb()
, rgba()
, hsl()
, hsla()
, hwb()
, and hsv()
.
grad, err := colorgrad.NewGradient().
HtmlColors("#C41189", "#00BFFF", "#FFD700").
Build()
data:image/s3,"s3://crabby-images/fd059/fd0594cf81f72601318424ee6bfada3bba6f665f" alt="img"
grad, err := colorgrad.NewGradient().
HtmlColors("gold", "hotpink", "darkturquoise").
Build()
data:image/s3,"s3://crabby-images/ba3e2/ba3e2748f959e7da8e3af6b931111ff0b24210ce" alt="img"
grad, err := colorgrad.NewGradient().
HtmlColors(
"rgb(125,110,221)",
"rgb(90%,45%,97%)",
"hsl(229,79%,85%)",
).
Build()
data:image/s3,"s3://crabby-images/1510b/1510b6b339196ddf22fe7527569f56a00060f70b" alt="img"
Domain & Color Position
Default domain is [0..1].
grad, err := colorgrad.NewGradient().
HtmlColors("deeppink", "gold", "seagreen").
Build()
data:image/s3,"s3://crabby-images/81d18/81d18986f21674db9b87f49b1adea0efdee7dba2" alt="img"
Set the domain to [0..100].
grad, err := colorgrad.NewGradient().
HtmlColors("deeppink", "gold", "seagreen").
Domain(0, 100).
Build()
data:image/s3,"s3://crabby-images/9135c/9135c99c4b1b4dc87f3bb1f4bb73bdc81fa99c6d" alt="img"
Set the domain to [-1..1].
grad, err := colorgrad.NewGradient().
HtmlColors("deeppink", "gold", "seagreen").
Domain(-1, 1).
Build()
data:image/s3,"s3://crabby-images/09739/097394d0d6425c8850e1c6c74e2f90d3b3504c35" alt="img"
Set exact position for each color. The domain is [0..1].
grad, err := colorgrad.NewGradient().
HtmlColors("deeppink", "gold", "seagreen").
Domain(0, 0.7, 1).
Build()
data:image/s3,"s3://crabby-images/1ee2a/1ee2ac4d6443cba28ba45f6b3c75563bd15bb14f" alt="img"
Set exact position for each color. The domain is [15..80].
grad, err := colorgrad.NewGradient().
HtmlColors("deeppink", "gold", "seagreen").
Domain(15, 30, 80).
Build()
data:image/s3,"s3://crabby-images/ecd52/ecd522c8a468417866c99842e6e3016e9b80bb2c" alt="img"
Blending Mode
grad, err := colorgrad.NewGradient().
HtmlColors("#FFF", "#00F").
Mode(colorgrad.BlendRgb).
Build()
data:image/s3,"s3://crabby-images/0f500/0f50026ff4a605f06bfa79620dfd80a7758ae67f" alt="blend-modes"
Interpolation Mode
grad, err := colorgrad.NewGradient().
HtmlColors("#C41189", "#00BFFF", "#FFD700").
Interpolation(colorgrad.InterpolationLinear).
Build()
InterpolationLinear
data:image/s3,"s3://crabby-images/0b1ac/0b1acfcc12aef316d68235f02e19d46224c31f44" alt="interpolation-linear"
InterpolationCatmullRom
data:image/s3,"s3://crabby-images/c6565/c656525aee5752e92910cb336807777cb33b16f2" alt="interpolation-catmull-rom"
InterpolationBasis
data:image/s3,"s3://crabby-images/fd418/fd4183b508e9406ebb398b424145a366bafe6f42" alt="interpolation-basis"
Preset Gradients
See PRESET.md
Parsing GIMP Gradient
import "os"
foreground := colorgrad.Rgb(0, 0, 0, 1)
background := colorgrad.Rgb(1, 1, 1, 1)
file, err := os.Open("Abstract_1.ggr")
if err != nil {
panic(err)
}
defer file.Close()
grad, name, err2 := colorgrad.ParseGgr(file, foreground, background)
fmt.Println(name)
data:image/s3,"s3://crabby-images/bf70b/bf70b4d32fcf26af7c525bdf43a84006a44778c9" alt="gimp-gradient"
Using the Gradient
Get the domain
grad := colorgrad.Rainbow()
fmt.Println(grad.Domain())
Get single color at certain position
grad := colorgrad.Rainbow()
fmt.Println(grad.At(0.0).HexString())
fmt.Println(grad.At(0.5).HexString())
fmt.Println(grad.At(1.0).HexString())
Get n colors evenly spaced across gradient
grad := colorgrad.Rainbow()
for _, c := range grad.Colors(10) {
fmt.Println(c.HexString())
}
Output:
#6e40aa
#c83dac
#ff5375
#ff8c38
#c9d33a
#7cf659
#5dea8d
#48b8d0
#4775de
#6e40aa
Hard-Edged Gradient
Convert gradient to hard-edged gradient with 11 segments and 0 smoothness.
grad := colorgrad.Rainbow().Sharp(11, 0)
data:image/s3,"s3://crabby-images/4ee61/4ee61cedd14d7781449ac9e32793b3b7e678d981" alt="img"
This is the effect of different smoothness.
data:image/s3,"s3://crabby-images/abfb4/abfb41507d5614e8cc15266c4c5af4442d45aa90" alt="img"
Examples
Gradient Image
package main
import (
"image"
"image/png"
"os"
"github.com/mazznoer/colorgrad"
)
func main() {
grad, _ := colorgrad.NewGradient().
HtmlColors("#C41189", "#00BFFF", "#FFD700").
Build()
w := 1500
h := 70
fw := float64(w)
img := image.NewRGBA(image.Rect(0, 0, w, h))
for x := 0; x < w; x++ {
col := grad.At(float64(x) / fw)
for y := 0; y < h; y++ {
img.Set(x, y, col)
}
}
file, err := os.Create("gradient.png")
if err != nil {
panic(err.Error())
}
defer file.Close()
png.Encode(file, img)
}
Example output:
data:image/s3,"s3://crabby-images/fd059/fd0594cf81f72601318424ee6bfada3bba6f665f" alt="img"
Colored Noise
package main
import (
"image"
"image/png"
"os"
"github.com/mazznoer/colorgrad"
"github.com/ojrac/opensimplex-go"
)
func main() {
w := 600
h := 350
scale := 0.02
grad := colorgrad.Rainbow().Sharp(7, 0.2)
noise := opensimplex.NewNormalized(996)
img := image.NewRGBA(image.Rect(0, 0, w, h))
for y := 0; y < h; y++ {
for x := 0; x < w; x++ {
t := noise.Eval2(float64(x)*scale, float64(y)*scale)
img.Set(x, y, grad.At(t))
}
}
file, err := os.Create("noise.png")
if err != nil {
panic(err.Error())
}
defer file.Close()
png.Encode(file, img)
}
Example output:
data:image/s3,"s3://crabby-images/44a75/44a75bca45a18e054651e7a3ef53b4eafa248d45" alt="noise"
Playground
Dependencies
Inspirations
Links