Mercurial > hg > beaglert
diff projects/basic_midi/render.cpp @ 184:9108a0a34cb8
Better(non ideal) monophonic behaviour of the basic midi implementation. Would require to remember what notes are being held down and release either the most recent or low/high priority.
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Sun, 17 Jan 2016 21:56:13 +0000 |
parents | 391ad036557d |
children | d7148d21aaa5 |
line wrap: on
line diff
--- a/projects/basic_midi/render.cpp Fri Jan 15 23:48:08 2016 +0000 +++ b/projects/basic_midi/render.cpp Sun Jan 17 21:56:13 2016 +0000 @@ -49,11 +49,11 @@ static int velocity = 0; static int noteNumber = 0; static int waitingFor = kNoteOn; + static int playingNote = -1; while ((message = midi.getInput()) >= 0){ switch(waitingFor){ case kNoteOn: if(message == noteOnStatus){ - noteOn = true; waitingFor = kNoteNumber; } break; @@ -61,16 +61,27 @@ if((message & (1<<8)) == 0){ noteNumber = message; waitingFor = kVelocity; - f0 = powf(2, (noteNumber-69)/12.0f) * 440; - phaseIncrement = 2 * M_PI * f0 / context->audioSampleRate; } break; case kVelocity: if((message & (1<<8)) == 0){ - velocity = message; + int _velocity = message; waitingFor = kNoteOn; - if(velocity == 0) + // "monophonic" behaviour, with priority to the latest note on + // i.e.: a note off from a previous note does not stop the current note + // still you might end up having a key down and no note being played if you pressed and released another + // key in the meantime + if(_velocity == 0 && noteNumber == playingNote){ noteOn = false; + playingNote = -1; + velocity = _velocity; + } else if (_velocity > 0) { + noteOn = true; + velocity = _velocity; + playingNote = noteNumber; + f0 = powf(2, (playingNote-69)/12.0f) * 440; + phaseIncrement = 2 * M_PI * f0 / context->audioSampleRate; + } rt_printf("NoteOn: %d, NoteNumber: %d, velocity: %d\n", noteOn, noteNumber, velocity); } break;