color-interpolate
Version:
Pick color from a given color palette by index
48 lines (37 loc) • 984 B
JavaScript
/**
* @module color-interpolate
* Pick color from palette by index
*/
import parse from 'color-parse';
import hsl from 'color-space/hsl.js';
const lerp = (start, stop, step) => start*(1-step)+stop*step;
export default function interpolate (palette) {
palette = palette.map((c) => {
c = parse(c);
if (c.space != 'rgb') {
if (c.space != 'hsl') throw 'c.space' + 'space is not supported.';
c.values = hsl.rgb(c.values);
}
c.values.push(c.alpha);
return c.values;
});
return (t, mix) => {
mix = mix || lerp;
t = Math.min(Math.max(t, 0), 1);
var idx = ( palette.length - 1 ) * t,
lIdx = Math.floor( idx ),
rIdx = Math.ceil( idx );
t = idx - lIdx;
var lColor = palette[lIdx], rColor = palette[rIdx];
var result = lColor.map(function(v, i) {
v = mix(v, rColor[i], t);
if (i < 3) v = Math.round(v);
return v;
});
if (result[3] === 1) {
return 'rgb('+result.slice(0,3)+')';
}
return 'rgba('+result+')';
};
}