/[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 579 by torben, Tue Feb 2 08:52:45 2010 UTC revision 1485 by torben, Sat May 28 17:38:44 2011 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_satellitecount;
27    import static dk.thoerup.traininfo.R.string.stationlist_search;
28    import static dk.thoerup.traininfo.R.string.stationlist_stationadded;
29    import static dk.thoerup.traininfo.R.string.stationlist_stationmap;
30    import static dk.thoerup.traininfo.R.string.stationlist_stationremoved;
31    import static dk.thoerup.traininfo.R.string.stationlist_stationsearch;
32    import static dk.thoerup.traininfo.R.string.stationlist_twocharmin;
33    import static dk.thoerup.traininfo.R.string.stationlist_waitforlocation;
34    
35    import java.util.ArrayList;
36    
37    import android.app.Activity;
38  import android.app.AlertDialog;  import android.app.AlertDialog;
39  import android.app.Dialog;  import android.app.Dialog;
40  import android.app.ListActivity;  import android.app.ListActivity;
# Line 17  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;
52  import android.view.ContextMenu;  import android.view.ContextMenu;
53    import android.view.ContextMenu.ContextMenuInfo;
54  import android.view.LayoutInflater;  import android.view.LayoutInflater;
55  import android.view.Menu;  import android.view.Menu;
56  import android.view.MenuItem;  import android.view.MenuItem;
57  import android.view.View;  import android.view.View;
 import android.view.ContextMenu.ContextMenuInfo;  
58  import android.view.View.OnCreateContextMenuListener;  import android.view.View.OnCreateContextMenuListener;
59  import android.widget.AdapterView;  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.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 36  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  {
         public static final int GOTLOCATION = 1001;  
         public static final int GOTSTATIONLIST = 1002;  
         public static final int NOPROVIDER = 1003;  
         public static final int LOCATIONFIXTIMEOUT = 1004;  
           
         public static final int OPTIONS_MAP = 2003;  
         public static final int OPTIONS_GPSINFO = 2004;  
73    
74                    
75            
76            public static final int OPTIONS_MAP = 103;
77            public static final int OPTIONS_GPSINFO = 104;
78                    
79          public static final int DLG_PROGRESS = 3001;          public static final int DLG_PROGRESS = 3001;
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 = 15000; //how long are we willing to wait for gps fix -in milliseconds
84            
85            
86          static enum LookupMethod {          static enum LookupMethod {
87                  ByLocation,                  ByLocation,
88                  ByName,                  ByName,
# Line 67  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 isRunning = false;          boolean isLaunchedforShortcut;
103          List<StationBean> stations = new ArrayList<StationBean>();  
104            StationBean stations = new StationBean();
105                    
106          StationProvider stationProvider = ProviderFactory.getStationProvider();          StationProvider stationProvider = ProviderFactory.getStationProvider();
107                                    
# Line 81  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 98  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 110  public class StationList extends ListAct Line 141  public class StationList extends ListAct
141                  listType = (WelcomeScreen.ListType) getIntent().getSerializableExtra("type");                  listType = (WelcomeScreen.ListType) getIntent().getSerializableExtra("type");
142                  setTitle();                  setTitle();
143                                    
144                    isLaunchedforShortcut = getIntent().getBooleanExtra("shortcut", false);
145                    
146                    ProviderFactory.purgeOldEntries(); //cleanup before fetching more data
147                    
148                  if (savedInstanceState == null) {                  if (savedInstanceState == null) {
149    
150                                                    
151                          switch (listType) {                          switch (listType) {
152                          case ListNearest:                          case ListNearest:
153                                  startLookup();                                  startNearestLookup();
154                                  break;                                  break;
155                          case ListSearch:                          case ListSearch:                                
156                                  this.showDialog(DLG_STATIONNAME);                                  showDialog(DLG_STATIONNAME);
157                                  break;                                  break;
158                          case ListFavorites:                          case ListFavorites:
159                                  startFavoriteLookup();                                  startFavoriteLookup();
# Line 128  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
178            protected void onDestroy() {
179                    super.onDestroy();
180                    
181                    stationsFetched.removeMessages(0);
182                    
183                    
184                    if (locationLookup != null) {
185                            locationLookup.stopSearch();
186                    }
187                    if (findStationsTask != null) {
188                            findStationsTask.cancel(true);
189                    }              
190            }
191    
192            
193          protected void setTitle() {          protected void setTitle() {
194                  String dialogTitle = getResources().getString(app_name);                  String dialogTitle = getResources().getString(app_name);
195                  switch (listType) {                  switch (listType) {
# Line 151  public class StationList extends ListAct Line 207  public class StationList extends ListAct
207                  }                  }
208                    
209                  setTitle(dialogTitle);                  setTitle(dialogTitle);
210                    
211          }          }
212                    
213                            
   
214    
215      @Override      @Override
216      public void onSaveInstanceState(Bundle outState)      public void onSaveInstanceState(Bundle outState)
217      {      {
218          if (dialog != null && dialog.isShowing())          if (dialog != null && dialog.isShowing())
219                  dialog.dismiss();                  dialog.dismiss();
220          outState.putSerializable("stations", (ArrayList<StationBean>) stations);          outState.putSerializable("stations", (StationBean) stations);
         outState.putSerializable("location", location);  
221                    
222      }      }
223                    
# Line 176  public class StationList extends ListAct Line 231  public class StationList extends ListAct
231                  item.setIcon(android.R.drawable.ic_menu_mapmode);                  item.setIcon(android.R.drawable.ic_menu_mapmode);
232                                    
233                  item = menu.add(0, OPTIONS_GPSINFO, 0, getString(stationlist_gpsinfo));                  item = menu.add(0, OPTIONS_GPSINFO, 0, getString(stationlist_gpsinfo));
234                  item.setIcon(android.R.drawable.ic_menu_mapmode);                                item.setIcon(android.R.drawable.ic_menu_info_details);
235                    boolean hasLoc = (locationLookup.getLocation() != null);
236                    item.setEnabled(hasLoc);
237                                    
238                  return true;                  return true;
239          }          }
240            
241    
242    
243    
244          @Override          @Override
245          public boolean onOptionsItemSelected(MenuItem item) {          public boolean onOptionsItemSelected(MenuItem item) {
246                  boolean retval = true;                  boolean retval = true;
247    
248                  //TODO: Cleanup  
249                  switch (item.getItemId()) {                  switch (item.getItemId()) {
250                  case OPTIONS_MAP:                  case OPTIONS_MAP:
251                                                    
252                            if ( stations == null || stations.entries == null || stations.entries.size() == 0 ) {
253                                    Toast.makeText(this, "No stations to show on map", Toast.LENGTH_SHORT); //TODO: Translate
254                                    return true;
255                            }
256                            
257                          Intent intent = new Intent(this,StationMapView.class);                          Intent intent = new Intent(this,StationMapView.class);
258                                                    
259                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();
260                          for (StationBean st : stations ) {                          for (StationEntry st : stations.entries ) {
261                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );
262                          }                          }
263                                                    
# Line 204  public class StationList extends ListAct Line 269  public class StationList extends ListAct
269                          Location loc = locationLookup.getLocation();                          Location loc = locationLookup.getLocation();
270                          StringBuffer message = new StringBuffer();                          StringBuffer message = new StringBuffer();
271                          message.append( getString(stationlist_locationinfo) ).append(":\n");                          message.append( getString(stationlist_locationinfo) ).append(":\n");
272                          if (loc != null) {                          
273                                  message.append( getString(stationlist_obtainedby) ).append( loc.getProvider() ).append("\n");                          message.append( getString(stationlist_obtainedby) ).append( loc.getProvider() ).append("\n");
274                                  message.append( getString(stationlist_accuracy) ).append( (int)loc.getAccuracy()).append("m\n");                          message.append( getString(stationlist_accuracy) ).append( (int)loc.getAccuracy()).append("m\n");
275                                  message.append( getString(stationlist_latitude) ).append( (float)loc.getLatitude()).append("\n");                          message.append( getString(stationlist_latitude) ).append( (float)loc.getLatitude()).append("\n");
276                                  message.append( getString(stationlist_longitude) ).append( (float)loc.getLongitude() ).append("\n");                          message.append( getString(stationlist_longitude) ).append( (float)loc.getLongitude() ).append("\n");
277                          } else {                                                  
                                 message.append( getString(stationlist_nolocation) );  
                         }                        
278                                                    
279                          MessageBox.showMessage(this, message.toString());                          MessageBox.showMessage(this, message.toString(), false);
280                          break;                          break;
281                  default:                  default:
282                          retval = super.onOptionsItemSelected(item);                          retval = super.onOptionsItemSelected(item);
# Line 270  public class StationList extends ListAct Line 333  public class StationList extends ListAct
333                                  public void onClick(DialogInterface dialog, int which) {                                  public void onClick(DialogInterface dialog, int which) {
334                                          EditText et = (EditText) rootView.findViewById(R.id.EditText);                                          EditText et = (EditText) rootView.findViewById(R.id.EditText);
335                                          dialog.dismiss();                                          dialog.dismiss();
336                                          if (et.getText().toString().length() >= 2) {                                          String search = et.getText().toString().trim();
337                                                  startNameSearch(et.getText().toString());                                          if (search.length() >= 2) {
338                                                    startNameLookup(search);
339                                          } else {                                          } else {
340                                                  showMessageAndClose( getString(stationlist_twocharmin) );                                                  showMessageAndClose( getString(stationlist_twocharmin) );
341                                          }                                          }
# Line 310  public class StationList extends ListAct Line 374  public class StationList extends ListAct
374          protected void onListItemClick(ListView l, View v, int position, long id) {          protected void onListItemClick(ListView l, View v, int position, long id) {
375                  super.onListItemClick(l, v, position, id);                  super.onListItemClick(l, v, position, id);
376                                                                    
377                  StationBean station = stations.get(position);                  StationEntry station = stations.entries.get(position);
378                                    
379                  Intent intent = new Intent(this, DepartureList.class);                  if (isLaunchedforShortcut == true) {
380                  intent.putExtra("stationbean", station);                          Intent i = new Intent();
381                  startActivity(intent);                          i.putExtra("station", station);
382                            setResult(Activity.RESULT_OK, i);
383                            finish();
384                    } else {                
385                            Intent intent = new Intent(this, DepartureList.class);
386                            intent.putExtra("stationbean", station);
387                            startActivity(intent);
388                    }
389          }          }
390    
391          /////////////////////////////////////////////////////////////          /////////////////////////////////////////////////////////////
392          //          //
393    
394          public void startLookup() {          public void startNearestLookup() {
                 isRunning = true;                
395                  dialogMessage = getString( stationlist_waitforlocation );                  dialogMessage = getString( stationlist_waitforlocation );
396                  showDialog(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
397                                    
398                  locationLookup.locateStations();                  locationLookup.locateStations();
399                  stationsFetched.sendEmptyMessageDelayed(LOCATIONFIXTIMEOUT, 20000);                  stationsFetched.sendEmptyMessageDelayed(0, 500);
400          }          }
401                    
402          void startNameSearch(String name) {          void startNameLookup(String name) {
403                  dialogMessage = getString( stationlist_findbyname );                  dialogMessage = getString( stationlist_findbyname );
404                  showDialog(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
405    
# Line 358  public class StationList extends ListAct Line 428  public class StationList extends ListAct
428          void startLocatorTask()          void startLocatorTask()
429          {          {
430                  dialogMessage = getString( stationlist_findingnearby );                  dialogMessage = getString( stationlist_findingnearby );
431                  showDialog(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);              
432                                    
433                  findStationsTask = new FindStationsTask();                  findStationsTask = new FindStationsTask();
434                  findStationsTask.searchByLocation( locationLookup.getLocation() );                  findStationsTask.searchByLocation( locationLookup.getLocation() );
# Line 373  public class StationList extends ListAct Line 443  public class StationList extends ListAct
443                  @Override                  @Override
444                  public void handleMessage(Message msg) {                  public void handleMessage(Message msg) {
445    
446                          switch (msg.what) {                          LocationLookup.LookupStates state = locationLookup.getState();
447    
448    
449                            switch (state) {
450                          case GOTLOCATION:                          case GOTLOCATION:
451                                  dismissDialog(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
452                                    
453                                  startLocatorTask();                                  startLocatorTask();
454                                  location = GeoPair.fromLocation( locationLookup.getLocation() );  
455                                                                    return;
                                 break;  
456    
457                          case NOPROVIDER:                          case NOPROVIDER:
458                                  dismissDialog(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
459                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider) );                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider), true );
460                                  break;                                  //StationList.this.finish();
461                          case LOCATIONFIXTIMEOUT:                                                                  return;
462                                  if (isRunning) {                          case IDLE:
463                                          locationLookup.stopSearch();                                  Log.e("TrainInfo", "How did this happen ???");
464                                          if (locationLookup.hasLocation()) {                                  dismissDialog(DLG_PROGRESS); // how did we get here ??
465                                                  stationsFetched.sendEmptyMessage( GOTLOCATION );                                  return;
466                                          } else {                                                                                  
467                                                  dismissDialog(DLG_PROGRESS);                          }
468                                                    
469                                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                  
470                                                  builder.setMessage(  getString( stationlist_gpstimeout) );  
471                                                  builder.setCancelable(true);                          if (locationLookup.elapsedTime() >=  GPS_TIMEOUT_MS) {
472                                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {                                  dismissDialog(DLG_PROGRESS);
473                                                          public void onClick(DialogInterface dialog, int id) {  
474                                                                  dialog.dismiss();  
475                                                                  startLookup();                                  locationLookup.stopSearch();
476                                                                    
477                                                          }                                  if (locationLookup.hasLocation()) {
478                                                  });                                          startLocatorTask();
479                                                  builder.setNegativeButton( getString(generic_cancel), new DialogInterface.OnClickListener() {                                  } else {                                                
480                                                          public void onClick(DialogInterface dialog, int id) {                                          AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                
481                                                                  dialog.dismiss();                                          builder.setMessage(  getString( stationlist_gpstimeout) );
482                                                          }                                                                                                builder.setCancelable(true);
483                                                  });                                                                                                                                      builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {
484                                                  builder.show();                                                  public void onClick(DialogInterface dialog, int id) {
485                                                            dialog.dismiss();
486                                                            startNearestLookup();
487    
488                                                    }
489                                            });
490                                            builder.setNegativeButton( getString(generic_cancel), new DialogInterface.OnClickListener() {
491                                                    public void onClick(DialogInterface dialog, int id) {
492                                                            dialog.dismiss();
493                                                            StationList.this.finish(); // Close this Activity
494                                                    }                                                      
495                                            });
496                                            builder.show();
497    
                                         }  
498                                  }                                  }
499                                  break;                          } else {
500                                    if (locationLookup.hasGps()) {
501                                            int count = locationLookup.getSatCount();
502                                            String dialogMessage = getString( stationlist_waitforlocation ) + "\n" + getString( stationlist_satellitecount ) + ": " + count;
503                                            dialog.setMessage( dialogMessage );
504                                    }
505                                    this.sendEmptyMessageDelayed(0, 500);
506                          }                          }
507                          isRunning = false;                          
508                  }                  }
509          };          }
510    
511    
512    
513                    
514          class FindStationsTask extends AsyncTask<Void,Void,Void> {          class FindStationsTask extends AsyncTask<Void,Void,Void> {
515                                    
516                  LookupMethod method = LookupMethod.MethodNone;                  LookupMethod method = LookupMethod.MethodNone;
                 boolean success;  
517                  String name;                  String name;
518                  Location loc;                  Location loc;
519                  String ids;                  String ids;
# Line 458  public class StationList extends ListAct Line 548  public class StationList extends ListAct
548    
549                          switch (method) {                          switch (method) {
550                          case ByLocation:                          case ByLocation:
551                                  success = stationProvider.lookupStations(loc);                                  stations = stationProvider.lookupStationsByLocation(loc);
552                                  break;                                  break;
553                          case ByName:                          case ByName:
554                                  success = stationProvider.lookupStationsByName(name);                                  stations = stationProvider.lookupStationsByName(name);
555                                  break;                                  break;
556                          case ByList:                          case ByList:
557                                  success = stationProvider.lookupStationsByIds(ids);                                  stations = stationProvider.lookupStationsByIds(ids);
558                                  break;                                  break;
559                          default:                          default:
560                                  success = false; // not possible                                          stations = null; // not possible        
561                          }                          }
562                                                    
563                                                    
# Line 480  public class StationList extends ListAct Line 570  public class StationList extends ListAct
570                          dialog.dismiss();                          dialog.dismiss();
571                                                    
572                                                    
573                          if (success) {                                                    if (stations != null) {                        
574                                  if (stationProvider.getStations().size() == 0) {                                  if (stations.entries.size() == 0) {
575                                          showMessageAndClose(getString(stationlist_nostations));                                          showMessageAndClose(getString(stationlist_nostations));
576                                  }                                  }
577                                  stations = stationProvider.getStations();  
578                                    StationList.this.getListView().invalidateViews();
579                                  adapter.setStations( stations );                                                                  adapter.setStations( stations );                                
580                                                                    
581                                    
582                          } else { //communication or parse errors                          } else { //communication or parse errors
583                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                
584                                  builder.setMessage(getString(stationlist_nearbyerror));                                                          builder.setMessage(getString(stationlist_fetcherror));                          
585                                  builder.setCancelable(true);                                  builder.setCancelable(true);
586                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {
587                                          public void onClick(DialogInterface dialog, int id) {                                          public void onClick(DialogInterface dialog, int id) {
588                                                  dialog.dismiss();                                                  dialog.dismiss();
589                                                                                                    
590                                                  stationsFetched.post( new Runnable() {                                                  Runnable runner = null;
591                                                          @Override                                                  switch (method) {
592                                                          public void run() {                                                  case ByLocation:
593                                                                  startLocatorTask();                                                                                                                      runner = new Runnable() {
594                                                          }                                                                  @Override
595                                                  });                                                                  public void run() {
596                                                                            startLocatorTask();                                                            
597                                                                    }
598                                                            };
599                                                            break;
600                                                    case ByName:
601                                                            runner = new Runnable() {
602                                                                    @Override
603                                                                    public void run() {
604                                                                            startNameLookup( FindStationsTask.this.name );
605                                                                    }
606                                                            };
607                                                            break;
608                                                    case ByList:
609                                                            runner = new Runnable() {
610                                                                    @Override
611                                                                    public void run() {
612                                                                            startFavoriteLookup();
613                                                                    }
614                                                            };
615                                                            break;
616                                                    }
617                                                    
618                                                    stationsFetched.post( runner );
619                                          }                                          }
620                                  });                                  });
621                                  builder.setNegativeButton(getString(generic_cancel), new DialogInterface.OnClickListener() {                                  builder.setNegativeButton(getString(generic_cancel), new DialogInterface.OnClickListener() {
622                                          public void onClick(DialogInterface dialog, int id) {                                          public void onClick(DialogInterface dialog, int id) {
623                                                  dialog.dismiss();                                                  dialog.dismiss();
624                                                    StationList.this.finish();
625                                          }                                                                                                }                                                      
626                                  });                                                                                                                              });
627                                  builder.show();                                                          
628                                    builder.show();
629                          }                          }
630                  }                  }
631          }          }
# Line 526  public class StationList extends ListAct Line 643  public class StationList extends ListAct
643                                                                                                    
644                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;
645                          selectedPosition = info.position;                          selectedPosition = info.position;
646                          int stationID = stations.get(selectedPosition).getId();                          int stationID = stations.entries.get(selectedPosition).getId();
647    
648                          if (!favorites.contains(stationID)) {                          if (!favorites.contains(stationID)) {
649                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );
# Line 537  public class StationList extends ListAct Line 654  public class StationList extends ListAct
654                  }                  }
655                                    
656                  public void onContextItemSelected(MenuItem item) {                  public void onContextItemSelected(MenuItem item) {
657                          StationBean sb = stations.get(selectedPosition);                          StationEntry sb = stations.entries.get(selectedPosition);
658                                                    
659                          int stationID = sb.getId();                          int stationID = sb.getId();
660                          if (item.getItemId() == FAVORITES_ADD) {                          if (item.getItemId() == FAVORITES_ADD) {
# Line 550  public class StationList extends ListAct Line 667  public class StationList extends ListAct
667                                                                    
668                                                                    
669                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {
670                                          stations.remove(selectedPosition);                                          stations.entries.remove(selectedPosition);
671                                          adapter.notifyDataSetChanged();                                          adapter.notifyDataSetChanged();
672                                  }                                  }
673                          }                          }

Legend:
Removed from v.579  
changed lines
  Added in v.1485

  ViewVC Help
Powered by ViewVC 1.1.20