次の方法で共有


IMediaSeeking::SetTimeFormat メソッド (strmif.h)

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

メソッドは SetTimeFormat 、後続のシーク操作の時刻形式を設定します。

構文

HRESULT SetTimeFormat(
  [in] const GUID *pFormat
);

パラメーター

[in] pFormat

時刻形式を指定する GUID へのポインター。 「時刻形式 GUID」を参照してください。

戻り値

HRESULT 値を返します。 使用可能な値は次のとおりです。

リターン コード 説明
S_OK
正常終了しました。
E_INVALIDARG
引数が無効です。
E_NOTIMPL
メソッドはサポートされていません。
E_POINTER
NULL ポインター引数。
VFW_E_WRONG_STATE
フィルター グラフが停止していません。

注釈

このメソッドは、IMediaSeeking::GetPositions や IMediaSeeking::SetPositions など、他の IMediaSeeking メソッドで使用される時間単位を指定します。 これらの他のメソッドのいずれかを呼び出すたびに、時刻値を表すパラメーターは、現在の時刻形式の単位で指定されます。

既定の時刻形式は REFERENCE_TIME 単位 (100 ナノ秒) です。 その他の時間形式には、フレーム、サンプル、バイトが含まれます。 特定の形式がサポートされているかどうかを確認するには、 IMediaSeeking::IsFormatSupported メソッドを 呼び出します。 形式がサポートされている場合は、 を呼び出 SetTimeFormatして、その形式に切り替えることができます。 一度にアクティブな時刻形式は 1 つだけです。

要件

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

こちらもご覧ください

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

IMediaSeeking インターフェイス

IMediaSeeking::GetTimeFormat

IMediaSeeking::QueryPreferredFormat