X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dos_auplay;a=blobdiff_plain;f=src%2Fmain.c;fp=src%2Fmain.c;h=f62fdac11a82858c2a1846e96f3673bd12731e13;hp=4395af6db91028fd42e2f4e31540a7b6df86a15a;hb=43cd2e73225cd66e61d1e9754afcaa7eca02fcb7;hpb=49ef4e243def029b7e68bf92141acbeac600e1e8 diff --git a/src/main.c b/src/main.c index 4395af6..f62fdac 100644 --- a/src/main.c +++ b/src/main.c @@ -1,6 +1,8 @@ #include #include #include +#include +#include #include "aufile.h" #include "audio.h" @@ -10,6 +12,9 @@ static int play_file(const char *fname); static int cbfunc(void *buf, int size, void *cls); static void print_usage(const char *argv0); +static int vol = 220; +static int quit; + int main(int argc, char **argv) { int i; @@ -17,6 +22,7 @@ int main(int argc, char **argv) if(audio_init() == -1) { return 1; } + audio_volume(vol); for(i=1; irate, au->bits, au->chan); - while(audio_isplaying()); + while(audio_isplaying()) { + if(kbhit()) { + int c = getch(); + switch(c) { + case 27: + audio_stop(); + quit = 1; + goto end; + + case ' ': + paused = !paused; + if(paused) { + audio_pause(); + printf("pause\n"); + } else { + audio_resume(); + printf("resume\n"); + } + break; + + case '=': + vol += 32; + if(vol > 255) vol = 255; + audio_volume(vol); + printf("volume: %d%%\n", 101 * vol / 256); + break; + + case '-': + vol -= 32; + if(vol < 0) vol = 0; + audio_volume(vol); + printf("volume: %d%%\n", 101 * vol / 256); + break; + + default: + break; + } + } + + _disable(); + if(dbg_cur_offs != prev) { + prev = dbg_cur_offs; + _enable(); + + printf("%3d%% - offs: %lu/%lu\n", 100 * prev / au->size, prev, au->size); + } else { + _enable(); + } + + } +end: au_close(au); #ifdef DBG_PRELOAD free(dbg_samples);