diff options
Diffstat (limited to 'apps/codecs/wavpack.c')
| -rw-r--r-- | apps/codecs/wavpack.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/apps/codecs/wavpack.c b/apps/codecs/wavpack.c index 275f5f1..0da8a89 100644 --- a/apps/codecs/wavpack.c +++ b/apps/codecs/wavpack.c @@ -47,7 +47,7 @@ enum codec_status codec_start(struct codec_api* api) { WavpackContext *wpc; char error [80]; - int bps, nchans; + int bps, nchans, sr_100; /* Generic codec initialisation */ TEST_CODEC_API(api); @@ -90,6 +90,7 @@ enum codec_status codec_start(struct codec_api* api) bps = WavpackGetBytesPerSample (wpc); nchans = WavpackGetReducedChannels (wpc); + sr_100 = ci->id3->frequency / 100; ci->set_elapsed (0); @@ -99,7 +100,7 @@ enum codec_status codec_start(struct codec_api* api) long nsamples; if (ci->seek_time && ci->taginfo_ready && ci->id3->length) { - int curpos_ms = (WavpackGetSampleIndex (wpc) + 220) / 441 * 10; + int curpos_ms = WavpackGetSampleIndex (wpc) / sr_100 * 10; int n, d, skip; if (ci->seek_time > curpos_ms) { @@ -121,7 +122,7 @@ enum codec_status codec_start(struct codec_api* api) if (!wpc) break; - ci->set_elapsed ((int)((long long) WavpackGetSampleIndex (wpc) * 1000 / 44100)); + ci->set_elapsed (WavpackGetSampleIndex (wpc) / sr_100 * 10); rb->yield (); } @@ -189,7 +190,7 @@ enum codec_status codec_start(struct codec_api* api) while (!ci->audiobuffer_insert ((char *) temp_buffer, nsamples * 4)) rb->yield (); - ci->set_elapsed ((WavpackGetSampleIndex (wpc) + 220) / 441 * 10); + ci->set_elapsed (WavpackGetSampleIndex (wpc) / sr_100 * 10); } if (ci->request_next_track()) |