YUV图像转换java

// YV12 To NV21

private void YV12toNV21(final byte[] input, final byte[] output, final int width, final int height) {

long startMs = System.currentTimeMillis();

final int frameSize = width * height;

final int qFrameSize = frameSize / 4;

final int tempFrameSize = frameSize * 5 / 4;

System.arraycopy(input, 0, output, 0, frameSize); // Y

for (int i = 0; i < qFrameSize; i++) {

output[frameSize + i * 2] = input[frameSize + i]; // Cb (U)

output[frameSize + i * 2 + 1] = input[tempFrameSize + i]; // Cr (V)

}

}

//I420 To NV21

private void I420ToNV21(final byte[] input, final byte[] output, final int width, final int height) {

//long startMs = System.currentTimeMillis();

final int frameSize = width * height;

final int qFrameSize = frameSize / 4;

final int tempFrameSize = frameSize * 5 / 4;

System.arraycopy(input, 0, output, 0, frameSize); // Y

for (int i = 0; i < qFrameSize; i++) {

output[frameSize + i * 2] = input[tempFrameSize + i]; // Cb (U)

output[frameSize + i * 2 + 1] = input[frameSize + i]; // Cr (V)

}

}

//YV12Resize

private void YV12Resize(byte[] pSrc,Point szSrc,byte[] pDst,Point szDst){int srcPitchY=szSrc.x,srcPitchUV=szSrc.x/2,dstPitchY=szDst.x,dstPitchUV=szDst.x/2;int rateX=(szSrc.x<<16)/szDst.x;int rateY=(szSrc.y<<16)/szDst.y;for (int i=0;i>16;for (int j=0;j>16;pDst[dstPitchY * i + j] = pSrc[srcY*srcPitchY + srcX];//*(pSrcYLine+srcX);}}for (int i=0;i>16;for (int j=0;j>16;

pDst[dstPitchY*szDst.y+i*dstPitchUV + j] = pSrc[srcPitchY*szSrc.y+srcY*srcPitchUV + srcX];//*(pSrcVLine+srcX);

pDst[dstPitchY*szDst.y+i*dstPitchUV + dstPitchUV*szDst.y/2 + j]= pSrc[srcPitchY*szSrc.y+srcY*srcPitchUV + srcPitchUV*szSrc.y/2 + srcX];

}

}

}


// eg.

private void test(){

byte[] resizeYV12 = new byte[destWidth * destHeight * 3 / 2];

Point pointSrc = new Point(mSize.width, mSize.height);

try {

YV12Resize(mData, pointSrc, resizeYV12, new Point(destWidth, destHeight));

} catch (Exception e) {

// TODO: handle exception

return null;

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,357评论 0 33
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile丽语阅读 9,367评论 0 6
  • Java经典问题算法大全 /*【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子...
    赵宇_阿特奇阅读 6,006评论 0 2
  • 水兵恋歌 蓝三色的港湾像开放的花朵, 年轻的水兵躺在花的漩涡, 战舰航行在蓝色的碧波, 大海上留下你的传说。 大海...
    冬青哥哥阅读 1,472评论 0 1
  • 思维减少依赖,工作增加独立性,成果整体性
    捻心阅读 1,675评论 0 0

友情链接更多精彩内容