2011-12-14 35 views
0

在我們的應用中,我們需要使用捕捉幀從相機@ 33 fps的,並通過它把它發送到服務器之前壓縮,創建一個從攝像頭預覽類/使用YUV圖像緩衝區

我的壓縮模塊可以採取YUV圖像來壓縮圖像,我的相機配置如下,

寬度= 500像素,
高度= 300像素,
圖像格式:YV12

在預覽回調

camera.setPreviewCallback(new PreviewCallback() { 

       public void onPreviewFrame(byte[] data, Camera arg1) { 

           } 
} 

數據大小出來是230400,但我想這將是大約

500 * 300(Y)+ 500 * 300/4(U)+ 500 * 300/4(V)即2250000

ie 5400字節多,這是否意味着,我可以忽略殘留的?

另外我需要創建YUVImage對象,但步幅信息不會來,所以我們如何從上面的數據創建YUVImage。

真誠謝謝你的閱讀,我真的很感謝任何人都可以幫助我解決這個問題。

回答

1

不能幫助數據大小的問題,但從相機預覽中獲得YUV你有2個選擇。如果運行Android 2.2或更高版本,則可以使用android.graphics.YuvImage類,並將它的構造函數從PreviewCallback傳遞給您的bytearray。

如果您需要支持預2.2,那麼你需要做的是這樣的:

/** 
* Decodes YUV frame to a buffer which can be use to create a bitmap. 
* use this for OS < FROYO which has a native YUV decoder 
* decode Y, U, and V values on the YUV 420 buffer described as YCbCr_422_SP by Android 
* @param rgb the outgoing array of RGB bytes 
* @param fg the incoming frame bytes 
* @param width of source frame 
* @param height of source frame 
* @throws NullPointerException 
* @throws IllegalArgumentException 
*/ 
private static void decodeYUV_impl(int[] rgb, byte[] fg, int width, int height) throws NullPointerException, IllegalArgumentException 
{ 
    int sz = width * height; 
    if (rgb == null) 
     throw new NullPointerException("buffer out is null"); 
    if (rgb.length < sz) 
     throw new IllegalArgumentException("buffer out size " + rgb.length 
       + " < minimum " + sz); 
    if (fg == null) 
     throw new NullPointerException("buffer 'fg' is null"); 

    if (fg.length < sz) 
     throw new IllegalArgumentException("buffer fg size " + fg.length 
       + " < minimum " + sz * 3/2); 

    int i, j; 
    int Y, Cr = 0, Cb = 0; 
    for (j = 0; j < height; j++) { 
     int pixPtr = j * width; 
     final int jDiv2 = j >> 1; 
    for (i = 0; i < width; i++) { 
     Y = fg[pixPtr]; 
     if (Y < 0) 
      Y += 255; 
     if ((i & 0x1) != 1) { 
      final int cOff = sz + jDiv2 * width + (i >> 1) * 2; 
      Cb = fg[cOff]; 
      if (Cb < 0) 
       Cb += 127; 
      else 
       Cb -= 128; 
      Cr = fg[cOff + 1]; 
      if (Cr < 0) 
       Cr += 127; 
      else 
       Cr -= 128; 
     } 
     int R = Y + Cr + (Cr >> 2) + (Cr >> 3) + (Cr >> 5); 
     if (R < 0) 
      R = 0; 
     else if (R > 255) 
      R = 255; 
     int G = Y - (Cb >> 2) + (Cb >> 4) + (Cb >> 5) - (Cr >> 1) 
       + (Cr >> 3) + (Cr >> 4) + (Cr >> 5); 
     if (G < 0) 
      G = 0; 
     else if (G > 255) 
      G = 255; 
     int B = Y + Cb + (Cb >> 1) + (Cb >> 2) + (Cb >> 6); 
     if (B < 0) 
      B = 0; 
     else if (B > 255) 
      B = 255; 
     rgb[pixPtr++] = (0xff000000 + (B << 16) + (G << 8) + R); 
    } 
    } 

} 
+0

謝謝,其實我只需要我的編碼器,libvpx給YUV數據,現在我有YUV數據,所以不要不想將其轉換爲RGB – Amitg2k12