diff options
| -rw-r--r-- | packages/SettingsLib/src/com/android/settingslib/TronUtils.java | 63 | ||||
| -rw-r--r-- | packages/SettingsLib/src/com/android/settingslib/wifi/AccessPointPreference.java | 5 |
2 files changed, 67 insertions, 1 deletions
diff --git a/packages/SettingsLib/src/com/android/settingslib/TronUtils.java b/packages/SettingsLib/src/com/android/settingslib/TronUtils.java new file mode 100644 index 000000000000..1d9d03a63711 --- /dev/null +++ b/packages/SettingsLib/src/com/android/settingslib/TronUtils.java @@ -0,0 +1,63 @@ +/* + * Copyright (C) 2015 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.settingslib; + +import android.content.Context; +import android.net.ScoredNetwork; + +import com.android.internal.logging.MetricsLogger; + +/** Utilites for Tron Logging. */ +public final class TronUtils { + + private TronUtils() {}; + + public static void logWifiSettingsBadge(Context context, int badgeEnum) { + logNetworkBadgeMetric(context, "settings_wifibadging", badgeEnum); + } + + /** + * Logs an occurrence of the given network badge to a Histogram. + * + * @param context Context + * @param histogram the Tron histogram name to write to + * @param badgeEnum the {@link ScoredNetwork.Badging} badge value + * @throws IllegalArgumentException if the given badge enum is not supported + */ + private static void logNetworkBadgeMetric( + Context context, String histogram, int badgeEnum) + throws IllegalArgumentException { + int bucket; + switch (badgeEnum) { + case ScoredNetwork.BADGING_NONE: + bucket = 0; + break; + case ScoredNetwork.BADGING_SD: + bucket = 1; + break; + case ScoredNetwork.BADGING_HD: + bucket = 2; + break; + case ScoredNetwork.BADGING_4K: + bucket = 3; + break; + default: + throw new IllegalArgumentException("Unsupported badge enum: " + badgeEnum); + } + + MetricsLogger.histogram(context, histogram, bucket); + } +} diff --git a/packages/SettingsLib/src/com/android/settingslib/wifi/AccessPointPreference.java b/packages/SettingsLib/src/com/android/settingslib/wifi/AccessPointPreference.java index 8ebea619e4ef..703bc17c15c4 100644 --- a/packages/SettingsLib/src/com/android/settingslib/wifi/AccessPointPreference.java +++ b/packages/SettingsLib/src/com/android/settingslib/wifi/AccessPointPreference.java @@ -34,7 +34,9 @@ import android.util.AttributeSet; import android.util.SparseArray; import android.widget.ImageView; import android.widget.TextView; + import com.android.settingslib.R; +import com.android.settingslib.TronUtils; import com.android.settingslib.Utils; public class AccessPointPreference extends Preference { @@ -184,7 +186,8 @@ public class AccessPointPreference extends Preference { if (level == -1) { safeSetDefaultIcon(); } else { - if (mWifiBadge != ScoredNetwork.BADGING_NONE) { + TronUtils.logWifiSettingsBadge(context, mWifiBadge); + if (mWifiBadge != ScoredNetwork.BADGING_NONE) { // TODO(sghuman): Refactor this to reuse drawable to save memory and add to a // special subclass of AccessPointPreference LayerDrawable drawable = Utils.getBadgedWifiIcon(context, level, mWifiBadge); |