-
-
Notifications
You must be signed in to change notification settings - Fork 35.7k
/
Copy pathColorConverter.js
58 lines (43 loc) · 1.45 KB
/
ColorConverter.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
48
49
50
51
52
53
54
55
56
57
58
import { MathUtils } from 'three';
const _hsl = {};
/**
* A utility class with helper functions for color conversion.
*
* @hideconstructor
* @three_import import { ColorConverter } from 'three/addons/math/ColorConverter.js';
*/
class ColorConverter {
/**
* Sets the given HSV color definition to the given color object.
*
* @param {Color} color - The color to set.
* @param {number} h - The hue.
* @param {number} s - The saturation.
* @param {number} v - The value.
* @return {Color} The update color.
*/
static setHSV( color, h, s, v ) {
// https://gist.github.com/xpansive/1337890#file-index-js
h = MathUtils.euclideanModulo( h, 1 );
s = MathUtils.clamp( s, 0, 1 );
v = MathUtils.clamp( v, 0, 1 );
return color.setHSL( h, ( s * v ) / ( ( h = ( 2 - s ) * v ) < 1 ? h : ( 2 - h ) ), h * 0.5 );
}
/**
* Returns a HSV color representation of the given color object.
*
* @param {Color} color - The color to get HSV values from.
* @param {{h:number,s:number,v:number}} target - The target object that is used to store the method's result.
* @return {{h:number,s:number,v:number}} The HSV color.
*/
static getHSV( color, target ) {
color.getHSL( _hsl );
// based on https://gist.github.com/xpansive/1337890#file-index-js
_hsl.s *= ( _hsl.l < 0.5 ) ? _hsl.l : ( 1 - _hsl.l );
target.h = _hsl.h;
target.s = 2 * _hsl.s / ( _hsl.l + _hsl.s );
target.v = _hsl.l + _hsl.s;
return target;
}
}
export { ColorConverter };