summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaisuke Miyakawa <dmiyakawa@google.com>2010-08-27 10:04:08 -0700
committerDaisuke Miyakawa <dmiyakawa@google.com>2010-09-01 16:17:51 -0700
commitd36699282cbd0a6897f425106081d3f2c0db55d4 (patch)
tree72721ae3dbb67a492e614ec29e7f4182fa99e15a
parent0b4dc9fd6f31a503e52d6663cc6b3bc9cade4c49 (diff)
downloadpackages_apps_Settings-d36699282cbd0a6897f425106081d3f2c0db55d4.zip
packages_apps_Settings-d36699282cbd0a6897f425106081d3f2c0db55d4.tar.gz
packages_apps_Settings-d36699282cbd0a6897f425106081d3f2c0db55d4.tar.bz2
Add Wifi Setup screen for Setup Wizard with XL size screen.
* Add WifiSettingsForSetupWizardXL as a new Activity The activity has WifiSettings fragment in it. It also contains several buttons, texts around the fragment. * Making configuration UI part of Preference list. In Wifi Setup for Setup Wizard XL, WifiSettings fragment lets a UI for configuring access points shown inside a PregerenceCategory object, while it has been shown as Dialog. To achieve this action, WifiDialog is decomposed into two parts: - WifiConfigUiBase (Mainly UI part) - WifiConfigController (Mainly Wifi controller part) All codes for wifi configuration in WifiDialog is now in WifiConfigController, which is reused from WifiConfigPreference. * Misc stuff - Remove AccessPoint#compareTo(). Instead, AccessPoint.AccessPointComparater should be used when needed. Change-Id: I520d690d3301837d32f91dad54a973a379ce1989
-rw-r--r--AndroidManifest.xml5
-rw-r--r--proguard.flags2
-rw-r--r--res/layout-xlarge/access_point_category_for_setup_wizard_xl.xml29
-rw-r--r--res/layout-xlarge/wifi_settings_for_setup_wizard_xl.xml149
-rw-r--r--res/layout/wifi_config_preference.xml151
-rw-r--r--res/values/strings.xml38
-rw-r--r--res/xml/wifi_access_points_for_wifi_setup_xl.xml24
-rw-r--r--src/com/android/settings/ProgressCategory.java17
-rw-r--r--src/com/android/settings/ProgressCategoryBase.java33
-rw-r--r--src/com/android/settings/wifi/AccessPoint.java63
-rw-r--r--src/com/android/settings/wifi/AccessPointCategoryForSetupWizardXL.java35
-rw-r--r--src/com/android/settings/wifi/Summary.java5
-rw-r--r--src/com/android/settings/wifi/WifiConfigController.java369
-rw-r--r--src/com/android/settings/wifi/WifiConfigPreference.java129
-rw-r--r--src/com/android/settings/wifi/WifiConfigUiBase.java42
-rw-r--r--src/com/android/settings/wifi/WifiDialog.java339
-rw-r--r--src/com/android/settings/wifi/WifiSettings.java378
-rw-r--r--src/com/android/settings/wifi/WifiSettingsForSetupWizardXL.java157
18 files changed, 1538 insertions, 427 deletions
diff --git a/AndroidManifest.xml b/AndroidManifest.xml
index 2885390..8cb1ec3 100644
--- a/AndroidManifest.xml
+++ b/AndroidManifest.xml
@@ -99,6 +99,11 @@
</intent-filter>
</activity-alias>
+ <activity android:name=".wifi.WifiSettingsForSetupWizardXL"
+ android:clearTaskOnLaunch="true"
+ android:screenOrientation="landscape"
+ android:exported="true" />
+
<activity android:name=".wifi.AdvancedSettings"
android:label="@string/wifi_ip_settings_titlebar"
>
diff --git a/proguard.flags b/proguard.flags
index 0e1b428..9427b09 100644
--- a/proguard.flags
+++ b/proguard.flags
@@ -3,4 +3,4 @@
-keep class com.android.settings.*Picker
-keep class com.android.settings.*Settings
-keep class com.android.settings.wifi.*Settings
--keep class com.android.settings.deviceinfo.*
+-keep class com.android.settings.deviceinfo.* \ No newline at end of file
diff --git a/res/layout-xlarge/access_point_category_for_setup_wizard_xl.xml b/res/layout-xlarge/access_point_category_for_setup_wizard_xl.xml
new file mode 100644
index 0000000..4d52deb
--- /dev/null
+++ b/res/layout-xlarge/access_point_category_for_setup_wizard_xl.xml
@@ -0,0 +1,29 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Copyright (C) 2006 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"
+ android:layout_width="match_parent"
+ android:layout_height="wrap_content"
+ android:gravity="center_vertical"
+ android:paddingRight="?android:attr/scrollbarSize">
+
+ <LinearLayout android:id="@+android:id/widget_frame"
+ android:layout_width="wrap_content"
+ android:layout_height="match_parent"
+ android:gravity="center_vertical"
+ android:orientation="vertical" />
+
+</LinearLayout>
diff --git a/res/layout-xlarge/wifi_settings_for_setup_wizard_xl.xml b/res/layout-xlarge/wifi_settings_for_setup_wizard_xl.xml
new file mode 100644
index 0000000..c6c5a03
--- /dev/null
+++ b/res/layout-xlarge/wifi_settings_for_setup_wizard_xl.xml
@@ -0,0 +1,149 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- 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.
+-->
+<LinearLayout
+ xmlns:android="http://schemas.android.com/apk/res/android"
+ android:orientation="horizontal"
+ android:layout_width="fill_parent"
+ android:layout_height="fill_parent"
+ android:paddingTop="70dip"
+ android:paddingBottom="80dip"
+ android:paddingLeft="60dip"
+ android:paddingRight="60dip">
+
+
+ <!-- Left: almost empty with one title at the top -->
+ <RelativeLayout
+ android:orientation="vertical"
+ android:layout_width="0px"
+ android:layout_weight=".3"
+ android:layout_height="fill_parent"
+ android:paddingRight="10dip"
+ android:paddingBottom="10dip">
+ <TextView
+ android:id="@+id/wifi_setup_title"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:gravity="center|top"
+ android:textSize="48dip"
+ android:textColor="#FF30FF30"
+ android:text="@string/wifi_setup_title"/>
+ <Button
+ android:id="@+id/wifi_setup_cancel"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_alignParentBottom="true"
+ android:textSize="24dip"
+ android:text="@string/wifi_cancel"
+ android:visibility="gone" />
+ </RelativeLayout>
+
+ <!-- Center: Full of fragment -->
+ <LinearLayout
+ android:orientation="vertical"
+ android:layout_width="0px"
+ android:layout_weight=".4"
+ android:layout_height="fill_parent"
+ android:paddingTop="20dip"
+ android:paddingLeft="10dip"
+ android:paddingRight="30dip"
+ android:paddingBottom="15dip">
+ <!-- Assume the text size of this text should be same as Preference's
+ texts. See also preference.xml -->
+ <TextView
+ android:id="@+id/wifi_setup_status"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:background="#ff113344"
+ android:paddingLeft="5dip"
+ android:paddingTop="5dip"
+ android:paddingBottom="5dip"
+ android:layout_marginBottom="20dip"
+ android:textAppearance="?android:attr/textAppearanceLarge"
+ android:text="@string/wifi_setup_status_select_network"/>
+ <fragment
+ class="com.android.settings.wifi.WifiSettings"
+ android:id="@+id/wifi_setup_fragment"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content" />
+ </LinearLayout>
+
+ <!-- Right: various information -->
+ <RelativeLayout
+ android:orientation="vertical"
+ android:layout_width="0px"
+ android:layout_weight=".3"
+ android:layout_height="fill_parent"
+ android:paddingTop="22dip"
+ android:paddingLeft="30dip"
+ android:paddingBottom="10dip">
+ <TextView
+ android:id="@+id/scanning_progress_text"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_alignParentTop="true"
+ android:textSize="24dip"
+ android:text="@string/progress_scanning"/>
+ <ProgressBar
+ android:id="@+id/scanning_progress_bar"
+ android:layout_width="100dip"
+ android:layout_height="wrap_content"
+ android:layout_below="@id/scanning_progress_text"
+ style="?android:attr/progressBarStyleHorizontal" />
+
+ <Button
+ android:id="@+id/wifi_setup_connect"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_alignParentBottom="true"
+ android:textSize="24dip"
+ android:text="@string/wifi_connect"
+ android:visibility="gone" />
+ <Button
+ android:id="@+id/wifi_setup_forget"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_alignParentBottom="true"
+ android:textSize="24dip"
+ android:text="@string/wifi_forget"
+ android:visibility="gone" />
+
+ <Button
+ android:id="@+id/wifi_setup_skip_or_next"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_marginTop="30dip"
+ android:layout_alignParentBottom="true"
+ android:textSize="24dip"
+ android:text="@string/wifi_setup_skip" />
+
+ <Button
+ android:id="@+id/wifi_setup_refresh_list"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_above="@id/wifi_setup_skip_or_next"
+ android:textSize="24dip"
+ android:text="@string/wifi_setup_refresh_list" />
+
+ <Button
+ android:id="@+id/wifi_setup_add_network"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:layout_above="@id/wifi_setup_refresh_list"
+ android:textSize="24dip"
+ android:text="@string/wifi_setup_add_network" />
+
+ </RelativeLayout>
+</LinearLayout>
diff --git a/res/layout/wifi_config_preference.xml b/res/layout/wifi_config_preference.xml
new file mode 100644
index 0000000..5cea2d4
--- /dev/null
+++ b/res/layout/wifi_config_preference.xml
@@ -0,0 +1,151 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- 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.
+-->
+<!-- All ids in this layout must be in wifi_dialog.xml -->
+<LinearLayout
+ xmlns:android="http://schemas.android.com/apk/res/android"
+ android:orientation="vertical"
+ android:layout_width="fill_parent"
+ android:layout_height="fill_parent">
+ <!-- <TextView android:id="@+id/title"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/title" /> -->
+
+ <LinearLayout android:id="@+id/info"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:orientation="vertical" />
+
+ <LinearLayout android:id="@+id/type"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:orientation="vertical"
+ android:visibility="gone">
+
+ <TextView android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_ssid" />
+
+ <EditText android:id="@+id/ssid"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:singleLine="true"
+ android:inputType="textNoSuggestions" />
+
+ <TextView android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_security" />
+
+ <Spinner android:id="@+id/security"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:prompt="@string/wifi_security"
+ android:entries="@array/wifi_security" />
+ </LinearLayout> <!-- android:id="@+id/type" -->
+
+ <LinearLayout android:id="@+id/fields"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:orientation="vertical"
+ android:visibility="gone">
+
+ <LinearLayout android:id="@+id/eap"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:orientation="vertical"
+ android:visibility="gone">
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_eap_method" />
+
+ <Spinner android:id="@+id/method"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:prompt="@string/wifi_eap_method"
+ android:entries="@array/wifi_eap_method" />
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/please_select_phase2" />
+
+ <Spinner android:id="@+id/phase2"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:prompt="@string/please_select_phase2"
+ android:entries="@array/wifi_phase2_entries" />
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_eap_ca_cert" />
+
+ <Spinner android:id="@+id/ca_cert"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:prompt="@string/wifi_eap_ca_cert" />
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_eap_user_cert" />
+
+ <Spinner android:id="@+id/user_cert"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:prompt="@string/wifi_eap_user_cert" />
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_eap_identity" />
+
+ <EditText android:id="@+id/identity"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:singleLine="true"
+ android:inputType="textNoSuggestions" />
+
+ <TextView
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_eap_anonymous" />
+
+ <EditText android:id="@+id/anonymous"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:singleLine="true"
+ android:inputType="textNoSuggestions" />
+ </LinearLayout> <!-- android:id="@+id/eap" -->
+
+ <TextView android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_password" />
+
+ <EditText android:id="@+id/password"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:singleLine="true"
+ android:password="true" />
+
+ <CheckBox android:id="@+id/show_password"
+ android:layout_width="fill_parent"
+ android:layout_height="wrap_content"
+ android:text="@string/wifi_show_password" />
+ </LinearLayout> <!-- android:id="@+id/fields" -->
+</LinearLayout>
diff --git a/res/values/strings.xml b/res/values/strings.xml
index 23b429c..6e8082d 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -2644,4 +2644,42 @@ found in the list of installed applications.</string>
<string name="sound_category_calls_title">Incoming calls</string>
<string name="sound_category_notification_title">Notifications</string>
<string name="sound_category_feedback_title">Feedback</string>
+
+ <!-- Wifi Setup For Setup Wizard with XL screen -->
+ <!-- Title shown in Wifi Setup For Setup Wizard with XL screen -->
+ <string name="wifi_setup_title">WiFi setup</string>
+ <!-- Text message shown when Wifi is not connected.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_not_connected">Not connected</string>
+ <!-- Button message shown on the button adding manual setting.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_add_network">Add network</string>
+ <!-- Button message shown on the button refreshing a list of network.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_refresh_list">Refresh list</string>
+ <!-- Button message shown on the button enabling users skip Wifi Setup.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_skip">Skip</string>
+ <!-- Button message shown on the button enabling users go the next step.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_next">Next</string>
+
+ <!-- Message shown above available network when there's no connected network.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_status_select_network">Touch to select network</string>
+ <!-- Message shown above available networks when a user clicked one of available
+ networks and the UI is showing one possible existing network.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_status_existing_network">Connect to existing network</string>
+ <!-- The message shown above available networks when a user clicked "Add network"
+ button. Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_status_new_network">Connect to new network</string>
+ <!-- The message shown above available networks when a user clicked one of available
+ networks or created another profile and he/she is waiting for the connection
+ is established.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_status_connecting">Connecting...</string>
+ <!-- The message show above available networks when connection is established.
+ Used in Wifi Setup For Setup Wizard with XL screen. -->
+ <string name="wifi_setup_status_connected">Connected</string>
</resources>
diff --git a/res/xml/wifi_access_points_for_wifi_setup_xl.xml b/res/xml/wifi_access_points_for_wifi_setup_xl.xml
new file mode 100644
index 0000000..7766611
--- /dev/null
+++ b/res/xml/wifi_access_points_for_wifi_setup_xl.xml
@@ -0,0 +1,24 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- 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.
+-->
+
+<PreferenceScreen
+ xmlns:android="http://schemas.android.com/apk/res/android">
+
+ <com.android.settings.wifi.AccessPointCategoryForSetupWizardXL
+ android:key="access_points"
+ android:persistent="false" />
+
+</PreferenceScreen>
diff --git a/src/com/android/settings/ProgressCategory.java b/src/com/android/settings/ProgressCategory.java
index f611137..e0d9f45 100644
--- a/src/com/android/settings/ProgressCategory.java
+++ b/src/com/android/settings/ProgressCategory.java
@@ -21,9 +21,7 @@ import android.preference.PreferenceCategory;
import android.util.AttributeSet;
import android.view.View;
-import java.util.Map;
-
-public class ProgressCategory extends PreferenceCategory {
+public class ProgressCategory extends ProgressCategoryBase {
private boolean mProgress = false;
private View oldView = null;
@@ -36,10 +34,10 @@ public class ProgressCategory extends PreferenceCategory {
@Override
public void onBindView(View view) {
super.onBindView(view);
- View textView = view.findViewById(R.id.scanning_text);
- View progressBar = view.findViewById(R.id.scanning_progress);
+ final View textView = view.findViewById(R.id.scanning_text);
+ final View progressBar = view.findViewById(R.id.scanning_progress);
- int visibility = mProgress ? View.VISIBLE : View.INVISIBLE;
+ final int visibility = mProgress ? View.VISIBLE : View.INVISIBLE;
textView.setVisibility(visibility);
progressBar.setVisibility(visibility);
@@ -50,11 +48,8 @@ public class ProgressCategory extends PreferenceCategory {
}
oldView = view;
}
-
- /**
- * Turn on/off the progress indicator and text on the right.
- * @param progressOn whether or not the progress should be displayed
- */
+
+ @Override
public void setProgress(boolean progressOn) {
mProgress = progressOn;
notifyChanged();
diff --git a/src/com/android/settings/ProgressCategoryBase.java b/src/com/android/settings/ProgressCategoryBase.java
new file mode 100644
index 0000000..d120b94
--- /dev/null
+++ b/src/com/android/settings/ProgressCategoryBase.java
@@ -0,0 +1,33 @@
+/*
+ * 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;
+
+import android.content.Context;
+import android.preference.PreferenceCategory;
+import android.util.AttributeSet;
+
+public abstract class ProgressCategoryBase extends PreferenceCategory {
+ public ProgressCategoryBase(Context context, AttributeSet attrs) {
+ super(context, attrs);
+ }
+
+ /**
+ * Turn on/off the progress indicator and text on the right.
+ * @param progressOn whether or not the progress should be displayed
+ */
+ public abstract void setProgress(boolean progressOn);
+} \ No newline at end of file
diff --git a/src/com/android/settings/wifi/AccessPoint.java b/src/com/android/settings/wifi/AccessPoint.java
index 141c412..856b2c2 100644
--- a/src/com/android/settings/wifi/AccessPoint.java
+++ b/src/com/android/settings/wifi/AccessPoint.java
@@ -16,24 +16,53 @@
package com.android.settings.wifi;
-import com.android.settings.R;
-
import android.content.Context;
import android.net.NetworkInfo.DetailedState;
+import android.net.wifi.ScanResult;
import android.net.wifi.WifiConfiguration;
import android.net.wifi.WifiConfiguration.KeyMgmt;
import android.net.wifi.WifiInfo;
import android.net.wifi.WifiManager;
-import android.net.wifi.ScanResult;
import android.preference.Preference;
-import android.text.TextUtils;
import android.view.View;
import android.widget.ImageView;
+import com.android.settings.R;
+
+import java.util.Comparator;
+
class AccessPoint extends Preference {
private static final int[] STATE_SECURED = {R.attr.state_encrypted};
private static final int[] STATE_NONE = {};
+ public static final class Comparater
+ implements Comparator<AccessPoint> {
+ @Override
+ public int compare(AccessPoint accessPoint1, AccessPoint accessPoint2) {
+ // Active one goes first.
+ if (accessPoint1.mInfo != accessPoint2.mInfo) {
+ return (accessPoint1.mInfo != null) ? -1 : 1;
+ }
+
+ // Reachable one goes before unreachable one.
+ if ((accessPoint1.mRssi ^ accessPoint2.mRssi) < 0) {
+ return (accessPoint1.mRssi != Integer.MAX_VALUE) ? -1 : 1;
+ }
+ // Configured one goes before unconfigured one.
+ if ((accessPoint1.networkId ^ accessPoint2.networkId) < 0) {
+ return (accessPoint1.networkId != -1) ? -1 : 1;
+ }
+ // Sort by signal strength.
+ int difference = WifiManager.compareSignalLevel(
+ accessPoint2.mRssi, accessPoint1.mRssi);
+ if (difference != 0) {
+ return difference;
+ }
+ // Sort by ssid.
+ return accessPoint1.ssid.compareToIgnoreCase(accessPoint2.ssid);
+ }
+ }
+
static final int SECURITY_NONE = 0;
static final int SECURITY_WEP = 1;
static final int SECURITY_PSK = 2;
@@ -105,32 +134,6 @@ class AccessPoint extends Preference {
super.onBindView(view);
}
- @Override
- public int compareTo(Preference preference) {
- if (!(preference instanceof AccessPoint)) {
- return 1;
- }
- AccessPoint other = (AccessPoint) preference;
- // Active one goes first.
- if (mInfo != other.mInfo) {
- return (mInfo != null) ? -1 : 1;
- }
- // Reachable one goes before unreachable one.
- if ((mRssi ^ other.mRssi) < 0) {
- return (mRssi != Integer.MAX_VALUE) ? -1 : 1;
- }
- // Configured one goes before unconfigured one.
- if ((networkId ^ other.networkId) < 0) {
- return (networkId != -1) ? -1 : 1;
- }
- // Sort by signal strength.
- int difference = WifiManager.compareSignalLevel(other.mRssi, mRssi);
- if (difference != 0) {
- return difference;
- }
- // Sort by ssid.
- return ssid.compareToIgnoreCase(other.ssid);
- }
boolean update(ScanResult result) {
// We do not call refresh() since this is called before onBindView().
diff --git a/src/com/android/settings/wifi/AccessPointCategoryForSetupWizardXL.java b/src/com/android/settings/wifi/AccessPointCategoryForSetupWizardXL.java
new file mode 100644
index 0000000..5887d4c
--- /dev/null
+++ b/src/com/android/settings/wifi/AccessPointCategoryForSetupWizardXL.java
@@ -0,0 +1,35 @@
+/*
+ * 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 android.content.Context;
+import android.util.AttributeSet;
+
+import com.android.settings.ProgressCategoryBase;
+import com.android.settings.R;
+
+public class AccessPointCategoryForSetupWizardXL extends ProgressCategoryBase {
+ public AccessPointCategoryForSetupWizardXL(Context context, AttributeSet attrs) {
+ super(context, attrs);
+ setLayoutResource(R.layout.access_point_category_for_setup_wizard_xl);
+ }
+
+ @Override
+ public void setProgress(boolean progressOn) {
+ notifyChanged();
+ }
+} \ No newline at end of file
diff --git a/src/com/android/settings/wifi/Summary.java b/src/com/android/settings/wifi/Summary.java
index 6da2fa5..857d29e 100644
--- a/src/com/android/settings/wifi/Summary.java
+++ b/src/com/android/settings/wifi/Summary.java
@@ -16,11 +16,10 @@
package com.android.settings.wifi;
-import com.android.settings.R;
-
import android.content.Context;
import android.net.NetworkInfo.DetailedState;
-import android.text.TextUtils;
+
+import com.android.settings.R;
class Summary {
static String get(Context context, String ssid, DetailedState state) {
diff --git a/src/com/android/settings/wifi/WifiConfigController.java b/src/com/android/settings/wifi/WifiConfigController.java
new file mode 100644
index 0000000..f662acb
--- /dev/null
+++ b/src/com/android/settings/wifi/WifiConfigController.java
@@ -0,0 +1,369 @@
+/*
+ * 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 android.content.Context;
+import android.content.DialogInterface;
+import android.content.res.Resources;
+import android.net.NetworkInfo.DetailedState;
+import android.net.wifi.WifiConfiguration;
+import android.net.wifi.WifiConfiguration.AuthAlgorithm;
+import android.net.wifi.WifiConfiguration.KeyMgmt;
+import android.net.wifi.WifiInfo;
+import android.security.Credentials;
+import android.security.KeyStore;
+import android.text.Editable;
+import android.text.InputType;
+import android.text.TextWatcher;
+import android.text.format.Formatter;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.AdapterView;
+import android.widget.ArrayAdapter;
+import android.widget.CheckBox;
+import android.widget.Spinner;
+import android.widget.TextView;
+
+import com.android.settings.R;
+
+/**
+ * The class for allowing UIs like {@link WifiDialog} and {@link WifiConfigPreference} to
+ * share the logic for controlling buttons, text fields, etc.
+ */
+public class WifiConfigController implements TextWatcher,
+ View.OnClickListener, AdapterView.OnItemSelectedListener {
+ private static final String KEYSTORE_SPACE = "keystore://";
+
+ private final WifiConfigUiBase mConfigUi;
+ private final View mView;
+ private final AccessPoint mAccessPoint;
+
+ private boolean mEdit;
+
+ private TextView mSsid;
+
+ // e.g. AccessPoint.SECURITY_NONE
+ private int mSecurityType;
+ private TextView mPasswordView;
+
+ private Spinner mEapMethod;
+ private Spinner mEapCaCert;
+ private Spinner mPhase2;
+ private Spinner mEapUserCert;
+ private TextView mEapIdentity;
+ private TextView mEapAnonymous;
+
+ static boolean requireKeyStore(WifiConfiguration config) {
+ String values[] = {config.ca_cert.value(), config.client_cert.value(),
+ config.private_key.value()};
+ for (String value : values) {
+ if (value != null && value.startsWith(KEYSTORE_SPACE)) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ public WifiConfigController(WifiConfigUiBase parent, View view, AccessPoint accessPoint,
+ boolean edit, DialogInterface.OnClickListener listener) {
+ mConfigUi = parent;
+
+ mView = view;
+ mAccessPoint = accessPoint;
+ mSecurityType = (accessPoint == null) ? AccessPoint.SECURITY_NONE : accessPoint.security;
+ mEdit = edit;
+
+ final Context context = mConfigUi.getContext();
+ final Resources resources = context.getResources();
+
+ if (mAccessPoint == null) {
+ mConfigUi.setTitle(R.string.wifi_add_network);
+ mView.findViewById(R.id.type).setVisibility(View.VISIBLE);
+ mSsid = (TextView) mView.findViewById(R.id.ssid);
+ mSsid.addTextChangedListener(this);
+ ((Spinner) mView.findViewById(R.id.security)).setOnItemSelectedListener(this);
+
+ mConfigUi.setSubmitButton(context.getString(R.string.wifi_save));
+ } else {
+ mConfigUi.setTitle(mAccessPoint.ssid);
+ ViewGroup group = (ViewGroup) mView.findViewById(R.id.info);
+
+ DetailedState state = mAccessPoint.getState();
+ if (state != null) {
+ addRow(group, R.string.wifi_status, Summary.get(mConfigUi.getContext(), state));
+ }
+
+ String[] type = resources.getStringArray(R.array.wifi_security);
+ addRow(group, R.string.wifi_security, type[mAccessPoint.security]);
+
+ int level = mAccessPoint.getLevel();
+ if (level != -1) {
+ String[] signal = resources.getStringArray(R.array.wifi_signal);
+ addRow(group, R.string.wifi_signal, signal[level]);
+ }
+
+ WifiInfo info = mAccessPoint.getInfo();
+ if (info != null) {
+ addRow(group, R.string.wifi_speed, info.getLinkSpeed() + WifiInfo.LINK_SPEED_UNITS);
+ // TODO: fix the ip address for IPv6.
+ int address = info.getIpAddress();
+ if (address != 0) {
+ addRow(group, R.string.wifi_ip_address, Formatter.formatIpAddress(address));
+ }
+ }
+
+ if (mAccessPoint.networkId == -1 || mEdit) {
+ showSecurityFields();
+ }
+
+ if (mEdit) {
+ mConfigUi.setSubmitButton(context.getString(R.string.wifi_save));
+ } else {
+ if (state == null && level != -1) {
+ mConfigUi.setSubmitButton(context.getString(R.string.wifi_connect));
+ }
+ if (mAccessPoint.networkId != -1) {
+ mConfigUi.setForgetButton(context.getString(R.string.wifi_forget));
+ }
+ }
+ }
+
+ mConfigUi.setCancelButton(context.getString(R.string.wifi_cancel));
+ if (mConfigUi.getSubmitButton() != null) {
+ enableSubmitIfAppropriate();
+ }
+ }
+
+ private void addRow(ViewGroup group, int name, String value) {
+ View row = mConfigUi.getLayoutInflater().inflate(R.layout.wifi_dialog_row, group, false);
+ ((TextView) row.findViewById(R.id.name)).setText(name);
+ ((TextView) row.findViewById(R.id.value)).setText(value);
+ group.addView(row);
+ }
+
+ private void enableSubmitIfAppropriate() {
+ // TODO: make sure this is complete.
+ if ((mSsid != null && mSsid.length() == 0) ||
+ ((mAccessPoint == null || mAccessPoint.networkId == -1) &&
+ ((mSecurityType == AccessPoint.SECURITY_WEP && mPasswordView.length() == 0) ||
+ (mSecurityType == AccessPoint.SECURITY_PSK && mPasswordView.length() < 8)))) {
+ mConfigUi.getSubmitButton().setEnabled(false);
+ } else {
+ mConfigUi.getSubmitButton().setEnabled(true);
+ }
+ }
+
+ /* package */ WifiConfiguration getConfig() {
+ if (mAccessPoint != null && mAccessPoint.networkId != -1 && !mEdit) {
+ return null;
+ }
+
+ WifiConfiguration config = new WifiConfiguration();
+
+ if (mAccessPoint == null) {
+ config.SSID = AccessPoint.convertToQuotedString(
+ mSsid.getText().toString());
+ // If the user adds a network manually, assume that it is hidden.
+ config.hiddenSSID = true;
+ } else if (mAccessPoint.networkId == -1) {
+ config.SSID = AccessPoint.convertToQuotedString(
+ mAccessPoint.ssid);
+ } else {
+ config.networkId = mAccessPoint.networkId;
+ }
+
+ switch (mSecurityType) {
+ case AccessPoint.SECURITY_NONE:
+ config.allowedKeyManagement.set(KeyMgmt.NONE);
+ return config;
+
+ case AccessPoint.SECURITY_WEP:
+ config.allowedKeyManagement.set(KeyMgmt.NONE);
+ config.allowedAuthAlgorithms.set(AuthAlgorithm.OPEN);
+ config.allowedAuthAlgorithms.set(AuthAlgorithm.SHARED);
+ if (mPasswordView.length() != 0) {
+ int length = mPasswordView.length();
+ String password = mPasswordView.getText().toString();
+ // WEP-40, WEP-104, and 256-bit WEP (WEP-232?)
+ if ((length == 10 || length == 26 || length == 58) &&
+ password.matches("[0-9A-Fa-f]*")) {
+ config.wepKeys[0] = password;
+ } else {
+ config.wepKeys[0] = '"' + password + '"';
+ }
+ }
+ return config;
+
+ case AccessPoint.SECURITY_PSK:
+ config.allowedKeyManagement.set(KeyMgmt.WPA_PSK);
+ if (mPasswordView.length() != 0) {
+ String password = mPasswordView.getText().toString();
+ if (password.matches("[0-9A-Fa-f]{64}")) {
+ config.preSharedKey = password;
+ } else {
+ config.preSharedKey = '"' + password + '"';
+ }
+ }
+ return config;
+
+ case AccessPoint.SECURITY_EAP:
+ config.allowedKeyManagement.set(KeyMgmt.WPA_EAP);
+ config.allowedKeyManagement.set(KeyMgmt.IEEE8021X);
+ config.eap.setValue((String) mEapMethod.getSelectedItem());
+
+ config.phase2.setValue((mPhase2.getSelectedItemPosition() == 0) ? "" :
+ "auth=" + mPhase2.getSelectedItem());
+ config.ca_cert.setValue((mEapCaCert.getSelectedItemPosition() == 0) ? "" :
+ KEYSTORE_SPACE + Credentials.CA_CERTIFICATE +
+ (String) mEapCaCert.getSelectedItem());
+ config.client_cert.setValue((mEapUserCert.getSelectedItemPosition() == 0) ? "" :
+ KEYSTORE_SPACE + Credentials.USER_CERTIFICATE +
+ (String) mEapUserCert.getSelectedItem());
+ config.private_key.setValue((mEapUserCert.getSelectedItemPosition() == 0) ? "" :
+ KEYSTORE_SPACE + Credentials.USER_PRIVATE_KEY +
+ (String) mEapUserCert.getSelectedItem());
+ config.identity.setValue((mEapIdentity.length() == 0) ? "" :
+ mEapIdentity.getText().toString());
+ config.anonymous_identity.setValue((mEapAnonymous.length() == 0) ? "" :
+ mEapAnonymous.getText().toString());
+ if (mPasswordView.length() != 0) {
+ config.password.setValue(mPasswordView.getText().toString());
+ }
+ return config;
+ }
+ return null;
+ }
+
+ private void showSecurityFields() {
+ if (mSecurityType == AccessPoint.SECURITY_NONE) {
+ mView.findViewById(R.id.fields).setVisibility(View.GONE);
+ return;
+ }
+ mView.findViewById(R.id.fields).setVisibility(View.VISIBLE);
+
+ if (mPasswordView == null) {
+ mPasswordView = (TextView) mView.findViewById(R.id.password);
+ mPasswordView.addTextChangedListener(this);
+ ((CheckBox) mView.findViewById(R.id.show_password)).setOnClickListener(this);
+
+ if (mAccessPoint != null && mAccessPoint.networkId != -1) {
+ mPasswordView.setHint(R.string.wifi_unchanged);
+ }
+ }
+
+ if (mSecurityType != AccessPoint.SECURITY_EAP) {
+ mView.findViewById(R.id.eap).setVisibility(View.GONE);
+ return;
+ }
+ mView.findViewById(R.id.eap).setVisibility(View.VISIBLE);
+
+ if (mEapMethod == null) {
+ mEapMethod = (Spinner) mView.findViewById(R.id.method);
+ mPhase2 = (Spinner) mView.findViewById(R.id.phase2);
+ mEapCaCert = (Spinner) mView.findViewById(R.id.ca_cert);
+ mEapUserCert = (Spinner) mView.findViewById(R.id.user_cert);
+ mEapIdentity = (TextView) mView.findViewById(R.id.identity);
+ mEapAnonymous = (TextView) mView.findViewById(R.id.anonymous);
+
+ loadCertificates(mEapCaCert, Credentials.CA_CERTIFICATE);
+ loadCertificates(mEapUserCert, Credentials.USER_PRIVATE_KEY);
+
+ if (mAccessPoint != null && mAccessPoint.networkId != -1) {
+ WifiConfiguration config = mAccessPoint.getConfig();
+ setSelection(mEapMethod, config.eap.value());
+ setSelection(mPhase2, config.phase2.value());
+ setCertificate(mEapCaCert, Credentials.CA_CERTIFICATE,
+ config.ca_cert.value());
+ setCertificate(mEapUserCert, Credentials.USER_PRIVATE_KEY,
+ config.private_key.value());
+ mEapIdentity.setText(config.identity.value());
+ mEapAnonymous.setText(config.anonymous_identity.value());
+ }
+ }
+ }
+
+ private void loadCertificates(Spinner spinner, String prefix) {
+ final Context context = mConfigUi.getContext();
+ final String unspecified = context.getString(R.string.wifi_unspecified);
+
+ String[] certs = KeyStore.getInstance().saw(prefix);
+ if (certs == null || certs.length == 0) {
+ certs = new String[] {unspecified};
+ } else {
+ final String[] array = new String[certs.length + 1];
+ array[0] = unspecified;
+ System.arraycopy(certs, 0, array, 1, certs.length);
+ certs = array;
+ }
+
+ final ArrayAdapter<String> adapter = new ArrayAdapter<String>(
+ context, android.R.layout.simple_spinner_item, certs);
+ adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
+ spinner.setAdapter(adapter);
+ }
+
+ private void setCertificate(Spinner spinner, String prefix, String cert) {
+ prefix = KEYSTORE_SPACE + prefix;
+ if (cert != null && cert.startsWith(prefix)) {
+ setSelection(spinner, cert.substring(prefix.length()));
+ }
+ }
+
+ private void setSelection(Spinner spinner, String value) {
+ if (value != null) {
+ ArrayAdapter<String> adapter = (ArrayAdapter<String>) spinner.getAdapter();
+ for (int i = adapter.getCount() - 1; i >= 0; --i) {
+ if (value.equals(adapter.getItem(i))) {
+ spinner.setSelection(i);
+ break;
+ }
+ }
+ }
+ }
+
+ @Override
+ public void afterTextChanged(Editable s) {
+ enableSubmitIfAppropriate();
+ }
+
+ @Override
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+ }
+
+ @Override
+ public void onTextChanged(CharSequence s, int start, int before, int count) {
+ }
+
+ @Override
+ public void onClick(View view) {
+ mPasswordView.setInputType(
+ InputType.TYPE_CLASS_TEXT | (((CheckBox) view).isChecked() ?
+ InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD :
+ InputType.TYPE_TEXT_VARIATION_PASSWORD));
+ }
+
+ @Override
+ public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
+ mSecurityType = position;
+ showSecurityFields();
+ enableSubmitIfAppropriate();
+ }
+
+ @Override
+ public void onNothingSelected(AdapterView<?> parent) {
+ }
+} \ No newline at end of file
diff --git a/src/com/android/settings/wifi/WifiConfigPreference.java b/src/com/android/settings/wifi/WifiConfigPreference.java
new file mode 100644
index 0000000..c5a366d
--- /dev/null
+++ b/src/com/android/settings/wifi/WifiConfigPreference.java
@@ -0,0 +1,129 @@
+/*
+ * 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 android.content.Context;
+import android.content.DialogInterface;
+import android.preference.Preference;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.Button;
+
+import com.android.settings.R;
+
+/**
+ * Preference letting users modify a setting for Wifi network. This work as an alternative UI
+ * for {@link WifiDialog} without shouwing popup Dialog.
+ */
+public class WifiConfigPreference extends Preference implements WifiConfigUiBase {
+ private WifiSettings mWifiSettings;
+ private View mView;
+ private final DialogInterface.OnClickListener mListener;
+ private WifiConfigController mController;
+ private AccessPoint mAccessPoint;
+ private boolean mEdit;
+
+ private LayoutInflater mInflater;
+
+ public WifiConfigPreference(WifiSettings wifiSettings,
+ DialogInterface.OnClickListener listener,
+ AccessPoint accessPoint, boolean edit) {
+ super(wifiSettings.getActivity());
+ mWifiSettings = wifiSettings;
+ setLayoutResource(R.layout.wifi_config_preference);
+ mListener = listener;
+ mAccessPoint = accessPoint;
+ mEdit = edit;
+ mInflater = (LayoutInflater)
+ wifiSettings.getActivity().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
+ }
+
+ @Override
+ protected View onCreateView(ViewGroup parent) {
+ // Called every time the list is created.
+ if (mView != null) {
+ // TODO: we need to re-forcus something.
+ return mView;
+ }
+ mView = mInflater.inflate(getLayoutResource(), parent, false);
+ mController = new WifiConfigController(this, mView, mAccessPoint, mEdit, mListener);
+ return mView;
+ }
+
+ @Override
+ public WifiConfigController getController() {
+ return mController;
+ }
+
+ public View findViewById(int id) {
+ return mView.findViewById(id);
+ }
+
+ public AccessPoint getAccessPoint() {
+ return mAccessPoint;
+ }
+
+ @Override
+ public boolean isEdit() {
+ return mEdit;
+ }
+
+ @Override
+ public LayoutInflater getLayoutInflater() {
+ return mInflater;
+ }
+
+ @Override
+ public Button getSubmitButton() {
+ return (Button)mWifiSettings.getActivity().findViewById(R.id.wifi_setup_connect);
+ }
+
+ @Override
+ public Button getForgetButton() {
+ return (Button)mWifiSettings.getActivity().findViewById(R.id.wifi_setup_forget);
+ }
+
+ @Override
+ public Button getCancelButton() {
+ return (Button)mWifiSettings.getActivity().findViewById(R.id.wifi_setup_cancel);
+ }
+
+ @Override
+ public void setSubmitButton(CharSequence text) {
+ final Button button = (Button)
+ mWifiSettings.getActivity().findViewById(R.id.wifi_setup_connect);
+ button.setVisibility(View.VISIBLE);
+
+ // test
+ mWifiSettings.getActivity().findViewById(R.id.wifi_setup_forget).setVisibility(View.GONE);
+ }
+
+ @Override
+ public void setForgetButton(CharSequence text) {
+ final Button button = (Button)
+ mWifiSettings.getActivity().findViewById(R.id.wifi_setup_forget);
+ button.setVisibility(View.VISIBLE);
+ }
+
+ @Override
+ public void setCancelButton(CharSequence text) {
+ final Button button = (Button)
+ mWifiSettings.getActivity().findViewById(R.id.wifi_setup_cancel);
+ button.setVisibility(View.VISIBLE);
+ }
+} \ No newline at end of file
diff --git a/src/com/android/settings/wifi/WifiConfigUiBase.java b/src/com/android/settings/wifi/WifiConfigUiBase.java
new file mode 100644
index 0000000..e17d491
--- /dev/null
+++ b/src/com/android/settings/wifi/WifiConfigUiBase.java
@@ -0,0 +1,42 @@
+/*
+ * 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 android.content.Context;
+import android.view.LayoutInflater;
+import android.widget.Button;
+
+/**
+ * Foundation interface glues between Activities and UIs like
+ * {@link WifiDialog} or {@link WifiConfigController}.
+ */
+public interface WifiConfigUiBase {
+ public Context getContext();
+ public WifiConfigController getController();
+ public LayoutInflater getLayoutInflater();
+ public boolean isEdit();
+
+ public void setTitle(int id);
+ public void setTitle(CharSequence title);
+
+ public void setSubmitButton(CharSequence text);
+ public void setForgetButton(CharSequence text);
+ public void setCancelButton(CharSequence text);
+ public Button getSubmitButton();
+ public Button getForgetButton();
+ public Button getCancelButton();
+} \ No newline at end of file
diff --git a/src/com/android/settings/wifi/WifiDialog.java b/src/com/android/settings/wifi/WifiDialog.java
index a8bf717..e8ab2a0 100644
--- a/src/com/android/settings/wifi/WifiDialog.java
+++ b/src/com/android/settings/wifi/WifiDialog.java
@@ -16,154 +16,37 @@
package com.android.settings.wifi;
-import com.android.settings.R;
-
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
-import android.content.res.Resources;
-import android.net.NetworkInfo.DetailedState;
-import android.net.wifi.WifiConfiguration;
-import android.net.wifi.WifiConfiguration.AuthAlgorithm;
-import android.net.wifi.WifiConfiguration.KeyMgmt;
-import android.net.wifi.WifiInfo;
import android.os.Bundle;
-import android.security.Credentials;
-import android.security.KeyStore;
-import android.text.Editable;
-import android.text.InputType;
-import android.text.TextWatcher;
-import android.text.format.Formatter;
import android.view.View;
-import android.view.ViewGroup;
-import android.widget.AdapterView;
-import android.widget.ArrayAdapter;
-import android.widget.CheckBox;
-import android.widget.Spinner;
-import android.widget.TextView;
+import android.widget.Button;
-class WifiDialog extends AlertDialog implements View.OnClickListener,
- TextWatcher, AdapterView.OnItemSelectedListener {
- private static final String KEYSTORE_SPACE = "keystore://";
+import com.android.settings.R;
+class WifiDialog extends AlertDialog implements WifiConfigUiBase {
static final int BUTTON_SUBMIT = DialogInterface.BUTTON_POSITIVE;
static final int BUTTON_FORGET = DialogInterface.BUTTON_NEUTRAL;
- final boolean edit;
+ private final boolean mEdit;
private final DialogInterface.OnClickListener mListener;
private final AccessPoint mAccessPoint;
private View mView;
- private TextView mSsid;
- private int mSecurity;
- private TextView mPassword;
-
- private Spinner mEapMethod;
- private Spinner mEapCaCert;
- private Spinner mPhase2;
- private Spinner mEapUserCert;
- private TextView mEapIdentity;
- private TextView mEapAnonymous;
+ private WifiConfigController mController;
- static boolean requireKeyStore(WifiConfiguration config) {
- String values[] = {config.ca_cert.value(), config.client_cert.value(),
- config.private_key.value()};
- for (String value : values) {
- if (value != null && value.startsWith(KEYSTORE_SPACE)) {
- return true;
- }
- }
- return false;
- }
-
- WifiDialog(Context context, DialogInterface.OnClickListener listener,
+ public WifiDialog(Context context, DialogInterface.OnClickListener listener,
AccessPoint accessPoint, boolean edit) {
super(context);
- this.edit = edit;
+ mEdit = edit;
mListener = listener;
mAccessPoint = accessPoint;
- mSecurity = (accessPoint == null) ? AccessPoint.SECURITY_NONE : accessPoint.security;
}
- WifiConfiguration getConfig() {
- if (mAccessPoint != null && mAccessPoint.networkId != -1 && !edit) {
- return null;
- }
-
- WifiConfiguration config = new WifiConfiguration();
-
- if (mAccessPoint == null) {
- config.SSID = AccessPoint.convertToQuotedString(
- mSsid.getText().toString());
- // If the user adds a network manually, assume that it is hidden.
- config.hiddenSSID = true;
- } else if (mAccessPoint.networkId == -1) {
- config.SSID = AccessPoint.convertToQuotedString(
- mAccessPoint.ssid);
- } else {
- config.networkId = mAccessPoint.networkId;
- }
-
- switch (mSecurity) {
- case AccessPoint.SECURITY_NONE:
- config.allowedKeyManagement.set(KeyMgmt.NONE);
- return config;
-
- case AccessPoint.SECURITY_WEP:
- config.allowedKeyManagement.set(KeyMgmt.NONE);
- config.allowedAuthAlgorithms.set(AuthAlgorithm.OPEN);
- config.allowedAuthAlgorithms.set(AuthAlgorithm.SHARED);
- if (mPassword.length() != 0) {
- int length = mPassword.length();
- String password = mPassword.getText().toString();
- // WEP-40, WEP-104, and 256-bit WEP (WEP-232?)
- if ((length == 10 || length == 26 || length == 58) &&
- password.matches("[0-9A-Fa-f]*")) {
- config.wepKeys[0] = password;
- } else {
- config.wepKeys[0] = '"' + password + '"';
- }
- }
- return config;
-
- case AccessPoint.SECURITY_PSK:
- config.allowedKeyManagement.set(KeyMgmt.WPA_PSK);
- if (mPassword.length() != 0) {
- String password = mPassword.getText().toString();
- if (password.matches("[0-9A-Fa-f]{64}")) {
- config.preSharedKey = password;
- } else {
- config.preSharedKey = '"' + password + '"';
- }
- }
- return config;
-
- case AccessPoint.SECURITY_EAP:
- config.allowedKeyManagement.set(KeyMgmt.WPA_EAP);
- config.allowedKeyManagement.set(KeyMgmt.IEEE8021X);
- config.eap.setValue((String) mEapMethod.getSelectedItem());
-
- config.phase2.setValue((mPhase2.getSelectedItemPosition() == 0) ? "" :
- "auth=" + mPhase2.getSelectedItem());
- config.ca_cert.setValue((mEapCaCert.getSelectedItemPosition() == 0) ? "" :
- KEYSTORE_SPACE + Credentials.CA_CERTIFICATE +
- (String) mEapCaCert.getSelectedItem());
- config.client_cert.setValue((mEapUserCert.getSelectedItemPosition() == 0) ? "" :
- KEYSTORE_SPACE + Credentials.USER_CERTIFICATE +
- (String) mEapUserCert.getSelectedItem());
- config.private_key.setValue((mEapUserCert.getSelectedItemPosition() == 0) ? "" :
- KEYSTORE_SPACE + Credentials.USER_PRIVATE_KEY +
- (String) mEapUserCert.getSelectedItem());
- config.identity.setValue((mEapIdentity.length() == 0) ? "" :
- mEapIdentity.getText().toString());
- config.anonymous_identity.setValue((mEapAnonymous.length() == 0) ? "" :
- mEapAnonymous.getText().toString());
- if (mPassword.length() != 0) {
- config.password.setValue(mPassword.getText().toString());
- }
- return config;
- }
- return null;
+ @Override
+ public WifiConfigController getController() {
+ return mController;
}
@Override
@@ -171,200 +54,42 @@ class WifiDialog extends AlertDialog implements View.OnClickListener,
mView = getLayoutInflater().inflate(R.layout.wifi_dialog, null);
setView(mView);
setInverseBackgroundForced(true);
-
- Context context = getContext();
- Resources resources = context.getResources();
-
- if (mAccessPoint == null) {
- setTitle(R.string.wifi_add_network);
- mView.findViewById(R.id.type).setVisibility(View.VISIBLE);
- mSsid = (TextView) mView.findViewById(R.id.ssid);
- mSsid.addTextChangedListener(this);
- ((Spinner) mView.findViewById(R.id.security)).setOnItemSelectedListener(this);
- setButton(BUTTON_SUBMIT, context.getString(R.string.wifi_save), mListener);
- } else {
- setTitle(mAccessPoint.ssid);
- ViewGroup group = (ViewGroup) mView.findViewById(R.id.info);
-
- DetailedState state = mAccessPoint.getState();
- if (state != null) {
- addRow(group, R.string.wifi_status, Summary.get(getContext(), state));
- }
-
- String[] type = resources.getStringArray(R.array.wifi_security);
- addRow(group, R.string.wifi_security, type[mAccessPoint.security]);
-
- int level = mAccessPoint.getLevel();
- if (level != -1) {
- String[] signal = resources.getStringArray(R.array.wifi_signal);
- addRow(group, R.string.wifi_signal, signal[level]);
- }
-
- WifiInfo info = mAccessPoint.getInfo();
- if (info != null) {
- addRow(group, R.string.wifi_speed, info.getLinkSpeed() + WifiInfo.LINK_SPEED_UNITS);
- // TODO: fix the ip address for IPv6.
- int address = info.getIpAddress();
- if (address != 0) {
- addRow(group, R.string.wifi_ip_address, Formatter.formatIpAddress(address));
- }
- }
-
- if (mAccessPoint.networkId == -1 || edit) {
- showSecurityFields();
- }
-
- if (edit) {
- setButton(BUTTON_SUBMIT, context.getString(R.string.wifi_save), mListener);
- } else {
- if (state == null && level != -1) {
- setButton(BUTTON_SUBMIT, context.getString(R.string.wifi_connect), mListener);
- }
- if (mAccessPoint.networkId != -1) {
- setButton(BUTTON_FORGET, context.getString(R.string.wifi_forget), mListener);
- }
- }
- }
-
- setButton(DialogInterface.BUTTON_NEGATIVE,
- context.getString(R.string.wifi_cancel), mListener);
-
+ mController = new WifiConfigController(this, mView, mAccessPoint, mEdit, mListener);
super.onCreate(savedInstanceState);
-
- if (getButton(BUTTON_SUBMIT) != null) {
- validate();
- }
}
- private void addRow(ViewGroup group, int name, String value) {
- View row = getLayoutInflater().inflate(R.layout.wifi_dialog_row, group, false);
- ((TextView) row.findViewById(R.id.name)).setText(name);
- ((TextView) row.findViewById(R.id.value)).setText(value);
- group.addView(row);
- }
-
- private void validate() {
- // TODO: make sure this is complete.
- if ((mSsid != null && mSsid.length() == 0) ||
- ((mAccessPoint == null || mAccessPoint.networkId == -1) &&
- ((mSecurity == AccessPoint.SECURITY_WEP && mPassword.length() == 0) ||
- (mSecurity == AccessPoint.SECURITY_PSK && mPassword.length() < 8)))) {
- getButton(BUTTON_SUBMIT).setEnabled(false);
- } else {
- getButton(BUTTON_SUBMIT).setEnabled(true);
- }
- }
-
- public void onClick(View view) {
- mPassword.setInputType(
- InputType.TYPE_CLASS_TEXT | (((CheckBox) view).isChecked() ?
- InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD :
- InputType.TYPE_TEXT_VARIATION_PASSWORD));
- }
-
- public void onTextChanged(CharSequence s, int start, int before, int count) {
- }
-
- public void beforeTextChanged(CharSequence s, int start, int count, int after) {
- }
-
- public void afterTextChanged(Editable editable) {
- validate();
+ @Override
+ public boolean isEdit() {
+ return mEdit;
}
- public void onItemSelected(AdapterView parent, View view, int position, long id) {
- mSecurity = position;
- showSecurityFields();
- validate();
+ @Override
+ public Button getSubmitButton() {
+ return getButton(BUTTON_SUBMIT);
}
- public void onNothingSelected(AdapterView parent) {
+ @Override
+ public Button getForgetButton() {
+ return getButton(BUTTON_FORGET);
}
- private void showSecurityFields() {
- if (mSecurity == AccessPoint.SECURITY_NONE) {
- mView.findViewById(R.id.fields).setVisibility(View.GONE);
- return;
- }
- mView.findViewById(R.id.fields).setVisibility(View.VISIBLE);
-
- if (mPassword == null) {
- mPassword = (TextView) mView.findViewById(R.id.password);
- mPassword.addTextChangedListener(this);
- ((CheckBox) mView.findViewById(R.id.show_password)).setOnClickListener(this);
-
- if (mAccessPoint != null && mAccessPoint.networkId != -1) {
- mPassword.setHint(R.string.wifi_unchanged);
- }
- }
-
- if (mSecurity != AccessPoint.SECURITY_EAP) {
- mView.findViewById(R.id.eap).setVisibility(View.GONE);
- return;
- }
- mView.findViewById(R.id.eap).setVisibility(View.VISIBLE);
-
- if (mEapMethod == null) {
- mEapMethod = (Spinner) mView.findViewById(R.id.method);
- mPhase2 = (Spinner) mView.findViewById(R.id.phase2);
- mEapCaCert = (Spinner) mView.findViewById(R.id.ca_cert);
- mEapUserCert = (Spinner) mView.findViewById(R.id.user_cert);
- mEapIdentity = (TextView) mView.findViewById(R.id.identity);
- mEapAnonymous = (TextView) mView.findViewById(R.id.anonymous);
-
- loadCertificates(mEapCaCert, Credentials.CA_CERTIFICATE);
- loadCertificates(mEapUserCert, Credentials.USER_PRIVATE_KEY);
-
- if (mAccessPoint != null && mAccessPoint.networkId != -1) {
- WifiConfiguration config = mAccessPoint.getConfig();
- setSelection(mEapMethod, config.eap.value());
- setSelection(mPhase2, config.phase2.value());
- setCertificate(mEapCaCert, Credentials.CA_CERTIFICATE,
- config.ca_cert.value());
- setCertificate(mEapUserCert, Credentials.USER_PRIVATE_KEY,
- config.private_key.value());
- mEapIdentity.setText(config.identity.value());
- mEapAnonymous.setText(config.anonymous_identity.value());
- }
- }
+ @Override
+ public Button getCancelButton() {
+ return getButton(BUTTON_NEGATIVE);
}
- private void loadCertificates(Spinner spinner, String prefix) {
- String[] certs = KeyStore.getInstance().saw(prefix);
- Context context = getContext();
- String unspecified = context.getString(R.string.wifi_unspecified);
-
- if (certs == null || certs.length == 0) {
- certs = new String[] {unspecified};
- } else {
- String[] array = new String[certs.length + 1];
- array[0] = unspecified;
- System.arraycopy(certs, 0, array, 1, certs.length);
- certs = array;
- }
-
- ArrayAdapter<String> adapter = new ArrayAdapter<String>(
- context, android.R.layout.simple_spinner_item, certs);
- adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
- spinner.setAdapter(adapter);
+ @Override
+ public void setSubmitButton(CharSequence text) {
+ setButton(BUTTON_SUBMIT, text, mListener);
}
- private void setCertificate(Spinner spinner, String prefix, String cert) {
- prefix = KEYSTORE_SPACE + prefix;
- if (cert != null && cert.startsWith(prefix)) {
- setSelection(spinner, cert.substring(prefix.length()));
- }
+ @Override
+ public void setForgetButton(CharSequence text) {
+ setButton(BUTTON_FORGET, text, mListener);
}
- private void setSelection(Spinner spinner, String value) {
- if (value != null) {
- ArrayAdapter<String> adapter = (ArrayAdapter<String>) spinner.getAdapter();
- for (int i = adapter.getCount() - 1; i >= 0; --i) {
- if (value.equals(adapter.getItem(i))) {
- spinner.setSelection(i);
- break;
- }
- }
- }
+ @Override
+ public void setCancelButton(CharSequence text) {
+ setButton(BUTTON_NEGATIVE, text, mListener);
}
}
diff --git a/src/com/android/settings/wifi/WifiSettings.java b/src/com/android/settings/wifi/WifiSettings.java
index 5332fb3..dc8f6db 100644
--- a/src/com/android/settings/wifi/WifiSettings.java
+++ b/src/com/android/settings/wifi/WifiSettings.java
@@ -47,16 +47,32 @@ import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
+import android.view.View.OnClickListener;
import android.widget.AdapterView.AdapterContextMenuInfo;
+import android.widget.Button;
+import android.widget.ProgressBar;
+import android.widget.TextView;
import android.widget.Toast;
-import com.android.settings.ProgressCategory;
+import com.android.settings.ProgressCategoryBase;
import com.android.settings.R;
import com.android.settings.SettingsPreferenceFragment;
-import java.util.ArrayList;
+import java.util.Collection;
import java.util.List;
+import java.util.TreeSet;
+/**
+ * This currently provides three types of UI.
+ *
+ * Two are for phones with relatively small screens: "for SetupWizard" and "for usual Settings".
+ * Users just need to launch WifiSettings Activity as usual. The request will be appropriately
+ * handled by ActivityManager, and they will have appropriate look-and-feel with this fragment.
+ *
+ * Third type is for Setup Wizard with X-Large, landscape UI. Users need to launch
+ * {@link WifiSettingsForSetupWizardXL} Activity, which contains this fragment but also has
+ * other decorations specific to that screen.
+ */
public class WifiSettings extends SettingsPreferenceFragment
implements DialogInterface.OnClickListener {
private static final int MENU_ID_SCAN = Menu.FIRST;
@@ -65,7 +81,13 @@ public class WifiSettings extends SettingsPreferenceFragment
private static final int MENU_ID_FORGET = Menu.FIRST + 3;
private static final int MENU_ID_MODIFY = Menu.FIRST + 4;
+ // Indicates that this fragment is used as a part of Setup Wizard with XL screen settings.
+ // This fragment should show information which has been shown as Dialog in combined UI
+ // inside this fragment.
+ /* package */ static final String IN_XL_SETUP_WIZARD = "in_setup_wizard";
+
// this boolean extra specifies whether to disable the Next button when not connected
+ // Note: this is only effective in Setup Wizard with XL screen size.
private static final String EXTRA_ENABLE_NEXT_ON_CONNECT = "wifi_enable_next_on_connect";
private final IntentFilter mFilter;
@@ -75,19 +97,26 @@ public class WifiSettings extends SettingsPreferenceFragment
private WifiManager mWifiManager;
private WifiEnabler mWifiEnabler;
private CheckBoxPreference mNotifyOpenNetworks;
- private ProgressCategory mAccessPoints;
+ private ProgressCategoryBase mAccessPoints;
private Preference mAddNetwork;
+ // An access point being editted is stored here.
+ private AccessPoint mSelectedAccessPoint;
private DetailedState mLastState;
private WifiInfo mLastInfo;
private int mKeyStoreNetworkId = -1;
- private AccessPoint mSelected;
- private WifiDialog mDialog;
-
// should Next button only be enabled when we have a connection?
private boolean mEnableNextOnConnection;
+ private boolean mInXlSetupWizard;
+
+
+ // TODO: merge into one
+ private WifiConfigPreference mConfigPreference;
+ private WifiDialog mDialog;
+
+ private boolean mRefrainListUpdate;
public WifiSettings() {
mFilter = new IntentFilter();
@@ -120,19 +149,26 @@ public class WifiSettings extends SettingsPreferenceFragment
final Activity activity = getActivity();
final Intent intent = activity.getIntent();
+ mInXlSetupWizard = intent.getBooleanExtra(IN_XL_SETUP_WIZARD, false);
+
// if we're supposed to enable/disable the Next button based on our current connection
// state, start it off in the right state
mEnableNextOnConnection = intent.getBooleanExtra(EXTRA_ENABLE_NEXT_ON_CONNECT, false);
- if (mEnableNextOnConnection && hasNextButton()) {
- ConnectivityManager connectivity = (ConnectivityManager)
- getActivity().getSystemService(Context.CONNECTIVITY_SERVICE);
- if (connectivity != null) {
- NetworkInfo info = connectivity.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
- getNextButton().setEnabled(info.isConnected());
+
+ if (mEnableNextOnConnection) {
+ if (mEnableNextOnConnection && hasNextButton()) {
+ final ConnectivityManager connectivity = (ConnectivityManager)
+ getActivity().getSystemService(Context.CONNECTIVITY_SERVICE);
+ if (connectivity != null) {
+ NetworkInfo info = connectivity.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
+ changeNextButtonState(info.isConnected());
+ }
}
}
- if (intent.getBooleanExtra("only_access_points", false)) {
+ if (mInXlSetupWizard) {
+ addPreferencesFromResource(R.xml.wifi_access_points_for_wifi_setup_xl);
+ } else if (intent.getBooleanExtra("only_access_points", false)) {
addPreferencesFromResource(R.xml.wifi_access_points);
} else {
addPreferencesFromResource(R.xml.wifi_settings);
@@ -147,8 +183,11 @@ public class WifiSettings extends SettingsPreferenceFragment
// After confirming PreferenceScreen is available, we call super.
super.onActivityCreated(savedInstanceState);
- mAccessPoints = (ProgressCategory) findPreference("access_points");
- mAccessPoints.setOrderingAsAdded(false);
+ // This may be either ProgressCategory or AccessPointCategoryForXL.
+ final ProgressCategoryBase preference =
+ (ProgressCategoryBase) findPreference("access_points");
+ mAccessPoints = preference;
+ mAccessPoints.setOrderingAsAdded(true);
mAddNetwork = findPreference("add_network");
registerForContextMenu(getListView());
@@ -167,7 +206,34 @@ public class WifiSettings extends SettingsPreferenceFragment
mWifiManager.connectNetwork(mKeyStoreNetworkId);
}
mKeyStoreNetworkId = -1;
- updateAccessPoints();
+ if (mInXlSetupWizard) {
+ // We show "Now scanning"
+ final int wifiState = mWifiManager.getWifiState();
+ switch (wifiState) {
+ case WifiManager.WIFI_STATE_ENABLED: {
+ updateAccessPoints();
+ break;
+ }
+ case WifiManager.WIFI_STATE_DISABLED:
+ case WifiManager.WIFI_STATE_DISABLING:
+ case WifiManager.WIFI_STATE_UNKNOWN: {
+ mWifiManager.setWifiEnabled(true);
+ } // $FALL-THROUGH$
+ default: {
+ mAccessPoints.removeAll();
+ Preference preference = new Preference(getActivity());
+ preference.setLayoutResource(R.layout.preference_widget_shortcut);
+ preference.setSelectable(false);
+ preference.setTitle("Connecting");
+ preference.setSummary("COONNECTING");
+ mAccessPoints.addPreference(preference);
+ break;
+ }
+ }
+ } else {
+ Log.d("@@@", "updateAccessPoints");
+ updateAccessPoints();
+ }
}
@Override
@@ -186,10 +252,13 @@ public class WifiSettings extends SettingsPreferenceFragment
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
- menu.add(Menu.NONE, MENU_ID_SCAN, 0, R.string.wifi_menu_scan)
- .setIcon(R.drawable.ic_menu_scan_network);
- menu.add(Menu.NONE, MENU_ID_ADVANCED, 0, R.string.wifi_menu_advanced)
- .setIcon(android.R.drawable.ic_menu_manage);
+ // We don't want menus in Setup Wizard XL.
+ if (!mInXlSetupWizard) {
+ menu.add(Menu.NONE, MENU_ID_SCAN, 0, R.string.wifi_menu_scan)
+ .setIcon(R.drawable.ic_menu_scan_network);
+ menu.add(Menu.NONE, MENU_ID_ADVANCED, 0, R.string.wifi_menu_advanced)
+ .setIcon(android.R.drawable.ic_menu_manage);
+ }
super.onCreateOptionsMenu(menu, inflater);
}
@@ -215,14 +284,15 @@ public class WifiSettings extends SettingsPreferenceFragment
((AdapterContextMenuInfo) info).position);
if (preference instanceof AccessPoint) {
- mSelected = (AccessPoint) preference;
- menu.setHeaderTitle(mSelected.ssid);
- if (mSelected.getLevel() != -1 && mSelected.getState() == null) {
+ mSelectedAccessPoint = (AccessPoint) preference;
+ menu.setHeaderTitle(mSelectedAccessPoint.ssid);
+ if (mSelectedAccessPoint.getLevel() != -1
+ && mSelectedAccessPoint.getState() == null) {
menu.add(Menu.NONE, MENU_ID_CONNECT, 0, R.string.wifi_menu_connect);
}
- if (mSelected.networkId != -1) {
+ if (mSelectedAccessPoint.networkId != -1) {
menu.add(Menu.NONE, MENU_ID_FORGET, 0, R.string.wifi_menu_forget);
- if (mSelected.security != AccessPoint.SECURITY_NONE) {
+ if (mSelectedAccessPoint.security != AccessPoint.SECURITY_NONE) {
menu.add(Menu.NONE, MENU_ID_MODIFY, 0, R.string.wifi_menu_modify);
}
}
@@ -232,31 +302,34 @@ public class WifiSettings extends SettingsPreferenceFragment
@Override
public boolean onContextItemSelected(MenuItem item) {
- if (mSelected == null) {
+ if (mSelectedAccessPoint == null) {
return super.onContextItemSelected(item);
}
switch (item.getItemId()) {
- case MENU_ID_CONNECT:
- if (mSelected.networkId != -1) {
- if (!requireKeyStore(mSelected.getConfig())) {
- mWifiManager.connectNetwork(mSelected.networkId);
+ case MENU_ID_CONNECT: {
+ if (mSelectedAccessPoint.networkId != -1) {
+ if (!requireKeyStore(mSelectedAccessPoint.getConfig())) {
+ mWifiManager.connectNetwork(mSelectedAccessPoint.networkId);
}
- } else if (mSelected.security == AccessPoint.SECURITY_NONE) {
+ } else if (mSelectedAccessPoint.security == AccessPoint.SECURITY_NONE) {
// Shortcut for open networks.
WifiConfiguration config = new WifiConfiguration();
- config.SSID = AccessPoint.convertToQuotedString(mSelected.ssid);
+ config.SSID = AccessPoint.convertToQuotedString(mSelectedAccessPoint.ssid);
config.allowedKeyManagement.set(KeyMgmt.NONE);
mWifiManager.connectNetwork(config);
} else {
- showDialog(mSelected, false);
+ showConfigUi(mSelectedAccessPoint, true);
}
return true;
- case MENU_ID_FORGET:
- mWifiManager.forgetNetwork(mSelected.networkId);
+ }
+ case MENU_ID_FORGET: {
+ mWifiManager.forgetNetwork(mSelectedAccessPoint.networkId);
return true;
- case MENU_ID_MODIFY:
- showDialog(mSelected, true);
+ }
+ case MENU_ID_MODIFY: {
+ showConfigUi(mSelectedAccessPoint, true);
return true;
+ }
}
return super.onContextItemSelected(item);
}
@@ -264,11 +337,10 @@ public class WifiSettings extends SettingsPreferenceFragment
@Override
public boolean onPreferenceTreeClick(PreferenceScreen screen, Preference preference) {
if (preference instanceof AccessPoint) {
- mSelected = (AccessPoint) preference;
- showDialog(mSelected, false);
+ mSelectedAccessPoint = (AccessPoint) preference;
+ showConfigUi(mSelectedAccessPoint, false);
} else if (preference == mAddNetwork) {
- mSelected = null;
- showDialog(null, true);
+ onAddNetworkPressed();
} else if (preference == mNotifyOpenNetworks) {
Secure.putInt(getContentResolver(),
Secure.WIFI_NETWORKS_AVAILABLE_NOTIFICATION_ON,
@@ -279,27 +351,51 @@ public class WifiSettings extends SettingsPreferenceFragment
return true;
}
- public void onClick(DialogInterface dialogInterface, int button) {
- if (button == WifiDialog.BUTTON_FORGET && mSelected != null) {
- mWifiManager.forgetNetwork(mSelected.networkId);
- } else if (button == WifiDialog.BUTTON_SUBMIT && mDialog != null) {
- WifiConfiguration config = mDialog.getConfig();
-
- if (config == null) {
- if (mSelected != null && !requireKeyStore(mSelected.getConfig())) {
- mWifiManager.connectNetwork(mSelected.networkId);
- }
- } else if (config.networkId != -1) {
- if (mSelected != null) {
- mWifiManager.saveNetwork(config);
- }
- } else {
- if (mDialog.edit || requireKeyStore(config)) {
- mWifiManager.saveNetwork(config);
- } else {
- mWifiManager.connectNetwork(config);
- }
- }
+ /**
+ * Called when a user clicks "Add network" preference or relevant button.
+ */
+ private void showConfigUi(AccessPoint accessPoint, boolean edit) {
+ synchronized (this) {
+ mRefrainListUpdate = false;
+ }
+ if (mInXlSetupWizard) {
+ final Activity activity = getActivity();
+ activity.findViewById(R.id.wifi_setup_connect).setVisibility(View.VISIBLE);
+ activity.findViewById(R.id.wifi_setup_cancel).setVisibility(View.VISIBLE);
+ showConfigPreference(accessPoint, edit);
+ } else {
+ showDialog(accessPoint, edit);
+ }
+ }
+
+ private void showConfigPreference(AccessPoint accessPoint, boolean edit) {
+ // We don't want to show more than one WifiConfigPreference
+ if (mConfigPreference != null) {
+ mAccessPoints.removePreference(mConfigPreference);
+ }
+
+ mConfigPreference = new WifiConfigPreference(this, this, accessPoint, edit);
+ toggleButtonsVisibility(false);
+
+ updateAccessPoints();
+ mScanner.pause();
+ }
+
+ private void toggleButtonsVisibility(boolean firstLayout) {
+ final Activity activity = getActivity();
+ if (firstLayout) {
+ activity.findViewById(R.id.wifi_setup_add_network).setVisibility(View.VISIBLE);
+ activity.findViewById(R.id.wifi_setup_refresh_list).setVisibility(View.VISIBLE);
+ activity.findViewById(R.id.wifi_setup_skip_or_next).setVisibility(View.VISIBLE);
+ activity.findViewById(R.id.wifi_setup_connect).setVisibility(View.GONE);
+ activity.findViewById(R.id.wifi_setup_forget).setVisibility(View.GONE);
+ activity.findViewById(R.id.wifi_setup_cancel).setVisibility(View.GONE);
+ } else {
+ activity.findViewById(R.id.wifi_setup_add_network).setVisibility(View.GONE);
+ activity.findViewById(R.id.wifi_setup_refresh_list).setVisibility(View.GONE);
+ activity.findViewById(R.id.wifi_setup_skip_or_next).setVisibility(View.GONE);
+
+ // made visible from controller.
}
}
@@ -312,7 +408,7 @@ public class WifiSettings extends SettingsPreferenceFragment
}
private boolean requireKeyStore(WifiConfiguration config) {
- if (WifiDialog.requireKeyStore(config) &&
+ if (WifiConfigController.requireKeyStore(config) &&
KeyStore.getInstance().test() != KeyStore.NO_ERROR) {
mKeyStoreNetworkId = config.networkId;
Credentials.getInstance().unlock(getActivity());
@@ -321,10 +417,40 @@ public class WifiSettings extends SettingsPreferenceFragment
return false;
}
+ /**
+ * Shows the latest access points available with supplimental information like
+ * the strength of network and the security for it.
+ */
private void updateAccessPoints() {
- List<AccessPoint> accessPoints = new ArrayList<AccessPoint>();
+ synchronized (this) {
+ if (mRefrainListUpdate) {
+ return;
+ }
+ }
+
+ if (mConfigPreference != null) {
+ mAccessPoints.removeAll();
+ final AccessPoint parent = mConfigPreference.getAccessPoint();
+ if (parent != null) {
+ parent.setSelectable(false);
+ mAccessPoints.addPreference(parent);
+ }
+ mAccessPoints.addPreference(mConfigPreference);
+ } else {
+ // AccessPoints are automatically sorted with TreeSet.
+ final Collection<AccessPoint> accessPoints = constructAccessPoints();
+ mAccessPoints.removeAll();
+ for (AccessPoint accessPoint : accessPoints) {
+ mAccessPoints.addPreference(accessPoint);
+ }
+ }
+ }
- List<WifiConfiguration> configs = mWifiManager.getConfiguredNetworks();
+ private Collection<AccessPoint> constructAccessPoints() {
+ Collection<AccessPoint> accessPoints =
+ new TreeSet<AccessPoint>(new AccessPoint.Comparater());
+
+ final List<WifiConfiguration> configs = mWifiManager.getConfiguredNetworks();
if (configs != null) {
for (WifiConfiguration config : configs) {
AccessPoint accessPoint = new AccessPoint(getActivity(), config);
@@ -333,7 +459,7 @@ public class WifiSettings extends SettingsPreferenceFragment
}
}
- List<ScanResult> results = mWifiManager.getScanResults();
+ final List<ScanResult> results = mWifiManager.getScanResults();
if (results != null) {
for (ScanResult result : results) {
// Ignore hidden and ad-hoc networks.
@@ -354,10 +480,7 @@ public class WifiSettings extends SettingsPreferenceFragment
}
}
- mAccessPoints.removeAll();
- for (AccessPoint accessPoint : accessPoints) {
- mAccessPoints.addPreference(accessPoint);
- }
+ return accessPoints;
}
private void handleEvent(Intent intent) {
@@ -367,16 +490,14 @@ public class WifiSettings extends SettingsPreferenceFragment
WifiManager.WIFI_STATE_UNKNOWN));
} else if (WifiManager.SCAN_RESULTS_AVAILABLE_ACTION.equals(action) ||
WifiManager.SUPPLICANT_CONFIG_CHANGED_ACTION.equals(action)) {
- updateAccessPoints();
+ updateAccessPoints();
} else if (WifiManager.SUPPLICANT_STATE_CHANGED_ACTION.equals(action)) {
updateConnectionState(WifiInfo.getDetailedStateOf((SupplicantState)
intent.getParcelableExtra(WifiManager.EXTRA_NEW_STATE)));
} else if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(action)) {
NetworkInfo info = (NetworkInfo) intent.getParcelableExtra(
WifiManager.EXTRA_NETWORK_INFO);
- if (mEnableNextOnConnection && hasNextButton()) {
- getNextButton().setEnabled(info.isConnected());
- }
+ changeNextButtonState(info.isConnected());
updateConnectionState(info.getDetailedState());
} else if (WifiManager.RSSI_CHANGED_ACTION.equals(action)) {
updateConnectionState(null);
@@ -402,7 +523,16 @@ public class WifiSettings extends SettingsPreferenceFragment
}
for (int i = mAccessPoints.getPreferenceCount() - 1; i >= 0; --i) {
- ((AccessPoint) mAccessPoints.getPreference(i)).update(mLastInfo, mLastState);
+ // Maybe there's a WifiConfigPreference
+ Preference preference = mAccessPoints.getPreference(i);
+ if (preference instanceof AccessPoint) {
+ ((AccessPoint) preference).update(mLastInfo, mLastState);
+ }
+ }
+
+ final Activity activity = getActivity();
+ if (activity instanceof WifiSettingsForSetupWizardXL) {
+ ((WifiSettingsForSetupWizardXL)activity).updateConnectionState(mLastState);
}
}
@@ -419,6 +549,9 @@ public class WifiSettings extends SettingsPreferenceFragment
private int mRetry = 0;
void resume() {
+ synchronized (WifiSettings.this) {
+ mRefrainListUpdate = false;
+ }
if (!hasMessages(0)) {
sendEmptyMessage(0);
}
@@ -427,6 +560,9 @@ public class WifiSettings extends SettingsPreferenceFragment
void pause() {
mRetry = 0;
mAccessPoints.setProgress(false);
+ synchronized (WifiSettings.this) {
+ mRefrainListUpdate = true;
+ }
removeMessages(0);
}
@@ -445,4 +581,96 @@ public class WifiSettings extends SettingsPreferenceFragment
sendEmptyMessageDelayed(0, 10000);
}
}
+
+ private void changeNextButtonState(boolean wifiAvailable) {
+ if (mInXlSetupWizard) {
+ final Button button =
+ (Button)getActivity().findViewById(R.id.wifi_setup_skip_or_next);
+ button.setEnabled(true);
+ if (wifiAvailable) {
+ button.setText(R.string.wifi_setup_next);
+ } else {
+ button.setText(R.string.wifi_setup_skip);
+ }
+ } else if (mEnableNextOnConnection && hasNextButton()) {
+ // Assumes layout for phones has next button inside it.
+ getNextButton().setEnabled(wifiAvailable);
+ }
+ }
+
+ public void onClick(DialogInterface dialogInterface, int button) {
+ if (button == WifiDialog.BUTTON_FORGET && mSelectedAccessPoint != null) {
+ forget();
+ } else if (button == WifiDialog.BUTTON_SUBMIT) {
+ submit();
+ }
+ }
+
+ /* package */ void submit() {
+ final WifiConfigUiBase uiBase = (mDialog != null ? mDialog : mConfigPreference);
+ final WifiConfiguration config = uiBase.getController().getConfig();
+
+ if (config == null) {
+ if (mSelectedAccessPoint != null
+ && !requireKeyStore(mSelectedAccessPoint.getConfig())) {
+ mWifiManager.connectNetwork(mSelectedAccessPoint.networkId);
+ }
+ } else if (config.networkId != -1) {
+ if (mSelectedAccessPoint != null) {
+ mWifiManager.saveNetwork(config);
+ }
+ } else {
+ if (uiBase.isEdit() || requireKeyStore(config)) {
+ mWifiManager.saveNetwork(config);
+ } else {
+ mWifiManager.connectNetwork(config);
+ }
+ }
+
+ detachConfigPreference();
+ }
+
+ /* package */ void forget() {
+ mWifiManager.forgetNetwork(mSelectedAccessPoint.networkId);
+
+ detachConfigPreference();
+
+ changeNextButtonState(false);
+
+ final Activity activity = getActivity();
+ if (activity instanceof WifiSettingsForSetupWizardXL) {
+ ((WifiSettingsForSetupWizardXL)activity).onForget();
+ }
+ }
+
+ /* package */ void refreshAccessPoints() {
+ if (mWifiManager.isWifiEnabled()) {
+ mScanner.resume();
+ }
+
+ mConfigPreference = null;
+ mAccessPoints.removeAll();
+
+ final Activity activity = getActivity();
+ if (activity instanceof WifiSettingsForSetupWizardXL) {
+ ((WifiSettingsForSetupWizardXL)activity).onRefreshAccessPoints();
+ }
+ }
+
+ /* package */ void detachConfigPreference() {
+ if (mConfigPreference != null) {
+ if (mWifiManager.isWifiEnabled()) {
+ mScanner.resume();
+ }
+ mAccessPoints.removePreference(mConfigPreference);
+ mConfigPreference = null;
+ updateAccessPoints();
+ toggleButtonsVisibility(true);
+ }
+ }
+
+ /* package */ void onAddNetworkPressed() {
+ mSelectedAccessPoint = null;
+ showConfigUi(null, true);
+ }
}
diff --git a/src/com/android/settings/wifi/WifiSettingsForSetupWizardXL.java b/src/com/android/settings/wifi/WifiSettingsForSetupWizardXL.java
new file mode 100644
index 0000000..1743157
--- /dev/null
+++ b/src/com/android/settings/wifi/WifiSettingsForSetupWizardXL.java
@@ -0,0 +1,157 @@
+/*
+ * 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 android.app.Activity;
+import android.net.NetworkInfo.DetailedState;
+import android.os.Bundle;
+import android.util.Log;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.view.Window;
+import android.widget.Button;
+import android.widget.ProgressBar;
+import android.widget.TextView;
+
+import com.android.settings.R;
+
+import java.util.EnumMap;
+
+/**
+ * WifiSetings Activity specific for SetupWizard with X-Large screen size.
+ */
+public class WifiSettingsForSetupWizardXL extends Activity implements OnClickListener {
+
+ private static final EnumMap<DetailedState, DetailedState> stateMap =
+ new EnumMap<DetailedState, DetailedState>(DetailedState.class);
+
+ static {
+ stateMap.put(DetailedState.IDLE, DetailedState.DISCONNECTED);
+ stateMap.put(DetailedState.SCANNING, DetailedState.DISCONNECTED);
+ stateMap.put(DetailedState.CONNECTING, DetailedState.CONNECTING);
+ stateMap.put(DetailedState.AUTHENTICATING, DetailedState.CONNECTING);
+ stateMap.put(DetailedState.OBTAINING_IPADDR, DetailedState.CONNECTING);
+ stateMap.put(DetailedState.CONNECTED, DetailedState.CONNECTED);
+ stateMap.put(DetailedState.SUSPENDED, DetailedState.SUSPENDED); // ?
+ stateMap.put(DetailedState.DISCONNECTING, DetailedState.DISCONNECTED);
+ stateMap.put(DetailedState.DISCONNECTED, DetailedState.DISCONNECTED);
+ stateMap.put(DetailedState.FAILED, DetailedState.DISCONNECTED);
+ }
+
+ private TextView mProgressText;
+ private ProgressBar mProgressBar;
+ private WifiSettings mWifiSettings;
+ private TextView mStatusText;
+
+ @Override
+ public void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ requestWindowFeature(Window.FEATURE_NO_TITLE);
+ setContentView(R.layout.wifi_settings_for_setup_wizard_xl);
+ mWifiSettings =
+ (WifiSettings)getFragmentManager().findFragmentById(R.id.wifi_setup_fragment);
+ setup();
+ // XXX: should we use method?
+ getIntent().putExtra(WifiSettings.IN_XL_SETUP_WIZARD, true);
+ }
+
+ public void setup() {
+ mProgressText = (TextView)findViewById(R.id.scanning_progress_text);
+ mProgressBar = (ProgressBar)findViewById(R.id.scanning_progress_bar);
+ mProgressBar.setMax(2);
+ mProgressBar.setIndeterminate(true);
+ mStatusText = (TextView)findViewById(R.id.wifi_setup_status);
+
+ ((Button)findViewById(R.id.wifi_setup_refresh_list)).setOnClickListener(this);
+ ((Button)findViewById(R.id.wifi_setup_add_network)).setOnClickListener(this);
+ ((Button)findViewById(R.id.wifi_setup_skip_or_next)).setOnClickListener(this);
+ ((Button)findViewById(R.id.wifi_setup_connect)).setOnClickListener(this);
+ ((Button)findViewById(R.id.wifi_setup_forget)).setOnClickListener(this);
+ ((Button)findViewById(R.id.wifi_setup_cancel)).setOnClickListener(this);
+ }
+
+ @Override
+ public void onClick(View view) {
+ final int id = view.getId();
+ switch (id) {
+ case R.id.wifi_setup_refresh_list:
+ mWifiSettings.refreshAccessPoints();
+ break;
+ case R.id.wifi_setup_add_network:
+ mWifiSettings.onAddNetworkPressed();
+ break;
+ case R.id.wifi_setup_skip_or_next:
+ setResult(Activity.RESULT_OK);
+ finish();
+ break;
+ case R.id.wifi_setup_connect:
+ mWifiSettings.submit();
+ break;
+ case R.id.wifi_setup_forget:
+ mWifiSettings.forget();
+ break;
+ case R.id.wifi_setup_cancel:
+ mWifiSettings.detachConfigPreference();
+ break;
+ }
+ }
+
+ public void updateConnectionState(DetailedState originalState) {
+ final DetailedState state = stateMap.get(originalState);
+ final String message;
+ mProgressBar.setIndeterminate(false);
+ switch (state) {
+ case CONNECTING: {
+ message = Summary.get(this, state);
+ mProgressBar.setProgress(1);
+ mStatusText.setText(R.string.wifi_setup_status_connecting);
+ break;
+ }
+ case CONNECTED: {
+ message = Summary.get(this, state);
+ mProgressBar.setProgress(2);
+ mStatusText.setText(R.string.wifi_setup_status_connected);
+ break;
+ }
+ default: // Not connected.
+ message = getString(R.string.wifi_setup_not_connected);
+ mProgressBar.setProgress(0);
+ mStatusText.setText(R.string.wifi_setup_status_select_network);
+ break;
+ }
+ mProgressText.setText(message);
+ }
+
+ public void onWifiConfigPreferenceAttached(boolean isNewNetwork) {
+ if (isNewNetwork) {
+ mStatusText.setText(R.string.wifi_setup_status_new_network);
+ } else {
+ mStatusText.setText(R.string.wifi_setup_status_existing_network);
+ }
+ }
+
+ public void onForget() {
+ mProgressBar.setIndeterminate(false);
+ mProgressBar.setProgress(0);
+ mProgressText.setText(getString(R.string.wifi_setup_not_connected));
+ }
+
+ public void onRefreshAccessPoints() {
+ mProgressBar.setIndeterminate(true);
+ mProgressText.setText(Summary.get(this, DetailedState.SCANNING));
+ }
+}