summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJeff Sharkey <jsharkey@android.com>2011-09-02 16:10:24 -0700
committerJeff Sharkey <jsharkey@android.com>2011-09-02 16:15:25 -0700
commit28130d96385d7d7b17992b45fb5d124836d85880 (patch)
treef05e9eb5842250ac07a2153d843476272c4c6148 /src
parent4e658ba969830e8c9617dc8938271df1ed09aa44 (diff)
downloadpackages_apps_Settings-28130d96385d7d7b17992b45fb5d124836d85880.tar.gz
packages_apps_Settings-28130d96385d7d7b17992b45fb5d124836d85880.tar.bz2
packages_apps_Settings-28130d96385d7d7b17992b45fb5d124836d85880.zip
Unify data/power layout, confirm disable, round.
Share consistent layout between data usage and battery usage. Show confirmation dialog before disabling mobile data. Round warning/limit sweep values to match displayed label. Suppress fade when switching data usage tabs. Bug: 5208510, 5058157, 5038589, 5252816 Change-Id: I3c76f3397445d2d3b173666a41672871df4c61af
Diffstat (limited to 'src')
-rw-r--r--src/com/android/settings/DataUsageSummary.java87
-rw-r--r--src/com/android/settings/fuelgauge/PercentageBar.java67
-rw-r--r--src/com/android/settings/fuelgauge/PowerGaugePreference.java56
-rw-r--r--src/com/android/settings/fuelgauge/PowerUsageDetail.java31
-rw-r--r--src/com/android/settings/fuelgauge/PowerUsageSummary.java9
-rw-r--r--src/com/android/settings/widget/ChartAxis.java7
-rw-r--r--src/com/android/settings/widget/ChartDataUsageView.java18
-rw-r--r--src/com/android/settings/widget/ChartSweepView.java7
-rw-r--r--src/com/android/settings/widget/InvertedChartAxis.java4
9 files changed, 135 insertions, 151 deletions
diff --git a/src/com/android/settings/DataUsageSummary.java b/src/com/android/settings/DataUsageSummary.java
index eb747887b..87ce772e8 100644
--- a/src/com/android/settings/DataUsageSummary.java
+++ b/src/com/android/settings/DataUsageSummary.java
@@ -153,7 +153,8 @@ public class DataUsageSummary extends Fragment {
private static final String TAB_WIFI = "wifi";
private static final String TAB_ETHERNET = "ethernet";
- private static final String TAG_CONFIRM_ROAMING = "confirmRoaming";
+ private static final String TAG_CONFIRM_DATA_DISABLE = "confirmDataDisable";
+ private static final String TAG_CONFIRM_DATA_ROAMING = "confirmDataRoaming";
private static final String TAG_CONFIRM_LIMIT = "confirmLimit";
private static final String TAG_CYCLE_EDITOR = "cycleEditor";
private static final String TAG_CONFIRM_RESTRICT = "confirmRestrict";
@@ -485,6 +486,7 @@ public class DataUsageSummary extends Fragment {
final LayoutTransition chartTransition = buildLayoutTransition();
chartTransition.setStartDelay(LayoutTransition.APPEARING, 0);
chartTransition.setStartDelay(LayoutTransition.DISAPPEARING, 0);
+ chartTransition.setAnimator(LayoutTransition.DISAPPEARING, null);
mChart.setLayoutTransition(chartTransition);
}
};
@@ -595,7 +597,6 @@ public class DataUsageSummary extends Fragment {
if (TAB_MOBILE.equals(currentTab)) {
setPreferenceTitle(mDataEnabledView, R.string.data_usage_enable_mobile);
setPreferenceTitle(mDisableAtLimitView, R.string.data_usage_disable_mobile_limit);
- mDataEnabled.setChecked(mConnService.getMobileDataEnabled());
mTemplate = buildTemplateMobileAll(getActiveSubscriberId(context));
} else if (TAB_3G.equals(currentTab)) {
@@ -799,6 +800,28 @@ public class DataUsageSummary extends Fragment {
updatePolicy(false);
}
+ /**
+ * Local cache of value, used to work around delay when
+ * {@link ConnectivityManager#setMobileDataEnabled(boolean)} is async.
+ */
+ private Boolean mMobileDataEnabled;
+
+ private boolean isMobileDataEnabled() {
+ if (mMobileDataEnabled != null) {
+ // TODO: deprecate and remove this once enabled flag is on policy
+ return mMobileDataEnabled;
+ } else {
+ return mConnService.getMobileDataEnabled();
+ }
+ }
+
+ private void setMobileDataEnabled(boolean enabled) {
+ if (LOGD) Log.d(TAG, "setMobileDataEnabled()");
+ mConnService.setMobileDataEnabled(enabled);
+ mMobileDataEnabled = enabled;
+ updatePolicy(false);
+ }
+
private boolean isNetworkPolicyModifiable(NetworkPolicy policy) {
return policy != null && isBandwidthControlEnabled() && mDataEnabled.isChecked();
}
@@ -888,6 +911,13 @@ public class DataUsageSummary extends Fragment {
}
}
+ // TODO: move enabled state directly into policy
+ if (TAB_MOBILE.equals(mCurrentTab)) {
+ mBinding = true;
+ mDataEnabled.setChecked(isMobileDataEnabled());
+ mBinding = false;
+ }
+
final NetworkPolicy policy = mPolicyEditor.getPolicy(mTemplate);
if (isNetworkPolicyModifiable(policy)) {
mDisableAtLimitView.setVisibility(View.VISIBLE);
@@ -979,15 +1009,18 @@ public class DataUsageSummary extends Fragment {
if (mBinding) return;
final boolean dataEnabled = isChecked;
- mDataEnabled.setChecked(dataEnabled);
-
final String currentTab = mCurrentTab;
if (TAB_MOBILE.equals(currentTab)) {
- mConnService.setMobileDataEnabled(dataEnabled);
+ if (dataEnabled) {
+ setMobileDataEnabled(true);
+ } else {
+ // disabling data; show confirmation dialog which eventually
+ // calls setMobileDataEnabled() once user confirms.
+ ConfirmDataDisableFragment.show(DataUsageSummary.this);
+ }
}
- // rebind policy to match radio state
- updatePolicy(true);
+ updatePolicy(false);
}
};
@@ -1358,14 +1391,14 @@ public class DataUsageSummary extends Fragment {
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(parent.getContext()).inflate(
- R.layout.data_usage_item, parent, false);
+ R.layout.app_percentage_item, parent, false);
}
final Context context = parent.getContext();
final ImageView icon = (ImageView) convertView.findViewById(android.R.id.icon);
final TextView title = (TextView) convertView.findViewById(android.R.id.title);
- final TextView summary = (TextView) convertView.findViewById(android.R.id.summary);
+ final TextView text1 = (TextView) convertView.findViewById(android.R.id.text1);
final ProgressBar progress = (ProgressBar) convertView.findViewById(
android.R.id.progress);
@@ -1374,7 +1407,7 @@ public class DataUsageSummary extends Fragment {
icon.setImageDrawable(detail.icon);
title.setText(detail.label);
- summary.setText(Formatter.formatFileSize(context, item.total));
+ text1.setText(Formatter.formatFileSize(context, item.total));
final int percentTotal = mLargest != 0 ? (int) (item.total * 100 / mLargest) : 0;
progress.setProgress(percentTotal);
@@ -1545,6 +1578,38 @@ public class DataUsageSummary extends Fragment {
}
/**
+ * Dialog to request user confirmation before disabling data.
+ */
+ public static class ConfirmDataDisableFragment extends DialogFragment {
+ public static void show(DataUsageSummary parent) {
+ final ConfirmDataDisableFragment dialog = new ConfirmDataDisableFragment();
+ dialog.setTargetFragment(parent, 0);
+ dialog.show(parent.getFragmentManager(), TAG_CONFIRM_DATA_DISABLE);
+ }
+
+ @Override
+ public Dialog onCreateDialog(Bundle savedInstanceState) {
+ final Context context = getActivity();
+
+ final AlertDialog.Builder builder = new AlertDialog.Builder(context);
+ builder.setMessage(R.string.data_usage_disable_mobile);
+
+ builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ final DataUsageSummary target = (DataUsageSummary) getTargetFragment();
+ if (target != null) {
+ // TODO: extend to modify policy enabled flag.
+ target.setMobileDataEnabled(false);
+ }
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+
+ return builder.create();
+ }
+ }
+
+ /**
* Dialog to request user confirmation before setting
* {@link Settings.Secure#DATA_ROAMING}.
*/
@@ -1552,7 +1617,7 @@ public class DataUsageSummary extends Fragment {
public static void show(DataUsageSummary parent) {
final ConfirmDataRoamingFragment dialog = new ConfirmDataRoamingFragment();
dialog.setTargetFragment(parent, 0);
- dialog.show(parent.getFragmentManager(), TAG_CONFIRM_ROAMING);
+ dialog.show(parent.getFragmentManager(), TAG_CONFIRM_DATA_ROAMING);
}
@Override
diff --git a/src/com/android/settings/fuelgauge/PercentageBar.java b/src/com/android/settings/fuelgauge/PercentageBar.java
deleted file mode 100644
index 1c4478bf4..000000000
--- a/src/com/android/settings/fuelgauge/PercentageBar.java
+++ /dev/null
@@ -1,67 +0,0 @@
-/*
- * Copyright (C) 2009 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.fuelgauge;
-
-import android.graphics.Canvas;
-import android.graphics.ColorFilter;
-import android.graphics.PixelFormat;
-import android.graphics.drawable.Drawable;
-
-/**
- * A drawable for drawing a bar with a background.
- */
-class PercentageBar extends Drawable {
-
- Drawable bar;
- double percent;
- int lastWidth = -1;
-
- @Override
- public void draw(Canvas canvas) {
- if (lastWidth == -1) {
- lastWidth = getBarWidth();
- bar.setBounds(0, 0, lastWidth, bar.getIntrinsicHeight());
- }
- bar.draw(canvas);
- }
-
- @Override
- public int getOpacity() {
- return PixelFormat.TRANSLUCENT;
- }
-
- @Override
- public void setAlpha(int alpha) {
- // Ignore
- }
-
- @Override
- public void setColorFilter(ColorFilter cf) {
- // Ignore
- }
-
- private int getBarWidth() {
- int width = (int) ((this.getBounds().width() * percent) / 100);
- int intrinsicWidth = bar.getIntrinsicWidth();
- return Math.max(width, intrinsicWidth);
- }
-
- @Override
- public int getIntrinsicHeight() {
- return bar.getIntrinsicHeight();
- }
-}
diff --git a/src/com/android/settings/fuelgauge/PowerGaugePreference.java b/src/com/android/settings/fuelgauge/PowerGaugePreference.java
index 00e397e5c..7b11ae1ff 100644
--- a/src/com/android/settings/fuelgauge/PowerGaugePreference.java
+++ b/src/com/android/settings/fuelgauge/PowerGaugePreference.java
@@ -20,70 +20,46 @@ import android.content.Context;
import android.graphics.drawable.Drawable;
import android.preference.Preference;
import android.view.View;
-import android.widget.ImageView;
+import android.widget.ProgressBar;
import android.widget.TextView;
import com.android.settings.R;
/**
- * Custom preference for displaying power consumption as a bar and an icon on the left for the
- * subsystem/app type.
- *
+ * Custom preference for displaying power consumption as a bar and an icon on
+ * the left for the subsystem/app type.
*/
public class PowerGaugePreference extends Preference {
-
- private Drawable mIcon;
- private PercentageBar mGauge;
- private double mValue;
private BatterySipper mInfo;
- private double mPercent;
+ private int mProgress;
+ private CharSequence mProgressText;
public PowerGaugePreference(Context context, Drawable icon, BatterySipper info) {
super(context);
- setLayoutResource(R.layout.preference_powergauge);
- mIcon = icon;
- mGauge = new PercentageBar();
- mGauge.bar = context.getResources().getDrawable(R.drawable.app_gauge);
+ setLayoutResource(R.layout.app_percentage_item);
+ setIcon(icon);
mInfo = info;
}
- /**
- * Sets the width of the gauge in percentage (0 - 100)
- * @param percent
- */
- void setGaugeValue(double percent) {
- mValue = percent;
- mGauge.percent = mValue;
- }
-
- void setPercent(double percent) {
- mPercent = percent;
+ public void setPercent(double percentOfMax, double percentOfTotal) {
+ mProgress = (int) Math.ceil(percentOfMax);
+ mProgressText = getContext().getResources().getString(
+ R.string.percentage, (int) Math.ceil(percentOfTotal));
+ notifyChanged();
}
BatterySipper getInfo() {
return mInfo;
}
- void setPowerIcon(Drawable icon) {
- mIcon = icon;
- notifyChanged();
- }
-
@Override
protected void onBindView(View view) {
super.onBindView(view);
- ImageView appIcon = (ImageView) view.findViewById(R.id.appIcon);
- if (mIcon == null) {
- mIcon = getContext().getResources().getDrawable(android.R.drawable.sym_def_app_icon);
- }
- appIcon.setImageDrawable(mIcon);
+ final ProgressBar progress = (ProgressBar) view.findViewById(android.R.id.progress);
+ progress.setProgress(mProgress);
- ImageView appGauge = (ImageView) view.findViewById(R.id.appGauge);
- appGauge.setImageDrawable(mGauge);
-
- TextView percentView = (TextView) view.findViewById(R.id.percent);
- percentView.setText((int) (Math.ceil(mPercent)) + "%");
+ final TextView text1 = (TextView) view.findViewById(android.R.id.text1);
+ text1.setText(mProgressText);
}
-
}
diff --git a/src/com/android/settings/fuelgauge/PowerUsageDetail.java b/src/com/android/settings/fuelgauge/PowerUsageDetail.java
index b70312b91..e6552ce10 100644
--- a/src/com/android/settings/fuelgauge/PowerUsageDetail.java
+++ b/src/com/android/settings/fuelgauge/PowerUsageDetail.java
@@ -41,6 +41,7 @@ import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageView;
+import android.widget.ProgressBar;
import android.widget.TextView;
import com.android.settings.DisplaySettings;
@@ -116,7 +117,6 @@ public class PowerUsageDetail extends Fragment implements Button.OnClickListener
private ViewGroup mControlsParent;
private long mStartTime;
private DrainType mDrainType;
- private PercentageBar mGauge;
private Drawable mAppIcon;
private double mNoCoverage; // Percentage of time that there was no coverage
@@ -181,30 +181,29 @@ public class PowerUsageDetail extends Fragment implements Button.OnClickListener
}
// Set the description
- String summary = getDescriptionForDrainType();
- ((TextView)mRootView.findViewById(R.id.summary)).setText(summary);
-
+ final TextView summary = (TextView) mRootView.findViewById(android.R.id.summary);
+ summary.setText(getDescriptionForDrainType());
+ summary.setVisibility(View.VISIBLE);
+
mTypes = args.getIntArray(EXTRA_DETAIL_TYPES);
mValues = args.getDoubleArray(EXTRA_DETAIL_VALUES);
- mTitleView = (TextView)mRootView.findViewById(R.id.name);
+ mTitleView = (TextView) mRootView.findViewById(android.R.id.title);
mTitleView.setText(mTitle);
- ((TextView)mRootView.findViewById(R.id.battery_percentage))
- .setText(String.format("%d%%", percentage));
+
+ final TextView text1 = (TextView)mRootView.findViewById(android.R.id.text1);
+ text1.setText(getString(R.string.percentage, percentage));
mTwoButtonsPanel = (ViewGroup)mRootView.findViewById(R.id.two_buttons_panel);
mForceStopButton = (Button)mRootView.findViewById(R.id.left_button);
mReportButton = (Button)mRootView.findViewById(R.id.right_button);
mForceStopButton.setEnabled(false);
-
- ImageView gaugeImage = (ImageView)mRootView.findViewById(R.id.gauge);
- mGauge = new PercentageBar();
- mGauge.percent = gaugeValue;
- mGauge.bar = getResources().getDrawable(R.drawable.app_gauge);
- gaugeImage.setImageDrawable(mGauge);
-
- ImageView iconImage = (ImageView)mRootView.findViewById(R.id.icon);
- iconImage.setImageDrawable(mAppIcon);
+
+ final ProgressBar progress = (ProgressBar) mRootView.findViewById(android.R.id.progress);
+ progress.setProgress(gaugeValue);
+
+ final ImageView icon = (ImageView) mRootView.findViewById(android.R.id.icon);
+ icon.setImageDrawable(mAppIcon);
mDetailsParent = (ViewGroup)mRootView.findViewById(R.id.details);
mControlsParent = (ViewGroup)mRootView.findViewById(R.id.controls);
diff --git a/src/com/android/settings/fuelgauge/PowerUsageSummary.java b/src/com/android/settings/fuelgauge/PowerUsageSummary.java
index 32ba2790d..c24c5ea83 100644
--- a/src/com/android/settings/fuelgauge/PowerUsageSummary.java
+++ b/src/com/android/settings/fuelgauge/PowerUsageSummary.java
@@ -23,7 +23,6 @@ import android.content.IntentFilter;
import android.hardware.SensorManager;
import android.os.BatteryStats;
import android.os.BatteryStats.Uid;
-import android.os.BatteryManager;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
@@ -382,12 +381,11 @@ public class PowerUsageSummary extends PreferenceFragment implements Runnable {
final double percentOfTotal = ((sipper.getSortValue() / mTotalPower) * 100);
if (percentOfTotal < 1) continue;
PowerGaugePreference pref = new PowerGaugePreference(getActivity(), sipper.getIcon(), sipper);
- double percentOfMax = (sipper.getSortValue() * 100) / mMaxPower;
+ final double percentOfMax = (sipper.getSortValue() * 100) / mMaxPower;
sipper.percent = percentOfTotal;
pref.setTitle(sipper.name);
- pref.setPercent(percentOfTotal);
pref.setOrder(Integer.MAX_VALUE - (int) sipper.getSortValue()); // Invert the order
- pref.setGaugeValue(percentOfMax);
+ pref.setPercent(percentOfMax, percentOfTotal);
if (sipper.uidObj != null) {
pref.setKey(Integer.toString(sipper.uidObj.getUid()));
}
@@ -771,8 +769,7 @@ public class PowerUsageSummary extends PreferenceFragment implements Runnable {
(PowerGaugePreference) findPreference(
Integer.toString(bs.uidObj.getUid()));
if (pgp != null) {
- pgp.setPowerIcon(bs.icon);
- pgp.setPercent(bs.percent);
+ pgp.setIcon(bs.icon);
pgp.setTitle(bs.name);
}
break;
diff --git a/src/com/android/settings/widget/ChartAxis.java b/src/com/android/settings/widget/ChartAxis.java
index 4e0da1db9..d3d499c7b 100644
--- a/src/com/android/settings/widget/ChartAxis.java
+++ b/src/com/android/settings/widget/ChartAxis.java
@@ -35,8 +35,11 @@ public interface ChartAxis {
/** Convert screen point into raw value. */
public long convertToValue(float point);
- /** Build label that describes given raw value. */
- public void buildLabel(Resources res, SpannableStringBuilder builder, long value);
+ /**
+ * Build label that describes given raw value. If the label is rounded for
+ * display, return the rounded value.
+ */
+ public long buildLabel(Resources res, SpannableStringBuilder builder, long value);
/** Return list of tick points for drawing a grid. */
public float[] getTickPoints();
diff --git a/src/com/android/settings/widget/ChartDataUsageView.java b/src/com/android/settings/widget/ChartDataUsageView.java
index 955436853..cad2ed893 100644
--- a/src/com/android/settings/widget/ChartDataUsageView.java
+++ b/src/com/android/settings/widget/ChartDataUsageView.java
@@ -27,7 +27,6 @@ import android.text.SpannableStringBuilder;
import android.text.TextUtils;
import android.text.format.DateUtils;
import android.util.AttributeSet;
-import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
@@ -334,11 +333,11 @@ public class ChartDataUsageView extends ChartView {
}
public long getWarningBytes() {
- return mSweepWarning.getValue();
+ return mSweepWarning.getLabelValue();
}
public long getLimitBytes() {
- return mSweepLimit.getValue();
+ return mSweepLimit.getLabelValue();
}
private long getStatsStart() {
@@ -433,9 +432,10 @@ public class ChartDataUsageView extends ChartView {
}
/** {@inheritDoc} */
- public void buildLabel(Resources res, SpannableStringBuilder builder, long value) {
+ public long buildLabel(Resources res, SpannableStringBuilder builder, long value) {
// TODO: convert to better string
builder.replace(0, builder.length(), Long.toString(value));
+ return value;
}
/** {@inheritDoc} */
@@ -493,16 +493,19 @@ public class ChartDataUsageView extends ChartView {
private static final Object sSpanUnit = new Object();
/** {@inheritDoc} */
- public void buildLabel(Resources res, SpannableStringBuilder builder, long value) {
+ public long buildLabel(Resources res, SpannableStringBuilder builder, long value) {
- float result = value;
final CharSequence unit;
+ float result = value;
+ long labelValue = 1;
if (result <= 100 * MB_IN_BYTES) {
unit = res.getText(com.android.internal.R.string.megabyteShort);
result /= MB_IN_BYTES;
+ labelValue = MB_IN_BYTES;
} else {
unit = res.getText(com.android.internal.R.string.gigabyteShort);
result /= GB_IN_BYTES;
+ labelValue = GB_IN_BYTES;
}
final CharSequence size;
@@ -511,11 +514,14 @@ public class ChartDataUsageView extends ChartView {
} else {
size = String.format("%.0f", result);
}
+ labelValue *= Float.parseFloat(size.toString());
final int[] sizeBounds = findOrCreateSpan(builder, sSpanSize, "^1");
builder.replace(sizeBounds[0], sizeBounds[1], size);
final int[] unitBounds = findOrCreateSpan(builder, sSpanUnit, "^2");
builder.replace(unitBounds[0], unitBounds[1], unit);
+
+ return labelValue;
}
/** {@inheritDoc} */
diff --git a/src/com/android/settings/widget/ChartSweepView.java b/src/com/android/settings/widget/ChartSweepView.java
index 0d91a763c..33e90c8b3 100644
--- a/src/com/android/settings/widget/ChartSweepView.java
+++ b/src/com/android/settings/widget/ChartSweepView.java
@@ -67,6 +67,7 @@ public class ChartSweepView extends View {
private ChartAxis mAxis;
private long mValue;
+ private long mLabelValue;
private long mValidAfter;
private long mValidBefore;
@@ -226,7 +227,7 @@ public class ChartSweepView extends View {
private void invalidateLabel() {
if (mLabelTemplate != null && mAxis != null) {
- mAxis.buildLabel(getResources(), mLabelTemplate, mValue);
+ mLabelValue = mAxis.buildLabel(getResources(), mLabelTemplate, mValue);
invalidate();
}
}
@@ -265,6 +266,10 @@ public class ChartSweepView extends View {
return mValue;
}
+ public long getLabelValue() {
+ return mLabelValue;
+ }
+
public float getPoint() {
if (isEnabled()) {
return mAxis.convertToPoint(mValue);
diff --git a/src/com/android/settings/widget/InvertedChartAxis.java b/src/com/android/settings/widget/InvertedChartAxis.java
index 96aec7b93..7dcc78a02 100644
--- a/src/com/android/settings/widget/InvertedChartAxis.java
+++ b/src/com/android/settings/widget/InvertedChartAxis.java
@@ -52,8 +52,8 @@ public class InvertedChartAxis implements ChartAxis {
}
/** {@inheritDoc} */
- public void buildLabel(Resources res, SpannableStringBuilder builder, long value) {
- mWrapped.buildLabel(res, builder, value);
+ public long buildLabel(Resources res, SpannableStringBuilder builder, long value) {
+ return mWrapped.buildLabel(res, builder, value);
}
/** {@inheritDoc} */