gpt4 book ai didi

c++ - 使用 SWScale 的 FFMpeg RGB32 到 NV12

转载 作者:行者123 更新时间:2023-11-30 05:30:16 31 4
gpt4 key购买 nike

我正在尝试将 RGB32 帧转换为 NV12 帧以输入编码器。

m_iWidthIn = 1920;
m_iHeightIn = 1080;
m_iWidthOut = (((iWidthIn + 31) >> 5) << 5) //32bit align
m_heightOut = (((iHeightIn + 31) >> 5) << 5) //32bit align
m_outputPixelFormat = AV_PIX_FMT_NV12;

// allocate and fill buffers

m_sws = ::sws_getContext(m_iWidthIn, m_iHeightIn, AV_PIX_FMT_RGB32, m_iWidthOut, m_iHeightOut, m_outputPixelFormat, SWS_FAST_BILINEAR, nullptr, nullptr, nullptr);
AVFrame* frameOut = av_frame_alloc();
frameOut->height = m_iHeightOut;
frameOut->width = m_iWidthOut;
frameOut->format = m_outputPixelFormat;
av_frame_get_buffer(frameOut, 32);
int linesize[1] = { m_iWidthIn * 4 };
uint8_t * data[1] = { m_inputBuffer };
if (m_bFlip)
{
data[0] += linesize[0] * (m_iHeightIn - 1);
linesize[0] = -linesize[0];
}
::sws_scale(m_sws, data, linesize, 0, m_iHeightIn, frameOut->data, frameOut->linesize);
::av_image_copy_to_buffer(pOutputBuffer, lDataLen, frameOut->data, frameOut->linesize, m_outputPixelFormat, m_iWidthOut, m_iHeightOut, 32);

如果我制作 m_outputPixelFormat AV_PIX_FMT_RGB32 并使用 DMO 色彩空间转换器,视频会正确输出。但是,如果我将其更改为 NV12,我最终会得到一个底部缺少数据的倾斜视频。我知道这是由于我错误地将数据从缓冲区中复制出来造成的,但我不确定我做错了什么。

最佳答案

你的问题在这里:

m_heightOut = (((iHeightIn + 31) >> 5) << 5) //32bit align

您不需要对齐高度。所以 frameOut->datam_iHeightIn 高度。正确的行是:

m_heightOut = iHeightIn;

关于c++ - 使用 SWScale 的 FFMpeg RGB32 到 NV12,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36038675/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com