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 |