Zamieszanie przy konwersji YUV NV21 na RGB

Wedłughttp://developer.android.com/reference/android/graphics/ImageFormat.html#NV21, NV21 jest domyślnym formatem używanym.

W internecie jest sporo kodu dotyczącego konwersji YUV NV21 na RGB. Jednakże, kiedy przechodzę przez kod, wątpię w poprawność kodu.

Pierwszy komponent V powinien być pierwszy, a za nim pierwszy komponent U

Wedłughttp://wiki.videolan.org/YUV#NV21, NV21 is like NV12, but with U and V order reversed: it starts with V. Jednak kiedy przeszedłem implementację kodu

http://pastebin.com/T0my7zSc - Zakłada, że ​​U jest pierwszyhttps://stackoverflow.com/a/8394202/72437 - Zakłada się, że pierwsze miejsce zajmuje również Uhttps://stackoverflow.com/a/10125048/72437 - Zakłada, że ​​U również jest na pierwszym miejscu

R powinna być najbardziej znaczącą pozycją Zgodnie z realizacjąint argb wColor.java, R ma być na najbardziej znaczącej pozycji. Jednak przeszedłem następującą implementację kodu

http://pastebin.com/T0my7zSc - Zakłada, że ​​R jest w najmniej znaczącej pozycjihttps://stackoverflow.com/a/8394202/72437 - Zakłada, że ​​R jest w najmniej znaczącej pozycji

Zastanawiałem się, czy popełniają częsty błąd, czy coś przeoczyłem?

Obecnie moja realizacja jest następująca.

public static void YUV_NV21_TO_RGB(int[] argb, byte[] yuv, int width, int height) {
    final int frameSize = width * height;

    final int ii = 0;
    final int ij = 0;
    final int di = +1;
    final int dj = +1;

    int a = 0;
    for (int i = 0, ci = ii; i < height; ++i, ci += di) {
        for (int j = 0, cj = ij; j < width; ++j, cj += dj) {
            int y = (0xff & ((int) yuv[ci * width + cj]));
            int v = (0xff & ((int) yuv[frameSize + (ci >> 1) * width + (cj & ~1) + 0]));
            int u = (0xff & ((int) yuv[frameSize + (ci >> 1) * width + (cj & ~1) + 1]));
            y = y < 16 ? 16 : y;

            int r = (int) (1.164f * (y - 16) + 1.596f * (v - 128));
            int g = (int) (1.164f * (y - 16) - 0.813f * (v - 128) - 0.391f * (u - 128));
            int b = (int) (1.164f * (y - 16) + 2.018f * (u - 128));

            r = r < 0 ? 0 : (r > 255 ? 255 : r);
            g = g < 0 ? 0 : (g > 255 ? 255 : g);
            b = b < 0 ? 0 : (b > 255 ? 255 : b);

            argb[a++] = 0xff000000 | (r << 16) | (g << 8) | b;
        }
    }
}