83 lines
2.8 KiB
C
83 lines
2.8 KiB
C
|
//
|
||
|
//
|
||
|
//
|
||
|
#ifndef _Garglep_
|
||
|
#define _Garglep_
|
||
|
|
||
|
#include "dsdmobse.h"
|
||
|
#include "dmocom.h"
|
||
|
#include "dsdmo.h"
|
||
|
#include "PropertyHelp.h"
|
||
|
#include "param.h"
|
||
|
|
||
|
class CDirectSoundGargleDMO :
|
||
|
public CDirectSoundDMO,
|
||
|
public CParamsManager,
|
||
|
public ISpecifyPropertyPages,
|
||
|
public IDirectSoundFXGargle,
|
||
|
public CParamsManager::UpdateCallback,
|
||
|
public CComBase
|
||
|
{
|
||
|
public:
|
||
|
CDirectSoundGargleDMO( IUnknown *pUnk, HRESULT *phr);
|
||
|
~CDirectSoundGargleDMO();
|
||
|
|
||
|
DECLARE_IUNKNOWN;
|
||
|
STDMETHODIMP NDQueryInterface(REFIID riid, void **ppv);
|
||
|
static CComBase* WINAPI CreateInstance(IUnknown *pUnk, HRESULT *phr);
|
||
|
|
||
|
// InitOnCreation is called by the class factory to give the object a chance to initialize
|
||
|
// immediately after it is created. This is used to prepare the object's parameter information.
|
||
|
HRESULT InitOnCreation();
|
||
|
|
||
|
// The Init function is an override from the CPCMDMO base class and it provides initialization
|
||
|
// for the effect's actual audio processing. Note that InputType must have been set before this
|
||
|
// occurs in order for this to work.
|
||
|
HRESULT Init();
|
||
|
|
||
|
STDMETHOD(Clone) (THIS_ IMediaObjectInPlace **);
|
||
|
|
||
|
// IPersist methods
|
||
|
virtual HRESULT STDMETHODCALLTYPE GetClassID( CLSID *pClassID );
|
||
|
|
||
|
// ISpecifyPropertyPages
|
||
|
STDMETHOD(GetPages)(CAUUID * pPages) { return PropertyHelp::GetPages(CLSID_DirectSoundPropGargle, pPages); }
|
||
|
|
||
|
// IPersistStream
|
||
|
STDMETHOD(IsDirty)(void) { return m_fDirty ? S_OK : S_FALSE; }
|
||
|
STDMETHOD(Load)(IStream *pStm) { return PropertyHelp::Load(this, DSFXGargle(), pStm); }
|
||
|
STDMETHOD(Save)(IStream *pStm, BOOL fClearDirty) { return PropertyHelp::Save(this, DSFXGargle(), pStm, fClearDirty); }
|
||
|
STDMETHOD(GetSizeMax)(ULARGE_INTEGER *pcbSize) { if (!pcbSize) return E_POINTER; pcbSize->QuadPart = sizeof(DSFXGargle); return S_OK; }
|
||
|
|
||
|
// IDirectSoundFXGargle
|
||
|
STDMETHOD(SetAllParameters) (THIS_ LPCDSFXGargle);
|
||
|
STDMETHOD(GetAllParameters) (THIS_ LPDSFXGargle);
|
||
|
|
||
|
// SetParam handling
|
||
|
STDMETHODIMP SetParam(DWORD dwParamIndex,MP_DATA value) { return SetParamInternal(dwParamIndex, value, false); }
|
||
|
HRESULT SetParamUpdate(DWORD dwParamIndex, MP_DATA value) { return SetParamInternal(dwParamIndex, value, true); }
|
||
|
HRESULT SetParamInternal(DWORD dwParamIndex, MP_DATA value, bool fSkipPasssingToParamManager);
|
||
|
|
||
|
// All of these methods are called by the base class
|
||
|
HRESULT FBRProcess(DWORD cQuanta, BYTE *pIn, BYTE *pOut);
|
||
|
HRESULT Discontinuity();
|
||
|
HRESULT ProcessInPlace(ULONG ulQuanta, LPBYTE pcbData, REFERENCE_TIME rtStart, DWORD dwFlags);
|
||
|
|
||
|
bool m_fDirty;
|
||
|
|
||
|
private:
|
||
|
// gargle params
|
||
|
ULONG m_ulShape;
|
||
|
ULONG m_ulGargleFreqHz;
|
||
|
|
||
|
// gargle state
|
||
|
ULONG m_ulPeriod;
|
||
|
ULONG m_ulPhase;
|
||
|
|
||
|
BOOL m_bInitialized;
|
||
|
};
|
||
|
|
||
|
EXT_STD_CREATE(Gargle);
|
||
|
|
||
|
#endif
|