我想使用 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,
×tamp, // [out] LONGLONG *pllTimestamp,
&pSample); // [out] IMFSample **ppSample
最后一个参数 pSample 就是我想要的。
现在,我希望获得指向当前已解码样本数据的双重,浮点或字节指针。
如何做到这一点?
提前致谢。
答案 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,但您肯定想要这样做。