_hslToRgb.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. "use strict";
  2. exports.__esModule = true;
  3. exports["default"] = void 0;
  4. function colorToInt(color) {
  5. return Math.round(color * 255);
  6. }
  7. function convertToInt(red, green, blue) {
  8. return colorToInt(red) + "," + colorToInt(green) + "," + colorToInt(blue);
  9. }
  10. function hslToRgb(hue, saturation, lightness, convert) {
  11. if (convert === void 0) {
  12. convert = convertToInt;
  13. }
  14. if (saturation === 0) {
  15. // achromatic
  16. return convert(lightness, lightness, lightness);
  17. } // formulae from https://en.wikipedia.org/wiki/HSL_and_HSV
  18. var huePrime = (hue % 360 + 360) % 360 / 60;
  19. var chroma = (1 - Math.abs(2 * lightness - 1)) * saturation;
  20. var secondComponent = chroma * (1 - Math.abs(huePrime % 2 - 1));
  21. var red = 0;
  22. var green = 0;
  23. var blue = 0;
  24. if (huePrime >= 0 && huePrime < 1) {
  25. red = chroma;
  26. green = secondComponent;
  27. } else if (huePrime >= 1 && huePrime < 2) {
  28. red = secondComponent;
  29. green = chroma;
  30. } else if (huePrime >= 2 && huePrime < 3) {
  31. green = chroma;
  32. blue = secondComponent;
  33. } else if (huePrime >= 3 && huePrime < 4) {
  34. green = secondComponent;
  35. blue = chroma;
  36. } else if (huePrime >= 4 && huePrime < 5) {
  37. red = secondComponent;
  38. blue = chroma;
  39. } else if (huePrime >= 5 && huePrime < 6) {
  40. red = chroma;
  41. blue = secondComponent;
  42. }
  43. var lightnessModification = lightness - chroma / 2;
  44. var finalRed = red + lightnessModification;
  45. var finalGreen = green + lightnessModification;
  46. var finalBlue = blue + lightnessModification;
  47. return convert(finalRed, finalGreen, finalBlue);
  48. }
  49. var _default = hslToRgb;
  50. exports["default"] = _default;
  51. module.exports = exports.default;