たった3つの数の組み合わせなのに奥が深いのが色。chroma.jsで、悩むアプリづくりでの色づかいを計算で解決してみましょう。
「
データ可視化向けのカラー生成ライブラリ「chroma.js」」
data:image/s3,"s3://crabby-images/f25eb/f25eb77c8ee9364afa5da2d471f195b245fc4876" alt=""
「chroma.js api docs!」chroma-es src on GitHub
カラフルな公式ドキュメントがかわいい!いつものようにESモジュール化したいので、forkして、良さそうな
プルリクを
反映、esブランチを作ってNode.js用のrequire構文をimport/exportに変更して、deno bundleでまとめて、
terserで
圧縮して、GitHub Pagesで公開してできあがり!下記のようにブラウザやDenoでサクッと使えます。「
chroma-es on GitHub」
import chroma from "https://code4fukui.github.io/chroma-es/chroma.min.js";
const cs = chroma.scale(["red", "white"]).mode("rgb").out("hex");
console.log(cs(0.0));
console.log(cs(0.5));
console.log(cs(1.0));
任意の色を使ったグラデーションを計算しています。
data:image/s3,"s3://crabby-images/50907/5090776d6a7c579e74314aacc675a83829fb99c9" alt=""
いろんな色空間でグラデーション描画するサンプルはこちら。ES-Jamに貼り付けて動かせます。
<script type="module">
import chroma from "https://code4fukui.github.io/chroma-es/chroma.min.js";
const cfrom = "#f00";
const cto = "#0ff";
const modes = ["rgb", "lab", "lch", "hsv", "hsl", "hsi"];
for (const mode of modes) {
const cs = chroma.scale([cfrom, cto]).mode(mode).out("hex");
const txt = document.createElement("div");
txt.textContent = mode;
document.body.appendChild(txt);
const n = 20;
for (let i = 0; i < n; i++) {
const div = document.createElement("div");
div.style.width = div.style.height = 30;
div.style.display = "inline-block";
div.style.backgroundColor = cs(i / n);
document.body.appendChild(div);
}
}
</script>
cfromやctoの色を変えて試してみましょう!
下記は、chroma.js のサンプルプログラムへのリンクです。レッツ、色あそび!
data:image/s3,"s3://crabby-images/7d1a2/7d1a276dff2f7f3b42c7fd2a46475b434ea0bfa0" alt=""
bezier
data:image/s3,"s3://crabby-images/3decf/3decf3fb4e398e8f4eebebd8e0067ea4cd4db591" alt=""
blend
data:image/s3,"s3://crabby-images/ed0cd/ed0cd4985e5d2c8813ab5662d466eca83fc83b97" alt=""
colorspaces
data:image/s3,"s3://crabby-images/03ec1/03ec1fd8b97d52d0f76aadd0a3ff85ba38862c99" alt=""
cubehelix