123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- #pragma once
- #include "openmpt/all/BuildSettings.hpp"
- #ifndef NO_REVERB
- #include "../soundlib/Mixer.h"
- OPENMPT_NAMESPACE_BEGIN
- #define SNDMIX_REFLECTIONS_DELAY_MASK 0x1fff
- #define SNDMIX_PREDIFFUSION_DELAY_MASK 0x7f
- #define SNDMIX_REVERB_DELAY_MASK 0xfff
- union LR16
- {
- struct { int16 l, r; } c;
- int32 lr;
- };
- struct SWRvbReflection
- {
- uint32 Delay, DelayDest;
- LR16 Gains[2];
- };
- struct SWRvbRefDelay
- {
- uint32 nDelayPos, nPreDifPos, nRefOutPos;
- int32 lMasterGain;
- LR16 nCoeffs;
- LR16 History;
- LR16 nPreDifCoeffs;
- LR16 ReflectionsGain;
- SWRvbReflection Reflections[8];
- LR16 RefDelayBuffer[SNDMIX_REFLECTIONS_DELAY_MASK + 1];
- LR16 PreDifBuffer[SNDMIX_PREDIFFUSION_DELAY_MASK + 1];
- LR16 RefOut[SNDMIX_REVERB_DELAY_MASK + 1];
- };
- struct SNDMIX_REVERB_PROPERTIES;
- #define RVBDIF1L_LEN (149*2)
- #define RVBDIF1R_LEN (223*2)
- #define RVBDIF2L_LEN (421*2)
- #define RVBDIF2R_LEN (647*2)
- #define RVBDLY1L_LEN (683*2)
- #define RVBDLY1R_LEN (811*2)
- #define RVBDLY2L_LEN (773*2)
- #define RVBDLY2R_LEN (1013*2)
- #define RVBDLY_MASK 2047
- #define RVBMINREFDELAY 96
- #define RVBMAXREFDELAY 7500
- #define RVBMINRVBDELAY 128
- #define RVBMAXRVBDELAY 3800
- struct SWLateReverb
- {
- uint32 nReverbDelay;
- uint32 nDelayPos;
- LR16 nDifCoeffs[2];
- LR16 nDecayDC[2];
- LR16 nDecayLP[2];
- LR16 LPHistory[2];
- LR16 Dif2InGains[2];
- LR16 RvbOutGains[2];
- int32 lMasterGain;
- int32 lDummyAlign;
-
- LR16 Diffusion1[RVBDLY_MASK + 1];
- LR16 Diffusion2[RVBDLY_MASK + 1];
- LR16 Delay1[RVBDLY_MASK + 1];
- LR16 Delay2[RVBDLY_MASK + 1];
- };
- #define ENVIRONMENT_NUMREFLECTIONS 8
- struct EnvironmentReflection
- {
- int16 GainLL, GainRR, GainLR, GainRL;
- uint32 Delay;
- };
- struct EnvironmentReverb
- {
- int32 ReverbLevel;
- int32 ReflectionsLevel;
- int32 RoomHF;
- uint32 ReverbDecay;
- int32 PreDiffusion;
- int32 TankDiffusion;
- uint32 ReverbDelay;
- float flReverbDamping;
- int32 ReverbDecaySamples;
- EnvironmentReflection Reflections[ENVIRONMENT_NUMREFLECTIONS];
- };
- class CReverbSettings
- {
- public:
- uint32 m_nReverbDepth = 8;
- uint32 m_nReverbType = 0;
- };
- class CReverb
- {
- public:
- CReverbSettings m_Settings;
- private:
- const SNDMIX_REVERB_PROPERTIES *m_currentPreset = nullptr;
- bool gnReverbSend = false;
- uint32 gnReverbSamples = 0;
- uint32 gnReverbDecaySamples = 0;
-
- bool g_bLastInPresent = 0;
- bool g_bLastOutPresent = 0;
- int g_nLastRvbIn_xl = 0;
- int g_nLastRvbIn_xr = 0;
- int g_nLastRvbIn_yl = 0;
- int g_nLastRvbIn_yr = 0;
- int g_nLastRvbOut_xl = 0;
- int g_nLastRvbOut_xr = 0;
- int32 gnDCRRvb_Y1[2] = { 0, 0 };
- int32 gnDCRRvb_X1[2] = { 0, 0 };
-
- SWRvbRefDelay g_RefDelay;
- SWLateReverb g_LateReverb;
- public:
- CReverb();
- public:
- void Initialize(bool bReset, MixSampleInt &gnRvbROfsVol, MixSampleInt &gnRvbLOfsVol, uint32 MixingFreq);
-
- void TouchReverbSendBuffer(MixSampleInt *MixReverbBuffer, MixSampleInt &gnRvbROfsVol, MixSampleInt &gnRvbLOfsVol, uint32 nSamples);
-
- void Process(MixSampleInt *MixSoundBuffer, MixSampleInt *MixReverbBuffer, MixSampleInt &gnRvbROfsVol, MixSampleInt &gnRvbLOfsVol, uint32 nSamples);
- private:
- void Shutdown(MixSampleInt &gnRvbROfsVol, MixSampleInt &gnRvbLOfsVol);
-
- uint32 ReverbProcessPreFiltering1x(int32 *pWet, uint32 nSamples);
- uint32 ReverbProcessPreFiltering2x(int32 *pWet, uint32 nSamples);
- void ReverbProcessPostFiltering1x(const int32 *pRvb, int32 *pDry, uint32 nSamples);
- void ReverbProcessPostFiltering2x(const int32 *pRvb, int32 *pDry, uint32 nSamples);
- void ReverbDCRemoval(int32 *pBuffer, uint32 nSamples);
- void ReverbDryMix(int32 *pDry, int32 *pWet, int lDryVol, uint32 nSamples);
-
- static void ProcessPreDelay(SWRvbRefDelay *pPreDelay, const int32 *pIn, uint32 nSamples);
-
- static void ProcessReflections(SWRvbRefDelay *pPreDelay, LR16 *pRefOut, int32 *pMixOut, uint32 nSamples);
-
- static void ProcessLateReverb(SWLateReverb *pReverb, LR16 *pRefOut, int32 *pMixOut, uint32 nSamples);
- };
- struct SNDMIX_REVERB_PROPERTIES
- {
- int32 lRoom;
- int32 lRoomHF;
- float flDecayTime;
- float flDecayHFRatio;
- int32 lReflections;
- float flReflectionsDelay;
- int32 lReverb;
- float flReverbDelay;
- float flDiffusion;
- float flDensity;
- };
- enum : uint32
- {
- NUM_REVERBTYPES = 29
- };
- mpt::ustring GetReverbPresetName(uint32 preset);
- const SNDMIX_REVERB_PROPERTIES *GetReverbPreset(uint32 preset);
- OPENMPT_NAMESPACE_END
- #endif
|