我想使用从将 HSV 颜色值转换为 RGB 颜色的算法来计算 200 x 200 RGB 位图,其角落的颜色为红色、绿色、蓝色和白色,并在其他地方双线性插值 HSV 颜色,并计算位图双线性插值 RGB 颜色。我在维基百科中找到了这个公式,但我对如何做到这一点感到困惑。
任何帮助,将不胜感激。
好的,我想我知道你在说什么。我没有尝试运行任何这个,所以它可能有一些错误......
首先,您需要计算出红色、绿色、蓝色和白色的 HSV 值。顺时针调用这些,a,b,c,d - 例如,白色将是 [0,0,1] 或类似的缩放
对于网格中的位置,(x,y)
插值0 <= x <= 1
位类似于将值放入数组out
:
for(int i=0; i<3; i++){
out[i] = y*((x*a[i]) + ((1-x)*b[i])) + (1-y)*((x*d[i]) + ((1-x)*c[i]));
}
在寻找线性插值时,A 和 B 之间的 x 分数由下式给出x*A + (1-x)*B
。每个方向只做一次。
然后使用维基百科文章中的约定将它们转换为 RGB
void HSVtoRGB(double H, double S, double V, double[] out){
double C = S*V;
double H_prime = H/60; // a number in [0,3]
double X = C*(1 - abs((H_prime%2)-1));
// Do the big if bit
switch((int)X){
case 0:
out[0] = C;
out[1] = X;
out[2] = 0;
case 1:
out[0] = X;
out[1] = C;
out[2] = 0;
// etc etc
}
double m = V - C;
for(int i=0; i<3; i++){
out[i] += m;
}
}
应该这样做,给予或接受。好吧,至少应该给你一个粗略的想法。