#include #include "map.h" #include "kshlp.h" #include "clone.h" STD_CAPTURE_CREATE(MicArray) STDMETHODIMP CDirectSoundCaptureMicArrayDMO::NDQueryInterface ( REFIID riid, LPVOID *ppv ) { IMP_DSDMO_QI(riid,ppv); if (riid == IID_IPersist) { return GetInterface((IPersist*)this, ppv); } else if (riid == IID_IMediaObject) { return GetInterface((IMediaObject*)this, ppv); } else if (riid == IID_IDirectSoundCaptureFXMicArray) { return GetInterface((IDirectSoundCaptureFXMicArray*)this, ppv); } else if (riid == IID_IMediaParams) { return GetInterface((IMediaParams*)this, ppv); } else if (riid == IID_IMediaParamInfo) { return GetInterface((IMediaParamInfo*)this, ppv); } else return CComBase::NDQueryInterface(riid, ppv); } CDirectSoundCaptureMicArrayDMO::CDirectSoundCaptureMicArrayDMO( IUnknown *pUnk, HRESULT *phr ) : CComBase( pUnk, phr ), m_fEnable(FALSE), m_fReset(FALSE), m_fDirty(FALSE), m_bInitialized(FALSE) { } CDirectSoundCaptureMicArrayDMO::~CDirectSoundCaptureMicArrayDMO() { } const MP_CAPS g_MicArrayCapsAll = 0; static ParamInfo g_params[] = { // index type caps min, max, neutral, unit text, label, pwchText?? MAP_Enable, MPT_BOOL, g_MicArrayCapsAll, 0, 1, 0, L"", L"", L"", MAP_Reset, MPT_BOOL, g_MicArrayCapsAll, 0, 1, 0, L"", L"", L"" }; HRESULT CDirectSoundCaptureMicArrayDMO::InitOnCreation() { HRESULT hr = InitParams(1, &GUID_TIME_REFERENCE, 0, 0, sizeof(g_params)/sizeof(*g_params), g_params); return hr; } HRESULT CDirectSoundCaptureMicArrayDMO::Init() { m_bInitialized = TRUE; return S_OK; } ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureMicArrayDMO::Clone // STDMETHODIMP CDirectSoundCaptureMicArrayDMO::Clone(IMediaObjectInPlace **pp) { return StandardDMOClone(this, pp); } HRESULT CDirectSoundCaptureMicArrayDMO::Discontinuity() { return NOERROR; } HRESULT CDirectSoundCaptureMicArrayDMO::FBRProcess ( DWORD cSamples, BYTE *pIn, BYTE *pOut ) { if (!m_bInitialized) return DMO_E_TYPE_NOT_SET; return NOERROR; } // ==============Implementation of the private IMicArray interface ========== // ==================== needed to support the property page =============== ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureMicArrayDMO::SetAllParameters // STDMETHODIMP CDirectSoundCaptureMicArrayDMO::SetAllParameters(LPCDSCFXMicArray pParm) { HRESULT hr = S_OK; // Check that the pointer is not NULL if (pParm == NULL) { Trace(1,"ERROR: pParm is NULL\n"); hr = E_POINTER; } // Set the parameters if (SUCCEEDED(hr)) hr = SetParam(MAP_Enable, static_cast(pParm->fEnable)); if (SUCCEEDED(hr)) hr = SetParam(MAP_Reset, static_cast(pParm->fReset)); m_fDirty = true; return hr; } ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureMicArrayDMO::GetAllParameters // STDMETHODIMP CDirectSoundCaptureMicArrayDMO::GetAllParameters(LPDSCFXMicArray pParm) { if (pParm == NULL) { return E_POINTER; } HRESULT hr = S_OK; MP_DATA var; GetParam(MAP_Enable, &var); pParm->fEnable = (BOOL)var; GetParam(MAP_Reset, &var); pParm->fReset = (BOOL)var; return S_OK; } ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureMicArrayDMO::SetParam // STDMETHODIMP CDirectSoundCaptureMicArrayDMO::SetParam ( DWORD dwParamIndex, MP_DATA value, bool fSkipPasssingToParamManager ) { HRESULT hr = S_OK; BOOL fEnable = (BOOL)value; BOOL fReset = (BOOL)value; switch (dwParamIndex) { case MAP_Enable: if (fEnable) { hr = KsSetTopologyNodeEnable(m_hPin, m_ulNodeId, fEnable); if(SUCCEEDED(hr)) m_fEnable = fEnable; } break; case MAP_Reset: if (fReset) { hr = KsTopologyNodeReset(m_hPin, m_ulNodeId, fReset); if(SUCCEEDED(hr)) m_fReset = fReset; } break; } if (SUCCEEDED(hr)) { Init(); // FIXME - temp hack (sets m_bInitialized flag) } // Let base class set this so it can handle all the rest of the param calls. // Skip the base class if fSkipPasssingToParamManager. This indicates that we're calling the function // internally using valuds that came from the base class -- thus there's no need to tell it values it // already knows. return (FAILED(hr) || fSkipPasssingToParamManager) ? hr : CParamsManager::SetParam(dwParamIndex, value); } ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureAecDMO::GetParam // STDMETHODIMP CDirectSoundCaptureMicArrayDMO::GetParam ( DWORD dwParamIndex, MP_DATA* value ) { HRESULT hr = S_OK; BOOL fTemp; switch (dwParamIndex) { case MAP_Enable: hr = KsGetTopologyNodeEnable(m_hPin, m_ulNodeId, &fTemp); if(SUCCEEDED(hr)) { m_fEnable = fTemp; *value = (MP_DATA)fTemp; } break; case MAP_Reset: *value = (MP_DATA)m_fReset; break; } return hr; } ////////////////////////////////////////////////////////////////////////////// // // CDirectSoundCaptureMicArrayDMO::ProcessInPlace // HRESULT CDirectSoundCaptureMicArrayDMO::ProcessInPlace ( ULONG ulQuanta, LPBYTE pcbData, REFERENCE_TIME rtStart, DWORD dwFlags ) { // Update parameter values from any curves that may be in effect. // Do this in the same order as SetAllParameters in case there are any interdependencies. return FBRProcess(ulQuanta, pcbData, pcbData); }