/[projects]/android/TrainInfo/src/dk/thoerup/traininfo/StationList.java
ViewVC logotype

Diff of /android/TrainInfo/src/dk/thoerup/traininfo/StationList.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 983 by torben, Sun Jul 11 15:15:04 2010 UTC revision 1143 by torben, Tue Sep 28 15:30:13 2010 UTC
# Line 1  Line 1 
1  package dk.thoerup.traininfo;  package dk.thoerup.traininfo;
2    
3  import java.util.ArrayList;  import static dk.thoerup.traininfo.R.string.app_name;
4  import java.util.List;  import static dk.thoerup.traininfo.R.string.generic_cancel;
5    import static dk.thoerup.traininfo.R.string.generic_retry;
6    import static dk.thoerup.traininfo.R.string.generic_search;
7    import static dk.thoerup.traininfo.R.string.stationlist_accuracy;
8    import static dk.thoerup.traininfo.R.string.stationlist_addfavorite;
9    import static dk.thoerup.traininfo.R.string.stationlist_favorites;
10    import static dk.thoerup.traininfo.R.string.stationlist_fetcherror;
11    import static dk.thoerup.traininfo.R.string.stationlist_findbyname;
12    import static dk.thoerup.traininfo.R.string.stationlist_findingnearby;
13    import static dk.thoerup.traininfo.R.string.stationlist_gpsinfo;
14    import static dk.thoerup.traininfo.R.string.stationlist_gpstimeout;
15    import static dk.thoerup.traininfo.R.string.stationlist_latitude;
16    import static dk.thoerup.traininfo.R.string.stationlist_loadfavorites;
17    import static dk.thoerup.traininfo.R.string.stationlist_locationinfo;
18    import static dk.thoerup.traininfo.R.string.stationlist_longitude;
19    import static dk.thoerup.traininfo.R.string.stationlist_nearbystations;
20    import static dk.thoerup.traininfo.R.string.stationlist_nofavorites;
21    import static dk.thoerup.traininfo.R.string.stationlist_nolocation;
22    import static dk.thoerup.traininfo.R.string.stationlist_nolocationprovider;
23    import static dk.thoerup.traininfo.R.string.stationlist_nostations;
24    import static dk.thoerup.traininfo.R.string.stationlist_obtainedby;
25    import static dk.thoerup.traininfo.R.string.stationlist_removefavorite;
26    import static dk.thoerup.traininfo.R.string.stationlist_search;
27    import static dk.thoerup.traininfo.R.string.stationlist_stationadded;
28    import static dk.thoerup.traininfo.R.string.stationlist_stationmap;
29    import static dk.thoerup.traininfo.R.string.stationlist_stationremoved;
30    import static dk.thoerup.traininfo.R.string.stationlist_stationsearch;
31    import static dk.thoerup.traininfo.R.string.stationlist_twocharmin;
32    import static dk.thoerup.traininfo.R.string.stationlist_waitforlocation;
33    import static dk.thoerup.traininfo.R.string.stationlist_satellitecount;
34    
35    import java.util.ArrayList;
36    
37  import android.app.Activity;  import android.app.Activity;
38  import android.app.AlertDialog;  import android.app.AlertDialog;
# Line 18  import android.os.AsyncTask; Line 48  import android.os.AsyncTask;
48  import android.os.Bundle;  import android.os.Bundle;
49  import android.os.Handler;  import android.os.Handler;
50  import android.os.Message;  import android.os.Message;
   
