summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/VoiceInputOutputSettings.java
diff options
context:
space:
mode:
authorAmith Yamasani <yamasani@google.com>2010-12-10 13:17:34 -0800
committerAmith Yamasani <yamasani@google.com>2010-12-10 13:20:52 -0800
commitb44161f3ed9b91f39086247d8efbdac42656b93b (patch)
tree6810836a7aefc52695d49f22c70026f37257c028 /src/com/android/settings/VoiceInputOutputSettings.java
parentb8f9ab6792b621e34441ebf08574325e98fba340 (diff)
downloadpackages_apps_Settings-b44161f3ed9b91f39086247d8efbdac42656b93b.zip
packages_apps_Settings-b44161f3ed9b91f39086247d8efbdac42656b93b.tar.gz
packages_apps_Settings-b44161f3ed9b91f39086247d8efbdac42656b93b.tar.bz2
Move Voice input/output settings to Language & keyboard
Bug: 3267042 Change-Id: I127a2e9d11fb70283812e68979bdde3976e32cf9
Diffstat (limited to 'src/com/android/settings/VoiceInputOutputSettings.java')
-rw-r--r--src/com/android/settings/VoiceInputOutputSettings.java82
1 files changed, 37 insertions, 45 deletions
diff --git a/src/com/android/settings/VoiceInputOutputSettings.java b/src/com/android/settings/VoiceInputOutputSettings.java
index b07c69e..1e86801 100644
--- a/src/com/android/settings/VoiceInputOutputSettings.java
+++ b/src/com/android/settings/VoiceInputOutputSettings.java
@@ -16,9 +16,6 @@
package com.android.settings;
-import org.xmlpull.v1.XmlPullParser;
-import org.xmlpull.v1.XmlPullParserException;
-
import android.content.ComponentName;
import android.content.Intent;
import android.content.pm.PackageManager;
@@ -28,7 +25,6 @@ import android.content.pm.PackageManager.NameNotFoundException;
import android.content.res.Resources;
import android.content.res.TypedArray;
import android.content.res.XmlResourceParser;
-import android.os.Bundle;
import android.preference.ListPreference;
import android.preference.Preference;
import android.preference.PreferenceCategory;
@@ -45,15 +41,16 @@ import java.io.IOException;
import java.util.HashMap;
import java.util.List;
+import org.xmlpull.v1.XmlPullParser;
+import org.xmlpull.v1.XmlPullParserException;
+
/**
* Settings screen for voice input/output.
*/
-public class VoiceInputOutputSettings extends SettingsPreferenceFragment
- implements OnPreferenceChangeListener {
-
+public class VoiceInputOutputSettings implements OnPreferenceChangeListener {
+
private static final String TAG = "VoiceInputOutputSettings";
-
- private static final String KEY_PARENT = "parent";
+
private static final String KEY_VOICE_INPUT_CATEGORY = "voice_input_category";
private static final String KEY_RECOGNIZER = "recognizer";
private static final String KEY_RECOGNIZER_SETTINGS = "recognizer_settings";
@@ -62,41 +59,42 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
private PreferenceCategory mVoiceInputCategory;
private ListPreference mRecognizerPref;
private PreferenceScreen mSettingsPref;
-
+ private SettingsPreferenceFragment mFragment;
+
private HashMap<String, ResolveInfo> mAvailableRecognizersMap;
-
- @Override
- public void onCreate(Bundle icicle) {
- super.onCreate(icicle);
- addPreferencesFromResource(R.xml.voice_input_output_settings);
+ public VoiceInputOutputSettings(SettingsPreferenceFragment fragment) {
+ mFragment = fragment;
+ }
+
+ public void onCreate() {
- mParent = (PreferenceGroup) findPreference(KEY_PARENT);
+ mParent = (PreferenceGroup) mFragment.getPreferenceScreen();
mVoiceInputCategory = (PreferenceCategory) mParent.findPreference(KEY_VOICE_INPUT_CATEGORY);
- mRecognizerPref = (ListPreference) mParent.findPreference(KEY_RECOGNIZER);
+ mRecognizerPref = (ListPreference) mVoiceInputCategory.findPreference(KEY_RECOGNIZER);
mRecognizerPref.setOnPreferenceChangeListener(this);
- mSettingsPref = (PreferenceScreen) mParent.findPreference(KEY_RECOGNIZER_SETTINGS);
-
+ mSettingsPref = (PreferenceScreen)
+ mVoiceInputCategory.findPreference(KEY_RECOGNIZER_SETTINGS);
+
mAvailableRecognizersMap = new HashMap<String, ResolveInfo>();
-
+
populateOrRemoveRecognizerPreference();
}
-
+
private void populateOrRemoveRecognizerPreference() {
- List<ResolveInfo> availableRecognitionServices = getPackageManager().queryIntentServices(
+ List<ResolveInfo> availableRecognitionServices =
+ mFragment.getPackageManager().queryIntentServices(
new Intent(RecognitionService.SERVICE_INTERFACE), PackageManager.GET_META_DATA);
int numAvailable = availableRecognitionServices.size();
if (numAvailable == 0) {
// No recognizer available - remove all related preferences.
- removePreference(mVoiceInputCategory);
- removePreference(mRecognizerPref);
- removePreference(mSettingsPref);
+ mFragment.getPreferenceScreen().removePreference(mVoiceInputCategory);
} else if (numAvailable == 1) {
// Only one recognizer available, so don't show the list of choices, but do
// set up the link to settings for the available recognizer.
- removePreference(mRecognizerPref);
-
+ mVoiceInputCategory.removePreference(mRecognizerPref);
+
// But first set up the available recognizers map with just the one recognizer.
ResolveInfo resolveInfo = availableRecognitionServices.get(0);
String recognizerComponent =
@@ -106,20 +104,14 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
mAvailableRecognizersMap.put(recognizerComponent, resolveInfo);
String currentSetting = Settings.Secure.getString(
- getContentResolver(), Settings.Secure.VOICE_RECOGNITION_SERVICE);
+ mFragment.getContentResolver(), Settings.Secure.VOICE_RECOGNITION_SERVICE);
updateSettingsLink(currentSetting);
} else {
// Multiple recognizers available, so show the full list of choices.
populateRecognizerPreference(availableRecognitionServices);
}
}
-
- private void removePreference(Preference pref) {
- if (pref != null) {
- mParent.removePreference(pref);
- }
- }
-
+
private void populateRecognizerPreference(List<ResolveInfo> recognizers) {
int size = recognizers.size();
CharSequence[] entries = new CharSequence[size];
@@ -127,7 +119,7 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
// Get the current value from the secure setting.
String currentSetting = Settings.Secure.getString(
- getContentResolver(), Settings.Secure.VOICE_RECOGNITION_SERVICE);
+ mFragment.getContentResolver(), Settings.Secure.VOICE_RECOGNITION_SERVICE);
// Iterate through all the available recognizers and load up their info to show
// in the preference. Also build up a map of recognizer component names to their
@@ -140,7 +132,7 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
mAvailableRecognizersMap.put(recognizerComponent, resolveInfo);
- entries[i] = resolveInfo.loadLabel(getPackageManager());
+ entries[i] = resolveInfo.loadLabel(mFragment.getPackageManager());
values[i] = recognizerComponent;
}
@@ -159,13 +151,14 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
XmlResourceParser parser = null;
String settingsActivity = null;
try {
- parser = si.loadXmlMetaData(getPackageManager(), RecognitionService.SERVICE_META_DATA);
+ parser = si.loadXmlMetaData(mFragment.getPackageManager(),
+ RecognitionService.SERVICE_META_DATA);
if (parser == null) {
throw new XmlPullParserException("No " + RecognitionService.SERVICE_META_DATA +
" meta-data for " + si.packageName);
}
- Resources res = getPackageManager().getResourcesForApplication(
+ Resources res = mFragment.getPackageManager().getResourcesForApplication(
si.applicationInfo);
AttributeSet attrs = Xml.asAttributeSet(parser);
@@ -200,25 +193,24 @@ public class VoiceInputOutputSettings extends SettingsPreferenceFragment
// No settings preference available - hide the preference.
Log.w(TAG, "no recognizer settings available for " + si.packageName);
mSettingsPref.setIntent(null);
- mParent.removePreference(mSettingsPref);
+ mVoiceInputCategory.removePreference(mSettingsPref);
} else {
Intent i = new Intent(Intent.ACTION_MAIN);
i.setComponent(new ComponentName(si.packageName, settingsActivity));
mSettingsPref.setIntent(i);
- mRecognizerPref.setSummary(currentRecognizer.loadLabel(getPackageManager()));
+ mRecognizerPref.setSummary(currentRecognizer.loadLabel(mFragment.getPackageManager()));
}
}
public boolean onPreferenceChange(Preference preference, Object newValue) {
if (preference == mRecognizerPref) {
String setting = (String) newValue;
-
+
// Put the new value back into secure settings.
- Settings.Secure.putString(
- getContentResolver(),
+ Settings.Secure.putString(mFragment.getContentResolver(),
Settings.Secure.VOICE_RECOGNITION_SERVICE,
setting);
-
+
// Update the settings item so it points to the right settings.
updateSettingsLink(setting);
}