-
Notifications
You must be signed in to change notification settings - Fork 2
/
hwb.js
47 lines (43 loc) · 1.16 KB
/
hwb.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import { fromHSL, toHSL } from "./hsl.js";
import { setAlpha } from "./utils.js";
/**
* @typedef {number[]} hwb hue, whiteness, blackness.
*
* All components in the range 0 <= x <= 1
* @see {@link https://en.wikipedia.org/wiki/HWB_color_model}
*/
/**
* Updates a color based on HWB values and alpha.
* @alias module:pex-color.fromHWB
* @param {import("./color.js").color} color
* @param {number} h
* @param {number} w
* @param {number} b
* @param {number} [a]
* @returns {import("./color.js").color}
*/
export function fromHWB(color, h, w, b, a) {
if (w + b >= 1) {
color[0] = color[1] = color[2] = w / (w + b);
} else {
fromHSL(color, h, 1, 0.5);
for (let i = 0; i < 3; i++) {
color[i] *= 1 - w - b;
color[i] += w;
}
}
return setAlpha(color, a);
}
/**
* Returns a HWB representation of a given color.
* @alias module:pex-color.toHWB
* @param {import("./color.js").color} color
* @param {Array} out
* @returns {hwb}
*/
export function toHWB(color, out = []) {
toHSL(color, out);
out[1] = Math.min(color[0], color[1], color[2]);
out[2] = 1 - Math.max(color[0], color[1], color[2]);
return setAlpha(out, color[3]);
}