android nv21 转 yuv420sp

上面两个函数的目标都是将NV21格式的数据转换为YUV420P格式,但是它们在处理U和V分量的方式上有所不同。

在第一个函数NV21toYUV420P_1中,U和V分量的处理方式是这样的:对于U分量,它从NV21数据的Y分量之后的每个奇数位置取数据;对于V分量,它从NV21数据的Y分量之后的每个偶数位置取数据。

而在第二个函数NV21toYUV420P中,U和V分量的处理方式是这样的:对于U分量,它从NV21数据的Y分量之后的每个偶数位置取数据;对于V分量,它从NV21数据的Y分量之后的每个奇数位置取数据。

因此,这两个函数并不完全相同。如果你的NV21数据是标准的,即V和U分量是交错存储的(首先是V,然后是U),那么你应该使用第二个函数NV21toYUV420P

java 复制代码
private byte[] NV21toYUV420P_1(byte[] nv21, int width, int height) {
byte[] yuv420p = new byte[widthheight3/2];
int i, j;
int ySize = width * height;

    // 拷贝Y分量
    System.arraycopy(nv21, 0, yuv420p, 0, ySize);

    // 处理并拷贝U分量
    for (i = 0; i < ySize/4; i++) {
        yuv420p[ySize + i] = nv21[ySize + 2 * i + 1];
    }

    // 处理并拷贝V分量
    for (j = 0; j < ySize/4; j++) {
        yuv420p[ySize + i + j] = nv21[ySize + 2 * j];
    }

    return yuv420p;
}

public static byte[] NV21toYUV420P(byte[] nv21, int width, int height) {
    byte[] yuv420p = new byte[width*height*3/2];
    int i, j;
    int ySize = width * height;

    // Copy Y
    System.arraycopy(nv21, 0, yuv420p, 0, ySize);

    // Copy U and V
    for (i = 0; i < ySize/2; i += 2) {
        yuv420p[ySize + i/2] = nv21[ySize + i]; // U
        yuv420p[ySize + ySize/4 + i/2] = nv21[ySize + i + 1]; // V
    }

    return yuv420p;
}
相关推荐
wuweijianlove7 分钟前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong15 分钟前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志15 分钟前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光1 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_111 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg1 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒1 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾2 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
SatVision炼金士2 小时前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法