次の方法で共有


IMemAllocatorCallbackTemp::SetNotify メソッド (strmif.h)

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

メソッドは SetNotify 、アロケーターのコールバックを設定または削除します。 アロケーターは、アロケーターの IMemAllocator::ReleaseBuffer メソッドが呼び出されるたびにコールバック メソッドを呼び出します。

構文

HRESULT SetNotify(
  IMemAllocatorNotifyCallbackTemp *pNotify
);

パラメーター

pNotify

コールバックに使用される IMemAllocatorNotifyCallbackTemp インターフェイスへのポインター。 呼び出し元は インターフェイスを実装する必要があります。 値 NULL を使用して、コールバックを削除します。

戻り値

成功した場合はS_OK、それ以外の場合はエラー コードを返します。

注釈

アロケーターの ReleaseBuffer メソッドが呼び出されるたびに、アロケーターは pNotify で提供されるインターフェイスで NotifyRelease メソッドを呼び出します。 ReleaseBuffer メソッドは、メディア サンプルをアロケーターの空きリストに返します。 サンプルでは、参照カウントが 0 に達すると、このメソッドが呼び出されます。

アロケーターは、呼び出し元の IMemAllocatorNotifyCallbackTemp インターフェイスの参照カウントを保持します。 これにより循環参照カウントが作成され、グラフ内のオブジェクトが正しく解放されなくなります。 したがって、呼び出し元がコールバック通知を必要としなくなった場合は 、このメソッドを NULL 値で再度呼び出す必要があります。 適切なタイミングは、グラフが停止したとき、またはピンが切断されたときです。

要件

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

こちらもご覧ください

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

IMemAllocatorCallbackTemp インターフェイス