Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(384)

Side by Side Diff: content/renderer/media/renderer_webaudiodevice_impl.cc

Issue 2060833002: Implementation of 'AudioContext.getOutputTimestamp' method (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebased 'global-interface-listing-expected' layout test results Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/renderer/media/renderer_webaudiodevice_impl.h" 5 #include "content/renderer/media/renderer_webaudiodevice_impl.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <string> 9 #include <string>
10 10
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after
103 103
104 int RendererWebAudioDeviceImpl::Render(base::TimeDelta delay, 104 int RendererWebAudioDeviceImpl::Render(base::TimeDelta delay,
105 base::TimeTicks delay_timestamp, 105 base::TimeTicks delay_timestamp,
106 int prior_frames_skipped, 106 int prior_frames_skipped,
107 media::AudioBus* dest) { 107 media::AudioBus* dest) {
108 // Wrap the output pointers using WebVector. 108 // Wrap the output pointers using WebVector.
109 WebVector<float*> web_audio_dest_data(static_cast<size_t>(dest->channels())); 109 WebVector<float*> web_audio_dest_data(static_cast<size_t>(dest->channels()));
110 for (int i = 0; i < dest->channels(); ++i) 110 for (int i = 0; i < dest->channels(); ++i)
111 web_audio_dest_data[i] = dest->channel(i); 111 web_audio_dest_data[i] = dest->channel(i);
112 112
113 // Substruct the bus duration to get hardware delay.
114 delay -= media::AudioTimestampHelper::FramesToTime(dest->frames(),
miu 2016/11/04 21:29:40 Is this correct? I thought |delay| already did not
Mikhail 2016/11/07 18:28:03 that comes from https://codereview.chromium.org/24
miu 2016/11/07 23:49:40 Right, but isn't the output position correct witho
Mikhail 2016/11/28 15:15:59 You are right, this will be an estimation of the n
miu 2016/11/29 20:51:04 Seems right. I went through and re-read the spec a
115 params_.sample_rate());
116
113 // TODO(xians): Remove the following |web_audio_source_data| after 117 // TODO(xians): Remove the following |web_audio_source_data| after
114 // changing the blink interface. 118 // changing the blink interface.
115 WebVector<float*> web_audio_source_data(static_cast<size_t>(0)); 119 WebVector<float*> web_audio_source_data(static_cast<size_t>(0));
116 client_callback_->render(web_audio_source_data, web_audio_dest_data, 120 client_callback_->render(web_audio_source_data, web_audio_dest_data,
117 dest->frames()); 121 dest->frames(), delay.InSecondsF(),
122 (delay_timestamp - base::TimeTicks()).InSecondsF(),
123 prior_frames_skipped);
124
118 return dest->frames(); 125 return dest->frames();
119 } 126 }
120 127
121 void RendererWebAudioDeviceImpl::OnRenderError() { 128 void RendererWebAudioDeviceImpl::OnRenderError() {
122 // TODO(crogers): implement error handling. 129 // TODO(crogers): implement error handling.
123 } 130 }
124 131
125 } // namespace content 132 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698