gpt4 book ai didi

javascript - 将 Hsl 转换为 rgb 和 hex

转载 作者:数据小太阳 更新时间:2023-10-29 04:53:56 33 4
gpt4 key购买 nike

我需要一个颜色转换器来将 hsl 值转换为 rgb 值和十六进制值。我将做类似的事情 this .为此,我正在使用 jquery 和 jquery ui range slider。这是我的代码:

$(function() {
$( "#hsl_hue_range" ).slider({
min: 0,
max: 100,
value: 0,
range: false,
animate:"slow",
orientation: "horizontal",
slide: function( event, ui ) {
var hsl_hue = ui.value;
}
});
});

$(function() {
$( "#hsl_saturation_range" ).slider({
min: 0,
max: 100,
value: 0,
range: false,
animate:"slow",
orientation: "horizontal",
slide: function( event, ui ) {
var hsl_saturation = ui.value;
}
});
});

$(function() {
$( "#hsl_light_range" ).slider({
min: 0,
max: 100,
value: 0,
range: false,
animate:"slow",
orientation: "horizontal",
slide: function( event, ui ) {
var hsl_light = ui.value;
}
});
});

我想要这样的解决方案:

转换器的输入可以由变量给出。像 hsl_hue hsl_saturation hsl_light.

有什么办法吗?
如果不行,我该怎么办?

最佳答案

新方法(灵感来自 @Kamil-Kiełczewski solution )
获取 degree, percentage, percentage 并返回 css hex color:

function hslToHex(h, s, l) {
l /= 100;
const a = s * Math.min(l, 1 - l) / 100;
const f = n => {
const k = (n + h / 30) % 12;
const color = l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);
return Math.round(255 * color).toString(16).padStart(2, '0'); // convert to Hex and prefix "0" if needed
};
return `#${f(0)}${f(8)}${f(4)}`;
}

示例:

hslToHex(360, 100, 50)  // "#ff0000" -> red

原始版本:(仍然可以,只是更长)

获取degree, percentage, percentage 并返回css hex color:

function hslToHex(h, s, l) {
h /= 360;
s /= 100;
l /= 100;
let r, g, b;
if (s === 0) {
r = g = b = l; // achromatic
} else {
const hue2rgb = (p, q, t) => {
if (t < 0) t += 1;
if (t > 1) t -= 1;
if (t < 1 / 6) return p + (q - p) * 6 * t;
if (t < 1 / 2) return q;
if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;
return p;
};
const q = l < 0.5 ? l * (1 + s) : l + s - l * s;
const p = 2 * l - q;
r = hue2rgb(p, q, h + 1 / 3);
g = hue2rgb(p, q, h);
b = hue2rgb(p, q, h - 1 / 3);
}
const toHex = x => {
const hex = Math.round(x * 255).toString(16);
return hex.length === 1 ? '0' + hex : hex;
};
return `#${toHex(r)}${toHex(g)}${toHex(b)}`;
}

示例:

hslToHex(360, 100, 50)  // "#ff0000" -> red

关于javascript - 将 Hsl 转换为 rgb 和 hex,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36721830/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com