IMemAllocator::GetBuffer (Compact 2013)
3/26/2014
This method retrieves a container for a sample.
Syntax
HRESULT GetBuffer(
IMediaSample** ppBuffer,
REFERENCE_TIME* pStartTime,
REFERENCE_TIME* pEndTime,
DWORD dwFlags
);
Parameters
- ppBuffer
[out] Pointer to a retrieved media sample buffer.
pStartTime
[in] Either NULL or set to the beginning time of the sample to retrieve.Only the video renderer uses this.
pEndTime
[in] Either NULL or set to the ending time of the sample to retrieve.Only the video renderer uses this.
dwFlags
[in] GetBuffer supports the following flags.Flag
Description
AM_GBF_NOTASYNCPOINT
Dynamic format changes are not allowed on this buffer because it is not a key frame.
AM_GBF_PREVFRAMESKIPPED
Set to TRUE if this sample is the first after a discontinuity.
Only the video renderer uses this.
Return Value
Returns an HRESULT value that depends on the implementation.
HRESULT can be one of the following standard constants, or other values not listed.
Value |
Description |
---|---|
E_FAIL |
Failure. |
E_POINTER |
Null pointer argument. |
E_INVALIDARG |
Invalid argument. |
E_NOTIMPL |
Method is not supported. |
S_OK or NOERROR |
Success. |
Remarks
IMemAllocator::GetBuffer is a locking, synchronous method to get the next free buffer. Upon return, the properties are invalid, but the buffer pointer and size are correct.
This method succeeds only if memory has been committed.
GetBuffer returns with an error value if it is blocked waiting for a buffer, and the IMemAllocator::Decommit method is called on another thread.
If the pStartTime and pEndTime parameters are not NULL, they specify the intended start and end time for the sample in stream time (reference clock time minus the stream time offset).
The video renderer applies these parameters when using DirectDraw to schedule when to return a sample.
If pStartTime and pEndTime are NULL the video renderer will not use DirectDraw.
Requirements
Header |
dshow.h |
Library |
Strmiids.lib |