0

这是FillBuffer功能:

HRESULT CVCamStream::FillBuffer(IMediaSample *pms)
{
    REFERENCE_TIME rtNow;
    REFERENCE_TIME avgFrameTime = ((VIDEOINFOHEADER*)m_mt.pbFormat)->AvgTimePerFrame;

    rtNow = m_rtLastTime;
    m_rtLastTime += avgFrameTime;
    pms->SetTime(&rtNow, &m_rtLastTime);
    pms->SetSyncPoint(TRUE);

    BYTE *pData;
    pms->GetPointer(&pData);
    long lDataLen = pms->GetSize();

    ProcessFrame(hdc, &pData);

    return NOERROR;
}

我在里面做什么ProcessFrame

void ProcessFrame(HDC hdc, BYTE **lpbitmap)
{
    BYTE *q = *lpbitmap;
    const int32_t height = 640;
    const int32_t width = 480;
    for (int y = 0; y < height; y++)
    {
        uint8_t* p = bgra_image_data;
        for (int x = 0; x < width; x++)
        {
            if (p[3] > 0) for (int i = 0; i < 3; i++) q[i] = p[i];

            p += 4;
            q += 3;
        }
    }
}

详细地说,我正在使用BRGA相同尺寸的图像字节。

好吧,使用 graphedt 它就像一个魅力!相反,选择此过滤器作为 Skype 源有时会呈现完全黑色,有时会弄乱一切 - 图像不可读。

在任何情况下,几秒钟后它都会由于写访问冲突而崩溃。您是否在我的代码中看到任何被 graphedt 可能忽略的错误证据?

4

0 回答 0