Swadge 2024 2.0.0
APIs to develop games for the Magfest Swadge
Loading...
Searching...
No Matches
midiPlayer.h
Go to the documentation of this file.
1#pragma once
2
56//==============================================================================
57// Includes
58//==============================================================================
59
60#include "swSynth.h"
61#include "midiFileParser.h"
62
63#include <stdint.h>
64#include <stdbool.h>
65#include <stddef.h>
66
67//==============================================================================
68// Defines
69//==============================================================================
70
71#define MIDI_CHANNEL_COUNT 16
72// The total number of pooled voices
73#define POOL_VOICE_COUNT 24
74// The number of voices reserved for percussion
75#define PERCUSSION_VOICES 8
76// The number of oscillators each voice gets. Maybe we'll need more than one for like, chorus?
77#define OSC_PER_VOICE 1
78// The number of global MIDI players
79#define NUM_GLOBAL_PLAYERS 2
80// The index of the system-wide MIDI player for sound effects
81#define MIDI_SFX 0
82// The index of the system-wide MIDI player for background music
83#define MIDI_BGM 1
84// The maximum volume setting for globalMidiPlayerSetVolume()
85#define MAX_VOLUME 13
86
87#define MIDI_TRUE 0x7F
88#define MIDI_FALSE 0x00
89#define MIDI_TO_BOOL(val) (val > 63)
90#define BOOL_TO_MIDI(val) (val ? MIDI_TRUE : MIDI_FALSE)
91#define MIDI_DEF_HEADROOM 0x2666
92#define PITCH_BEND_CENTER 0x2000
93
95#define SAMPLES_TO_MIDI_TICKS(n, tempo, div) ((int64_t)(n) * 1000000 * (div) / DAC_SAMPLE_RATE_HZ / (tempo))
96
98#define TICKS_TO_SAMPLES(ticks, tempo, div) ((int64_t)(ticks) * DAC_SAMPLE_RATE_HZ / (1000000) * (tempo) / (div))
99
101#define SAMPLES_TO_MS(samp) (((samp) * 1000) / DAC_SAMPLE_RATE_HZ)
102
104#define SAMPLES_TO_US(samp) (((samp) * 1000000) / DAC_SAMPLE_RATE_HZ)
105
107#define MS_TO_SAMPLES(ms) ((ms) * DAC_SAMPLE_RATE_HZ / 1000)
108
110#define MIDI_TICKS_TO_US(ticks, tempo, div) (int64_t)((int64_t)((int64_t)(ticks) * (int64_t)(tempo)) / ((int64_t)(div)))
111
113typedef void (*songFinishedCbFn)(void);
114
115//==============================================================================
116// Enums
117//==============================================================================
118
131
143
147typedef enum
148{
156
160typedef enum
161{
162 // Roland GS Extensions
163 /*HIGH_Q_OR_FILTER_SNAP = 27,
164 SLAP_NOISE = 28,
165 SCRATCH_PUSH = 29,
166 SCRATCH_PULL = 30,
167 DRUM_STICKS = 31,
168 SQUARE_CLICK = 32,
169 METRONOME_CLICK = 33,
170 METRONOME_BELL = 34,*/
171 // End Roland GS Extensions
209 CABASA = 69,
219 CLAVES = 75,
230 // Roland GS Extensions
231 /*SHAKER = 82,
232 JINGLE_BELL = 83,
233 BELLTREE = 84,
234 CASTANETS = 85,
235 MUTE_SURDO = 86,
236 OPEN_SURDO = 87,*/
237 // End Roland GS Extensions
239
249typedef enum
250{
254
260
265
270
274
280
285
286 //< Switch
288 //< Switch
290 //< Switch
292 //< Switch
294 //< Switch
296 //< Switch
303 // Decay
305 // Sustain level
310 //< Switch
312 //< Switch
314 //< Switch
316 //< Switch
318
330
331 //< No data
333 //< No data
335 //< Switch
337 //< No data
339 //< No data
341 //< No data
343 //< No data
345 //< No data
348
358
359//==============================================================================
360// Structs
361//==============================================================================
362
367typedef struct
368{
370 int32_t attackTime;
371
374
376 int32_t decayTime;
377
380
382 int32_t releaseTime;
383
386
388 uint8_t sustainVol;
389
392
394 // uint32_t loopStart;
396 // uint32_t loopEnd;
397
398} envelope_t;
399
400typedef struct
401{
403 uint8_t chorus;
405
415typedef int8_t (*percussionFunc_t)(percussionNote_t drum, uint32_t idx, bool* done, uint32_t scratch[4], void* data);
416
424typedef void (*midiTextCallback_t)(metaEventType_t type, const char* text, uint32_t length);
425
430typedef bool (*midiStreamingCallback_t)(midiEvent_t* event);
431
435typedef struct
436{
439
442
443 union
444 {
445 struct
446 {
448 uint16_t waveIndex;
449
451 waveFunc_t waveFunc;
452 };
453
454 struct
455 {
457
458 // This should just always be C4? (440 << 8)
459 // uint32_t freq = (440 << 8);
460
461 union
462 {
463 struct
464 {
466 const uint8_t* data;
467
469 uint32_t count;
470 };
471
472 struct
473 {
475 const char* sampleName;
476 } config;
477 };
478
480 uint32_t rate;
481
483 uq8_24 baseNote;
484
486 uint32_t loop;
487 } sample;
488
489 struct
490 {
492 percussionFunc_t playFunc;
494 void* data;
495 } percussion;
496
498 oscillatorShape_t shape;
499 };
500
503
506
508 const char* name;
510
516typedef struct
517{
520
523
526
528 uint8_t targetVol;
529
531 uint32_t sampleTick;
532
534 uint8_t note;
535
537 uint8_t velocity;
538
540 uint8_t channel;
541
544
545 // TODO union this with the oscillators? They shouldn't both be used
546 // But we need to make sure those oscillators don't get summed
547 union
548 {
550 uint32_t percScratch[4];
551
552 struct
553 {
555 uint32_t sampleError;
556
558 uint32_t sampleLoops;
559 };
560 };
561
565
571typedef struct
572{
574 uint32_t on;
575
577 uint32_t attack;
578
580 uint32_t sustain;
581
583 uint32_t decay;
584
586 uint32_t release;
587
589 uint32_t held;
590
592 uint32_t sustenuto;
594
598typedef struct
599{
601 uint16_t volume;
602
604 uint16_t bank;
605
607 uint8_t program;
608
611
614
617
620
622 uint16_t pitchBend;
623
626
628 bool held;
629
632
634 bool ignore;
636
719
725void midiPlayerInit(midiPlayer_t* player);
726
732void midiPlayerReset(midiPlayer_t* player);
733
741
748int32_t midiPlayerStep(midiPlayer_t* player);
749
758void midiPlayerFillBuffer(midiPlayer_t* player, uint8_t* samples, int16_t len);
759
768void midiPlayerFillBufferMulti(midiPlayer_t* players, uint8_t playerCount, uint8_t* samples, int16_t len);
769
775void midiAllSoundOff(midiPlayer_t* player);
776
787void midiResetChannelControllers(midiPlayer_t* player, uint8_t channel);
788
794void midiGmOn(midiPlayer_t* player);
795
801void midiGmOff(midiPlayer_t* player);
802
810void midiAllNotesOff(midiPlayer_t* player, uint8_t channel);
811
822void midiNoteOn(midiPlayer_t* player, uint8_t channel, uint8_t note, uint8_t velocity);
823
832void midiAfterTouch(midiPlayer_t* player, uint8_t channel, uint8_t note, uint8_t velocity);
833
842void midiNoteOff(midiPlayer_t* player, uint8_t channel, uint8_t note, uint8_t velocity);
843
851void midiSetProgram(midiPlayer_t* player, uint8_t channel, uint8_t program);
852
865void midiSustain(midiPlayer_t* player, uint8_t channel, uint8_t val);
866
877void midiSustenuto(midiPlayer_t* player, uint8_t channel, uint8_t val);
878
887void midiControlChange(midiPlayer_t* player, uint8_t channel, midiControl_t control, uint8_t val);
888
897uint8_t midiGetControlValue(midiPlayer_t* player, uint8_t channel, midiControl_t control);
898
907uint16_t midiGetControlValue14bit(midiPlayer_t* player, uint8_t channel, midiControl_t control);
908
918void midiSetParameter(midiPlayer_t* player, uint8_t channel, bool registered, uint16_t param, uint16_t value);
919
930uint16_t midiGetParameterValue(midiPlayer_t* player, uint8_t channel, bool registered, uint16_t param);
931
945void midiPitchWheel(midiPlayer_t* player, uint8_t channel, uint16_t value);
946
953void midiSetTempo(midiPlayer_t* player, uint32_t tempo);
954
961void midiSetFile(midiPlayer_t* player, const midiFile_t* file);
962
969void midiPause(midiPlayer_t* player, bool pause);
970
982void midiSeek(midiPlayer_t* player, uint32_t ticks);
983
984//==============================================================================
985// Global MIDI Player Functions
986//==============================================================================
987
991void initGlobalMidiPlayer(void);
992
997void deinitGlobalMidiPlayer(void);
998
1006void globalMidiPlayerFillBuffer(uint8_t* samples, int16_t len);
1007
1014void globalMidiPlayerPlaySong(midiFile_t* song, uint8_t trackType);
1015
1023void globalMidiPlayerPlaySongCb(midiFile_t* song, uint8_t trackType, songFinishedCbFn cb);
1024
1031void globalMidiPlayerSetVolume(uint8_t trackType, int32_t volumeSetting);
1032
1037void globalMidiPlayerPauseAll(void);
1038
1043void globalMidiPlayerResumeAll(void);
1044
1051void globalMidiPlayerStop(bool reset);
1052
1059void* globalMidiSave(void);
1060
1067void globalMidiRestore(void* data);
1068
1076midiPlayer_t* globalMidiPlayerGet(uint8_t trackType);
uint32_t uq8_24
unsigned 8 bits integer, 24 bits fraction
Definition fp_math.h:43
int32_t q24_8
24 bits integer, 8 bits fraction
Definition fp_math.h:36
metaEventType_t
The possible types of meta-events.
Definition midiFileParser.h:31
Contains information for an entire MIDI event or non-MIDI meta-event.
Definition midiFileParser.h:233
Definition midiFileParser.h:107
Contains information which applies to the entire MIDI file.
Definition midiFileParser.h:84
int32_t releaseTime
Base time it takes to silence the note after release, in DAC samples.
Definition midiPlayer.h:382
void midiNoteOn(midiPlayer_t *player, uint8_t channel, uint8_t note, uint8_t velocity)
Begin playing a note on a given MIDI channel.
Definition midiPlayer.c:1556
uint16_t midiGetControlValue14bit(midiPlayer_t *player, uint8_t channel, midiControl_t control)
Get the combined value of two MIDI control registers.
Definition midiPlayer.c:2194
midiEvent_t pendingEvent
The next event in the MIDI file, which occurs after the current time.
Definition midiPlayer.h:702
bool paused
True when playback of the current file is paused.
Definition midiPlayer.h:711
q24_8 sustainVolVel
This value will be multiplied by the note velocity and added to the attack time.
Definition midiPlayer.h:391
void midiSustain(midiPlayer_t *player, uint8_t channel, uint8_t val)
Set the hold pedal status.
Definition midiPlayer.c:1884
void globalMidiRestore(void *data)
Resume MIDI playback from the state stored in the given pointer. The data will be freed after this ca...
Definition midiFileParser.c:1054
void midiResetChannelControllers(midiPlayer_t *player, uint8_t channel)
Reset all controllers on a MIDI channel.
Definition midiPlayer.c:1455
bool registeredParameter
Whether selectedParameter represents a registered or non-registered parameter.
Definition midiPlayer.h:610
timbreType_t
The sample source for an instrument.
Definition midiPlayer.h:136
@ SAMPLE
Definition midiPlayer.h:139
@ WAVETABLE
Samples are generated by sampling a particular wave shape.
Definition midiPlayer.h:138
@ WAVE_SHAPE
Definition midiPlayer.h:141
@ NOISE
Definition midiPlayer.h:140
q24_8 releaseTimeVel
This value will be multiplied by the note velocity and added to the attack time.
Definition midiPlayer.h:385
envelope_t envelope
The ASDR characteristics of this timbre.
Definition midiPlayer.h:502
void midiGmOn(midiPlayer_t *player)
Activate General MIDI mode on a MIDI player.
Definition midiPlayer.c:1470
uint32_t tempo
The number of microseconds per quarter note.
Definition midiPlayer.h:708
void midiPlayerResetNewSong(midiPlayer_t *player)
Reset the MIDI player state by only doing the bare minimum. This is useful when playing multiple soun...
Definition midiPlayer.c:1246
void globalMidiPlayerPlaySong(midiFile_t *song, uint8_t trackType)
Play a song on one of the system-wide MIDI players, either BGM or SFX.
Definition midiPlayer.c:2499
uint32_t transitionTicksTotal
The number of samples remaining before the next volume adjustment.
Definition midiPlayer.h:522
uint32_t sustenuto
Bitfield of voices which are being held by the sustenuto pedal.
Definition midiPlayer.h:592
uint32_t held
Bitfield of voices which are being held by the pedal.
Definition midiPlayer.h:589
midiManufacturerId_t
Values that can be directly compared against midiSysexEvent_t::manufacturerId.
Definition midiPlayer.h:353
@ MMFR_EDUCATIONAL_USE
Definition midiPlayer.h:354
@ MMFR_UNIVERSAL_NON_REAL_TIME
Definition midiPlayer.h:355
@ MMFR_UNIVERSAL_REAL_TIME
Definition midiPlayer.h:356
int32_t midiPlayerStep(midiPlayer_t *player)
Calculate and return the next MIDI sample, stepping the player state forward by one sample.
Definition midiPlayer.c:1257
void midiAfterTouch(midiPlayer_t *player, uint8_t channel, uint8_t note, uint8_t velocity)
Change the velocity of a note on a given MIDI channel, after the note starts playing.
Definition midiPlayer.c:1750
voiceStates_t poolVoiceStates
The global voice pool state bitmaps.
Definition midiPlayer.h:665
uint8_t transitionStartVol
The volume at the start of the transition time.
Definition midiPlayer.h:525
void midiPlayerFillBuffer(midiPlayer_t *player, uint8_t *samples, int16_t len)
Fill a buffer with the next set of samples from the MIDI player. This should be called by the callbac...
Definition midiPlayer.c:1331
midiTimbre_t timbre
The actual current timbre definition which the program ID corresponds to.
Definition midiPlayer.h:616
int32_t attackTime
Base time taken to ramp up to full volume.
Definition midiPlayer.h:370
voiceStates_t percVoiceStates
The percussion voice state bitmaps.
Definition midiPlayer.h:652
const midiTimbre_t * timbre
A pointer to the timbre of this voice, which defines its musical characteristics.
Definition midiPlayer.h:563
q24_8 attackTimeVel
This value will be multiplied by the note velocity and added to the attack time,.
Definition midiPlayer.h:373
timbreType_t type
The source of samples for this instrument.
Definition midiPlayer.h:438
uint16_t oscillatorCount
The total number of oscillators in the allOscillators array.
Definition midiPlayer.h:671
void midiSetParameter(midiPlayer_t *player, uint8_t channel, bool registered, uint16_t param, uint16_t value)
Set a registered or non-registered parameter value.
Definition midiPlayer.c:2212
void midiSeek(midiPlayer_t *player, uint32_t ticks)
Seek to a given time offset within a file.
Definition midiPlayer.c:2365
void deinitGlobalMidiPlayer(void)
Deinitialize and free memory associated with the system-wide MIDI players.
Definition midiPlayer.c:2471
void globalMidiPlayerStop(bool reset)
Stop all songs currently being played by the system-wide MIDI players, optionally resetting their sta...
Definition midiPlayer.c:2565
bool held
Whether notes will be held after release.
Definition midiPlayer.h:628
uint32_t percSpecialStates
A bitmap to track which percussion voices have special notes playing This includes all 3 hi-hats (ope...
Definition midiPlayer.h:659
void midiSustenuto(midiPlayer_t *player, uint8_t channel, uint8_t val)
Set the sustenuto pedal status.
Definition midiPlayer.c:1931
void midiSetProgram(midiPlayer_t *player, uint8_t channel, uint8_t program)
Change the program (instrument) on a given MIDI channel.
Definition midiPlayer.c:1867
bool loop
If true, the playing file will automatically repeat when complete.
Definition midiPlayer.h:717
bool sustenuto
Whether certain notes will be held after release.
Definition midiPlayer.h:631
midiFileReader_t reader
A MIDI reader to use for file playback, when in MIDI_FILE mode.
Definition midiPlayer.h:677
uint8_t velocity
The MIDI note velocity of the playing note.
Definition midiPlayer.h:537
void midiPlayerInit(midiPlayer_t *player)
Initialize the MIDI player.
Definition midiPlayer.c:1196
uint8_t channel
The index of the MIDI channel that owns the currently playing note.
Definition midiPlayer.h:540
uint8_t sustainVol
The base volume of the sustained note, proportional to the sample volume.
Definition midiPlayer.h:388
void globalMidiPlayerResumeAll(void)
Resume all songs currently being played by the system-wide MIDI players.
Definition midiPlayer.c:2554
#define PERCUSSION_VOICES
Definition midiPlayer.h:75
int32_t headroom
The constant value to multiply each frame's samples by, before being shifted right 16 bits This value...
Definition midiPlayer.h:692
void globalMidiPlayerFillBuffer(uint8_t *samples, int16_t len)
Fill the given sample buffer with samples from both the BGM and SFX system-wide MIDI players.
Definition midiPlayer.c:2487
void midiPitchWheel(midiPlayer_t *player, uint8_t channel, uint16_t value)
Set the pitch wheel value on a given MIDI channel.
Definition midiPlayer.c:2300
uint32_t attack
Bitfield of voices currently in the attack stage.
Definition midiPlayer.h:577
void midiGmOff(midiPlayer_t *player)
Deactivate General MIDI mode on a MIDI player.
Definition midiPlayer.c:1486
uint8_t note
The MIDI note number for the sound being played.
Definition midiPlayer.h:534
void midiNoteOff(midiPlayer_t *player, uint8_t channel, uint8_t note, uint8_t velocity)
Stop playing a particular note on a given MIDI channel.
Definition midiPlayer.c:1800
#define POOL_VOICE_COUNT
Definition midiPlayer.h:73
midiPlayerMode_t
Represents the source of MIDI data.
Definition midiPlayer.h:124
@ MIDI_STREAMING
Streaming over USB.
Definition midiPlayer.h:126
@ MIDI_FILE
Reading from a midiFileReader_t.
Definition midiPlayer.h:129
uint32_t decay
Bitfield of voices currently in the decay stage.
Definition midiPlayer.h:583
bool percussion
Whether this channel is reserved for percussion.
Definition midiPlayer.h:625
void globalMidiPlayerPauseAll(void)
Pause all songs currently being played by the system-wide MIDI players.
Definition midiPlayer.c:2543
int32_t decayTime
Base time taken for the volume to fade to the sustain volume.
Definition midiPlayer.h:376
uint32_t clipped
Number of samples that were clipped Note: This is not set when using midiPlayerFillBufferMulti()
Definition midiPlayer.h:696
void midiAllSoundOff(midiPlayer_t *player)
Stop all sound immediately. This is not affected by the sustain pedal.
Definition midiPlayer.c:1400
const char * name
The name of this timbre, if any.
Definition midiPlayer.h:508
void(* midiTextCallback_t)(metaEventType_t type, const char *text, uint32_t length)
A function to handle text meta-messages from playing MIDI files.
Definition midiPlayer.h:424
#define MIDI_CHANNEL_COUNT
Definition midiPlayer.h:71
bool eventAvailable
True if pendingEvent is valid, false if it must be updated.
Definition midiPlayer.h:705
midiTextCallback_t textMessageCallback
A callback to call when a text meta-message is received.
Definition midiPlayer.h:683
uint64_t sampleCount
The number of samples elapsed in the playing song.
Definition midiPlayer.h:699
q24_8 decayTimeVel
This value will be multiplied by the note velocity and added to the decay time.
Definition midiPlayer.h:379
uint32_t allocedVoices
A bitmap of which voices have been allocated to this channel.
Definition midiPlayer.h:619
uint16_t selectedParameter
The ID of the currently selected registered or non-registered parameter.
Definition midiPlayer.h:613
void midiAllNotesOff(midiPlayer_t *player, uint8_t channel)
Tun off all notes which are currently on, as though midiNoteOff() were called for each note....
Definition midiPlayer.c:1538
uint32_t release
Bitfield of voices currently in the release stage.
Definition midiPlayer.h:586
bool seeking
True when the MIDI player is seeking, and will not produce sound.
Definition midiPlayer.h:714
uint8_t midiGetControlValue(midiPlayer_t *player, uint8_t channel, midiControl_t control)
Get the value of a MIDI control.
Definition midiPlayer.c:2156
void globalMidiPlayerPlaySongCb(midiFile_t *song, uint8_t trackType, songFinishedCbFn cb)
Play a song on noe of the system-wide MIDI players, with a callback once the song finishes.
Definition midiPlayer.c:2513
uint16_t bank
The bank to use for program changes on this channel.
Definition midiPlayer.h:604
uint32_t transitionTicks
The number of samples remaining before transitioning to the next state.
Definition midiPlayer.h:519
#define OSC_PER_VOICE
Definition midiPlayer.h:77
uint8_t program
The ID of the program (timbre) set for this channel.
Definition midiPlayer.h:607
uint32_t on
Whether this note is set to on via MIDI, regardless of if it's making sound.
Definition midiPlayer.h:574
void midiControlChange(midiPlayer_t *player, uint8_t channel, midiControl_t control, uint8_t val)
Set a MIDI control value.
Definition midiPlayer.c:1974
midiPlayerMode_t mode
Whether this player is playing a song or a MIDI stream.
Definition midiPlayer.h:674
uint16_t volume
The 14-bit volume level for this channel only.
Definition midiPlayer.h:601
void midiSetFile(midiPlayer_t *player, const midiFile_t *file)
Configure this MIDI player to read from a MIDI file.
Definition midiPlayer.c:2341
songFinishedCbFn songFinishedCallback
A callback to call when the playing song is finished.
Definition midiPlayer.h:686
void initGlobalMidiPlayer(void)
Initialize the system-wide MIDI players for both BGM and SFX.
Definition midiPlayer.c:2459
timbreFlags_t flags
Flags bitfield for this timbre.
Definition midiPlayer.h:441
void midiPause(midiPlayer_t *player, bool pause)
Set the paused state of a MIDI song.
Definition midiPlayer.c:2360
midiControl_t
Defines the MIDI continuous controller registers.
Definition midiPlayer.h:250
@ MCC_GP_BUTTON_1
Definition midiPlayer.h:311
@ MCC_PAN_LSB
Definition midiPlayer.h:281
@ MCC_OMNI_MODE_ON
Definition midiPlayer.h:342
@ MCC_EFFECT_1_MSB
Definition midiPlayer.h:263
@ MCC_DETUNE_LEVEL
Definition midiPlayer.h:322
@ MCC_BREATH_LSB
Definition midiPlayer.h:273
@ MCC_BANK_LSB
Definition midiPlayer.h:271
@ MCC_MODULATION_WHEEL_MSB
Definition midiPlayer.h:252
@ MCC_PORTAMENTO
Definition midiPlayer.h:289
@ MCC_SOUND_CONTROL_10
Definition midiPlayer.h:309
@ MCC_GP_SLIDER_4
Definition midiPlayer.h:269
@ MCC_FOOT_PEDAL_MSB
Definition midiPlayer.h:255
@ MCC_BALANCE_MSB
Definition midiPlayer.h:259
@ MCC_LOCAL_KEYBOARD
Definition midiPlayer.h:336
@ MCC_FOOT_PEDAL_LSB
Definition midiPlayer.h:275
@ MCC_PAN_MSB
Definition midiPlayer.h:261
@ MCC_SOUND_CONTROL_7
Definition midiPlayer.h:306
@ MCC_REGISTERED_PARAM_MSB
Definition midiPlayer.h:329
@ MCC_VOLUME_LSB
Definition midiPlayer.h:278
@ MCC_OMNI_MODE_OFF
Definition midiPlayer.h:340
@ MCC_HOLD_PEDAL
Definition midiPlayer.h:287
@ MCC_GP_BUTTON_2
Definition midiPlayer.h:313
@ MCC_NON_REGISTERED_PARAM_MSB
Definition midiPlayer.h:327
@ MCC_GP_SLIDER_2
Definition midiPlayer.h:267
@ MCC_ALL_SOUND_OFF
Definition midiPlayer.h:332
@ MCC_HOLD_2_PEDAL
Definition midiPlayer.h:297
@ MCC_PORTAMENTO_TIME_MSB
Definition midiPlayer.h:256
@ MCC_DATA_BUTTON_DEC
Definition midiPlayer.h:325
@ MCC_LEGATO_PEDAL
Definition midiPlayer.h:295
@ MCC_PORTAMENTO_TIME_LSB
Definition midiPlayer.h:276
@ MCC_SOUND_CONTROL_8
Definition midiPlayer.h:307
@ MCC_EFFECT_2_LSB
Definition midiPlayer.h:284
@ MCC_DATA_ENTRY_LSB
Definition midiPlayer.h:277
@ MCC_VOLUME_MSB
Definition midiPlayer.h:258
@ MCC_DATA_BUTTON_INC
Definition midiPlayer.h:324
@ MCC_BREATH_MSB
Definition midiPlayer.h:253
@ MCC_EFFECT_2_MSB
Definition midiPlayer.h:264
@ MCC_SOFT_PEDAL
Definition midiPlayer.h:293
@ MCC_SOUND_VARIATION
Definition midiPlayer.h:298
@ MCC_PHASER_LEVEL
Definition midiPlayer.h:323
@ MCC_CHORUS_LEVEL
Definition midiPlayer.h:321
@ MCC_EFFECT_1_LSB
Definition midiPlayer.h:283
@ MCC_DATA_ENTRY_MSB
Definition midiPlayer.h:257
@ MCC_ALL_CONTROLS_OFF
Definition midiPlayer.h:334
@ MCC_BANK_MSB
Definition midiPlayer.h:251
@ MCC_BALANCE_LSB
Definition midiPlayer.h:279
@ MCC_EXPRESSION_LSB
Definition midiPlayer.h:282
@ MCC_GP_BUTTON_4
Definition midiPlayer.h:317
@ MCC_SOUND_BRIGHTNESS
Definition midiPlayer.h:302
@ MCC_SOUND_TIMBRE
Definition midiPlayer.h:299
@ MCC_SOUND_CONTROL_9
Definition midiPlayer.h:308
@ MCC_MODULATION_WHEEL_LSB
Definition midiPlayer.h:272
@ MCC_GP_SLIDER_3
Definition midiPlayer.h:268
@ MCC_SOUND_ATTACK_TIME
Definition midiPlayer.h:301
@ MCC_SOUND_RELEASE_TIME
Definition midiPlayer.h:300
@ MCC_REGISTERED_PARAM_LSB
Definition midiPlayer.h:328
@ MCC_NON_REGISTERED_PARAM_LSB
Definition midiPlayer.h:326
@ MCC_MONO_OPERATION
Definition midiPlayer.h:344
@ MCC_ALL_NOTE_OFF
Definition midiPlayer.h:338
@ MCC_TREMOLO_LEVEL
Definition midiPlayer.h:320
@ MCC_EFFECTS_LEVEL
Definition midiPlayer.h:319
@ MCC_SOUND_CONTROL_6
Definition midiPlayer.h:304
@ MCC_SUSTENUTO_PEDAL
Definition midiPlayer.h:291
@ MCC_POLY_OPERATION
Definition midiPlayer.h:346
@ MCC_EXPRESSION_MSB
Definition midiPlayer.h:262
@ MCC_GP_SLIDER_1
Definition midiPlayer.h:266
@ MCC_GP_BUTTON_3
Definition midiPlayer.h:315
uint32_t sampleTick
The monotonic tick counter for playback of sampled timbres.
Definition midiPlayer.h:531
uint16_t midiGetParameterValue(midiPlayer_t *player, uint8_t channel, bool registered, uint16_t param)
Get the value of a registered or non-registered parameter.
Definition midiPlayer.c:2273
void(* songFinishedCbFn)(void)
Callback function used to provide feedback when a song finishes playing.
Definition midiPlayer.h:113
bool ignore
If set, events on this channel will be completely ignored.
Definition midiPlayer.h:634
uint32_t sustain
Bitfield of voices currently in the sustain stage.
Definition midiPlayer.h:580
percussionNote_t
Defines the MIDI note numbers mapped to by the General MIDI percussion note names.
Definition midiPlayer.h:161
@ OPEN_TRIANGLE
This note supersedes any MUTE_TRIANGLE or OPEN_TRIANGLE notes playing.
Definition midiPlayer.h:229
@ COWBELL
Definition midiPlayer.h:196
@ ACOUSTIC_SNARE
Definition midiPlayer.h:175
@ CLOSED_HI_HAT
This note supersedes any CLOSED_HI_HAT, PEDAL_HI_HAT, or OPEN_HI_HAT notes playing.
Definition midiPlayer.h:180
@ LOW_BONGO
Definition midiPlayer.h:201
@ HIGH_BONGO
Definition midiPlayer.h:200
@ CHINESE_CYMBAL
Definition midiPlayer.h:192
@ RIDE_CYMBAL_2
Definition midiPlayer.h:199
@ LONG_GUIRO
This note supersedes any SHORT_GUIRO or LONG_GUIRO notes playing.
Definition midiPlayer.h:218
@ RIDE_BELL
Definition midiPlayer.h:193
@ SHORT_GUIRO
This note supersedes any SHORT_GUIRO or LONG_GUIRO notes playing.
Definition midiPlayer.h:216
@ HIGH_TOM
Definition midiPlayer.h:190
@ MUTE_CUICA
This note supersedes any SHORT_GUIRO or LONG_GUIRO notes playing.
Definition midiPlayer.h:223
@ CABASA
Definition midiPlayer.h:209
@ CRASH_CYMBAL_2
Definition midiPlayer.h:197
@ CRASH_CYMBAL_1
Definition midiPlayer.h:189
@ LOW_MID_TOM
Definition midiPlayer.h:187
@ LOW_AGOGO
Definition midiPlayer.h:208
@ HIGH_TIMBALE
Definition midiPlayer.h:205
@ SIDE_STICK
Definition midiPlayer.h:174
@ RIDE_CYMBAL_1
Definition midiPlayer.h:191
@ ELECTRIC_SNARE_OR_RIMSHOT
Definition midiPlayer.h:177
@ CLAVES
Definition midiPlayer.h:219
@ OPEN_HIGH_CONGA
Definition midiPlayer.h:203
@ LONG_WHISTLE
This note supersedes any SHORT_WHISTLE or LONG_WHISTLE notes playing.
Definition midiPlayer.h:214
@ LOW_TOM
Definition midiPlayer.h:184
@ HIGH_AGOGO
Definition midiPlayer.h:207
@ TAMBOURINE
Definition midiPlayer.h:194
@ HIGH_MID_TOM
Definition midiPlayer.h:188
@ MUTE_HIGH_CONGA
Definition midiPlayer.h:202
@ SPLASH_CYMBAL
Definition midiPlayer.h:195
@ HIGH_WOODBLOCK
Definition midiPlayer.h:220
@ LOW_FLOOR_TOM
Definition midiPlayer.h:178
@ VIBRASLAP
Definition midiPlayer.h:198
@ SHORT_WHISTLE
This note supersedes any SHORT_WHISTLE or LONG_WHISTLE notes playing.
Definition midiPlayer.h:212
@ PEDAL_HI_HAT
This note supersedes any CLOSED_HI_HAT, PEDAL_HI_HAT, or OPEN_HI_HAT notes playing.
Definition midiPlayer.h:183
@ LOW_CONGA
Definition midiPlayer.h:204
@ LOW_TIMBALE
Definition midiPlayer.h:206
@ OPEN_CUICA
This note supersedes any SHORT_GUIRO or LONG_GUIRO notes playing.
Definition midiPlayer.h:225
@ ELECTRIC_BASS_DRUM_OR_HIGH_BASS_DRUM
Definition midiPlayer.h:173
@ LOW_WOODBLOCK
Definition midiPlayer.h:221
@ HIGH_FLOOR_TOM
Definition midiPlayer.h:181
@ MARACAS
Definition midiPlayer.h:210
@ HAND_CLAP
Definition midiPlayer.h:176
@ MUTE_TRIANGLE
This note supersedes any MUTE_TRIANGLE or OPEN_TRIANGLE notes playing.
Definition midiPlayer.h:227
@ OPEN_HI_HAT
This note supersedes any CLOSED_HI_HAT, PEDAL_HI_HAT, or OPEN_HI_HAT notes playing.
Definition midiPlayer.h:186
@ ACOUSTIC_BASS_DRUM_OR_LOW_BASS_DRUM
Definition midiPlayer.h:172
uint8_t chorus
The number of chorused voices to mix.
Definition midiPlayer.h:403
void globalMidiPlayerSetVolume(uint8_t trackType, int32_t volumeSetting)
Set the volume using a value from 0 to 13.
Definition midiPlayer.c:2522
void midiPlayerFillBufferMulti(midiPlayer_t *players, uint8_t playerCount, uint8_t *samples, int16_t len)
Fill a buffer with the next set of samples from an array of MIDI players.
Definition midiPlayer.c:1365
midiPlayer_t * globalMidiPlayerGet(uint8_t trackType)
Return a pointer to the system-wide MIDI player for the given track type, either MIDI_SFX or MIDI_BGM...
Definition midiPlayer.c:2583
uint16_t pitchBend
The 14-bit pitch wheel value.
Definition midiPlayer.h:622
bool(* midiStreamingCallback_t)(midiEvent_t *event)
A function to return MIDI events in streaming mode.
Definition midiPlayer.h:430
void midiSetTempo(midiPlayer_t *player, uint32_t tempo)
Change the MIDI playback tempo.
Definition midiPlayer.c:2333
void * globalMidiSave(void)
Stop all MIDI playback and return a pointer containing the full playback state. This state must be pa...
Definition midiFileParser.c:1019
uint8_t targetVol
The target volume of this tick.
Definition midiPlayer.h:528
int8_t(* percussionFunc_t)(percussionNote_t drum, uint32_t idx, bool *done, uint32_t scratch[4], void *data)
A function that returns samples for a percussion timbre rather than a melodic one.
Definition midiPlayer.h:415
void midiPlayerReset(midiPlayer_t *player)
Reset the MIDI player state.
Definition midiPlayer.c:1224
midiStreamingCallback_t streamingCallback
A callback function to retrieve the next event, when in MIDI_STREAMING mode.
Definition midiPlayer.h:680
timbreFlags_t
A bitfield which may contain various flags for a timbre.
Definition midiPlayer.h:148
@ TF_PERCUSSION
This timbre plays percussion sounds (percussionNote_t) rather than melodic notes.
Definition midiPlayer.h:152
@ TF_MONO
This timbre represents a monophonic instrument.
Definition midiPlayer.h:154
@ TF_NONE
No flags.
Definition midiPlayer.h:150
timbreEffects_t effects
Various effects applied to this timbre. May be ignored by percussion timbres.
Definition midiPlayer.h:505
Describes the characteristics of a particular timbre while.
Definition midiPlayer.h:368
Tracks the state of a single MIDI channel.
Definition midiPlayer.h:599
Tracks the state of the entire MIDI apparatus.
Definition midiPlayer.h:641
Defines the sound characteristics of a particular instrument.
Definition midiPlayer.h:436
Tracks the state of a single voice, playing a single note.
Definition midiPlayer.h:517
Definition midiPlayer.h:401
Holds several bitfields that track the state of each voice for fast access. This may be used for dyna...
Definition midiPlayer.h:572
oscillatorShape_t
The different wave shapes that can be generated.
Definition swSynth.h:65
int8_t(* waveFunc_t)(uint16_t idx, void *data)
Function typedef to return a sample from a wave.
Definition swSynth.h:97
A software oscillator with controllable frequency, amplitude, and shape.
Definition swSynth.h:107