fix some seeking stuff for mp3's
git-svn-id: https://svn.musicpd.org/mpd/trunk@1106 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
4db5224b47
commit
52d4200cb1
8
TODO
8
TODO
@ -2,8 +2,7 @@
|
|||||||
a) make seekings non-blocking:
|
a) make seekings non-blocking:
|
||||||
1) player:
|
1) player:
|
||||||
a) first check that seekWhere isn't already buffered
|
a) first check that seekWhere isn't already buffered
|
||||||
2) check that stream is seekable before seeking forward!
|
2) deal with seeking forward better by calling seek function
|
||||||
3) deal with seeking forward better by calling seek function
|
|
||||||
(for mp3 and mp4)!
|
(for mp3 and mp4)!
|
||||||
b) bufferInput in outputBuffer waiting!
|
b) bufferInput in outputBuffer waiting!
|
||||||
1) implement some sort of callback mechanism for this
|
1) implement some sort of callback mechanism for this
|
||||||
@ -15,12 +14,11 @@
|
|||||||
3) if not seekable, reset buffer, and elapsedTime when
|
3) if not seekable, reset buffer, and elapsedTime when
|
||||||
unpaused
|
unpaused
|
||||||
d) put some sort of error reporting for streaming/inputStream!
|
d) put some sort of error reporting for streaming/inputStream!
|
||||||
e) ogg streams
|
e) fetch metadata and store in DecoderControl and pass to
|
||||||
f) fetch metadata and store in DecoderControl and pass to
|
|
||||||
PlayerControl
|
PlayerControl
|
||||||
1) eventually deal with icy-metadata
|
1) eventually deal with icy-metadata
|
||||||
2) parse metadata on the fly in decoders
|
2) parse metadata on the fly in decoders
|
||||||
g) command for dealing with the changing metadata, currentsonginfo
|
f) command for dealing with the changing metadata, currentsonginfo
|
||||||
or something
|
or something
|
||||||
|
|
||||||
2) how to deal with streams and the db
|
2) how to deal with streams and the db
|
||||||
|
@ -55,6 +55,9 @@
|
|||||||
#define DECODE_CONT -1
|
#define DECODE_CONT -1
|
||||||
#define DECODE_OK 0
|
#define DECODE_OK 0
|
||||||
|
|
||||||
|
#define MUTEFRAME_SKIP 1
|
||||||
|
#define MUTEFRAME_SEEK 2
|
||||||
|
|
||||||
/* this is stolen from mpg321! */
|
/* this is stolen from mpg321! */
|
||||||
struct audio_dither {
|
struct audio_dither {
|
||||||
mad_fixed_t error[3];
|
mad_fixed_t error[3];
|
||||||
@ -356,7 +359,7 @@ int decodeFirstFrame(mp3DecodeData * data, DecoderControl * dc) {
|
|||||||
if(xing.flags & XING_FRAMES) {
|
if(xing.flags & XING_FRAMES) {
|
||||||
mad_timer_t duration = data->frame.header.duration;
|
mad_timer_t duration = data->frame.header.duration;
|
||||||
mad_timer_multiply(&duration,xing.frames);
|
mad_timer_multiply(&duration,xing.frames);
|
||||||
data->muteFrame = 1;
|
data->muteFrame = MUTEFRAME_SKIP;
|
||||||
data->totalTime = ((float)mad_timer_count(duration,
|
data->totalTime = ((float)mad_timer_count(duration,
|
||||||
MAD_UNITS_MILLISECONDS))/1000;
|
MAD_UNITS_MILLISECONDS))/1000;
|
||||||
data->maxFrames = xing.frames;
|
data->maxFrames = xing.frames;
|
||||||
@ -429,10 +432,10 @@ int openMp3FromInputStream(InputStream * inStream, mp3DecodeData * data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
||||||
static int i;
|
int i;
|
||||||
static int ret;
|
int ret;
|
||||||
static struct audio_dither dither;
|
struct audio_dither dither;
|
||||||
static int skip;
|
int skip;
|
||||||
|
|
||||||
if(data->currentFrame>=data->highestFrame) {
|
if(data->currentFrame>=data->highestFrame) {
|
||||||
mad_timer_add(&data->timer,(data->frame).header.duration);
|
mad_timer_add(&data->timer,(data->frame).header.duration);
|
||||||
@ -457,18 +460,19 @@ int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
|||||||
data->currentFrame++;
|
data->currentFrame++;
|
||||||
data->elapsedTime = ((float)mad_timer_count(data->timer,MAD_UNITS_MILLISECONDS))/1000;
|
data->elapsedTime = ((float)mad_timer_count(data->timer,MAD_UNITS_MILLISECONDS))/1000;
|
||||||
|
|
||||||
if(data->muteFrame) {
|
switch(data->muteFrame) {
|
||||||
if(!dc->seek) data->muteFrame = 0;
|
case MUTEFRAME_SKIP:
|
||||||
else if(dc->seekWhere<=data->elapsedTime) {
|
data->muteFrame = 0;
|
||||||
|
break;
|
||||||
|
case MUTEFRAME_SEEK:
|
||||||
|
if(dc->seekWhere<=data->elapsedTime) {
|
||||||
clearOutputBuffer(cb);
|
clearOutputBuffer(cb);
|
||||||
dc->seekChunk = cb->end;
|
dc->seekChunk = cb->end;
|
||||||
data->muteFrame = 0;
|
data->muteFrame = 0;
|
||||||
dc->seek = 0;
|
dc->seek = 0;
|
||||||
}
|
}
|
||||||
}
|
break;
|
||||||
else {
|
default:
|
||||||
long ret;
|
|
||||||
|
|
||||||
mad_synth_frame(&data->synth,&data->frame);
|
mad_synth_frame(&data->synth,&data->frame);
|
||||||
|
|
||||||
for(i=0;i<(data->synth).pcm.length;i++) {
|
for(i=0;i<(data->synth).pcm.length;i++) {
|
||||||
@ -489,6 +493,7 @@ int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(data->outputPtr==data->outputBufferEnd) {
|
if(data->outputPtr==data->outputBufferEnd) {
|
||||||
|
long ret;
|
||||||
ret = sendDataToOutputBuffer(cb,dc,
|
ret = sendDataToOutputBuffer(cb,dc,
|
||||||
data->outputBuffer,
|
data->outputBuffer,
|
||||||
MP3_DATA_OUTPUT_BUFFER_SIZE,
|
MP3_DATA_OUTPUT_BUFFER_SIZE,
|
||||||
@ -506,7 +511,7 @@ int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
|||||||
|
|
||||||
if(dc->seek) {
|
if(dc->seek) {
|
||||||
long i = 0;
|
long i = 0;
|
||||||
data->muteFrame = 1;
|
data->muteFrame = MUTEFRAME_SEEK;
|
||||||
while(i<data->highestFrame && dc->seekWhere >
|
while(i<data->highestFrame && dc->seekWhere >
|
||||||
((float)mad_timer_count(data->times[i],
|
((float)mad_timer_count(data->times[i],
|
||||||
MAD_UNITS_MILLISECONDS))/1000)
|
MAD_UNITS_MILLISECONDS))/1000)
|
||||||
@ -524,6 +529,7 @@ int mp3Read(mp3DecodeData * data, OutputBuffer * cb, DecoderControl * dc) {
|
|||||||
}
|
}
|
||||||
dc->seek = 0;
|
dc->seek = 0;
|
||||||
}
|
}
|
||||||
|
else if(!data->inStream->seekable) dc->seek = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user