WifiEnabler: add support to show supplicant state.
This commit is contained in:
@@ -17,7 +17,7 @@
|
|||||||
** limitations under the License.
|
** limitations under the License.
|
||||||
*/
|
*/
|
||||||
-->
|
-->
|
||||||
<resources>
|
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<!-- Choices for timezone picker first level.
|
<!-- Choices for timezone picker first level.
|
||||||
These values will be used as search terms for TimeZone displayName
|
These values will be used as search terms for TimeZone displayName
|
||||||
strings. --> <skip />
|
strings. --> <skip />
|
||||||
@@ -180,6 +180,56 @@
|
|||||||
|
|
||||||
<!-- Wi-Fi settings -->
|
<!-- Wi-Fi settings -->
|
||||||
|
|
||||||
|
<!-- Match this with the order of NetworkInfo.DetailedState. --> <skip />
|
||||||
|
<!-- Wi-Fi settings. The status messages when the network is unknown. -->
|
||||||
|
<string-array name="wifi_status">
|
||||||
|
<!-- Status message of Wi-Fi when it is idle. -->
|
||||||
|
<item></item>
|
||||||
|
<!-- Status message of Wi-Fi when it is scanning. -->
|
||||||
|
<item>Scanning\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is connecting. -->
|
||||||
|
<item>Connecting\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is authenticating. -->
|
||||||
|
<item>Authenticating\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is obtaining IP address. -->
|
||||||
|
<item>Obtaining IP address\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is connected. -->
|
||||||
|
<item>Connected</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is suspended. -->
|
||||||
|
<item>Suspended</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is disconnecting. -->
|
||||||
|
<item>Disconnecting\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is disconnected. -->
|
||||||
|
<item>Disconnected</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is a failure. -->
|
||||||
|
<item>Unsuccessful</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
|
<!-- Match this with the order of NetworkInfo.DetailedState. --> <skip />
|
||||||
|
<!-- Wi-Fi settings. The status messages when the network is known. -->
|
||||||
|
<string-array name="wifi_status_with_ssid">
|
||||||
|
<!-- Status message of Wi-Fi when it is idle. -->
|
||||||
|
<item></item>
|
||||||
|
<!-- Status message of Wi-Fi when it is scanning. -->
|
||||||
|
<item>Scanning\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is connecting to a network. -->
|
||||||
|
<item>Connecting to <xliff:g id="network_name">%1$s</xliff:g>\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is authenticating with a network. -->
|
||||||
|
<item>Authenticating with <xliff:g id="network_name">%1$s</xliff:g>\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is obtaining IP address from a network. -->
|
||||||
|
<item>Obtaining IP address from <xliff:g id="network_name">%1$s</xliff:g>\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is connected to a network. -->
|
||||||
|
<item>Connected to <xliff:g id="network_name">%1$s</xliff:g></item>
|
||||||
|
<!-- Status message of Wi-Fi when it is suspended. -->
|
||||||
|
<item>Suspended</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is disconnecting from a network. -->
|
||||||
|
<item>Disconnecting from <xliff:g id="network_name">%1$s</xliff:g>\u2026</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is disconnected. -->
|
||||||
|
<item>Disconnected</item>
|
||||||
|
<!-- Status message of Wi-Fi when it is a failure. -->
|
||||||
|
<item>Unsuccessful</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
<!-- Match this with code. --> <skip />
|
<!-- Match this with code. --> <skip />
|
||||||
<!-- Wi-Fi settings. The type of security a Wi-Fi network has. The user can choose this when he adds a manual network, or configures an existing network. -->
|
<!-- Wi-Fi settings. The type of security a Wi-Fi network has. The user can choose this when he adds a manual network, or configures an existing network. -->
|
||||||
<string-array name="wifi_security_entries">
|
<string-array name="wifi_security_entries">
|
||||||
|
40
src/com/android/settings/wifi/Summary.java
Normal file
40
src/com/android/settings/wifi/Summary.java
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2010 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.wifi;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.NetworkInfo.DetailedState;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
class Summary {
|
||||||
|
static String get(Context context, String ssid, DetailedState state) {
|
||||||
|
String[] formats = context.getResources().getStringArray((ssid == null)
|
||||||
|
? R.array.wifi_status : R.array.wifi_status_with_ssid);
|
||||||
|
int index = state.ordinal();
|
||||||
|
|
||||||
|
if (index >= formats.length || formats[index].length() == 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return String.format(formats[index], ssid);
|
||||||
|
}
|
||||||
|
|
||||||
|
static String get(Context context, DetailedState state) {
|
||||||
|
return get(context, null, state);
|
||||||
|
}
|
||||||
|
}
|
@@ -24,6 +24,8 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
|
import android.net.wifi.SupplicantState;
|
||||||
|
import android.net.wifi.WifiInfo;
|
||||||
import android.net.wifi.WifiManager;
|
import android.net.wifi.WifiManager;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.CheckBoxPreference;
|
import android.preference.CheckBoxPreference;
|
||||||
@@ -45,9 +47,12 @@ public class WifiEnabler implements Preference.OnPreferenceChangeListener {
|
|||||||
if (WifiManager.WIFI_STATE_CHANGED_ACTION.equals(action)) {
|
if (WifiManager.WIFI_STATE_CHANGED_ACTION.equals(action)) {
|
||||||
handleWifiStateChanged(intent.getIntExtra(
|
handleWifiStateChanged(intent.getIntExtra(
|
||||||
WifiManager.EXTRA_WIFI_STATE, WifiManager.WIFI_STATE_UNKNOWN));
|
WifiManager.EXTRA_WIFI_STATE, WifiManager.WIFI_STATE_UNKNOWN));
|
||||||
|
} else if (WifiManager.SUPPLICANT_STATE_CHANGED_ACTION.equals(action)) {
|
||||||
|
handleStateChanged(WifiInfo.getDetailedStateOf((SupplicantState)
|
||||||
|
intent.getParcelableExtra(WifiManager.EXTRA_NEW_STATE)));
|
||||||
} else if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(action)) {
|
} else if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(action)) {
|
||||||
handleNetworkStateChanged((NetworkInfo)
|
handleStateChanged(((NetworkInfo) intent.getParcelableExtra(
|
||||||
intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO));
|
WifiManager.EXTRA_NETWORK_INFO)).getDetailedState());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -66,6 +71,8 @@ public class WifiEnabler implements Preference.OnPreferenceChangeListener {
|
|||||||
checkBox.setPersistent(false);
|
checkBox.setPersistent(false);
|
||||||
|
|
||||||
mIntentFilter = new IntentFilter(WifiManager.WIFI_STATE_CHANGED_ACTION);
|
mIntentFilter = new IntentFilter(WifiManager.WIFI_STATE_CHANGED_ACTION);
|
||||||
|
// The order matters! We really should not depend on this. :(
|
||||||
|
mIntentFilter.addAction(WifiManager.SUPPLICANT_STATE_CHANGED_ACTION);
|
||||||
mIntentFilter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
mIntentFilter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -128,11 +135,14 @@ public class WifiEnabler implements Preference.OnPreferenceChangeListener {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleNetworkStateChanged(NetworkInfo networkInfo) {
|
private void handleStateChanged(NetworkInfo.DetailedState state) {
|
||||||
if (mWifiManager.isWifiEnabled()) {
|
// WifiInfo is valid if and only if Wi-Fi is enabled.
|
||||||
String summary = WifiStatus.getStatus(mContext,
|
// Here we use the state of the check box as an optimization.
|
||||||
mWifiManager.getConnectionInfo().getSSID(), networkInfo.getDetailedState());
|
if (state != null && mCheckBox.isChecked()) {
|
||||||
mCheckBox.setSummary(summary);
|
WifiInfo info = mWifiManager.getConnectionInfo();
|
||||||
|
if (info != null) {
|
||||||
|
mCheckBox.setSummary(Summary.get(mContext, info.getSSID(), state));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user