【问题标题】:How to retrieve RGB value for each color apart from one dimensional integer RGB array如何从一维整数 RGB 数组中检索每种颜色的 RGB 值
【发布时间】:2011-12-06 11:48:34
【问题描述】:

我对位移不太熟悉,所以我有以下问题。 我使用下面的函数(在其他地方找到)将 YUV 解码为 RGB int 数组。

现在我想调整红色或绿色或蓝色值以创建一些自定义滤镜效果。 我需要检索 R 值、G 值和 B 值。每个值的范围为 0-255。 之后,我需要在指定索引处的 rgb 数组中恢复它。 所以我需要从rgb[i] 中检索每种颜色,然后再将其存储在rgb[i]

void decodeYUV420SP(int[] rgb, byte[] yuv420sp, int width, int height) {
final int frameSize = width * height;
for (int j = 0, yp = 0; j < height; j++) { 
 int uvp = frameSize + (j >> 1) * width, u = 0, v = 0;
 for (int i = 0; i < width; i++, yp++) {
   int y = (0xff & ((int) yuv420sp[yp])) - 16;
   if (y < 0)
   y = 0;
   if ((i & 1) == 0) {
   v = (0xff & yuv420sp[uvp++]) - 128;
   u = (0xff & yuv420sp[uvp++]) - 128;
    }
  int y1192 = 1192 * y;
  int r = (y1192 + 1634 * v);
  int g = (y1192 - 833 * v - 400 * u);
  int b = (y1192 + 2066 * u);
  if (r < 0)
    r = 0;
  else if (r > 262143)
    r = 262143;
  if (g < 0) 
    g = 0;
  else if (g > 262143)
    g = 262143;
  if (b < 0)
    b = 0;
  else if (b > 262143)
    b = 262143;
   rgb[yp] = 0xff000000 | ((r << 6) & 0xff0000) | ((g >> 2) & 0xff00) | ((b >> 10) & 0xff);
  }
}
  }
}

【问题讨论】:

    标签: android arrays camera rgb yuv


    【解决方案1】:

    颜色变换基本上是颜色向量乘以矩阵,android 提供支持。看:

    http://developer.android.com/reference/android/graphics/ColorMatrix.html

    它提供了几种方便的方法来创建所需的转换。 (见最后示例)

    How to change colors of a Drawable in Android?

    【讨论】:

      【解决方案2】:

      为方便起见,Color-class 包含许多用于获取和设置 32 位颜色整数的特定部分的方法,例如

      Color.red(color) 
      

      返回 int 颜色的红色部分。
      或者

      Color.argb(alpha, red, green, blue)
      

      从指定的值(范围 0-255)创建一个整数。
      不同方法的文档还指定了如何自己实现位移,如果这是你想做的。

      【讨论】:

      • hmm 但是在他们分配的方法中:r = 262143,所以我们这里的最大值是 262143 而不是 255?
      • 但是话又说回来,当它们将值存储在数组中时,它们只保留 8 位,即:每个 r、g、b 和 a 的最大值均为 255。但请看康斯坦丁回答。我不知道 ColorMatrix 有一个在 RGB 和 YUV 之间转换的内置方法。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-06-15
      • 2014-02-01
      • 2012-07-15
      • 2014-08-27
      • 2013-03-26
      • 2021-10-21
      相关资源
      最近更新 更多