次の方法で共有


IMemInputPin::Receive メソッド (strmif.h)

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

メソッドは Receive 、ストリーム内の次のメディア サンプルを受け取ります。

構文

HRESULT Receive(
  [in] IMediaSample *pSample
);

パラメーター

[in] pSample

サンプルの IMediaSample インターフェイスへのポインター。

戻り値

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

リターン コード 説明
S_OK
成功しました。
S_FALSE
サンプルは拒否されました。
E_POINTER
NULL ポインター引数。
VFW_E_INVALIDMEDIATYPE
メディアの種類が無効です。
VFW_E_RUNTIME_ERROR
実行時エラーが発生しました。
VFW_E_WRONG_STATE
ピンが停止しています。

注釈

このメソッドは同期的であり、ブロックしている可能性があります。 ピンは、次のいずれかの処理を行います。

  • サンプルを拒否します。
  • すぐにを返し、ワーカー スレッドでサンプルを処理します。
  • 戻る前にサンプルを処理します。
最後のケースでは、 メソッドが無期限にブロックされる可能性があります。 この場合、 IMemInputPin::ReceiveCanBlock メソッドはS_OKを返します。

ピンは、ワーカー スレッドを使用してサンプルを処理する場合、サンプルの参照カウントを保持します。 いずれの場合も、出力ピンでこのサンプルを直接再利用することはできません。 新しいサンプルを取得するには、 IMemAllocator::GetBuffer メソッドを呼び出す必要があります。

このメソッドがS_FALSEまたはエラー コードを返す場合、グラフが停止するかフラッシュ操作が完了するまで、アップストリーム フィルターはサンプルの送信を停止する必要があります。 S_FALSE戻り値の一般的な理由は次のとおりです。

  • ダウンストリーム ピンはフラッシュ中です。つまり、 BeginFlush 呼び出しを受信し、 EndFlush 呼び出しをまだ受信していません。
  • ダウンストリーム フィルターによってストリームの末尾が検出されました。 (「Streamの終了通知」を参照してください)。

要件

要件
サポートされている最小のクライアント Windows 2000 Professional [デスクトップ アプリのみ]
サポートされている最小のサーバー Windows 2000 Server [デスクトップ アプリのみ]
対象プラットフォーム Windows
ヘッダー strmif.h (Dshow.h を含む)
Library Strmiids.lib

こちらもご覧ください

エラーコードと成功コード

IMemInputPin インターフェイス