CSource クラス
[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、および Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayer、IMFMediaEngine、Audio/Video Capture を使用することを強くお勧めします。 Microsoft は、従来の API を使用する既存のコードを、可能であれば新しい API を使用するように書き直すよう提案しています。]
CSource クラスは、ソース フィルターを実装するための基本クラスです。 CSource から派生したフィルターには、CSourceStream クラスから派生した 1 つ以上の出力ピンが含まれています。 各出力ピンは、メディア サンプルをダウンストリームにプッシュするワーカー スレッドを作成します。
注意
CSource クラスは、データ フローのプッシュ モデルをサポートするように設計されています。 このクラスは、ファイル リーダー フィルターを作成する場合には推奨されません。 ファイル リーダーは、 IAsyncReader インターフェイスを介してプル モデルをサポートする必要があります。 詳細については、「フィルター開発者向けのData Flow」を参照してください。
保護されたメンバー変数 | 説明 |
---|---|
m_iPins | フィルター上のピンの数。 |
m_paStreams | ピンの配列。 |
m_cStateLock | フィルター状態を保護するクリティカル セクション オブジェクト。 |
パブリック メソッド | 説明 |
CSource | コンストラクター メソッド。 |
~CSource | デストラクター メソッド。 |
GetPinCount | フィルター上のピンの数を取得します。 |
GetPin | ピンを取得します。 |
pStateLock | フィルターのクリティカル セクション オブジェクトへのポインターを取得します。 |
AddPin | フィルターに新しい出力ピンを追加します。 |
RemovePin | フィルターから指定したピンを削除します。 |
FindPinNumber | フィルター上の指定したピンの番号を取得します。 |
IBaseFilter メソッド | 説明 |
FindPin | 指定した識別子を持つピンを取得します。 |
解説
出力ピンを実装するには、次の操作を行います。
- CSourceStream からクラスを派生させます。
- CSourceStream::GetMediaType メソッドと、ピンのメディアの種類を検証する CSourceStream::CheckMediaType メソッドをオーバーライドします。
- ピンのバッファー要件を返 す CBaseOutputPin::D ecideBufferSize メソッドを実装します。
- メディア サンプル バッファーにデータを格納する CSourceStream::FillBuffer メソッドを実装します。
フィルターを実装するには、次の操作を行います。
- CSource からクラスを派生させます。
- コンストラクターで、 CSourceStream から派生した 1 つ以上の出力ピンを作成します。 ピンは、コンストラクター メソッドのフィルターに自動的に追加され、デストラクター メソッドで自身を削除します。
複数のスレッド間でフィルター状態を同期するには、 CSource::p StateLock メソッドを呼び出します。 このメソッドは、フィルター状態クリティカル セクションへのポインターを返します。 クリティカル セクションを保持するには、 CAutoLock クラスを使用します。 ピンから、次のように、ピンの CBasePin::m_pFilter メンバー変数から pStateLock にアクセスできます。
CAutoLock lock(m_pFilter->pStateLock());
要件
要件 | 値 |
---|---|
ヘッダー |
|
ライブラリ |
|