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

Unified Diff: chrome/browser/chromeos/audio/audio_handler.h

Issue 9169033: Support for showing/hiding status area volume controls in desktop devices (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: minor fixes Created 8 years, 11 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/audio/audio_handler.h
===================================================================
--- chrome/browser/chromeos/audio/audio_handler.h (revision 119043)
+++ chrome/browser/chromeos/audio/audio_handler.h (working copy)
@@ -18,17 +18,26 @@
class AudioHandler {
public:
+ class VolumeObserver {
+ public:
+ VolumeObserver();
xiyuan 2012/01/26 18:07:10 nit: move this into protected as we don't expect p
achuithb 2012/01/27 01:48:05 Done.
+ virtual void OnVolumeChanged() = 0;
+ protected:
+ virtual ~VolumeObserver();
+ };
+
static void Initialize();
static void Shutdown();
// GetInstance returns NULL if not initialized or if already shutdown.
static AudioHandler* GetInstance();
- // Is the mixer initialized?
+ // GetInitialized returns NULL if GetInstance returns NULL or if the
+ // mixer has not finished initializing.
// TODO(derat): All of the volume-percent methods will produce "interesting"
// results before the mixer is initialized, since the driver's volume range
// isn't known at that point. This could be avoided if AudioMixer objects
// instead took percentages and did their own conversions to decibels.
- bool IsInitialized();
+ static AudioHandler* GetInitialized();
Daniel Erat 2012/01/26 17:55:21 chrome os code includes too many static methods.
xiyuan 2012/01/26 18:07:10 Yeah, let's reuse the GetInstance() above.
achuithb 2012/01/26 23:19:34 Both SystemKeyEventListener and VolumeMenuBotton h
xiyuan 2012/01/26 23:41:58 Okay. In this case, I am okay to have it here so t
Daniel Erat 2012/01/26 23:53:28 Well, my preference would be for the above TODO to
achuithb 2012/01/27 01:48:05 Done.
// Gets volume level in our internal 0-100% range, 0 being pure silence.
double GetVolumePercent();
@@ -45,6 +54,10 @@
// Mutes or unmutes all audio.
void SetMuted(bool do_mute);
+ // Adds/Removes a VolumeObserver.
Daniel Erat 2012/01/26 17:55:21 nit: remove unnecessary comment
+ void AddVolumeObserver(VolumeObserver* observer);
+ void RemoveVolumeObserver(VolumeObserver* observer);
+
private:
// Defines the delete on exit Singleton traits we like. Best to have this
// and constructor/destructor private as recommended for Singletons.
@@ -53,12 +66,18 @@
AudioHandler();
virtual ~AudioHandler();
+ bool IsMixerInitialized();
+
// Conversion between our internal scaling (0-100%) and decibels.
double VolumeDbToPercent(double volume_db) const;
double PercentToVolumeDb(double volume_percent) const;
+ void VolumeChanged();
+
scoped_ptr<AudioMixer> mixer_;
+ ObserverList<VolumeObserver> volume_observers_;
+
DISALLOW_COPY_AND_ASSIGN(AudioHandler);
};
« no previous file with comments | « no previous file | chrome/browser/chromeos/audio/audio_handler.cc » ('j') | chrome/browser/chromeos/audio/audio_handler.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698