HSV (0 .. 255) to RGB (0 .. 255)

HSV (0 .. 255) to RGB (0 .. 255)

本文关键字:RGB to HSV      更新时间:2023-10-16

可能重复:
将RGB转换为HSV和将HSV转换为RGB的算法?

有人能解释一下当HSV值为0到255时如何将其转换为RGB吗?此外,

作为参考,我正在尝试用C++来做这件事。

在此处找到http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript

function hsvToRgb(h, s, v){
    var r, g, b;
    var i = Math.floor(h * 6);
    var f = h * 6 - i;
    var p = v * (1 - s);
    var q = v * (1 - f * s);
    var t = v * (1 - (1 - f) * s);
    switch(i % 6){
        case 0: r = v, g = t, b = p; break;
        case 1: r = q, g = v, b = p; break;
        case 2: r = p, g = v, b = t; break;
        case 3: r = p, g = q, b = v; break;
        case 4: r = t, g = p, b = v; break;
        case 5: r = v, g = p, b = q; break;
    }
    return [r * 255, g * 255, b * 255];
}

编辑:

我曾经写过一个颜色选择器,并且曾经理解所有这些。当时,我看了看photoshop颜色选择器,试着在十字头发周围移动,观察hsv/rgb数字的变化,并弄清楚它们是如何工作的。在这种情况下,i似乎定位主色,色调,指向它的点。色调的值实际上是循环中完全饱和颜色的程度,从红色开始,到红色结束。有一个三角形,每个点代表R、G和B,其中0度是R。在R和G之间是黄色,在R和B之间是品红色,在B和G之间,是青色。我们总共有6种颜色。这6种颜色的大小写从0到5。