CBaseControlVideo.SetDefaultSourceRect 方法

[與此頁面 相關的功能 DirectShow是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議盡可能重寫使用舊版 API 的現有程式碼,以使用新的 API。]

方法 SetDefaultSourceRect 會設定純虛擬) (預設來源視訊矩形。 這在內部成員函式中,會在重設來源矩形時呼叫。

語法

virtual HRESULT SetDefaultSourceRect() = 0;

參數

這個方法沒有任何參數。

傳回值

傳回 HRESULT 值。

備註

衍生類別應該覆寫此專案以重設來源矩形。 它會從 CBaseControlVideo::SetDefaultSourcePosition呼叫。

下列範例示範衍生類別中此函式的實作。

// This is called when you reset the default source rectangle.
HRESULT CVideoText::SetDefaultSourceRect()
{
    VIDEOINFO *pVideoInfo = (VIDEOINFO *) m_pRenderer->m_mtIn.Format();
    BITMAPINFOHEADER *pHeader = HEADER(pVideoInfo);
    RECT SourceRect = {0,0,pHeader->biWidth,pHeader->biHeight};
    m_pRenderer->m_DrawImage.SetSourceRect(&SourceRect);
    return NOERROR;
}

在此範例中,CVideoText 是衍生自 CBaseControlVideo的類別,m_pRenderer保存衍生自 CBaseVideoRenderer之類別的物件,以及衍生類別中定義的m_DrawImage資料成員,保留 CDrawImage 物件。 m_mtIn資料成員也會在衍生類別中定義,保留具有輸入針腳之媒體類型的 CMediaType 物件。

規格需求

需求
標頭
Ctlutil.h (包含 Streams.h)
程式庫
Strmbase.lib (零售組建) ;
Strmbasd.lib (偵錯組建)

另請參閱

CBaseControlVideo 類別