CSource クラス

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

csource クラス階層

CSource クラスは、ソース フィルターを実装するための基本クラスです。 CSource から派生したフィルターには、CSourceStream クラスから派生した 1 つ以上の出力ピンが含まれています。 各出力ピンは、メディア サンプルをダウンストリームにプッシュするワーカー スレッドを作成します。

注意

CSource クラスは、データ フローのプッシュ モデルをサポートするように設計されています。 このクラスは、ファイル リーダー フィルターを作成する場合には推奨されません。 ファイル リーダーは、 IAsyncReader インターフェイスを介してプル モデルをサポートする必要があります。 詳細については、「フィルター開発者向けのData Flow」を参照してください。

保護されたメンバー変数 説明
m_iPins フィルター上のピンの数。
m_paStreams ピンの配列。
m_cStateLock フィルター状態を保護するクリティカル セクション オブジェクト。
パブリック メソッド 説明
CSource コンストラクター メソッド。
~CSource デストラクター メソッド。
GetPinCount フィルター上のピンの数を取得します。
GetPin ピンを取得します。
pStateLock フィルターのクリティカル セクション オブジェクトへのポインターを取得します。
AddPin フィルターに新しい出力ピンを追加します。
RemovePin フィルターから指定したピンを削除します。
FindPinNumber フィルター上の指定したピンの番号を取得します。
IBaseFilter メソッド 説明
FindPin 指定した識別子を持つピンを取得します。

解説

出力ピンを実装するには、次の操作を行います。

フィルターを実装するには、次の操作を行います。

  • CSource からクラスを派生させます。
  • コンストラクターで、 CSourceStream から派生した 1 つ以上の出力ピンを作成します。 ピンは、コンストラクター メソッドのフィルターに自動的に追加され、デストラクター メソッドで自身を削除します。

複数のスレッド間でフィルター状態を同期するには、 CSource::p StateLock メソッドを呼び出します。 このメソッドは、フィルター状態クリティカル セクションへのポインターを返します。 クリティカル セクションを保持するには、 CAutoLock クラスを使用します。 ピンから、次のように、ピンの CBasePin::m_pFilter メンバー変数から pStateLock にアクセスできます。

CAutoLock lock(m_pFilter->pStateLock());

要件

要件
ヘッダー
Source.h (include Streams.h)
ライブラリ
Strmbase.lib (小売ビルド);
Strmbasd.lib (デバッグ ビルド)

関連項目

ソース フィルターの作成