next event calculation properly based on frames played in performace time now

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3401 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
beveloper 2003-06-03 01:15:18 +00:00
parent f180ef79b2
commit 11b92ae72b
2 changed files with 4 additions and 4 deletions

View File

@ -1242,7 +1242,7 @@ AudioMixer::HandleEvent( const media_timed_event *event, bigtime_t lateness, boo
// if this is the first buffer, mark with the start time // if this is the first buffer, mark with the start time
// we need this to calculate the other buffer times // we need this to calculate the other buffer times
if (fStartTime == 0) { if (fStartTime == 0) {
fStartTime = TimeSource()->RealTimeFor(event->event_time, 0); fStartTime = event->event_time;
} }
// count frames that have been played // count frames that have been played
@ -1252,7 +1252,7 @@ AudioMixer::HandleEvent( const media_timed_event *event, bigtime_t lateness, boo
fFramesSent += framesperbuffer; fFramesSent += framesperbuffer;
// calculate the start time for the next event and add the event // calculate the start time for the next event and add the event
bigtime_t nextevent = TimeSource()->PerformanceTimeFor(bigtime_t(fStartTime + double(fFramesSent / fOutput.format.u.raw_audio.frame_rate) * 1000000.0)); bigtime_t nextevent = bigtime_t(fStartTime + double(fFramesSent / fOutput.format.u.raw_audio.frame_rate) * 1000000.0);
media_timed_event nextBufferEvent(nextevent, SEND_NEW_BUFFER_EVENT); media_timed_event nextBufferEvent(nextevent, SEND_NEW_BUFFER_EVENT);
EventQueue()->AddEvent(nextBufferEvent); EventQueue()->AddEvent(nextBufferEvent);
break; break;

View File

@ -608,7 +608,7 @@ _SoundPlayNode::SendNewBuffer(const media_timed_event *event, bigtime_t lateness
// The buffer is on its way; now schedule the next one to go // The buffer is on its way; now schedule the next one to go
// nextEvent is the time at which the buffer should arrive at it's destination // nextEvent is the time at which the buffer should arrive at it's destination
bigtime_t nextEvent = TimeSource()->PerformanceTimeFor(mStartTime + bigtime_t((1000000LL * mFramesSent) / mOutput.format.u.raw_audio.frame_rate)); bigtime_t nextEvent = mStartTime + bigtime_t((1000000LL * mFramesSent) / mOutput.format.u.raw_audio.frame_rate);
media_timed_event nextBufferEvent(nextEvent, SEND_NEW_BUFFER_EVENT); media_timed_event nextBufferEvent(nextEvent, SEND_NEW_BUFFER_EVENT);
EventQueue()->AddEvent(nextBufferEvent); EventQueue()->AddEvent(nextBufferEvent);
@ -650,7 +650,7 @@ _SoundPlayNode::HandleStart(
// and fire off the first "produce a buffer" event. // and fire off the first "produce a buffer" event.
mFramesSent = 0; mFramesSent = 0;
mStartTime = TimeSource()->RealTimeFor(event->event_time, 0); mStartTime = event->event_time;
media_timed_event firstBufferEvent(event->event_time, SEND_NEW_BUFFER_EVENT); media_timed_event firstBufferEvent(event->event_time, SEND_NEW_BUFFER_EVENT);
// Alternatively, we could call HandleEvent() directly with this event, to avoid a trip through // Alternatively, we could call HandleEvent() directly with this event, to avoid a trip through