From bdfe87c0f11c152e95cb9034d50cd97e94e7be72 Mon Sep 17 00:00:00 2001 From: Stepan Moskovchenko Date: Mon, 5 Nov 2007 05:35:10 +0000 Subject: MIDI: Make seeking neater by moving it into another file. Will be more useful later. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15467 a1c6a512-1295-4272-9138-f99709370657 --- apps/plugins/midi/midiplay.c | 58 +++----------------------------------------- 1 file changed, 4 insertions(+), 54 deletions(-) (limited to 'apps/plugins/midi/midiplay.c') diff --git a/apps/plugins/midi/midiplay.c b/apps/plugins/midi/midiplay.c index c69c8b1..cc87463 100644 --- a/apps/plugins/midi/midiplay.c +++ b/apps/plugins/midi/midiplay.c @@ -108,7 +108,6 @@ int numberOfSamples IBSS_ATTR; /* the number of samples in the current tick */ int playingTime IBSS_ATTR; /* How many seconds into the file have we been playing? */ int samplesThisSecond IBSS_ATTR; /* How many samples produced during this second so far? */ - long bpm IBSS_ATTR; int32_t gmbuf[BUF_SIZE*NBUF]; @@ -123,6 +122,7 @@ enum plugin_status plugin_start(struct plugin_api* api, void* parameter) { int retval = 0; + PLUGIN_IRAM_INIT(api) rb = api; @@ -317,66 +317,16 @@ static int midimain(void * filename) /* Rewinding is tricky. Basically start the file over */ /* but run through the tracks without the synth running */ rb->pcm_play_stop(); - - int desiredTime = playingTime - 5; /* Rewind 5 sec */ - - if(desiredTime < 0) - desiredTime = 0; - - /* Set controllers to default values */ - resetControllers(); - - /* Set the tempo to defalt */ - bpm=mf->div*1000000/tempo; - numberOfSamples=SAMPLE_RATE/bpm; - - - /* Reset the tracks to start */ - rewindFile(); - - /* Reset the time counter to 0 */ - playingTime = 0; - samplesThisSecond = 0; - - /* Quickly run through any initial things that occur before notes */ - do - { - notesUsed = 0; - for(a=0; apcm_play_data(&get_more, NULL, 0); + break; } case BTN_RIGHT: { - /* Skip 5 seconds forward */ - /* Skipping forward is easy */ - /* Should skip length be retrieved from the RB settings? */ - int samp = 5*SAMPLE_RATE; - - /* Have the issue where numberOfSamples changes within this tick */ - int tickCount = samp / numberOfSamples; - int a=0; - rb->pcm_play_stop(); - - for(a=0; apcm_play_data(&get_more, NULL, 0); break; } -- cgit v1.1