Merge "Forward wallpaper activity results to the caller."
This commit is contained in:
committed by
Android (Google) Code Review
commit
f558d4663b
@@ -504,6 +504,26 @@ public final class Utils extends com.android.settingslib.Utils {
|
||||
metricsCategory);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Start a new instance of the activity, showing only the given fragment.
|
||||
* When launched in this mode, the given preference fragment will be instantiated and fill the
|
||||
* entire activity.
|
||||
*
|
||||
* @param context The context.
|
||||
* @param fragmentName The name of the fragment to display.
|
||||
* @param titleResId resource id for the String to display for the title of this set
|
||||
* of preferences.
|
||||
* @param metricsCategory The current metricsCategory for logging source when fragment starts
|
||||
* @param intentFlags flag that should be added to the intent.
|
||||
*/
|
||||
public static void startWithFragment(Context context, String fragmentName, int titleResId,
|
||||
int metricsCategory, int intentFlags) {
|
||||
startWithFragment(context, fragmentName, null, null, 0,
|
||||
null /* titleResPackageName */, titleResId, null, false /* not a shortcut */,
|
||||
metricsCategory, intentFlags);
|
||||
}
|
||||
|
||||
/**
|
||||
* Start a new instance of the activity, showing only the given fragment.
|
||||
* When launched in this mode, the given preference fragment will be instantiated and fill the
|
||||
@@ -544,8 +564,17 @@ public final class Utils extends com.android.settingslib.Utils {
|
||||
public static void startWithFragment(Context context, String fragmentName, Bundle args,
|
||||
Fragment resultTo, int resultRequestCode, String titleResPackageName, int titleResId,
|
||||
CharSequence title, boolean isShortcut, int metricsCategory) {
|
||||
startWithFragment(context, fragmentName, args, resultTo, resultRequestCode,
|
||||
titleResPackageName, titleResId, title, isShortcut, metricsCategory, 0);
|
||||
}
|
||||
|
||||
|
||||
public static void startWithFragment(Context context, String fragmentName, Bundle args,
|
||||
Fragment resultTo, int resultRequestCode, String titleResPackageName, int titleResId,
|
||||
CharSequence title, boolean isShortcut, int metricsCategory, int flags) {
|
||||
Intent intent = onBuildStartFragmentIntent(context, fragmentName, args, titleResPackageName,
|
||||
titleResId, title, isShortcut, metricsCategory);
|
||||
intent.addFlags(flags);
|
||||
if (resultTo == null) {
|
||||
context.startActivity(intent);
|
||||
} else {
|
||||
|
@@ -51,9 +51,9 @@ public class WallpaperSuggestionActivity extends Activity {
|
||||
@VisibleForTesting
|
||||
void startFallbackSuggestion() {
|
||||
// fall back to default wallpaper picker
|
||||
Utils.startWithFragment(this, WallpaperTypeSettings.class.getName(), null, null, 0,
|
||||
R.string.wallpaper_suggestion_title, null,
|
||||
MetricsProto.MetricsEvent.DASHBOARD_SUMMARY);
|
||||
Utils.startWithFragment(this, WallpaperTypeSettings.class.getName(),
|
||||
R.string.wallpaper_suggestion_title, MetricsProto.MetricsEvent.DASHBOARD_SUMMARY,
|
||||
Intent.FLAG_ACTIVITY_FORWARD_RESULT);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
|
@@ -16,6 +16,7 @@
|
||||
|
||||
package com.android.settings.wallpaper;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
@@ -67,7 +68,7 @@ public class WallpaperTypeSettings extends SettingsPreferenceFragment implements
|
||||
// Add Preference items for each of the matching activities
|
||||
for (ResolveInfo info : rList) {
|
||||
Preference pref = new Preference(getPrefContext());
|
||||
Intent prefIntent = new Intent(intent);
|
||||
Intent prefIntent = new Intent(intent).addFlags(Intent.FLAG_ACTIVITY_FORWARD_RESULT);
|
||||
prefIntent.setComponent(new ComponentName(
|
||||
info.activityInfo.packageName, info.activityInfo.name));
|
||||
pref.setIntent(prefIntent);
|
||||
@@ -79,6 +80,16 @@ public class WallpaperTypeSettings extends SettingsPreferenceFragment implements
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceTreeClick(Preference preference) {
|
||||
if (preference.getIntent() == null) {
|
||||
return super.onPreferenceTreeClick(preference);
|
||||
}
|
||||
startActivity(preference.getIntent());
|
||||
finish();
|
||||
return true;
|
||||
}
|
||||
|
||||
public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||
new BaseSearchIndexProvider() {
|
||||
@Override
|
||||
|
Reference in New Issue
Block a user