1

我想使用从将 HSV 颜色值转换为 RGB 颜色的算法来计算 200 x 200 RGB 位图,其角落的颜色为红色、绿色、蓝色和白色,并在其他地方双线性插值 HSV 颜色,并计算位图双线性插值 RGB 颜色。我在维基百科中找到了这个公式,但我对如何做到这一点感到困惑。

任何帮助,将不胜感激。

4

1 回答 1

1

好的,我想我知道你在说什么。我没有尝试运行任何这个,所以它可能有一些错误......

首先,您需要计算出红色、绿色、蓝色和白色的 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;
  }
}

应该这样做,给予或接受。好吧,至少应该给你一个粗略的想法。

于 2012-10-21T02:50:31.773 回答