diff options
author | satish@chromium.org <satish@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-03-01 07:02:00 +0000 |
---|---|---|
committer | satish@chromium.org <satish@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-03-01 07:02:00 +0000 |
commit | 1784ad6252e50a5ca1a67026f53cb139490009cd (patch) | |
tree | 99a60deb561d5ff4db1b6dee6bf86b3499d6f914 /media/audio/win/audio_manager_win.cc | |
parent | 07f63c6bba7e33160fc54af7f2cf4cf207e0831b (diff) | |
download | chromium_src-1784ad6252e50a5ca1a67026f53cb139490009cd.zip chromium_src-1784ad6252e50a5ca1a67026f53cb139490009cd.tar.gz chromium_src-1784ad6252e50a5ca1a67026f53cb139490009cd.tar.bz2 |
Adds method to invoke platform provided audio input UI.
This will be used in a future CL by the speech input feature.
BUG=69886
TEST=none
Review URL: http://codereview.chromium.org/6602012
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@76363 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media/audio/win/audio_manager_win.cc')
-rw-r--r-- | media/audio/win/audio_manager_win.cc | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/media/audio/win/audio_manager_win.cc b/media/audio/win/audio_manager_win.cc index 0c896d1..7b3d6fa 100644 --- a/media/audio/win/audio_manager_win.cc +++ b/media/audio/win/audio_manager_win.cc @@ -11,9 +11,14 @@ #include <setupapi.h> #include "base/basictypes.h" +#include "base/command_line.h" +#include "base/file_path.h" +#include "base/path_service.h" +#include "base/process_util.h" #include "base/scoped_ptr.h" #include "base/string_number_conversions.h" #include "base/string_util.h" +#include "base/win/windows_version.h" #include "media/audio/fake_audio_input_stream.h" #include "media/audio/fake_audio_output_stream.h" #include "media/audio/win/audio_manager_win.h" @@ -229,6 +234,29 @@ string16 AudioManagerWin::GetAudioInputDeviceModel() { return string16(); } +bool AudioManagerWin::CanShowAudioInputSettings() { + return true; +} + +void AudioManagerWin::ShowAudioInputSettings() { + std::wstring program; + std::string argument; + if (base::win::GetVersion() <= base::win::VERSION_XP) { + program = L"sndvol32.exe"; + argument = "-R"; + } else { + program = L"control.exe"; + argument = "mmsys.cpl,,1"; + } + + FilePath path; + PathService::Get(base::DIR_SYSTEM, &path); + path = path.Append(program); + CommandLine command_line(path); + command_line.AppendArg(argument); + base::LaunchApp(command_line, false, false, NULL); +} + // static AudioManager* AudioManager::CreateAudioManager() { return new AudioManagerWin(); |