Use ThreadUtils instead of AsyncTask to get app title/icon

Change-Id: I44459d9e4a11329a3bd3bfda5057e05eb7e04d6a
Fixes: 63620905
Test: robotest
This commit is contained in:
Fan Zhang
2017-08-09 16:18:15 -07:00
parent e3ca685321
commit 97e535b603
2 changed files with 112 additions and 60 deletions

View File

@@ -15,38 +15,46 @@
package com.android.settings.datausage;
import android.content.Context;
import android.os.AsyncTask;
import android.support.v7.preference.Preference;
import android.support.v7.preference.PreferenceViewHolder;
import android.text.format.Formatter;
import android.view.View;
import android.widget.ProgressBar;
import com.android.settings.R;
import com.android.settingslib.AppItem;
import com.android.settingslib.net.UidDetail;
import com.android.settingslib.net.UidDetailProvider;
import static com.android.internal.util.Preconditions.checkNotNull;
import com.android.settingslib.utils.ThreadUtils;
public class AppDataUsagePreference extends Preference {
private final AppItem mItem;
private final int mPercent;
private UidDetail mDetail;
public AppDataUsagePreference(Context context, AppItem item, int percent,
UidDetailProvider provider) {
super(context);
mItem = item;
mPercent = percent;
setLayoutResource(com.android.settings.R.layout.data_usage_item);
setWidgetLayoutResource(com.android.settings.R.layout.widget_progress_bar);
setLayoutResource(R.layout.data_usage_item);
setWidgetLayoutResource(R.layout.widget_progress_bar);
if (item.restricted && item.total <= 0) {
setSummary(com.android.settings.R.string.data_usage_app_restricted);
} else {
setSummary(Formatter.formatFileSize(context, item.total));
}
// kick off async load of app details
UidDetailTask.bindView(provider, item, this);
mDetail = provider.getUidDetail(item.key, false /* blocking */);
if (mDetail != null) {
setAppInfo();
} else {
ThreadUtils.postOnBackgroundThread(() -> {
mDetail = provider.getUidDetail(mItem.key, true /* blocking */);
ThreadUtils.postOnMainThread(() -> setAppInfo());
});
}
}
@Override
@@ -64,59 +72,17 @@ public class AppDataUsagePreference extends Preference {
progress.setProgress(mPercent);
}
private void setAppInfo() {
if (mDetail != null) {
setIcon(mDetail.icon);
setTitle(mDetail.label);
} else {
setIcon(null);
setTitle(null);
}
}
public AppItem getItem() {
return mItem;
}
/**
* Background task that loads {@link UidDetail}, binding to
* {@link DataUsageAdapter} row item when finished.
*/
private static class UidDetailTask extends AsyncTask<Void, Void, UidDetail> {
private final UidDetailProvider mProvider;
private final AppItem mItem;
private final AppDataUsagePreference mTarget;
private UidDetailTask(UidDetailProvider provider, AppItem item,
AppDataUsagePreference target) {
mProvider = checkNotNull(provider);
mItem = checkNotNull(item);
mTarget = checkNotNull(target);
}
public static void bindView(UidDetailProvider provider, AppItem item,
AppDataUsagePreference target) {
final UidDetail cachedDetail = provider.getUidDetail(item.key, false);
if (cachedDetail != null) {
bindView(cachedDetail, target);
} else {
new UidDetailTask(provider, item, target).execute();
}
}
private static void bindView(UidDetail detail, Preference target) {
if (detail != null) {
target.setIcon(detail.icon);
target.setTitle(detail.label);
} else {
target.setIcon(null);
target.setTitle(null);
}
}
@Override
protected void onPreExecute() {
bindView(null, mTarget);
}
@Override
protected UidDetail doInBackground(Void... params) {
return mProvider.getUidDetail(mItem.key, true);
}
@Override
protected void onPostExecute(UidDetail result) {
bindView(result, mTarget);
}
}
}