如何将 Y、U、V 缓冲区转换为一维数组
how to covert Y,U,V buffer to one-dimensional array
我正在尝试将 hls 文件转换为 jpeg。首先,我使用了 openh264 to convert HLS file to YUV. I got a two dimensional array containing Y, U, V buffer (*pData[3]). After that, I try to combine the three arrays into one to pass it to CompressYUYV2JPEG。
这是我的转换方式:
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[0][i]);
}
l = bufferInfo.UsrData.sSystemBuffer.iWidth*bufferInfo.UsrData.sSystemBuffer.iHeight/4;
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[1][i]);
}
l = bufferInfo.UsrData.sSystemBuffer.iWidth*bufferInfo.UsrData.sSystemBuffer.iHeight/4;
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[2][i]);
}
但不幸的是,它没有产生预期的结果。将二维YUV数组转换为一维数组的正确方法是什么?
你需要YUV422。这意味着YUYV。对于每个输入数据,inbuf
必须能被 4 整除。您可以使用
for(i = 0; i < l/2; i++) {
inbuf.push_back(yuvData[0][2*i]);
inbuf.push_back((yuvData[1][2*i] + yuvData[1][2*i + 1])/2);
inbuf.push_back(yuvData[0][2*i + 1]);
inbuf.push_back((yuvData[2][2*i] + yuvData[2][2*i + 1])/2);
}
在此代码片段中,使用了所有 Y 值,但仅使用了两个 Cr 的平均值。使用 Cb 值。当然每个 yuvData 通道中的元素数量必须是偶数。否则你必须找到最后一个元素的解决方案。
刚才看到你用的是YUV420。然后你可以使用这个片段
for(i = 0; i < l/2; i++) {
inbuf.push_back(yuvData[0][2*i]);
inbuf.push_back(yuvData[1][i/2]);
inbuf.push_back(yuvData[0][2*i + 1]);
inbuf.push_back(yuvData[2][i/2]);
}
在此代码中,所有 Y 值都使用一次,所有 Cr 值都使用一次。 Cb值被使用了两次。
我正在尝试将 hls 文件转换为 jpeg。首先,我使用了 openh264 to convert HLS file to YUV. I got a two dimensional array containing Y, U, V buffer (*pData[3]). After that, I try to combine the three arrays into one to pass it to CompressYUYV2JPEG。 这是我的转换方式:
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[0][i]);
}
l = bufferInfo.UsrData.sSystemBuffer.iWidth*bufferInfo.UsrData.sSystemBuffer.iHeight/4;
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[1][i]);
}
l = bufferInfo.UsrData.sSystemBuffer.iWidth*bufferInfo.UsrData.sSystemBuffer.iHeight/4;
for(i = 0; i < l; i++) {
inbuf.push_back(yuvData[2][i]);
}
但不幸的是,它没有产生预期的结果。将二维YUV数组转换为一维数组的正确方法是什么?
你需要YUV422。这意味着YUYV。对于每个输入数据,inbuf
必须能被 4 整除。您可以使用
for(i = 0; i < l/2; i++) {
inbuf.push_back(yuvData[0][2*i]);
inbuf.push_back((yuvData[1][2*i] + yuvData[1][2*i + 1])/2);
inbuf.push_back(yuvData[0][2*i + 1]);
inbuf.push_back((yuvData[2][2*i] + yuvData[2][2*i + 1])/2);
}
在此代码片段中,使用了所有 Y 值,但仅使用了两个 Cr 的平均值。使用 Cb 值。当然每个 yuvData 通道中的元素数量必须是偶数。否则你必须找到最后一个元素的解决方案。
刚才看到你用的是YUV420。然后你可以使用这个片段
for(i = 0; i < l/2; i++) {
inbuf.push_back(yuvData[0][2*i]);
inbuf.push_back(yuvData[1][i/2]);
inbuf.push_back(yuvData[0][2*i + 1]);
inbuf.push_back(yuvData[2][i/2]);
}
在此代码中,所有 Y 值都使用一次,所有 Cr 值都使用一次。 Cb值被使用了两次。