diff options
author | Daniel Sandler <dsandler@google.com> | 2011-02-25 12:28:57 -0500 |
---|---|---|
committer | Daniel Sandler <dsandler@google.com> | 2011-02-25 15:37:47 -0500 |
commit | 9a7c7129760ac89ffebf3dd3b508ff755ecff844 (patch) | |
tree | 61010be51e2e853d018c458a870db226914baef3 /packages/SystemUI | |
parent | b7a8c1e781517b5c6b47ee2b0c7bd0e70d9a1880 (diff) | |
download | frameworks_base-9a7c7129760ac89ffebf3dd3b508ff755ecff844.zip frameworks_base-9a7c7129760ac89ffebf3dd3b508ff755ecff844.tar.gz frameworks_base-9a7c7129760ac89ffebf3dd3b508ff755ecff844.tar.bz2 |
When out of range, show device-appropriate no-signal bars.
Also, start using the 0-bars WiFi icon when necessary;
previously, one bar was the lowest the WiFi icon could show.
Bug: 3488403
Change-Id: I3018685db3cf302d10c5e525a7d2c90f3c664f10
Diffstat (limited to 'packages/SystemUI')
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java | 21 | ||||
-rw-r--r-- | packages/SystemUI/src/com/android/systemui/statusbar/policy/WifiIcons.java | 6 |
2 files changed, 22 insertions, 5 deletions
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java index 42868db..f2c838a 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java @@ -34,6 +34,7 @@ import android.net.wifi.WifiInfo; import android.net.wifi.WifiManager; import android.os.Binder; import android.os.RemoteException; +import android.os.SystemProperties; import android.provider.Settings; import android.provider.Telephony; import android.telephony.PhoneStateListener; @@ -85,7 +86,7 @@ public class NetworkController extends BroadcastReceiver { boolean mWifiEnabled, mWifiConnected; int mWifiLevel; String mWifiSsid; - int mWifiIconId; + int mWifiIconId = 0; // bluetooth private boolean mBluetoothTethered = false; @@ -123,6 +124,9 @@ public class NetworkController extends BroadcastReceiver { public NetworkController(Context context) { mContext = context; + // set up the default wifi icon, used when no radios have ever appeared + updateWifiIcons(); + // telephony mPhone = (TelephonyManager)context.getSystemService(Context.TELEPHONY_SERVICE); mPhone.listen(mPhoneStateListener, @@ -256,6 +260,10 @@ public class NetworkController extends BroadcastReceiver { } mDataState = state; mDataNetType = networkType; + if (state < 0) { + // device without a data connection + mSignalStrength = null; + } updateDataNetType(); updateDataIcon(); refreshViews(); @@ -321,6 +329,11 @@ public class NetworkController extends BroadcastReceiver { } } + private boolean hasMobileDataFeature() { + // XXX: HAX: replace when a more reliable method is available + return (! "wifi-only".equals(SystemProperties.get("ro.carrier"))); + } + private int getCdmaLevel() { if (mSignalStrength == null) return 0; final int cdmaDbm = mSignalStrength.getCdmaDbm(); @@ -723,11 +736,13 @@ public class NetworkController extends BroadcastReceiver { dataTypeIconId = 0; } else { label = context.getString(R.string.status_bar_settings_signal_meter_disconnected); - combinedSignalIconId = mDataSignalIconId; + // On devices without mobile radios, we want to show the wifi icon + combinedSignalIconId = + hasMobileDataFeature() ? mDataSignalIconId : mWifiIconId; dataTypeIconId = 0; } - if (false) { + if (DEBUG) { Slog.d(TAG, "refreshViews combinedSignalIconId=0x" + Integer.toHexString(combinedSignalIconId) + "/" + getResourceName(combinedSignalIconId) diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/WifiIcons.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/WifiIcons.java index 0787289..8d72eba 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/policy/WifiIcons.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/WifiIcons.java @@ -20,11 +20,13 @@ import com.android.systemui.R; class WifiIcons { static final int[][] WIFI_SIGNAL_STRENGTH = { - { R.drawable.stat_sys_wifi_signal_1, + { R.drawable.stat_sys_wifi_signal_0, + R.drawable.stat_sys_wifi_signal_1, R.drawable.stat_sys_wifi_signal_2, R.drawable.stat_sys_wifi_signal_3, R.drawable.stat_sys_wifi_signal_4 }, - { R.drawable.stat_sys_wifi_signal_1_fully, + { R.drawable.stat_sys_wifi_signal_0, + R.drawable.stat_sys_wifi_signal_1_fully, R.drawable.stat_sys_wifi_signal_2_fully, R.drawable.stat_sys_wifi_signal_3_fully, R.drawable.stat_sys_wifi_signal_4_fully } |