CBaseRenderer.GetSampleTimes メソッド
[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayer、IMFMediaEngine、Audio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]
メソッドは GetSampleTimes
、サンプルからタイム スタンプを取得します。
構文
virtual HRESULT GetSampleTimes(
IMediaSample *pMediaSample,
REFERENCE_TIME *pStartTime,
REFERENCE_TIME *pEndTime
);
パラメーター
-
pMediaSample
-
サンプルの IMediaSample インターフェイスへのポインター。
-
pStartTime
-
開始時刻を受け取る変数へのポインター。
-
pEndTime
-
終了時刻を受け取る変数へのポインター。
戻り値
HRESULT 値を返します。 次の表に示す値を指定できます。
リターン コード | 説明 |
---|---|
|
サンプルは直ちにレンダリングする必要があります。 |
|
サンプルは、タイム スタンプに基づいてレンダリング用にスケジュールする必要があります。 |
|
このサンプルはレンダリングしないでください。 |
|
不適切なタイム スタンプ: 終了時刻が開始時刻より前です。 |
解説
フィルターは、このメソッドを呼び出して、サンプルの処理方法を決定します。 戻り値がS_OK場合、フィルターはサンプルを直ちにレンダリングします。 戻り値がS_FALSE場合、フィルターはタイム スタンプに基づいてサンプルのレンダリングをスケジュールします。 戻り値がエラー コードの場合、フィルターはサンプルを拒否します。
このメソッドは、サンプルにタイム スタンプがない場合、またはフィルターに参照クロックがない場合にS_OKを返します。 それ以外の場合は、 CBaseRenderer::ShouldDrawSampleNow メソッドの値を返します。 基底クラスでは、 ShouldDrawSampleNow は 常にS_FALSEを返します。 派生クラスは、この動作をオーバーライドできます。 たとえば、派生クラスが品質管理管理を実装している場合、サンプルを削除するためにE_FAILを返す場合があります。
要件
要件 | 値 |
---|---|
ヘッダー |
|
ライブラリ |
|