Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mazznoer/colorgrad
Go (Golang) color scales library for maps, charts, data-visualization & creative coding.
https://github.com/mazznoer/colorgrad
color color-scales colormap data-visualization gradient visual-encoding visualization
Last synced: 3 months ago
JSON representation
Go (Golang) color scales library for maps, charts, data-visualization & creative coding.
- Host: GitHub
- URL: https://github.com/mazznoer/colorgrad
- Owner: mazznoer
- License: other
- Created: 2020-07-24T15:07:19.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-08-15T14:08:40.000Z (6 months ago)
- Last Synced: 2024-08-16T03:25:04.954Z (6 months ago)
- Topics: color, color-scales, colormap, data-visualization, gradient, visual-encoding, visualization
- Language: Go
- Homepage:
- Size: 777 KB
- Stars: 209
- Watchers: 7
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# colorgrad
[data:image/s3,"s3://crabby-images/ad933/ad93382289065b3ec5916861d757de96ca232097" alt="Release"](https://github.com/mazznoer/colorgrad/releases/latest)
[data:image/s3,"s3://crabby-images/7c648/7c648bced96fc6f0ddb25f5463fc5079565736c7" alt="PkgGoDev"](https://pkg.go.dev/github.com/mazznoer/colorgrad)
data:image/s3,"s3://crabby-images/bddb2/bddb2622c29221f07b9680409d1ba7f2c1a2ecf0" alt="Build Status"
[data:image/s3,"s3://crabby-images/598bf/598bfc7922ada0b5f7eae26a6f1449c80fb1fb33" alt="go report"](https://goreportcard.com/report/github.com/mazznoer/colorgrad)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"](https://liberapay.com/mazznoer/donate)
## Index
* [Custom Gradient](#custom-gradient)
* [Preset Gradients](#preset-gradients)
* [Using the Gradient](#using-the-gradient)
* [Examples](#examples)
* [Playground](#playground)```go
import "github.com/mazznoer/colorgrad"
```## Custom Gradient
### Basic
```go
grad, err := colorgrad.NewGradient().Build()
```
data:image/s3,"s3://crabby-images/71ab1/71ab165dd4a31d88e7883059a23ef466afe848f8" alt="img"### Custom Colors
```go
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/f8b52/f8b522b3f20cbd35dc4ccf2ba11205ad216bd598" alt="img"### Using Web Color Format
`HtmlColors()` method accepts [named colors](https://www.w3.org/TR/css-color-4/#named-colors), hexadecimal (`#rgb`, `#rgba`, `#rrggbb`, `#rrggbbaa`), `rgb()`, `rgba()`, `hsl()`, `hsla()`, `hwb()`, and `hsv()`.
```go
grad, err := colorgrad.NewGradient().
HtmlColors("#C41189", "#00BFFF", "#FFD700").
Build()
```
data:image/s3,"s3://crabby-images/5e527/5e527a766f4bd56378a4fefbb4fc3253e35b05c1" alt="img"```go
grad, err := colorgrad.NewGradient().
HtmlColors("gold", "hotpink", "darkturquoise").
Build()
```
data:image/s3,"s3://crabby-images/5de51/5de513db3cdd7a1a33e5f39f78ad0112785a0c21" alt="img"```go
grad, err := colorgrad.NewGradient().
HtmlColors(
"rgb(125,110,221)",
"rgb(90%,45%,97%)",
"hsl(229,79%,85%)",
).
Build()
```
data:image/s3,"s3://crabby-images/aeb5e/aeb5e0b5e62241408b33f3ce19975ae14a8b99b9" alt="img"### Domain & Color Position
Default domain is [0..1].
```go
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].
```go
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].
```go
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].
```go
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].
```go
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
```go
grad, err := colorgrad.NewGradient().
HtmlColors("#FFF", "#00F").
Mode(colorgrad.BlendRgb).
Build()
```
data:image/s3,"s3://crabby-images/d4f99/d4f9925b8547ea740c0ae5b39673ffa17b558288" alt="blend-modes"### Interpolation Mode
```go
grad, err := colorgrad.NewGradient().
HtmlColors("#C41189", "#00BFFF", "#FFD700").
Interpolation(colorgrad.InterpolationLinear).
Build()
````InterpolationLinear`
data:image/s3,"s3://crabby-images/3ac81/3ac8186d4016f4d95890e95c8a47716582dd98eb" alt="interpolation-linear"`InterpolationCatmullRom`
data:image/s3,"s3://crabby-images/463aa/463aa8389c35d2a27dd7b84593f5b38f82642f5a" alt="interpolation-catmull-rom"`InterpolationBasis`
data:image/s3,"s3://crabby-images/119ef/119ef964af23a45d60dd75a0527124ad2df805c7" alt="interpolation-basis"## Preset Gradients
See [PRESET.md](PRESET.md)
## Parsing GIMP Gradient
```go
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) // Abstract 1
```data:image/s3,"s3://crabby-images/8f489/8f489683a5f3743429ed2782c5efc158334bec8d" alt="gimp-gradient"
## Using the Gradient
### Get the domain
```go
grad := colorgrad.Rainbow()fmt.Println(grad.Domain()) // 0 1
```### Get single color at certain position
```go
grad := colorgrad.Rainbow()fmt.Println(grad.At(0.0).HexString()) // #6e40aa
fmt.Println(grad.At(0.5).HexString()) // #aff05b
fmt.Println(grad.At(1.0).HexString()) // #6e40aa
```### Get n colors evenly spaced across gradient
```go
grad := colorgrad.Rainbow()for _, c := range grad.Colors(10) {
fmt.Println(c.HexString())
}
```Output:
```console
#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.
```go
grad := colorgrad.Rainbow().Sharp(11, 0)
```
data:image/s3,"s3://crabby-images/ecf2e/ecf2e2ebcd4dade913c77598ea19c8986ec291b0" alt="img"This is the effect of different smoothness.
data:image/s3,"s3://crabby-images/794da/794da3ad7c3cf244efce76120e5014cb88b0bc36" alt="img"
## Examples
### Gradient Image
```go
package mainimport (
"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/5e527/5e527a766f4bd56378a4fefbb4fc3253e35b05c1" alt="img"
### Colored Noise
```go
package mainimport (
"image"
"image/png"
"os""github.com/mazznoer/colorgrad"
"github.com/ojrac/opensimplex-go"
)func main() {
w := 600
h := 350
scale := 0.02grad := 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/61de1/61de1a3fc6b28aefc9557d11eea07e80169ada4c" alt="noise"
## Playground
* [Basic](https://play.golang.org/p/PlMov8BKfRc)
* [Random colors](https://play.golang.org/p/d67x9di4sAF)## Dependencies
* [csscolorparser](https://github.com/mazznoer/csscolorparser)
## Inspirations
* [chroma.js](https://gka.github.io/chroma.js/#color-scales)
* [d3-scale-chromatic](https://github.com/d3/d3-scale-chromatic/)
* colorful's [gradientgen.go](https://github.com/lucasb-eyer/go-colorful/blob/master/doc/gradientgen/gradientgen.go)## Links
* [colorgrad-rs](https://github.com/mazznoer/colorgrad-rs) - Rust port of this library