Windows Media Foundation:获取AAC解码数据

时间:2016-07-07 13:20:05

标签: c++ audio aac ms-media-foundation data-extraction

我想使用 Windows Media Foundation 来获取AAC编码文件的音频数据。我发现正确的方法是声明一个IMFSample *,其中将保留音频的单个样本。在VS2015中,我看到这个类有一个方法getDouble(),但MSDN documentation中没有任何关于它的内容。

以下是我尝试的示例部分:

    IMFSample *pSample(NULL);

    hr = m_pReader->ReadSample(
        MF_SOURCE_READER_FIRST_AUDIO_STREAM, // [in] DWORD dwStreamIndex,
        0,                                   // [in] DWORD dwControlFlags,
        NULL,                                // [out] DWORD *pdwActualStreamIndex,
        &dwFlags,                            // [out] DWORD *pdwStreamFlags,
        &timestamp,                          // [out] LONGLONG *pllTimestamp,
        &pSample);                           // [out] IMFSample **ppSample

最后一个参数 pSample 就是我想要的。

现在,我希望获得指向当前已解码样本数据的双重,浮点或字节指针。

如何做到这一点?

提前致谢。

1 个答案:

答案 0 :(得分:2)

首先将样本转换为缓冲区:

Microsoft::WRL::ComPtr<IMFMediaBuffer> mediaBuffer;
sample->ConvertToContiguousBuffer(&mediaBuffer)

然后锁定缓冲区以获取指向其内部的指针:

BYTE *audioData = nullptr;
DWORD sampleBufferLength = 0;
mediaBuffer->Lock(&audioData, nullptr, &sampleBufferLength);
// use audioData...
mediaBuffer->Unlock();

要指定返回数据的格式,请在阅读器上使用SetCurrentMediaType(在开头执行此操作)

    Microsoft::WRL::ComPtr<IMFMediaType> pPartialType;
    MFCreateMediaType(&pPartialType);
    pPartialType->SetGUID(MF_MT_MAJOR_TYPE, MFMediaType_Audio);
    pPartialType->SetGUID(MF_MT_SUBTYPE, MFAudioFormat_Float);
    reader->SetCurrentMediaType(
        (DWORD)MF_SOURCE_READER_FIRST_AUDIO_STREAM,
        NULL, pPartialType.Get());

请使用MF处理智能指针,否则您将进入一个痛苦的世界。 Microsoft::WRL::ComPtr<XXX>是你的朋友!我错过了检查此示例代码中的HRESULT,但您肯定想要这样做。