IAsyncReader::WaitForNext method (strmif.h)
[The feature associated with this page, DirectShow, is a legacy feature. It has been superseded by MediaPlayer, IMFMediaEngine, and Audio/Video Capture in Media Foundation. Those features have been optimized for Windows 10 and Windows 11. Microsoft strongly recommends that new code use MediaPlayer, IMFMediaEngine and Audio/Video Capture in Media Foundation instead of DirectShow, when possible. Microsoft suggests that existing code that uses the legacy APIs be rewritten to use the new APIs if possible.]
The WaitForNext
method waits for the next pending read request to complete.
Syntax
HRESULT WaitForNext(
[in] DWORD dwTimeout,
[out] IMediaSample **ppSample,
[out] DWORD_PTR *pdwUser
);
Parameters
[in] dwTimeout
Specifies a time-out in milliseconds. Use the value INFINITE to wait indefinitely
[out] ppSample
Address of a variable that receives an IMediaSample interface pointer.
[out] pdwUser
Pointer to a variable that receives the value of the dwUser parameter specified in the IAsyncReader::Request method.
Return value
Returns an HRESULT value. Possible values include the following.
Return code | Description |
---|---|
|
The time-out expired, or the pin is flushing. |
|
The pin is flushing. |
|
A read error occurred. |
|
Success. |
|
Reached the end of the file; retrieved fewer bytes than requested. |
Remarks
If the method succeeds, the ppSample parameter contains a pointer to a media sample, whose buffer holds the requested data. Call the IMediaSample::GetTime method and divide the results by 10,000,000 to determine the start and stop bytes. Samples may be returned out of order. Release the sample when you are finished processing the data.
The method fails if the pin is flushing. However, it may return an empty sample in ppSample. If *ppSample is non-NULL, release the sample and discard it. For more information, see IAsyncReader::BeginFlush.
If a read error occurs, the source filter sends an error event to the Filter Graph Manager; the caller does not have to signal an error.
Requirements
Requirement | Value |
---|---|
Minimum supported client | Windows 2000 Professional [desktop apps only] |
Minimum supported server | Windows 2000 Server [desktop apps only] |
Target Platform | Windows |
Header | strmif.h (include Dshow.h) |
Library | Strmiids.lib |