51  import android.util.Log;  import android.util.Log;
52  import android.view.ContextMenu;  import android.view.ContextMenu;
53  import android.view.LayoutInflater;  import android.view.LayoutInflater;
# Line 31  import android.widget.AdapterView; Line 60  import android.widget.AdapterView;
60  import android.widget.EditText;  import android.widget.EditText;
61  import android.widget.ListView;  import android.widget.ListView;
62  import android.widget.Toast;  import android.widget.Toast;
63    import dk.thoerup.android.traininfo.common.StationBean;
64    import dk.thoerup.android.traininfo.common.StationBean.StationEntry;
65  import dk.thoerup.traininfo.provider.ProviderFactory;  import dk.thoerup.traininfo.provider.ProviderFactory;
66  import dk.thoerup.traininfo.provider.StationProvider;  import dk.thoerup.traininfo.provider.StationProvider;
67  import dk.thoerup.traininfo.stationmap.GeoPair;  import dk.thoerup.traininfo.stationmap.GeoPair;
# Line 38  import dk.thoerup.traininfo.stationmap.S Line 69  import dk.thoerup.traininfo.stationmap.S
69  import dk.thoerup.traininfo.util.IntSet;  import dk.thoerup.traininfo.util.IntSet;
70  import dk.thoerup.traininfo.util.MessageBox;  import dk.thoerup.traininfo.util.MessageBox;
71    
 import static dk.thoerup.traininfo.R.string.*;  
   
