Método CBaseRenderer.SourceThreadCanWait

El SourceThreadCanWait método contiene o libera el subproceso de streaming.

Sintaxis

virtual HRESULT SourceThreadCanWait(
   BOOL bCanWait
);

Parámetros

bCanWait

Valor booleano que indica si se debe contener el subproceso de streaming. Si es TRUE, el subproceso de streaming se bloquea mientras el filtro espera a representar los ejemplos siguientes. Si es FALSE, se libera el subproceso de streaming.

Valor devuelto

Devuelve S_OK.

Observaciones

Llamar al SourceThreadCanWait método con el valor FALSE obliga al filtro a devolver desde una llamada IMemInputPin::Receive bloqueada. Cuando se ejecuta el filtro, bloquea las llamadas Receive hasta el tiempo de presentación del ejemplo actual. Cuando el filtro está en pausa, bloquea las llamadas Receive indefinidamente. Este comportamiento regula el flujo de datos de la secuencia. Sin embargo, cuando el filtro se detiene o vacía, no debe bloquearse.

El bloqueo se controla mediante el método CBaseRenderer::WaitForRenderTime , que espera en dos eventos: CBaseRenderer::m_RenderEvent y CBaseRenderer::m_ThreadSignal. El evento m_RenderEvent se señala cuando llega el tiempo de presentación. El evento m_ThreadSignal se señala cuando SourceThreadCanWait se llama a con el valor FALSE. La llamada SourceThreadCanWait con el valor TRUE restablece el evento.

Los métodos CBaseRenderer::Stop y CBaseRenderer::BeginFlush llaman SourceThreadCanWait con el valor FALSE (liberando el subproceso de streaming). Los métodos CBaseRenderer::P ause, CBaseRenderer::Run y CBaseRenderer::EndFlush llaman SourceThreadCanWait con el valor TRUE.

Requisitos

Requisito Value
Encabezado
Renbase.h (include Secuencias.h)
Biblioteca
Strmbase.lib (compilaciones comerciales);
Strmbasd.lib (compilaciones de depuración)

Consulte también

CBaseRenderer (clase)