diff --git a/AndroidManifest.xml b/AndroidManifest.xml
index 8cb1ec31919..41dd0f8bad8 100644
--- a/AndroidManifest.xml
+++ b/AndroidManifest.xml
@@ -560,8 +560,6 @@
android:label="@string/lockpattern_change_lock_pattern_label">
-
-
diff --git a/res/values/strings.xml b/res/values/strings.xml
index 2cb21829645..798bb36a03e 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -492,7 +492,7 @@
Select a network operator
-
+
Date & time
@@ -2685,4 +2685,13 @@ found in the list of installed applications.
Connected
+
+
+ Experimental text
+
+ Experimental text
+
+ Skip
+
+ Next
diff --git a/res/xml/date_time_prefs.xml b/res/xml/date_time_prefs.xml
index 5e696de1c76..08c5d5c6d4c 100644
--- a/res/xml/date_time_prefs.xml
+++ b/res/xml/date_time_prefs.xml
@@ -25,8 +25,10 @@
android:title="@string/date_time_set_date"
android:summary="03/10/2008"
/>
-
timezoneSortedList = getZones();
- Collections.sort(timezoneSortedList, comparator);
- mTimezoneSortedAdapter = new SimpleAdapter(this,
- (List) timezoneSortedList,
- android.R.layout.simple_list_item_2,
- from,
- to);
-
- List alphabeticalList = new ArrayList(timezoneSortedList);
- comparator.setSortingKey(KEY_DISPLAYNAME);
- Collections.sort(alphabeticalList, comparator);
- mAlphabeticalAdapter = new SimpleAdapter(this,
- (List) alphabeticalList,
- android.R.layout.simple_list_item_2,
- from,
- to);
-
- // Sets the adapter
- setSorting(true);
-
- // If current timezone is in this list, move focus to it
- setSelection(mDefault);
-
- // Assume user may press Back
- setResult(RESULT_CANCELED);
- }
-
- @Override
- public boolean onCreateOptionsMenu(Menu menu) {
- menu.add(0, MENU_ALPHABETICAL, 0, R.string.zone_list_menu_sort_alphabetically)
- .setIcon(android.R.drawable.ic_menu_sort_alphabetically);
- menu.add(0, MENU_TIMEZONE, 0, R.string.zone_list_menu_sort_by_timezone)
- .setIcon(R.drawable.ic_menu_3d_globe);
-
- return true;
- }
-
- @Override
- public boolean onPrepareOptionsMenu(Menu menu) {
-
- if (mSortedByTimezone) {
- menu.findItem(MENU_TIMEZONE).setVisible(false);
- menu.findItem(MENU_ALPHABETICAL).setVisible(true);
- } else {
- menu.findItem(MENU_TIMEZONE).setVisible(true);
- menu.findItem(MENU_ALPHABETICAL).setVisible(false);
- }
-
- return true;
- }
-
- @Override
- public boolean onOptionsItemSelected(MenuItem item) {
- switch (item.getItemId()) {
-
- case MENU_TIMEZONE:
- setSorting(true);
- return true;
-
- case MENU_ALPHABETICAL:
- setSorting(false);
- return true;
-
- default:
- return false;
- }
- }
-
- private void setSorting(boolean timezone) {
- setListAdapter(timezone ? mTimezoneSortedAdapter : mAlphabeticalAdapter);
- mSortedByTimezone = timezone;
- }
-
- private List getZones() {
- List myData = new ArrayList();
- long date = Calendar.getInstance().getTimeInMillis();
- try {
- XmlResourceParser xrp = getResources().getXml(R.xml.timezones);
- while (xrp.next() != XmlResourceParser.START_TAG)
- continue;
- xrp.next();
- while (xrp.getEventType() != XmlResourceParser.END_TAG) {
- while (xrp.getEventType() != XmlResourceParser.START_TAG) {
- if (xrp.getEventType() == XmlResourceParser.END_DOCUMENT) {
- return myData;
- }
- xrp.next();
- }
- if (xrp.getName().equals(XMLTAG_TIMEZONE)) {
- String id = xrp.getAttributeValue(0);
- String displayName = xrp.nextText();
- addItem(myData, id, displayName, date);
- }
- while (xrp.getEventType() != XmlResourceParser.END_TAG) {
- xrp.next();
- }
- xrp.next();
- }
- xrp.close();
- } catch (XmlPullParserException xppe) {
- Log.e(TAG, "Ill-formatted timezones.xml file");
- } catch (java.io.IOException ioe) {
- Log.e(TAG, "Unable to read timezones.xml file");
- }
-
- return myData;
- }
-
- protected void addItem(List myData, String id, String displayName,
- long date) {
- HashMap map = new HashMap();
- map.put(KEY_ID, id);
- map.put(KEY_DISPLAYNAME, displayName);
- TimeZone tz = TimeZone.getTimeZone(id);
- int offset = tz.getOffset(date);
- int p = Math.abs(offset);
- StringBuilder name = new StringBuilder();
- name.append("GMT");
-
- if (offset < 0) {
- name.append('-');
- } else {
- name.append('+');
- }
-
- name.append(p / (HOURS_1));
- name.append(':');
-
- int min = p / 60000;
- min %= 60;
-
- if (min < 10) {
- name.append('0');
- }
- name.append(min);
-
- map.put(KEY_GMT, name.toString());
- map.put(KEY_OFFSET, offset);
-
- if (id.equals(TimeZone.getDefault().getID())) {
- mDefault = myData.size();
- }
-
- myData.add(map);
- }
-
- @Override
- protected void onListItemClick(ListView l, View v, int position, long id) {
- Map map = (Map) l.getItemAtPosition(position);
- // Update the system timezone value
- AlarmManager alarm = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
- alarm.setTimeZone((String) map.get(KEY_ID));
- setResult(RESULT_OK);
- finish();
- }
-
- private static class MyComparator implements Comparator {
- private String mSortingKey;
-
- public MyComparator(String sortingKey) {
- mSortingKey = sortingKey;
- }
-
- public void setSortingKey(String sortingKey) {
- mSortingKey = sortingKey;
- }
-
- public int compare(HashMap map1, HashMap map2) {
- Object value1 = map1.get(mSortingKey);
- Object value2 = map2.get(mSortingKey);
-
- /*
- * This should never happen, but just in-case, put non-comparable
- * items at the end.
- */
- if (!isComparable(value1)) {
- return isComparable(value2) ? 1 : 0;
- } else if (!isComparable(value2)) {
- return -1;
- }
-
- return ((Comparable) value1).compareTo(value2);
- }
-
- private boolean isComparable(Object value) {
- return (value != null) && (value instanceof Comparable);
- }
- }
-
-}
diff --git a/src/com/android/settings/ZonePicker.java b/src/com/android/settings/ZonePicker.java
index def5036ae18..c877bd7aa6a 100644
--- a/src/com/android/settings/ZonePicker.java
+++ b/src/com/android/settings/ZonePicker.java
@@ -16,55 +16,261 @@
package com.android.settings;
-import android.app.ListActivity;
-import android.content.Intent;
+import android.app.Activity;
+import android.app.AlarmManager;
+import android.app.ListFragment;
+import android.content.Context;
+import android.content.res.XmlResourceParser;
import android.os.Bundle;
+import android.util.Log;
+import android.view.Menu;
+import android.view.MenuInflater;
+import android.view.MenuItem;
import android.view.View;
-import android.widget.ArrayAdapter;
import android.widget.ListView;
+import android.widget.SimpleAdapter;
+import org.xmlpull.v1.XmlPullParserException;
+
+import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.Collections;
+import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
+import java.util.TimeZone;
-public class ZonePicker extends ListActivity {
+/**
+ * The class displaying a list of time zones that match a filter string
+ * such as "Africa", "Europe", etc. Choosing an item from the list will set
+ * the time zone. Pressing Back without choosing from the list will not
+ * result in a change in the time zone setting.
+ */
+public class ZonePicker extends ListFragment {
+ private static final String TAG = "ZonePicker";
- private ArrayAdapter mFilterAdapter;
-
- @Override
- public void onCreate(Bundle icicle) {
- super.onCreate(icicle);
- mFilterAdapter = ArrayAdapter.createFromResource(this,
- R.array.timezone_filters, android.R.layout.simple_list_item_1);
- setListAdapter(mFilterAdapter);
+ public static interface ZoneSelectionListener {
+ // You can add any argument if you really need it...
+ public void onZoneSelected();
}
-
- protected void addItem(List