diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile.am | 4 | ||||
| -rw-r--r-- | src/audiofile.cc | 6 | ||||
| -rw-r--r-- | src/drumgizmo.cc | 6 | ||||
| -rw-r--r-- | src/midimapper.cc | 8 | ||||
| -rw-r--r-- | src/midiplayer.cc | 58 | ||||
| -rw-r--r-- | src/midiplayer.h | 5 | 
6 files changed, 69 insertions, 18 deletions
| diff --git a/src/Makefile.am b/src/Makefile.am index 2108c43..5ec0802 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -1,8 +1,8 @@  bin_PROGRAMS = drumgizmo -drumgizmo_LDADD = $(JACK_LIBS) $(SNDFILE_LIBS) +drumgizmo_LDADD = $(JACK_LIBS) $(SNDFILE_LIBS) $(SMF_LIBS) -drumgizmo_CXXFLAGS = $(JACK_CXXFLAGS) $(SNDFILE_CXXFLAGS) +drumgizmo_CXXFLAGS = $(JACK_CXXFLAGS) $(SNDFILE_CXXFLAGS) $(SMF_CFLAGS)  drumgizmo_SOURCES = \  	audiofile.cc \ diff --git a/src/audiofile.cc b/src/audiofile.cc index a556bca..9c00bed 100644 --- a/src/audiofile.cc +++ b/src/audiofile.cc @@ -41,12 +41,12 @@ AudioFile::AudioFile(std::string filename, bool preload, int min_velocity)    int num = atoi(p);    if(num < 0) num *= -1; -  printf("%s", filename.c_str()); +  //printf("%s", filename.c_str());    if(preload && num  >= min_velocity) { -    printf(" ... loading"); +    //printf(" ... loading");      load();    } -  printf("\n"); +  printf("."); fflush(stdout);  }  AudioFile::~AudioFile() diff --git a/src/drumgizmo.cc b/src/drumgizmo.cc index a4d863f..3941f17 100644 --- a/src/drumgizmo.cc +++ b/src/drumgizmo.cc @@ -136,7 +136,11 @@ int main(int argc, char *argv[])    client.activate(); -  if(midifile) MidiPlayer player(midifile); +  if(midifile) { +    MidiPlayer player(midifile); +     +    while(1) sleep(1); +  }    while(1) sleep(1); diff --git a/src/midimapper.cc b/src/midimapper.cc index 1d2c7a8..6bf38c7 100644 --- a/src/midimapper.cc +++ b/src/midimapper.cc @@ -26,7 +26,7 @@   */  #include "midimapper.h" -#define NOTE_ON 0x90 +#define NOTE_ON 0x9  MidiMapper::MidiMapper(DrumKit *drumkit)  { @@ -64,8 +64,10 @@ Sample *MidiMapper::map(jack_midi_event_t event)  {    Sample *sample = NULL; +  //  printf("m"); fflush(stdout); +    if(event.size != 3) return NULL; -  if(event.buffer[0] != NOTE_ON) return NULL; +  if(event.buffer[0] & NOTE_ON != NOTE_ON) return NULL;    int key = event.buffer[1];    int velocity = event.buffer[2]; @@ -81,7 +83,7 @@ Sample *MidiMapper::map(jack_midi_event_t event)    printf("]\n");    */    if(drumkit->instruments.find(key) == drumkit->instruments.end()) { -    printf("Unknown intrsument %d\n", key); +    printf("Unknown instrument %d\n", key);      return NULL;    } diff --git a/src/midiplayer.cc b/src/midiplayer.cc index f8c462b..b55b225 100644 --- a/src/midiplayer.cc +++ b/src/midiplayer.cc @@ -26,8 +26,6 @@   */  #include "midiplayer.h" -#define NOTE_ON 0x90 -  int _process(jack_nframes_t nframes, void *arg)  {    return ((MidiPlayer*)arg)->process(nframes); @@ -35,9 +33,16 @@ int _process(jack_nframes_t nframes, void *arg)  MidiPlayer::MidiPlayer(std::string filename)  { +  timeline = 0; +  cur_event = NULL; + +  printf("Loading MIDI file: %s\n", filename.c_str()); +  smf = smf_load(filename.c_str()); +  printf("done\n"); +  	jack_status_t status; -  jack_client_t *jack_client = jack_client_open("MidiTest", JackNullOption, &status); +  jack_client_t *jack_client = jack_client_open("MidiGizmo", JackNullOption, &status);  	port = jack_port_register(jack_client,                              "midi_out", @@ -49,8 +54,9 @@ MidiPlayer::MidiPlayer(std::string filename)  	jack_activate(jack_client); -  jack_connect(jack_client, "MidiTest:midi_out", "DrumGizmo:midi_in"); +  jack_connect(jack_client, "MidiGizmo:midi_out", "DrumGizmo:midi_in"); +  jack_connect(jack_client, "DrumGizmo:Alesis", "system:playback_1");    jack_connect(jack_client, "DrumGizmo:Kick-R", "system:playback_1");    jack_connect(jack_client, "DrumGizmo:Kick-L", "system:playback_1");    jack_connect(jack_client, "DrumGizmo:SnareTop", "system:playback_1"); @@ -63,6 +69,7 @@ MidiPlayer::MidiPlayer(std::string filename)    jack_connect(jack_client, "DrumGizmo:Ride", "system:playback_1");    //  jack_connect(jack_client, "DrumGizmo:Hihat", "system:playback_1"); +  jack_connect(jack_client, "DrumGizmo:Alesis", "system:playback_2");    jack_connect(jack_client, "DrumGizmo:Kick-R", "system:playback_2");    jack_connect(jack_client, "DrumGizmo:Kick-L", "system:playback_2");    jack_connect(jack_client, "DrumGizmo:SnareTop", "system:playback_2"); @@ -80,12 +87,15 @@ MidiPlayer::MidiPlayer(std::string filename)    jack_connect(jack_client, "DrumGizmo:Amb-R", "system:playback_1");    jack_connect(jack_client, "DrumGizmo:Amb-L", "system:playback_2"); +  /*    timer = 0;    next = 44100; +  */  }  MidiPlayer::~MidiPlayer()  { +  smf_delete(smf);  }  #if 0 // All @@ -93,12 +103,12 @@ MidiPlayer::~MidiPlayer()  static int inst[] = { 35, 36, 38, 46, 41, 43, 45, 47, 49, 57, 51 };  #endif -#if 1 // Cymbals +#if 0 // Cymbals  #define NUM_INST 3  static int inst[] = { 51, 49, 57 };  #endif -#if 0 // Toms +#if 1 // Toms  #define NUM_INST 4  static int inst[] = { 41, 43, 45, 47 };  #endif @@ -109,13 +119,42 @@ static int inst[] = { 35, 36 };  #endif  int MidiPlayer::process(jack_nframes_t nframes)  { -  return 0; -    //  if(jack_port_connected_to(test_midi_port, "DrumGizmo:midi_in")) {    void* port_buf = jack_port_get_buffer(port, nframes); +     + +  double cur_max_time = (double)(timeline + nframes) / 44100.0; +  double cur_min_time = (double)(timeline) / 44100.0; + +  printf("["); fflush(stdout); + +  if(!cur_event) cur_event = smf_get_next_event(smf); +  do { +    if(cur_event) { +      if(!smf_event_is_metadata(cur_event)) { + +        printf("p"); fflush(stdout); + +        jack_nframes_t time = (jack_nframes_t)((cur_event->time_seconds - cur_min_time) * 44100.0); +        jack_midi_event_write(port_buf, time, (jack_midi_data_t*)cur_event->midi_buffer, +                              cur_event->midi_buffer_length); +      } +    } else { +      smf_rewind(smf); +    } +    cur_event = smf_get_next_event(smf); +    while(!cur_event) cur_event = smf_get_next_event(smf); +  } while(cur_event->time_seconds < cur_max_time && cur_event->time_seconds >= cur_min_time); + +  timeline += nframes; + +  printf("]\n"); fflush(stdout); + + +  /*    if(timer > next) { // activate every second (44100 samples) -    //    printf("ding\n"); +      jack_nframes_t time = (jack_nframes_t)(((float)rand() / (float)RAND_MAX) * nframes);      size_t size = 3; @@ -127,6 +166,7 @@ int MidiPlayer::process(jack_nframes_t nframes)    }    timer += nframes; +  */    return 0;  } diff --git a/src/midiplayer.h b/src/midiplayer.h index 3694939..e41c73a 100644 --- a/src/midiplayer.h +++ b/src/midiplayer.h @@ -30,6 +30,7 @@  #include <jack/jack.h>  #include <jack/midiport.h>  #include <string> +#include <smf.h>  class MidiPlayer {  public: @@ -44,6 +45,10 @@ private:    size_t timer;    size_t next; + +  smf_t *smf; +  smf_event_t *cur_event; +  unsigned int timeline;  };  #endif/*__DRUMGIZMO_MIDIPLAYER_H__*/ | 
