次の方法で共有


CBaseOutputPin.GetDeliveryBuffer メソッド

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]

メソッドは GetDeliveryBuffer 、空のバッファーを含むメディア サンプルを取得します。

構文

virtual HRESULT GetDeliveryBuffer(
   IMediaSample   **ppSample,
   REFERENCE_TIME *pStartTime,
   REFERENCE_TIME *pEndTime,
   DWORD          dwFlags
);

パラメーター

ppSample

バッファーの IMediaSample インターフェイスへのポインターを受け取る変数のアドレス。

pStartTime

サンプルの開始時刻 ( NULL) へのポインター。

pEndTime

サンプルの終了時刻 ( NULL) へのポインター。

dwFlags

IMemAllocator::GetBuffer インターフェイスでサポートされるフラグのビットごとの組み合わせ。

戻り値

HRESULT 値を返します。 次の表に示す値を指定できます。

リターン コード 説明
S_OK
成功しました。
E_NOINTERFACE
アロケーターを使用できません。

解説

このメソッドは、アロケーターで IMemAllocator::GetBuffer メソッドを呼び出し、そのメソッドにパラメーターを渡します。

要件

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

関連項目

CBaseOutputPin クラス