共用方式為


步驟 1: 定義設定屬性的機制

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

篩選準則必須支援屬性頁與其通訊的方式,讓屬性頁可以在篩選上設定和擷取屬性。 可能的機制包括:

  • 公開自訂 COM 介面。
  • 透過 IDispatch支援自動化屬性。
  • 公開 IPropertyBag 介面,並定義一組具名屬性。

此範例使用名為 ISaturation 的自訂 COM 介面。 這不是實際的 DirectShow 介面;它只會在此範例中定義。 首先,在標頭檔中宣告 介面,以及介面識別碼 (IID) :

// Always create new GUIDs! Never copy a GUID from an example.
DEFINE_GUID(IID_ISaturation, 0x19412d6e, 0x6401, 
0x475c, 0xb0, 0x48, 0x7a, 0xd2, 0x96, 0xe1, 0x6a, 0x19);

interface ISaturation : public IUnknown
{
    STDMETHOD(GetSaturation)(long *plSat) = 0;
    STDMETHOD(SetSaturation)(long lSat) = 0;
};

您也可以使用 IDL 定義介面,並使用 MIDL 編譯器來建立標頭檔。 接下來,在篩選中實作自訂介面。 此範例會針對篩選準則的飽和值使用 「Get」 和 「Set」 方法。 請注意,這兩種方法都會使用重要區段來保護m_lSaturation成員。

class CGrayFilter : public ISaturation, /* Other inherited classes. */
{
private:
    CCritSec  m_csShared;    // Protects shared data.
    long      m_lSaturation; // Saturation level.
public:
    STDMETHODIMP GetSaturation(long *plSat)
    {
        if (!plSat) return E_POINTER;
        CAutoLock lock(&m_csShared);
        *plSat = m_lSaturation;
        return S_OK;
    }
    STDMETHODIMP SetSaturation(long lSat)
    {
        CAutoLock lock(&m_csShared);
        if (lSat < SATURATION_MIN || lSat > SATURATION_MAX)
        {
            return E_INVALIDARG;
        }
        m_lSaturation = lSat;
        return S_OK;
    }
};

當然,您自己的實作詳細資料與這裡所示的範例不同。

下一 步:步驟 2。實作 ISpecifyPropertyPages

CCritSec 類別

建立篩選屬性頁