2
0

ColorConverter.js 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. console.warn( "THREE.ColorConverter: As part of the transition to ES6 Modules, the files in 'examples/js' were deprecated in May 2020 (r117) and will be deleted in December 2020 (r124). You can find more information about developing using ES6 Modules in https://threejs.org/docs/#manual/en/introduction/Installation." );
  2. THREE.ColorConverter = {
  3. setHSV: function ( color, h, s, v ) {
  4. // https://gist.github.com/xpansive/1337890#file-index-js
  5. h = THREE.MathUtils.euclideanModulo( h, 1 );
  6. s = THREE.MathUtils.clamp( s, 0, 1 );
  7. v = THREE.MathUtils.clamp( v, 0, 1 );
  8. return color.setHSL( h, ( s * v ) / ( ( h = ( 2 - s ) * v ) < 1 ? h : ( 2 - h ) ), h * 0.5 );
  9. },
  10. getHSV: function () {
  11. var hsl = {};
  12. return function getHSV( color, target ) {
  13. if ( target === undefined ) {
  14. console.warn( 'THREE.ColorConverter: .getHSV() target is now required' );
  15. target = { h: 0, s: 0, l: 0 };
  16. }
  17. color.getHSL( hsl );
  18. // based on https://gist.github.com/xpansive/1337890#file-index-js
  19. hsl.s *= ( hsl.l < 0.5 ) ? hsl.l : ( 1 - hsl.l );
  20. target.h = hsl.h;
  21. target.s = 2 * hsl.s / ( hsl.l + hsl.s );
  22. target.v = hsl.l + hsl.s;
  23. return target;
  24. };
  25. }(),
  26. // where c, m, y, k is between 0 and 1
  27. setCMYK: function ( color, c, m, y, k ) {
  28. var r = ( 1 - c ) * ( 1 - k );
  29. var g = ( 1 - m ) * ( 1 - k );
  30. var b = ( 1 - y ) * ( 1 - k );
  31. return color.setRGB( r, g, b );
  32. },
  33. getCMYK: function ( color, target ) {
  34. if ( target === undefined ) {
  35. console.warn( 'THREE.ColorConverter: .getCMYK() target is now required' );
  36. target = { c: 0, m: 0, y: 0, k: 0 };
  37. }
  38. var r = color.r;
  39. var g = color.g;
  40. var b = color.b;
  41. var k = 1 - Math.max( r, g, b );
  42. var c = ( 1 - r - k ) / ( 1 - k );
  43. var m = ( 1 - g - k ) / ( 1 - k );
  44. var y = ( 1 - b - k ) / ( 1 - k );
  45. target.c = c;
  46. target.m = m;
  47. target.y = y;
  48. target.k = k;
  49. return target;
  50. }
  51. };