Mercurial > hg > dmlib
view jmixtmpl_c.h @ 134:1ba202b448e0
Implement volume and panning ramps (interpolation between callbacks aka "frames")
in the mixer.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Fri, 05 Oct 2012 02:47:36 +0300 |
parents | 2edda27f951c |
children | 111f3e4b57ad |
line wrap: on
line source
/* * miniJSS - Mixing routine in C, innerloop template * Programmed and designed by Matti 'ccr' Hamalainen * (C) Copyright 2006-2007 Tecnic Software productions (TNSP) */ #ifdef JMIXER_HEADER int JMIXER_NAME (JSSMixer *, JSSChannel *, JMIXER_ADDBUF_TYPE *, const int, const Sint32); #else int JMIXER_NAME (JSSMixer *mixer, JSSChannel *chn, JMIXER_ADDBUF_TYPE *addBuffer, const int mixLength, const Sint32 endPos) { const DMFixedPoint tmpDelta = chn->chDeltaO, tmpDeltaV = chn->chDeltaV; DMFixedPoint tmpPos = chn->chPos, tmpVolume = chn->chVolume; JMIXER_ADDBUF_TYPE *ap = addBuffer, *tr = chn->chPrevR, *tl = chn->chPrevL; int strideLength = 0; JMIXER_SAMPLE_TYPE *sp = (JMIXER_SAMPLE_TYPE *) chn->chData; JMIXER_INIT while (strideLength < mixLength && JMIXER_ENDCOND) { JMIXER_FUNC JMIXER_DEBUG JMIXER_NEXT FP_ADD(tmpVolume, tmpDeltaV); strideLength++; } chn->chPos = tmpPos; chn->chVolume = tmpVolume; return strideLength; } #endif #undef JMIXER_NAME #undef JMIXER_NEXT #undef JMIXER_ENDCOND