CBaseControlVideo.GetStaticImage メソッド

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

派生クラスがオーバーライドする純粋仮想メソッド。

構文

virtual HRESULT GetStaticImage(
   long *pBufferSize,
   long *pDIBImage
) = 0;

パラメーター

pBufferSize

出力バッファーのサイズへのポインター。

pDIBImage

出力バッファーへのポインター。

戻り値

HRESULT 値を返します。

解説

アプリケーションは 、IBasicVideo インターフェイスを使用して、メモリ バッファー内の現在のイメージのコピーを渡すように要求できます (一部のレンダラーでは、サポートされていない場合はE_NOTIMPLに戻すことができます)。 派生クラスは、イメージを取得する方法を決定します。 アプリケーションが CBaseControlVideo::GetStaticImage を呼び出すと、派生クラスがオーバーライドして実装する必要があるこの純粋な仮想メソッドが呼び出されます。 これは、 CBaseControlVideo::GetCurrentImage メンバー関数によっても呼び出されます。

クラスは、イメージを含むサンプルを指定できるヘルパー メンバー関数 CBaseControlVideo::CopyImage を提供します。メンバー関数は、(現在のソースの四角形に基づいて) 関連するセクションをアプリケーションによって提供される出力バッファーにコピーします。

次の例は、派生クラスでのこのメンバー関数の実装を示しています。 この例では、m_pRenderer は CBaseVideoRenderer から派生したクラスのオブジェクトを保持します。

// Return a copy of the current image in the video renderer
HRESULT CVideoText::GetStaticImage(long *pBufferSize,long *pDIBImage)
{
    // Get any sample the renderer may be holding.

    IMediaSample *pMediaSample = m_pRenderer->GetCurrentSample();
    if (pMediaSample == NULL) {
        return E_UNEXPECTED;
    }

    // Call the base class helper method to do the work.

    HRESULT hr = CopyImage(pMediaSample,       // Buffer containing image
                      &m_pRenderer->m_mtIn,    // Type representing bitmap
                      pBufferSize,             // Size of buffer for DIB
                     (BYTE*) pDIBImage);       // Data buffer for output

    pMediaSample->Release();
    return hr;
}

要件

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

関連項目

CBaseControlVideo クラス