次の方法で共有


CBaseRenderer.GetSampleTimes メソッド

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/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
サンプルは、タイム スタンプに基づいてレンダリング用にスケジュールする必要があります。
E_FAIL
このサンプルはレンダリングしないでください。
VFW_E_START_TIME_AFTER_END
不適切なタイム スタンプ: 終了時刻が開始時刻より前です。

解説

フィルターは、このメソッドを呼び出して、サンプルの処理方法を決定します。 戻り値がS_OK場合、フィルターはサンプルを直ちにレンダリングします。 戻り値がS_FALSE場合、フィルターはタイム スタンプに基づいてサンプルのレンダリングをスケジュールします。 戻り値がエラー コードの場合、フィルターはサンプルを拒否します。

このメソッドは、サンプルにタイム スタンプがない場合、またはフィルターに参照クロックがない場合にS_OKを返します。 それ以外の場合は、 CBaseRenderer::ShouldDrawSampleNow メソッドの値を返します。 基底クラスでは、 ShouldDrawSampleNow は 常にS_FALSEを返します。 派生クラスは、この動作をオーバーライドできます。 たとえば、派生クラスが品質管理管理を実装している場合、サンプルを削除するためにE_FAILを返す場合があります。

要件

要件
ヘッダー
Renbase.h (Streams.h を含む)
ライブラリ
Strmbase.lib (製品版ビルド);
Strmbasd.lib (デバッグ ビルド)

関連項目

CBaseRenderer クラス