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;
}
相关推荐
Wect13 分钟前
LeetCode 39. 组合总和:DFS回溯解法详解
前端·算法·typescript
Wect16 分钟前
LeetCode 46. 全排列:深度解析+代码拆解
前端·算法·typescript
颜酱18 分钟前
Dijkstra 算法:从 BFS 到带权最短路径
javascript·后端·算法
木心月转码ing3 小时前
Hot100-Day24-T128最长连续序列
算法
小肥柴3 小时前
A2UI:面向 Agent 的声明式 UI 协议(三):相关概念和技术架构
算法
学高数就犯困6 小时前
性能优化:LRU缓存(清晰易懂带图解)
算法
CoovallyAIHub8 小时前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub9 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub9 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
颜酱21 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法