次の方法で共有


IMemAllocator::SetProperties メソッド (strmif.h)

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

メソッドは SetProperties 、割り当てるバッファーの数と各バッファーのサイズを指定します。

構文

HRESULT SetProperties(
  ALLOCATOR_PROPERTIES *pRequest,
  ALLOCATOR_PROPERTIES *pActual
);

パラメーター

pRequest

バッファー要件を含む ALLOCATOR_PROPERTIES 構造体へのポインター。

pActual

実際のバッファー プロパティを受け取る ALLOCATOR_PROPERTIES 構造体へのポインター。

戻り値

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

リターン コード 説明
S_OK
成功しました。
E_POINTER
NULL ポインター引数。
VFW_E_ALREADY_COMMITTED
フィルターがアクティブな間は、割り当てられたメモリを変更できません。
VFW_E_BADALIGN
無効な配置が指定されました。
VFW_E_BUFFERS_OUTSTANDING
1 つ以上のバッファーがまだアクティブです。

解説

このメソッドはバッファー要件を指定しますが、バッファーは割り当てません。 バッファーを割り当てるには、 IMemAllocator::Commit メソッドを呼び出します。

呼び出し元は、2 つのALLOCATOR_PROPERTIES構造体を割り当てます。 pRequest パラメーターには、バッファーの数や各バッファーのサイズなど、呼び出し元のバッファー要件が含まれます。 メソッドが返されると、 pActual パラメーターには、アロケーターによって設定された実際のバッファー プロパティが含まれます。

このメソッドが呼び出されると、アロケーターをコミットしたり、未処理のバッファーを持ったりすることはできません。

要件

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

関連項目

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

IMemAllocator インターフェイス