72  public class StationList extends ListActivity  {  public class StationList extends ListActivity  {
73          public static final int GOTLOCATION = 1001;  
74          public static final int GOTSTATIONLIST = 1002;          
         public static final int NOPROVIDER = 1003;  
         public static final int LOCATIONFIXTIMEOUT = 1004;  
75                    
76          public static final int OPTIONS_MAP = 2003;          public static final int OPTIONS_MAP = 2003;
77          public static final int OPTIONS_GPSINFO = 2004;          public static final int OPTIONS_GPSINFO = 2004;
# Line 53  public class StationList extends ListAct Line 80  public class StationList extends ListAct
80          public static final int DLG_STATIONNAME = 3002;          public static final int DLG_STATIONNAME = 3002;
81                    
82                    
83          public static final int GPS_TIMEOUT_MS = 17500; //how long are we willing to wait for gps fix -in milliseconds          public static final int GPS_TIMEOUT_MS = 15000; //how long are we willing to wait for gps fix -in milliseconds
84                    
85                    
86          static enum LookupMethod {          static enum LookupMethod {
# Line 70  public class StationList extends ListAct Line 97  public class StationList extends ListAct
97          FindStationsTask findStationsTask;          FindStationsTask findStationsTask;
98          StationsFetchedHandler stationsFetched = new StationsFetchedHandler();          StationsFetchedHandler stationsFetched = new StationsFetchedHandler();
99                    
100          GeoPair location = new GeoPair();          //GeoPair location = new GeoPair();
101    
102          boolean isLaunchedforShortcut;          boolean isLaunchedforShortcut;
103          boolean isRunning = false;  
104          List<StationBean> stations = new ArrayList<StationBean>();          StationBean stations = new StationBean();
105                    
106          StationProvider stationProvider = ProviderFactory.getStationProvider();          StationProvider stationProvider = ProviderFactory.getStationProvider();
107                                    
# Line 85  public class StationList extends ListAct Line 112  public class StationList extends ListAct
112    
113          WelcomeScreen.ListType listType;          WelcomeScreen.ListType listType;
114          SharedPreferences prefs;          SharedPreferences prefs;
115                                    
116          ///////////////////////////////////////////////////////////////////////////////////////////          ///////////////////////////////////////////////////////////////////////////////////////////
117          //Activity call backs          //Activity call backs
118                    
119          @SuppressWarnings("unchecked")  
120          @Override          @Override
121          public void onCreate(Bundle savedInstanceState) {          public void onCreate(Bundle savedInstanceState) {
122                  super.onCreate(savedInstanceState);                  super.onCreate(savedInstanceState);
# Line 102  public class StationList extends ListAct Line 129  public class StationList extends ListAct
129                  ListView lv = getListView();                  ListView lv = getListView();
130                  lv.setOnCreateContextMenuListener(contextMenu);                  lv.setOnCreateContextMenuListener(contextMenu);
131                                    
132                  locationLookup = new LocationLookup(this, stationsFetched);                  locationLookup = new LocationLookup(this);
133                                    
134    
135                  prefs = getSharedPreferences("TrainStation", 0);                  prefs = getSharedPreferences("TrainStation", 0);
# Line 116  public class StationList extends ListAct Line 143  public class StationList extends ListAct
143                                    
144                  isLaunchedforShortcut = getIntent().getBooleanExtra("shortcut", false);                  isLaunchedforShortcut = getIntent().getBooleanExtra("shortcut", false);
145                                    
146                    ProviderFactory.purgeOldEntries(); //cleanup before fetching more data
147                    
148                  if (savedInstanceState == null) {                  if (savedInstanceState == null) {
149    
150                                                    
# Line 124  public class StationList extends ListAct Line 153  public class StationList extends ListAct
153                                  startLookup();                                  startLookup();
154                                  break;                                  break;
155                          case ListSearch:                                                          case ListSearch:                                
156                                  showDialog(DLG_STATIONNAME); //TODO: this.showDialogSafe(DLG_STATIONNAME);                                  showDialog(DLG_STATIONNAME);
157                                  break;                                  break;
158                          case ListFavorites:                          case ListFavorites:
159                                  startFavoriteLookup();                                  startFavoriteLookup();
# Line 134  public class StationList extends ListAct Line 163  public class StationList extends ListAct
163                          }                          }
164                                                    
165                  } else {                  } else {
166                          stations = (ArrayList<StationBean>) savedInstanceState.getSerializable("stations");                          stations = (StationBean) savedInstanceState.getSerializable("stations");
167                          adapter.setStations(stations);                          adapter.setStations(stations);
                         location = (GeoPair) savedInstanceState.getSerializable("location");  
168                  }                  }
169                                    
170          }          }
171                    
172            
173    
174    
175    
176    
177          @Override          @Override
178          protected void onDestroy() {          protected void onDestroy() {
179                  super.onDestroy();                  super.onDestroy();
180                                    
181                  if (findStationsTask != null) {                  
                         findStationsTask.cancel(true);  
                 }  
182                  if (locationLookup != null) {                  if (locationLookup != null) {
183                          locationLookup.stopSearch();                          locationLookup.stopSearch();
184                  }                  }
185                  isRunning = false;                  if (findStationsTask != null) {
186                            findStationsTask.cancel(true);
187                    }              
188          }          }
189    
190                    
# Line 176  public class StationList extends ListAct Line 208  public class StationList extends ListAct
208                                    
209          }          }
210                    
           
         /* these 3 dialogs helper functions are very rude and ugly hack  
          * to remove these auto-reported exceptions  
          * - android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@436aaef8 is not valid; is your activity running?  
          * - java.lang.IllegalArgumentException: View not attached to window manager  
          */  
   
         /*  
         public void showDialogSafe(int id) {  
                 try {  
                         showDialog(id);  
                 } catch (Exception e) {  
                         Log.e("StationList", "showDialog failed", e);  
                 }  
         }  
           
         public void dismissDialogSafe(int id) {  
                 try {  
                         dismissDialog(id);  
                 } catch (Exception e) {  
                         Log.e("StationList", "dismissDialog failed", e);  
                 }  
         }  
         public void dismissDialogSafe(Dialog dlg) {  
                 try {  
                         dlg.dismiss();  
                 } catch (Exception e) {  
                         Log.e("StationList", "dismissDialog failed", e);  
                 }  
         }  
           
         public void builderShowSafe(AlertDialog.Builder builder) {  
                 try {  
                         builder.show();  
                 } catch (Exception e) {  
                         Log.e("StationList", "builder.show() failed", e);  
                 }  
211                                    
         }*/  
           
         /* EOF rude and ugly dialog hack */  
           
   
