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

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

メソッドは GetCurrentPosition 、ストリームの合計継続時間を基準にして、現在位置を取得します。

構文

HRESULT GetCurrentPosition(
  [out] LONGLONG *pCurrent
);

パラメーター

[out] pCurrent

現在の位置を受け取る変数へのポインター (現在の時刻形式の単位)。

戻り値

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

リターン コード 説明
S_OK
正常終了しました。
E_NOTIMPL
メソッドはサポートされていません。
E_POINTER
NULL ポインター引数。

注釈

このメソッドは、再生に達した現在の位置を返します。 この値には、再生レートと開始時刻の調整が含まれます。 たとえば、開始時刻が 5 秒の場合、再生レートは 2.0 で、グラフを 4 秒間実行すると、現在の位置は 5 + (4 x 2.0) = 13.0 秒になります。

戻り値は、現在の時刻形式の単位で表されます。 現在の時刻形式を確認するには、 GetTimeFormat メソッドを呼び出します。

グラフが一時停止または停止している場合、現在の位置は再生が再開されるポイントです。

フィルター グラフ マネージャーは、現在のストリーム時間からの位置を計算します。グラフ内のフィルターのクエリは実行されません。 ファイルの再生では、再生がストリーム時間に同期されるため、正確な結果が得られます。 ファイルの書き込みでは、結果は正確ではありません。 ファイル書き込みグラフの現在位置を取得するには、マルチプレクサー フィルターに対してクエリを実行します。 (ただし、位置はライブ キャプチャには関係ありません)。

戻り値は、現在の時刻形式で表されます。 既定の時刻形式は REFERENCE_TIME 単位 (100 ナノ秒) です。 時刻の形式を変更するには、 IMediaSeeking::SetTimeFormat メソッドを 使用します。

要件

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

こちらもご覧ください

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

IMediaSeeking インターフェイス