So konfigurieren Sie den Proxy-Locator
Die Anwendung kann die Standardkonfiguration des Proxy-Locators ändern, indem Sie die MFNETSOURCE_PROXYLOCATORFACTORY-Eigenschaft auf das Proxy-Locator-Factoryobjekt festlegen, das von der Anwendung implementiert wird. Wenn die Anwendung Quelllösermethoden aufruft, um die Netzwerkquelle zu erstellen, ruft Media Foundation die Proxy-Locator-Fabrik auf. Dieses Objekt erstellt den Proxy-Locator mit benutzerdefinierter Konfiguration.
So ändern Sie die Standardkonfigurationseinstellung des Proxy-Locators
- Implementieren Sie die IMFNetProxyLocatorFactory-Schnittstelle .
- Führen Sie in der IMFNetProxyLocatorFactory::CreateProxyLocator-Methode folgendes aus:
- Erstellen Sie einen Eigenschaftsspeicher.
- Legen Sie die Konfigurationseinstellungen für den Proxy-Locator fest. Informationen zu diesen Einstellungen finden Sie unter Proxy Locator Configuration Einstellungen.
- Rufen Sie die MFCreateProxyLocator-Funktion auf. Übergeben Sie den Eigenschaftsspeicher und das Protokoll. Das Protokoll wird im pszProtocol-Parameter von CreateProxyLocator angegeben.
- Erstellen Sie eine Instanz Ihrer Proxy-Locator-Fabrikklasse, und rufen Sie einen Zeiger auf die IMFNetProxyLocatorFactory-Schnittstelle ab.
- Erstellen Sie einen anderen Eigenschaftenspeicher, und legen Sie den Wert der MFNETSOURCE_PROXYLOCATORFACTORY-Eigenschaft gleich dem IMFNetProxyLocatorFactory-Zeiger von Schritt 3 fest.
- Wenn Sie die Netzwerkquelle erstellen, übergeben Sie den Eigenschaftsspeicher im pProps-Parameter der Quelllösermethoden wie IMFSourceResolver::BeginCreateObjectFromURL.
Beispiel
Im folgenden Codebeispiel wird die IMFNetProxyLocatorFactory-Schnittstelle implementiert. Die IMFNetProxyLocatorFactory::CreateProxyLocator-Methode erstellt eine Instanz des Standardproxy-Locators und konfiguriert sie, um im automatischen Erkennungsmodus zu arbeiten.
class CProxyLocatorFactory : public IMFNetProxyLocatorFactory
{
LONG m_cRef;
public:
CProxyLocatorFactory() : m_cRef(1)
{
}
STDMETHODIMP QueryInterface(REFIID riid, void** ppv)
{
static const QITAB qit[] =
{
QITABENT(CProxyLocatorFactory, IMFNetProxyLocatorFactory),
{ 0 }
};
return QISearch(this, qit, riid, ppv);
}
STDMETHODIMP_(ULONG) AddRef()
{
return InterlockedIncrement(&m_cRef);
}
STDMETHODIMP_(ULONG) Release()
{
LONG cRef = InterlockedDecrement(&m_cRef);
if (cRef == 0)
{
delete this;
}
return cRef;
}
STDMETHODIMP CreateProxyLocator(
LPCWSTR pszProtocol,
IMFNetProxyLocator **ppProxyLocator
)
{
*ppProxyLocator = NULL;
//Create the property store object
IPropertyStore *pProp = NULL;
HRESULT hr = PSCreateMemoryPropertyStore(IID_PPV_ARGS(&pProp));
if(SUCCEEDED(hr))
{
// Property key for proxy settings.
PROPERTYKEY key;
key.fmtid = MFNETSOURCE_PROXYSETTINGS;
key.pid = 0;
// Proxy settings
PROPVARIANT var;
var.vt = VT_I4;
var.lVal = MFNET_PROXYSETTING_AUTO;
hr = pProp->SetValue(key, var);
}
//Create the default proxy locator.
if(SUCCEEDED(hr))
{
hr = MFCreateProxyLocator(pszProtocol, pProp, ppProxyLocator);
}
SafeRelease(&pProp);
return hr;
}
};
Im nächsten Beispiel wird gezeigt, wie der IMFNetProxyLocatorFactory-Zeiger an die Netzwerkquelle übergeben wird.
// Creates a media source from a URL.
//
// This example demonstrates how to set a proxy locator on the network source.
HRESULT CreateMediaSourceWithProxyLocator(
PCWSTR pszURL,
IMFMediaSource **ppSource
)
{
IPropertyStore *pConfig = NULL;
IMFNetProxyLocatorFactory *pFactory = new (std::nothrow) CProxyLocatorFactory();
if (pFactory == NULL)
{
return E_OUTOFMEMORY;
}
// Configure the property store.
HRESULT hr = PSCreateMemoryPropertyStore(IID_PPV_ARGS(&pConfig));
if (SUCCEEDED(hr))
{
PROPERTYKEY key;
key.fmtid = MFNETSOURCE_PROXYLOCATORFACTORY;
key.pid = 0;
PROPVARIANT var;
var.vt = VT_UNKNOWN;
var.punkVal = pFactory;
hr = pConfig->SetValue(key, var);
}
// Create the source media source.
if (SUCCEEDED(hr))
{
hr = CreateMediaSource(pszURL, pConfig, ppSource);
}
SafeRelease(&pConfig);
return hr;
}
Zugehörige Themen