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

Side by Side Diff: content/browser/renderer_host/media/audio_renderer_host.h

Issue 1214883004: Fixed the audio backgrounding bug (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Implemented nick's suggestion Created 5 years, 4 months 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 // AudioRendererHost serves audio related requests from AudioRenderer which 5 // AudioRendererHost serves audio related requests from AudioRenderer which
6 // lives inside the render process and provide access to audio hardware. 6 // lives inside the render process and provide access to audio hardware.
7 // 7 //
8 // This class is owned by BrowserRenderProcessHost, and instantiated on UI 8 // This class is owned by BrowserRenderProcessHost, and instantiated on UI
9 // thread, but all other operations and method calls happen on IO thread, so we 9 // thread, but all other operations and method calls happen on IO thread, so we
10 // need to be extra careful about the lifetime of this object. AudioManager is a 10 // need to be extra careful about the lifetime of this object. AudioManager is a
(...skipping 198 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 media::AudioManager* const audio_manager_; 209 media::AudioManager* const audio_manager_;
210 AudioMirroringManager* const mirroring_manager_; 210 AudioMirroringManager* const mirroring_manager_;
211 scoped_ptr<media::AudioLog> audio_log_; 211 scoped_ptr<media::AudioLog> audio_log_;
212 212
213 // Used to access to AudioInputDeviceManager. 213 // Used to access to AudioInputDeviceManager.
214 MediaStreamManager* media_stream_manager_; 214 MediaStreamManager* media_stream_manager_;
215 215
216 // A map of stream IDs to audio sources. 216 // A map of stream IDs to audio sources.
217 AudioEntryMap audio_entries_; 217 AudioEntryMap audio_entries_;
218 218
219 // The number of streams in the playing state. 219 // The number of streams in the playing state. Atomic read safe from any
220 // thread, but should only be updated from the IO thread.
220 base::AtomicRefCount num_playing_streams_; 221 base::AtomicRefCount num_playing_streams_;
221 222
222 // Salt required to translate renderer device IDs to raw device IDs 223 // Salt required to translate renderer device IDs to raw device IDs
223 ResourceContext::SaltCallback salt_callback_; 224 ResourceContext::SaltCallback salt_callback_;
224 225
225 DISALLOW_COPY_AND_ASSIGN(AudioRendererHost); 226 DISALLOW_COPY_AND_ASSIGN(AudioRendererHost);
226 }; 227 };
227 228
228 } // namespace content 229 } // namespace content
229 230
230 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_AUDIO_RENDERER_HOST_H_ 231 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_AUDIO_RENDERER_HOST_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698