Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "chrome/browser/chromeos/audio/audio_handler.h" | 5 #include "chrome/browser/chromeos/audio/audio_handler.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <cmath> | 8 #include <cmath> |
| 9 | 9 |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 33 const int kPrefMuteOff = 0; | 33 const int kPrefMuteOff = 0; |
| 34 const int kPrefMuteOn = 1; | 34 const int kPrefMuteOn = 1; |
| 35 | 35 |
| 36 static AudioHandler* g_audio_handler = NULL; | 36 static AudioHandler* g_audio_handler = NULL; |
| 37 | 37 |
| 38 } // namespace | 38 } // namespace |
| 39 | 39 |
| 40 // static | 40 // static |
| 41 void AudioHandler::Initialize() { | 41 void AudioHandler::Initialize() { |
| 42 CHECK(!g_audio_handler); | 42 CHECK(!g_audio_handler); |
| 43 g_audio_handler = new AudioHandler(); | 43 #if defined(USE_CRAS) |
| 44 g_audio_handler = new AudioHandler(new AudioMixerCras()); | |
| 45 #else | |
| 46 g_audio_handler = new AudioHandler(new AudioMixerAlsa()); | |
| 47 #endif | |
| 44 } | 48 } |
| 45 | 49 |
| 46 // static | 50 // static |
| 47 void AudioHandler::Shutdown() { | 51 void AudioHandler::Shutdown() { |
| 48 // We may call Shutdown without calling Initialize, e.g. if we exit early. | 52 // We may call Shutdown without calling Initialize, e.g. if we exit early. |
| 49 if (g_audio_handler) { | 53 if (g_audio_handler) { |
| 50 delete g_audio_handler; | 54 delete g_audio_handler; |
| 51 g_audio_handler = NULL; | 55 g_audio_handler = NULL; |
| 52 } | 56 } |
| 53 } | 57 } |
| 54 | 58 |
| 55 // static | 59 // static |
| 60 void AudioHandler::InitializeForTesting(AudioMixer* mixer) { | |
| 61 CHECK(!g_audio_handler); | |
| 62 g_audio_handler = new AudioHandler(mixer); | |
| 63 } | |
| 64 | |
| 65 // static | |
| 56 AudioHandler* AudioHandler::GetInstance() { | 66 AudioHandler* AudioHandler::GetInstance() { |
| 57 VLOG_IF(1, !g_audio_handler) | 67 VLOG_IF(1, !g_audio_handler) |
| 58 << "AudioHandler::GetInstance() called with NULL global instance."; | 68 << "AudioHandler::GetInstance() called with NULL global instance."; |
| 59 return g_audio_handler; | 69 return g_audio_handler; |
| 60 } | 70 } |
| 61 | 71 |
| 62 // static | 72 // static |
| 63 void AudioHandler::RegisterPrefs(PrefService* local_state) { | 73 void AudioHandler::RegisterPrefs(PrefService* local_state) { |
| 64 if (!local_state->FindPreference(prefs::kAudioVolumePercent)) | 74 if (!local_state->FindPreference(prefs::kAudioVolumePercent)) |
| 65 local_state->RegisterDoublePref(prefs::kAudioVolumePercent, | 75 local_state->RegisterDoublePref(prefs::kAudioVolumePercent, |
| 66 kDefaultVolumePercent, | 76 kDefaultVolumePercent, |
| 67 PrefService::UNSYNCABLE_PREF); | 77 PrefService::UNSYNCABLE_PREF); |
| 68 if (!local_state->FindPreference(prefs::kAudioMute)) | 78 if (!local_state->FindPreference(prefs::kAudioMute)) |
| 69 local_state->RegisterIntegerPref(prefs::kAudioMute, | 79 local_state->RegisterIntegerPref(prefs::kAudioMute, |
| 70 kPrefMuteOff, | 80 kPrefMuteOff, |
| 71 PrefService::UNSYNCABLE_PREF); | 81 PrefService::UNSYNCABLE_PREF); |
| 72 | 82 |
| 73 // Register the old decibel-based pref so we can clear it. | 83 // Register the old decibel-based pref so we can clear it. |
| 74 // TODO(derat): Remove this after R20: http://crbug.com/112039 | 84 // TODO(derat): Remove this after R20: http://crbug.com/112039 |
| 75 if (!local_state->FindPreference(prefs::kAudioVolumeDb)) | 85 if (!local_state->FindPreference(prefs::kAudioVolumeDb)) |
| 76 local_state->RegisterDoublePref(prefs::kAudioVolumeDb, | 86 local_state->RegisterDoublePref(prefs::kAudioVolumeDb, |
| 77 0, | 87 0, |
| 78 PrefService::UNSYNCABLE_PREF); | 88 PrefService::UNSYNCABLE_PREF); |
| 79 local_state->ClearPref(prefs::kAudioVolumeDb); | 89 local_state->ClearPref(prefs::kAudioVolumeDb); |
| 80 local_state->UnregisterPreference(prefs::kAudioVolumeDb); | 90 local_state->UnregisterPreference(prefs::kAudioVolumeDb); |
| 81 } | 91 } |
| 82 | 92 |
| 83 double AudioHandler::GetVolumePercent() { | 93 double AudioHandler::GetVolumePercent() { |
| 84 return mixer_->GetVolumePercent(); | 94 return (mixer_->IsMuted()) ? 0.0 : mixer_->GetVolumePercent(); |
|
Daniel Erat
2012/05/18 23:45:13
I don't think that this UX decision should be refl
Jun Mukai
2012/05/18 23:53:19
Removed. I will make the UI change in another CL.
| |
| 85 } | 95 } |
| 86 | 96 |
| 87 void AudioHandler::SetVolumePercent(double volume_percent) { | 97 void AudioHandler::SetVolumePercent(double volume_percent) { |
| 88 volume_percent = min(max(volume_percent, 0.0), 100.0); | 98 volume_percent = min(max(volume_percent, 0.0), 100.0); |
| 89 mixer_->SetVolumePercent(volume_percent); | 99 mixer_->SetVolumePercent(volume_percent); |
| 90 prefs_->SetDouble(prefs::kAudioVolumePercent, volume_percent); | 100 prefs_->SetDouble(prefs::kAudioVolumePercent, volume_percent); |
| 91 FOR_EACH_OBSERVER(VolumeObserver, volume_observers_, OnVolumeChanged()); | 101 FOR_EACH_OBSERVER(VolumeObserver, volume_observers_, OnVolumeChanged()); |
| 92 } | 102 } |
| 93 | 103 |
| 94 void AudioHandler::AdjustVolumeByPercent(double adjust_by_percent) { | 104 void AudioHandler::AdjustVolumeByPercent(double adjust_by_percent) { |
| 95 SetVolumePercent(mixer_->GetVolumePercent() + adjust_by_percent); | 105 SetVolumePercent(mixer_->GetVolumePercent() + adjust_by_percent); |
| 96 } | 106 } |
| 97 | 107 |
| 98 bool AudioHandler::IsMuted() { | 108 bool AudioHandler::IsMuted() { |
| 99 return mixer_->IsMuted(); | 109 return mixer_->GetVolumePercent() == 0 || mixer_->IsMuted(); |
|
Daniel Erat
2012/05/18 23:45:13
ditto here
Jun Mukai
2012/05/18 23:53:19
Removed too.
| |
| 100 } | 110 } |
| 101 | 111 |
| 102 void AudioHandler::SetMuted(bool mute) { | 112 void AudioHandler::SetMuted(bool mute) { |
| 103 mixer_->SetMuted(mute); | 113 mixer_->SetMuted(mute); |
| 104 prefs_->SetInteger(prefs::kAudioMute, mute ? kPrefMuteOn : kPrefMuteOff); | 114 prefs_->SetInteger(prefs::kAudioMute, mute ? kPrefMuteOn : kPrefMuteOff); |
| 105 FOR_EACH_OBSERVER(VolumeObserver, volume_observers_, OnVolumeChanged()); | 115 FOR_EACH_OBSERVER(VolumeObserver, volume_observers_, OnVolumeChanged()); |
| 106 } | 116 } |
| 107 | 117 |
| 108 void AudioHandler::AddVolumeObserver(VolumeObserver* observer) { | 118 void AudioHandler::AddVolumeObserver(VolumeObserver* observer) { |
| 109 volume_observers_.AddObserver(observer); | 119 volume_observers_.AddObserver(observer); |
| 110 } | 120 } |
| 111 | 121 |
| 112 void AudioHandler::RemoveVolumeObserver(VolumeObserver* observer) { | 122 void AudioHandler::RemoveVolumeObserver(VolumeObserver* observer) { |
| 113 volume_observers_.RemoveObserver(observer); | 123 volume_observers_.RemoveObserver(observer); |
| 114 } | 124 } |
| 115 | 125 |
| 116 AudioHandler::AudioHandler() | 126 AudioHandler::AudioHandler(AudioMixer* mixer) |
| 117 #if defined(USE_CRAS) | 127 : mixer_(mixer), |
| 118 : mixer_(new AudioMixerCras()), | |
| 119 #else | |
| 120 : mixer_(new AudioMixerAlsa()), | |
| 121 #endif | |
| 122 prefs_(g_browser_process->local_state()) { | 128 prefs_(g_browser_process->local_state()) { |
| 123 mixer_->SetVolumePercent(prefs_->GetDouble(prefs::kAudioVolumePercent)); | 129 mixer_->SetVolumePercent(prefs_->GetDouble(prefs::kAudioVolumePercent)); |
| 124 mixer_->SetMuted(prefs_->GetInteger(prefs::kAudioMute) == kPrefMuteOn); | 130 mixer_->SetMuted(prefs_->GetInteger(prefs::kAudioMute) == kPrefMuteOn); |
| 125 mixer_->Init(); | 131 mixer_->Init(); |
| 126 } | 132 } |
| 127 | 133 |
| 128 AudioHandler::~AudioHandler() { | 134 AudioHandler::~AudioHandler() { |
| 129 mixer_.reset(); | 135 mixer_.reset(); |
| 130 }; | 136 }; |
| 131 | 137 |
| 132 } // namespace chromeos | 138 } // namespace chromeos |
| OLD | NEW |