Update data usage graph to use new graph ui
Bug: 27278313 Change-Id: Ia9e8598dcb970540877f7dac7061cfc55ed99d4d
This commit is contained in:
@@ -41,7 +41,7 @@
|
|||||||
<com.android.settingslib.graph.UsageView
|
<com.android.settingslib.graph.UsageView
|
||||||
android:id="@+id/battery_usage"
|
android:id="@+id/battery_usage"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="141dp"
|
||||||
settings:sideLabels="@array/battery_labels"
|
settings:sideLabels="@array/battery_labels"
|
||||||
android:colorAccent="?android:attr/colorAccent"
|
android:colorAccent="?android:attr/colorAccent"
|
||||||
android:gravity="end"
|
android:gravity="end"
|
||||||
|
34
res/layout/data_usage_graph.xml
Normal file
34
res/layout/data_usage_graph.xml
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright (C) 2016 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingStart="?android:attr/listPreferredItemPaddingStart"
|
||||||
|
android:paddingEnd="?android:attr/listPreferredItemPaddingEnd"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<com.android.settingslib.graph.UsageView
|
||||||
|
android:id="@+id/data_usage"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="@dimen/data_usage_chart_height"
|
||||||
|
settings:sideLabels="@array/battery_labels"
|
||||||
|
android:colorAccent="?android:attr/colorAccent"
|
||||||
|
android:gravity="end"
|
||||||
|
settings:textColor="?android:attr/textColorSecondary" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
@@ -5088,9 +5088,9 @@
|
|||||||
<string name="data_usage_restrict_background_multiuser" product="default">If you restrict background cellular data, some apps and services won\u2019t work unless you\u2019re connected to Wi\u2011Fi.\n\nThis setting affects all users on this phone.</string>
|
<string name="data_usage_restrict_background_multiuser" product="default">If you restrict background cellular data, some apps and services won\u2019t work unless you\u2019re connected to Wi\u2011Fi.\n\nThis setting affects all users on this phone.</string>
|
||||||
|
|
||||||
<!-- Label displaying current network data usage warning threshold. [CHAR LIMIT=18] -->
|
<!-- Label displaying current network data usage warning threshold. [CHAR LIMIT=18] -->
|
||||||
<string name="data_usage_sweep_warning"><font size="21"><xliff:g id="number" example="128">^1</xliff:g></font> <font size="9"><xliff:g id="unit" example="KB">^2</xliff:g></font>\n<font size="12">warning</font></string>
|
<string name="data_usage_sweep_warning"><font size="18"><xliff:g id="number" example="128">^1</xliff:g></font> <font size="9"><xliff:g id="unit" example="KB">^2</xliff:g></font>\n<font size="12">warning</font></string>
|
||||||
<!-- Label displaying current network data usage limit threshold. [CHAR LIMIT=18] -->
|
<!-- Label displaying current network data usage limit threshold. [CHAR LIMIT=18] -->
|
||||||
<string name="data_usage_sweep_limit"><font size="21"><xliff:g id="number" example="128">^1</xliff:g></font> <font size="9"><xliff:g id="unit" example="KB">^2</xliff:g></font>\n<font size="12">limit</font></string>
|
<string name="data_usage_sweep_limit"><font size="18"><xliff:g id="number" example="128">^1</xliff:g></font> <font size="9"><xliff:g id="unit" example="KB">^2</xliff:g></font>\n<font size="12">limit</font></string>
|
||||||
|
|
||||||
<!-- TODO: Remove it once the same entry in SettingsLib is translated. -->
|
<!-- TODO: Remove it once the same entry in SettingsLib is translated. -->
|
||||||
<!-- Title of data usage item that represents all uninstalled applications. [CHAR LIMIT=48] -->
|
<!-- Title of data usage item that represents all uninstalled applications. [CHAR LIMIT=48] -->
|
||||||
|
@@ -15,18 +15,31 @@
|
|||||||
package com.android.settings.datausage;
|
package com.android.settings.datausage;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Color;
|
import android.content.res.TypedArray;
|
||||||
import android.net.NetworkPolicy;
|
import android.net.NetworkPolicy;
|
||||||
import android.net.NetworkStatsHistory;
|
import android.net.NetworkStatsHistory;
|
||||||
|
import android.net.TrafficStats;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
import android.support.v7.preference.PreferenceViewHolder;
|
import android.support.v7.preference.PreferenceViewHolder;
|
||||||
|
import android.text.SpannableStringBuilder;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
import android.text.format.Formatter;
|
||||||
|
import android.text.style.ForegroundColorSpan;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
|
import android.util.SparseIntArray;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.widget.ChartDataUsageView;
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.widget.ChartNetworkSeriesView;
|
import com.android.settingslib.graph.UsageView;
|
||||||
|
|
||||||
public class ChartDataUsagePreference extends Preference {
|
public class ChartDataUsagePreference extends Preference {
|
||||||
|
|
||||||
|
// The resolution we show on the graph so that we can squash things down to ints.
|
||||||
|
// Set to half a meg for now.
|
||||||
|
private static final long RESOLUTION = TrafficStats.MB_IN_BYTES / 2;
|
||||||
|
|
||||||
|
private final int mWarningColor;
|
||||||
|
private final int mLimitColor;
|
||||||
|
|
||||||
private NetworkPolicy mPolicy;
|
private NetworkPolicy mPolicy;
|
||||||
private long mStart;
|
private long mStart;
|
||||||
private long mEnd;
|
private long mEnd;
|
||||||
@@ -36,21 +49,123 @@ public class ChartDataUsagePreference extends Preference {
|
|||||||
|
|
||||||
public ChartDataUsagePreference(Context context, AttributeSet attrs) {
|
public ChartDataUsagePreference(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
setLayoutResource(R.layout.data_usage_chart);
|
setSelectable(false);
|
||||||
|
// TODO: Resource.
|
||||||
|
mLimitColor = 0xfff4511e;
|
||||||
|
TypedArray a = context.getTheme().obtainStyledAttributes(
|
||||||
|
new int[]{android.R.attr.textColorSecondary});
|
||||||
|
mWarningColor = a.getColor(0, 0);
|
||||||
|
setLayoutResource(R.layout.data_usage_graph);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBindViewHolder(PreferenceViewHolder holder) {
|
public void onBindViewHolder(PreferenceViewHolder holder) {
|
||||||
super.onBindViewHolder(holder);
|
super.onBindViewHolder(holder);
|
||||||
ChartDataUsageView chart = (ChartDataUsageView) holder.itemView;
|
UsageView chart = (UsageView) holder.findViewById(R.id.data_usage);
|
||||||
chart.setVisibleRange(mStart, mEnd);
|
if (mNetwork == null) return;
|
||||||
chart.bindNetworkPolicy(mPolicy);
|
|
||||||
chart.bindNetworkStats(mNetwork);
|
int top = getTop();
|
||||||
ChartNetworkSeriesView series = (ChartNetworkSeriesView) holder.findViewById(R.id.series);
|
chart.clearPaths();
|
||||||
series.setChartColor(Color.BLACK, mSeriesColor, mSecondaryColor);
|
chart.configureGraph((int) (mEnd - mStart), top, false, false);
|
||||||
|
calcPoints(chart);
|
||||||
|
chart.setBottomLabels(new CharSequence[] {
|
||||||
|
Utils.formatDateRange(getContext(), mStart, mStart),
|
||||||
|
Utils.formatDateRange(getContext(), mEnd, mEnd),
|
||||||
|
});
|
||||||
|
|
||||||
|
bindNetworkPolicy(chart, mPolicy, top);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void bindNetworkPolicy(NetworkPolicy policy) {
|
public int getTop() {
|
||||||
|
NetworkStatsHistory.Entry entry = null;
|
||||||
|
long totalData = 0;
|
||||||
|
final int start = mNetwork.getIndexBefore(mStart);
|
||||||
|
final int end = mNetwork.getIndexAfter(mEnd);
|
||||||
|
|
||||||
|
for (int i = start; i <= end; i++) {
|
||||||
|
entry = mNetwork.getValues(i, entry);
|
||||||
|
|
||||||
|
// increment by current bucket total
|
||||||
|
totalData += entry.rxBytes + entry.txBytes;
|
||||||
|
}
|
||||||
|
long policyMax = mPolicy != null ? Math.max(mPolicy.limitBytes, mPolicy.warningBytes) : 0;
|
||||||
|
return (int) (Math.max(totalData, policyMax) / RESOLUTION);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void calcPoints(UsageView chart) {
|
||||||
|
SparseIntArray points = new SparseIntArray();
|
||||||
|
NetworkStatsHistory.Entry entry = null;
|
||||||
|
|
||||||
|
long lastTime = -1;
|
||||||
|
long totalData = 0;
|
||||||
|
|
||||||
|
final int start = mNetwork.getIndexAfter(mStart);
|
||||||
|
final int end = mNetwork.getIndexAfter(mEnd);
|
||||||
|
if (start < 0) return;
|
||||||
|
|
||||||
|
points.put(0, 0);
|
||||||
|
for (int i = start; i <= end; i++) {
|
||||||
|
entry = mNetwork.getValues(i, entry);
|
||||||
|
|
||||||
|
final long startTime = entry.bucketStart;
|
||||||
|
final long endTime = startTime + entry.bucketDuration;
|
||||||
|
|
||||||
|
// increment by current bucket total
|
||||||
|
totalData += entry.rxBytes + entry.txBytes;
|
||||||
|
|
||||||
|
if (lastTime != startTime) {
|
||||||
|
if (points.size() > 1) {
|
||||||
|
chart.addPath(points);
|
||||||
|
}
|
||||||
|
points.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
points.put((int) (startTime - mStart + 1), (int) (totalData / RESOLUTION));
|
||||||
|
points.put((int) (endTime - mStart), (int) (totalData / RESOLUTION));
|
||||||
|
|
||||||
|
lastTime = endTime;
|
||||||
|
}
|
||||||
|
if (points.size() > 1) {
|
||||||
|
chart.addPath(points);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void bindNetworkPolicy(UsageView chart, NetworkPolicy policy, int top) {
|
||||||
|
CharSequence[] labels = new CharSequence[3];
|
||||||
|
int middleVisibility = 0;
|
||||||
|
int topVisibility = 0;
|
||||||
|
if (policy == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (policy.limitBytes != NetworkPolicy.LIMIT_DISABLED) {
|
||||||
|
topVisibility = mLimitColor;
|
||||||
|
labels[2] = getLabel(policy.limitBytes, R.string.data_usage_sweep_limit, mLimitColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (policy.warningBytes != NetworkPolicy.WARNING_DISABLED) {
|
||||||
|
chart.setDividerLoc((int) (policy.warningBytes / RESOLUTION));
|
||||||
|
float weight = policy.warningBytes / RESOLUTION / (float) top;
|
||||||
|
float above = 1 - weight;
|
||||||
|
chart.setSideLabelWeights(above, weight);
|
||||||
|
middleVisibility = mWarningColor;
|
||||||
|
labels[1] = getLabel(policy.warningBytes, R.string.data_usage_sweep_warning,
|
||||||
|
mWarningColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
chart.setSideLabels(labels);
|
||||||
|
chart.setDividerColors(middleVisibility, topVisibility);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CharSequence getLabel(long bytes, int str, int mLimitColor) {
|
||||||
|
Formatter.BytesResult result = Formatter.formatBytes(getContext().getResources(),
|
||||||
|
bytes, Formatter.FLAG_SHORTER);
|
||||||
|
CharSequence label = TextUtils.expandTemplate(getContext().getText(str),
|
||||||
|
result.value, result.units);
|
||||||
|
return new SpannableStringBuilder().append(label, new ForegroundColorSpan(mLimitColor), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setNetworkPolicy(NetworkPolicy policy) {
|
||||||
mPolicy = policy;
|
mPolicy = policy;
|
||||||
notifyChanged();
|
notifyChanged();
|
||||||
}
|
}
|
||||||
@@ -69,7 +184,7 @@ public class ChartDataUsagePreference extends Preference {
|
|||||||
return mEnd;
|
return mEnd;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void bindNetworkStats(NetworkStatsHistory network) {
|
public void setNetworkStats(NetworkStatsHistory network) {
|
||||||
mNetwork = network;
|
mNetwork = network;
|
||||||
notifyChanged();
|
notifyChanged();
|
||||||
}
|
}
|
||||||
|
@@ -255,7 +255,7 @@ public class DataUsageList extends DataUsageBase {
|
|||||||
final NetworkPolicy policy = services.mPolicyEditor.getPolicy(mTemplate);
|
final NetworkPolicy policy = services.mPolicyEditor.getPolicy(mTemplate);
|
||||||
//SUB SELECT
|
//SUB SELECT
|
||||||
if (isNetworkPolicyModifiable(policy, mSubId) && isMobileDataAvailable(mSubId)) {
|
if (isNetworkPolicyModifiable(policy, mSubId) && isMobileDataAvailable(mSubId)) {
|
||||||
mChart.bindNetworkPolicy(policy);
|
mChart.setNetworkPolicy(policy);
|
||||||
mHeader.findViewById(R.id.filter_settings).setVisibility(View.VISIBLE);
|
mHeader.findViewById(R.id.filter_settings).setVisibility(View.VISIBLE);
|
||||||
mHeader.findViewById(R.id.filter_settings).setOnClickListener(
|
mHeader.findViewById(R.id.filter_settings).setOnClickListener(
|
||||||
new View.OnClickListener() {
|
new View.OnClickListener() {
|
||||||
@@ -269,7 +269,7 @@ public class DataUsageList extends DataUsageBase {
|
|||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
// controls are disabled; don't bind warning/limit sweeps
|
// controls are disabled; don't bind warning/limit sweeps
|
||||||
mChart.bindNetworkPolicy(null);
|
mChart.setNetworkPolicy(null);
|
||||||
mHeader.findViewById(R.id.filter_settings).setVisibility(View.GONE);
|
mHeader.findViewById(R.id.filter_settings).setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -521,7 +521,7 @@ public class DataUsageList extends DataUsageBase {
|
|||||||
public void onLoadFinished(Loader<ChartData> loader, ChartData data) {
|
public void onLoadFinished(Loader<ChartData> loader, ChartData data) {
|
||||||
setLoading(false, true);
|
setLoading(false, true);
|
||||||
mChartData = data;
|
mChartData = data;
|
||||||
mChart.bindNetworkStats(mChartData.network);
|
mChart.setNetworkStats(mChartData.network);
|
||||||
|
|
||||||
// calcuate policy cycles based on available data
|
// calcuate policy cycles based on available data
|
||||||
updatePolicy(true);
|
updatePolicy(true);
|
||||||
@@ -530,7 +530,7 @@ public class DataUsageList extends DataUsageBase {
|
|||||||
@Override
|
@Override
|
||||||
public void onLoaderReset(Loader<ChartData> loader) {
|
public void onLoaderReset(Loader<ChartData> loader) {
|
||||||
mChartData = null;
|
mChartData = null;
|
||||||
mChart.bindNetworkStats(null);
|
mChart.setNetworkStats(null);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user