次の方法で共有


CMediaSample.GetMediaType メソッド

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

メディアの種類が前のサンプルと異なる場合、メソッドは GetMediaType メディアの種類を取得します。 このメソッドは、 IMediaSample::GetMediaType メソッドを 実装します。

構文

HRESULT GetMediaType(
   AM_MEDIA_TYPE **ppMediaType
);

パラメーター

ppMediaType

AM_MEDIA_TYPE構造体へのポインターを受け取る変数のアドレス。 メディアの種類が前のサンプルから変更されていない場合、 *ppMediaType は NULL に設定 されます

戻り値

次の表に示す HRESULT 値のいずれかを返します。

リターン コード 説明
S_FALSE
メディアの種類は、前のサンプルから変更されていません。
S_OK
成功しました。
E_OUTOFMEMORY
メモリ不足です。

解説

メディアの種類が完了したら、 DeleteMediaType ユーティリティ関数を呼び出してメモリ ブロックを解放します。

CMediaSample::m_pMediaType メンバー変数は、メディアの種類を指定します。 CMediaSample::m_dwFlags メンバー変数は、メディアの種類が変更されたかどうかを指定します。

要件

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

関連項目

CMediaSample クラス