212    
213      @Override      @Override
214      public void onSaveInstanceState(Bundle outState)      public void onSaveInstanceState(Bundle outState)
215      {      {
216          if (dialog != null && dialog.isShowing())          if (dialog != null && dialog.isShowing())
217                  dialog.dismiss();                  dialog.dismiss();
218          outState.putSerializable("stations", (ArrayList<StationBean>) stations);          outState.putSerializable("stations", (StationBean) stations);
         outState.putSerializable("location", location);  
219                    
220      }      }
221                    
# Line 256  public class StationList extends ListAct Line 245  public class StationList extends ListAct
245                          Intent intent = new Intent(this,StationMapView.class);                          Intent intent = new Intent(this,StationMapView.class);
246                                                    
247                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();
248                          for (StationBean st : stations ) {                          for (StationEntry st : stations.entries ) {
249                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );
250                          }                          }
251                                                    
# Line 375  public class StationList extends ListAct Line 364  public class StationList extends ListAct
364          protected void onListItemClick(ListView l, View v, int position, long id) {          protected void onListItemClick(ListView l, View v, int position, long id) {
365                  super.onListItemClick(l, v, position, id);                  super.onListItemClick(l, v, position, id);
366                                                                    
367                  StationBean station = stations.get(position);                  StationEntry station = stations.entries.get(position);
368                                    
369                  if (isLaunchedforShortcut == true) {                  if (isLaunchedforShortcut == true) {
370                          Intent i = new Intent();                          Intent i = new Intent();
# Line 393  public class StationList extends ListAct Line 382  public class StationList extends ListAct
382          //          //
383    
384          public void startLookup() {          public void startLookup() {
                 isRunning = true;                
385                  dialogMessage = getString( stationlist_waitforlocation );                  dialogMessage = getString( stationlist_waitforlocation );
386                  showDialog(DLG_PROGRESS);//TODO:showDialogSafe(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
387                                    
388                  locationLookup.locateStations();                  locationLookup.locateStations();
389                  stationsFetched.sendEmptyMessageDelayed(LOCATIONFIXTIMEOUT, GPS_TIMEOUT_MS);                  stationsFetched.sendEmptyMessageDelayed(0, 500);
390          }          }
391                    
392          void startNameSearch(String name) {          void startNameSearch(String name) {
393                  dialogMessage = getString( stationlist_findbyname );                  dialogMessage = getString( stationlist_findbyname );
394                  showDialog(DLG_PROGRESS);//TODO:showDialogSafe(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
395    
396                  findStationsTask = new FindStationsTask();                  findStationsTask = new FindStationsTask();
397                  findStationsTask.searchByName(name);                  findStationsTask.searchByName(name);
# Line 415  public class StationList extends ListAct Line 403  public class StationList extends ListAct
403                                    
404                  if (favorites.size() > 0) {                  if (favorites.size() > 0) {
405                          dialogMessage = getString( stationlist_loadfavorites );                          dialogMessage = getString( stationlist_loadfavorites );
406                          showDialog(DLG_PROGRESS);//TODO:showDialogSafe(DLG_PROGRESS);                          showDialog(DLG_PROGRESS);
407    
408                          findStationsTask = new FindStationsTask();                          findStationsTask = new FindStationsTask();
409                          findStationsTask.searchByIds( favorites.toString() );                          findStationsTask.searchByIds( favorites.toString() );
# Line 430  public class StationList extends ListAct Line 418  public class StationList extends ListAct
418          void startLocatorTask()          void startLocatorTask()
419          {          {
420                  dialogMessage = getString( stationlist_findingnearby );                  dialogMessage = getString( stationlist_findingnearby );
421                  showDialog(DLG_PROGRESS);//TODO:showDialogSafe(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);              
422                                    
423                  findStationsTask = new FindStationsTask();                  findStationsTask = new FindStationsTask();
424                  findStationsTask.searchByLocation( locationLookup.getLocation() );                  findStationsTask.searchByLocation( locationLookup.getLocation() );
# Line 444  public class StationList extends ListAct Line 432  public class StationList extends ListAct
432          class StationsFetchedHandler extends Handler {          class StationsFetchedHandler extends Handler {
433                  @Override                  @Override
434                  public void handleMessage(Message msg) {                  public void handleMessage(Message msg) {
435                            Log.e("Handler", "WHAT:" + msg.what);
436    
437                            LocationLookup.LookupStates state = locationLookup.getState();
438    
439                          switch (msg.what) {  
440                            switch (state) {
441                          case GOTLOCATION:                          case GOTLOCATION:
442                                  dismissDialog(DLG_PROGRESS);//TODO:dismissDialogSafe(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
443                                    
444                                  startLocatorTask();                                  startLocatorTask();
445                                  location = GeoPair.fromLocation( locationLookup.getLocation() );  
446                                                                    return;
                                 break;  
447    
448                          case NOPROVIDER:                          case NOPROVIDER:
449                                  dismissDialog(DLG_PROGRESS);//TODO:dismissDialogSafe(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
450                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider), true );                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider), true );
451                                  //StationList.this.finish();                                  //StationList.this.finish();
452                                  break;                                  return;
453                          case LOCATIONFIXTIMEOUT:                                                          }
454                                  if (isRunning) {  
455                                          locationLookup.stopSearch();  
456                                          if (locationLookup.hasLocation()) {  
457                                                  stationsFetched.sendEmptyMessage( GOTLOCATION );                          if (locationLookup.elapsedTime() >=  GPS_TIMEOUT_MS) {
458                                          } else {                                                                                  dismissDialog(DLG_PROGRESS);
459                                                  dismissDialog(DLG_PROGRESS);//TODO:dismissDialogSafe(DLG_PROGRESS);  
460                                                                                    locationLookup.stopSearch();
461                                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                  
462                                                  builder.setMessage(  getString( stationlist_gpstimeout) );                                  if (locationLookup.hasLocation()) {
463                                                  builder.setCancelable(true);                                          startLocatorTask();
464                                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {                                  } else {                                                
465                                                          public void onClick(DialogInterface dialog, int id) {                                          AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                
466                                                                  dialog.dismiss();                                          builder.setMessage(  getString( stationlist_gpstimeout) );
467                                                                  startLookup();                                          builder.setCancelable(true);
468                                                                                                            builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {
469                                                          }                                                  public void onClick(DialogInterface dialog, int id) {
470                                                  });                                                          dialog.dismiss();
471                                                  builder.setNegativeButton( getString(generic_cancel), new DialogInterface.OnClickListener() {                                                          startLookup();
472                                                          public void onClick(DialogInterface dialog, int id) {  
473                                                                  dialog.dismiss();                                                  }
474                                                          }                                                                                                });
475                                                  });                                          builder.setNegativeButton( getString(generic_cancel), new DialogInterface.OnClickListener() {
476                                                  builder.show();//TODO:builderShowSafe(builder);                                                  public void onClick(DialogInterface dialog, int id) {
477                                                            dialog.dismiss();
478                                                    }                                                      
479                                            });
480                                            builder.show();
481    
                                         }  
482                                  }                                  }
483                                  break;                          } else {
484                                    if (locationLookup.hasGps()) {
485                                            int count = locationLookup.getSatCount();
486                                            String dialogMessage = getString( stationlist_waitforlocation ) + "\n" + getString( stationlist_satellitecount ) + ": " + count;
487                                            dialog.setMessage( dialogMessage );
488                                    }
489                                    this.sendEmptyMessageDelayed(0, 500);
490                          }                          }
491                          isRunning = false;                          
492                  }                  }
493          };          }
494    
495    
496    
497                    
498          class FindStationsTask extends AsyncTask<Void,Void,Void> {          class FindStationsTask extends AsyncTask<Void,Void,Void> {
499                                    
500                  LookupMethod method = LookupMethod.MethodNone;                  LookupMethod method = LookupMethod.MethodNone;
                 boolean success;  
501                  String name;                  String name;
502                  Location loc;                  Location loc;
503                  String ids;                  String ids;
# Line 531  public class StationList extends ListAct Line 532  public class StationList extends ListAct
532    
533                          switch (method) {                          switch (method) {
534                          case ByLocation:                          case ByLocation:
535                                  success = stationProvider.lookupStations(loc);                                  stations = stationProvider.lookupStations(loc);
536                                  break;                                  break;
537                          case ByName:                          case ByName:
538                                  success = stationProvider.lookupStationsByName(name);                                  stations = stationProvider.lookupStationsByName(name);
539                                  break;                                  break;
540                          case ByList:                          case ByList:
541                                  success = stationProvider.lookupStationsByIds(ids);                                  stations = stationProvider.lookupStationsByIds(ids);
542                                  break;                                  break;
543                          default:                          default:
544                                  success = false; // not possible                                          stations = null; // not possible        
545                          }                          }
546                                                    
547                                                    
# Line 550  public class StationList extends ListAct Line 551  public class StationList extends ListAct
551                  @Override                  @Override
552                  protected void onPostExecute(Void result) {                  protected void onPostExecute(Void result) {
553                          super.onPostExecute(result);                          super.onPostExecute(result);
554                          dialog.dismiss();//TODO:dismissDialogSafe(dialog);                          dialog.dismiss();
555                                                    
556                                                    
557                          if (success) {                                                    if (stations != null) {                        
558                                  if (stationProvider.getStations().size() == 0) {                                  if (stations.entries.size() == 0) {
559                                          showMessageAndClose(getString(stationlist_nostations));                                          showMessageAndClose(getString(stationlist_nostations));
560                                  }                                  }
                                 stations = stationProvider.getStations();  
561    
562                                  StationList.this.getListView().invalidateViews();                                  StationList.this.getListView().invalidateViews();
563                                  adapter.setStations( stations );                                                                  adapter.setStations( stations );                                
# Line 609  public class StationList extends ListAct Line 609  public class StationList extends ListAct
609                                          }                                                                                                }                                                      
610                                  });                                  });
611                                                                    
612                                  builder.show();//TODO:builderShowSafe(builder);                                  builder.show();
613                          }                          }
614                  }                  }
615          }          }
# Line 627  public class StationList extends ListAct Line 627  public class StationList extends ListAct
627                                                                                                    
628                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;
629                          selectedPosition = info.position;                          selectedPosition = info.position;
630                          int stationID = stations.get(selectedPosition).getId();                          int stationID = stations.entries.get(selectedPosition).getId();
631    
632                          if (!favorites.contains(stationID)) {                          if (!favorites.contains(stationID)) {
633                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );
# Line 638  public class StationList extends ListAct Line 638  public class StationList extends ListAct
638                  }                  }
639                                    
640                  public void onContextItemSelected(MenuItem item) {                  public void onContextItemSelected(MenuItem item) {
641                          StationBean sb = stations.get(selectedPosition);                          StationEntry sb = stations.entries.get(selectedPosition);
642                                                    
643                          int stationID = sb.getId();                          int stationID = sb.getId();
644                          if (item.getItemId() == FAVORITES_ADD) {                          if (item.getItemId() == FAVORITES_ADD) {
# Line 651  public class StationList extends ListAct Line 651  public class StationList extends ListAct
651                                                                    
652                                                                    
653                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {
654                                          stations.remove(selectedPosition);                                          stations.entries.remove(selectedPosition);
655                                          adapter.notifyDataSetChanged();                                          adapter.notifyDataSetChanged();
656                                  }                                  }
657                          }                          }

Legend:
Removed from v.983  
changed lines
  Added in v.1143

  ViewVC Help
Powered by ViewVC 1.1.20