/[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 566 by torben, Thu Jan 28 10:34:50 2010 UTC revision 1142 by torben, Tue Sep 28 14:58:45 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;
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.LayoutInflater;  import android.view.LayoutInflater;
54  import android.view.Menu;  import android.view.Menu;
# Line 29  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 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  {
73          public static final int GOTLOCATION = 1001;          public enum LookupStates {
74          public static final int GOTSTATIONLIST = 1002;                  GOTLOCATION,
75          public static final int NOPROVIDER = 1003;                  GOTSTATIONLIST,
76          public static final int LOCATIONFIXTIMEOUT = 1004;                  NOPROVIDER,
77                    LOCATIONFIXTIMEOUT,
78                    GPS_SAT_COUNT
79            }
80            
81                    
82          public static final int OPTIONS_MAP = 2003;          public static final int OPTIONS_MAP = 2003;
83          public static final int OPTIONS_GPSINFO = 2004;          public static final int OPTIONS_GPSINFO = 2004;
   
           
   
84                    
85          public static final int DLG_PROGRESS = 3001;          public static final int DLG_PROGRESS = 3001;
86          public static final int DLG_STATIONNAME = 3002;          public static final int DLG_STATIONNAME = 3002;
87                    
88            
89            public static final int GPS_TIMEOUT_MS = 15000; //how long are we willing to wait for gps fix -in milliseconds
90            
91            
92          static enum LookupMethod {          static enum LookupMethod {
93                  ByLocation,                  ByLocation,
94                  ByName,                  ByName,
# Line 68  public class StationList extends ListAct Line 104  public class StationList extends ListAct
104          StationsFetchedHandler stationsFetched = new StationsFetchedHandler();          StationsFetchedHandler stationsFetched = new StationsFetchedHandler();
105                    
106          GeoPair location = new GeoPair();          GeoPair location = new GeoPair();
107            
108            boolean isLaunchedforShortcut;
109          boolean isRunning = false;          boolean isRunning = false;
110          List<StationBean> stations = new ArrayList<StationBean>();          StationBean stations = new StationBean();
111                    
112          StationProvider stationProvider = ProviderFactory.getStationProvider();          StationProvider stationProvider = ProviderFactory.getStationProvider();
113                                    
# Line 85  public class StationList extends ListAct Line 122  public class StationList extends ListAct
122          ///////////////////////////////////////////////////////////////////////////////////////////          ///////////////////////////////////////////////////////////////////////////////////////////
123          //Activity call backs          //Activity call backs
124                    
125          @SuppressWarnings("unchecked")  
126          @Override          @Override
127          public void onCreate(Bundle savedInstanceState) {          public void onCreate(Bundle savedInstanceState) {
128                  super.onCreate(savedInstanceState);                  super.onCreate(savedInstanceState);
# Line 110  public class StationList extends ListAct Line 147  public class StationList extends ListAct
147                  listType = (WelcomeScreen.ListType) getIntent().getSerializableExtra("type");                  listType = (WelcomeScreen.ListType) getIntent().getSerializableExtra("type");
148                  setTitle();                  setTitle();
149                                    
150                    isLaunchedforShortcut = getIntent().getBooleanExtra("shortcut", false);
151                    
152                    ProviderFactory.purgeOldEntries(); //cleanup before fetching more data
153                    
154                  if (savedInstanceState == null) {                  if (savedInstanceState == null) {
155    
156                                                    
# Line 117  public class StationList extends ListAct Line 158  public class StationList extends ListAct
158                          case ListNearest:                          case ListNearest:
159                                  startLookup();                                  startLookup();
160                                  break;                                  break;
161                          case ListSearch:                          case ListSearch:                                
162                                  this.showDialog(DLG_STATIONNAME);                                  showDialog(DLG_STATIONNAME);
163                                  break;                                  break;
164                          case ListFavorites:                          case ListFavorites:
165                                  startFavoriteLookup();                                  startFavoriteLookup();
# Line 128  public class StationList extends ListAct Line 169  public class StationList extends ListAct
169                          }                          }
170                                                    
171                  } else {                  } else {
172                          stations = (ArrayList<StationBean>) savedInstanceState.getSerializable("stations");                          stations = (StationBean) savedInstanceState.getSerializable("stations");
173                          adapter.setStations(stations);                          adapter.setStations(stations);
174                          location = (GeoPair) savedInstanceState.getSerializable("location");                          location = (GeoPair) savedInstanceState.getSerializable("location");
175                  }                  }
176                                    
177          }          }
178            
179            
180    
181    
182    
183    
184            @Override
185            protected void onDestroy() {
186                    super.onDestroy();
187                    
188                    isRunning = false;
189                    
190                    if (locationLookup != null) {
191                            locationLookup.stopSearch();
192                    }
193                    if (findStationsTask != null) {
194                            findStationsTask.cancel(true);
195                    }              
196            }
197    
198            
199          protected void setTitle() {          protected void setTitle() {
200                  String dialogTitle = getResources().getString(app_name);                  String dialogTitle = getResources().getString(app_name);
201                  switch (listType) {                  switch (listType) {
# Line 151  public class StationList extends ListAct Line 213  public class StationList extends ListAct
213                  }                  }
214                    
215                  setTitle(dialogTitle);                  setTitle(dialogTitle);
216                    
217          }          }
218                    
219                            
   
220    
221      @Override      @Override
222      public void onSaveInstanceState(Bundle outState)      public void onSaveInstanceState(Bundle outState)
223      {      {
224          if (dialog != null && dialog.isShowing())          if (dialog != null && dialog.isShowing())
225                  dialog.dismiss();                  dialog.dismiss();
226          outState.putSerializable("stations", (ArrayList<StationBean>) stations);          outState.putSerializable("stations", (StationBean) stations);
227          outState.putSerializable("location", location);          outState.putSerializable("location", location);
228                    
229      }      }
# Line 192  public class StationList extends ListAct Line 254  public class StationList extends ListAct
254                          Intent intent = new Intent(this,StationMapView.class);                          Intent intent = new Intent(this,StationMapView.class);
255                                                    
256                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();                          ArrayList<GeoPair> stationPoints = new ArrayList<GeoPair>();
257                          for (StationBean st : stations ) {                          for (StationEntry st : stations.entries ) {
258                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );                                  stationPoints.add( new GeoPair(st.getLatitude(), st.getLongitude(), st.getName()) );
259                          }                          }
260                                                    
# Line 213  public class StationList extends ListAct Line 275  public class StationList extends ListAct
275                                  message.append( getString(stationlist_nolocation) );                                  message.append( getString(stationlist_nolocation) );
276                          }                                                }                      
277                                                    
278                          MessageBox.showMessage(this, message.toString());                          MessageBox.showMessage(this, message.toString(), false);
279                          break;                          break;
280                  default:                  default:
281                          retval = super.onOptionsItemSelected(item);                          retval = super.onOptionsItemSelected(item);
# Line 270  public class StationList extends ListAct Line 332  public class StationList extends ListAct
332                                  public void onClick(DialogInterface dialog, int which) {                                  public void onClick(DialogInterface dialog, int which) {
333                                          EditText et = (EditText) rootView.findViewById(R.id.EditText);                                          EditText et = (EditText) rootView.findViewById(R.id.EditText);
334                                          dialog.dismiss();                                          dialog.dismiss();
335                                          if (et.getText().toString().length() >= 2) {                                          String search = et.getText().toString().trim();
336                                                  startNameSearch(et.getText().toString());                                          if (search.length() >= 2) {
337                                                    startNameSearch(search);
338                                          } else {                                          } else {
339                                                  showMessageAndClose( getString(stationlist_twocharmin) );                                                  showMessageAndClose( getString(stationlist_twocharmin) );
340                                          }                                          }
# Line 310  public class StationList extends ListAct Line 373  public class StationList extends ListAct
373          protected void onListItemClick(ListView l, View v, int position, long id) {          protected void onListItemClick(ListView l, View v, int position, long id) {
374                  super.onListItemClick(l, v, position, id);                  super.onListItemClick(l, v, position, id);
375                                                                    
376                  StationBean station = stations.get(position);                  StationEntry station = stations.entries.get(position);
377                                    
378                  Intent intent = new Intent(this, DepartureList.class);                  if (isLaunchedforShortcut == true) {
379                  intent.putExtra("stationbean", station);                          Intent i = new Intent();
380                  startActivity(intent);                          i.putExtra("station", station);
381                            setResult(Activity.RESULT_OK, i);
382                            finish();
383                    } else {                
384                            Intent intent = new Intent(this, DepartureList.class);
385                            intent.putExtra("stationbean", station);
386                            startActivity(intent);
387                    }
388          }          }
389    
390          /////////////////////////////////////////////////////////////          /////////////////////////////////////////////////////////////
# Line 326  public class StationList extends ListAct Line 396  public class StationList extends ListAct
396                  showDialog(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
397                                    
398                  locationLookup.locateStations();                  locationLookup.locateStations();
399                  stationsFetched.sendEmptyMessageDelayed(LOCATIONFIXTIMEOUT, 20000);                  stationsFetched.sendEmptyMessageDelayed(LookupStates.LOCATIONFIXTIMEOUT.ordinal(), GPS_TIMEOUT_MS);
400          }          }
401                    
402          void startNameSearch(String name) {          void startNameSearch(String name) {
# Line 334  public class StationList extends ListAct Line 404  public class StationList extends ListAct
404                  showDialog(DLG_PROGRESS);                  showDialog(DLG_PROGRESS);
405    
406                  findStationsTask = new FindStationsTask();                  findStationsTask = new FindStationsTask();
407                  findStationsTask.searchByName(name, locationLookup.getLocation());                  findStationsTask.searchByName(name);
408                  findStationsTask.execute();                  findStationsTask.execute();
409                                    
410          }          }
# Line 346  public class StationList extends ListAct Line 416  public class StationList extends ListAct
416                          showDialog(DLG_PROGRESS);                          showDialog(DLG_PROGRESS);
417    
418                          findStationsTask = new FindStationsTask();                          findStationsTask = new FindStationsTask();
419                          findStationsTask.searchByIds(favorites.toString(), locationLookup.getLocation());                          findStationsTask.searchByIds( favorites.toString() );
420                          findStationsTask.execute();                          findStationsTask.execute();
421                  } else {                  } else {
422                          showMessageAndClose( getString( stationlist_nofavorites ) );                          showMessageAndClose( getString( stationlist_nofavorites ) );
# Line 364  public class StationList extends ListAct Line 434  public class StationList extends ListAct
434                  findStationsTask.searchByLocation( locationLookup.getLocation() );                  findStationsTask.searchByLocation( locationLookup.getLocation() );
435                  findStationsTask.execute();                      findStationsTask.execute();    
436          }          }
           
   
         /* TODO: Remove this no longer needed function  
         String lookupAddress(double latitude, double longitude) {  
                   
                 Geocoder coder = new Geocoder(this, new Locale("da"));  
                 StringBuilder sb = new StringBuilder();  
                 Log.i("lookupaddr", "" + latitude + "/" + longitude);  
                 try {  
                         List<Address> addressList = coder.getFromLocation(latitude, longitude, 1);  
                         Address addr = addressList.get(0);  
                           
                           
                         int max = addr.getMaxAddressLineIndex();  
                         for (int i=0; i<max; i++) {  
                                 if (i>0)  
                                         sb.append(", ");  
                                   
                                 sb.append(addr.getAddressLine(i));  
                         }  
                           
                           
                 } catch (Exception e) {  
                         Log.e("DepartureList", "geocoder failed", e);  
                 }  
437                                    
                 return sb.toString();  
         }*/  
           
438                    
439          ////////////////////////////////////////////////////////////////////////////          ////////////////////////////////////////////////////////////////////////////
440          // Inner classes          // Inner classes
# Line 400  public class StationList extends ListAct Line 442  public class StationList extends ListAct
442          class StationsFetchedHandler extends Handler {          class StationsFetchedHandler extends Handler {
443                  @Override                  @Override
444                  public void handleMessage(Message msg) {                  public void handleMessage(Message msg) {
445                            Log.e("Handler", "WHAT:" + msg.what);
446                            
447                            LookupStates state = LookupStates.values()[msg.what];
448    
449                          switch (msg.what) {                          switch (state) {
450                          case GOTLOCATION:                          case GOTLOCATION:
451                                  dismissDialog(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
452                                                                    
# Line 412  public class StationList extends ListAct Line 457  public class StationList extends ListAct
457    
458                          case NOPROVIDER:                          case NOPROVIDER:
459                                  dismissDialog(DLG_PROGRESS);                                  dismissDialog(DLG_PROGRESS);
460                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider) );                                  MessageBox.showMessage(StationList.this, getString(stationlist_nolocationprovider), true );
461                                    //StationList.this.finish();
462                                  break;                                  break;
463                            case GPS_SAT_COUNT:
464                                    int count = msg.arg1;
465                                    String dialogMessage = getString( stationlist_waitforlocation ) + "\n" + getString( stationlist_satellitecount ) + ": " + count;
466                                    dialog.setMessage( dialogMessage );
467                                    return; //abort immediately
468                          case LOCATIONFIXTIMEOUT:                                                          case LOCATIONFIXTIMEOUT:                                
469                                  if (isRunning) {                                  if (isRunning) {
470                                          locationLookup.stopSearch();                                          locationLookup.stopSearch();
471                                          if (locationLookup.hasLocation()) {                                          if (locationLookup.hasLocation()) {
472                                                  stationsFetched.sendEmptyMessage( GOTLOCATION );                                                  stationsFetched.sendEmptyMessage(  LookupStates.GOTLOCATION.ordinal() );
473                                          } else {                                                                                          } else {                                                
474                                                  dismissDialog(DLG_PROGRESS);                                                  dismissDialog(DLG_PROGRESS);
475                                                                                                    
# Line 436  public class StationList extends ListAct Line 487  public class StationList extends ListAct
487                                                          public void onClick(DialogInterface dialog, int id) {                                                          public void onClick(DialogInterface dialog, int id) {
488                                                                  dialog.dismiss();                                                                  dialog.dismiss();
489                                                          }                                                                                                                }                                                      
490                                                  });                                                                                                                                              });
491                                                  builder.show();                                                  builder.show();
492    
493                                          }                                          }
494                                  }                                  }
# Line 451  public class StationList extends ListAct Line 502  public class StationList extends ListAct
502          class FindStationsTask extends AsyncTask<Void,Void,Void> {          class FindStationsTask extends AsyncTask<Void,Void,Void> {
503                                    
504                  LookupMethod method = LookupMethod.MethodNone;                  LookupMethod method = LookupMethod.MethodNone;
                 boolean success;  
505                  String name;                  String name;
506                  Location loc;                  Location loc;
507                  String ids;                  String ids;
508                                    
509                  public void searchByName(String n, Location l) {                  public void searchByName(String n) {
510                                                    
511                          method = LookupMethod.ByName;                          method = LookupMethod.ByName;
                         loc = l;  
512                          name = n;                          name = n;
513                  }                  }
514                                    
# Line 468  public class StationList extends ListAct Line 517  public class StationList extends ListAct
517                          loc = l;                          loc = l;
518                  }                  }
519                                    
520                  public void searchByIds(String id, Location l) {                  public void searchByIds(String id) {
521                                                    
522                          method = LookupMethod.ByList;                          method = LookupMethod.ByList;
                         loc = l;  
523                          ids = id;                          ids = id;
524                  }                  }
525                                    
# Line 488  public class StationList extends ListAct Line 536  public class StationList extends ListAct
536    
537                          switch (method) {                          switch (method) {
538                          case ByLocation:                          case ByLocation:
539                                  success = stationProvider.lookupStations(loc);                                  stations = stationProvider.lookupStations(loc);
540                                  break;                                  break;
541                          case ByName:                          case ByName:
542                                  success = stationProvider.lookupStationsByName(name);                                  stations = stationProvider.lookupStationsByName(name);
543                                  break;                                  break;
544                          case ByList:                          case ByList:
545                                  success = stationProvider.lookupStationsByIds(ids);                                  stations = stationProvider.lookupStationsByIds(ids);
546                                  break;                                  break;
547                          default:                          default:
548                                  success = false; // not possible                                          stations = null; // not possible        
549                          }                          }
550                                                    
551                                                    
                         Location dummy = new Location("gps");  
                         List<StationBean> stations = stationProvider.getStations();  
                           
                         for (StationBean station : stations) {  
                                                                   
                                 if (method.equals(LookupMethod.ByName) || method.equals(LookupMethod.ByList)) {  
                                         if (loc != null) { //only do the distance calc if we have a location  
                                                 dummy.setLatitude(station.getLatitude());  
                                                 dummy.setLongitude(station.getLongitude());  
                                                 station.setDistance( (int)loc.distanceTo(dummy) );  
                                         } else {  
                                                 station.setDistance(0);  
                                         }  
                                 }  
   
                         }                                                
                           
552                          return null;                          return null;
553                  }                  }
554    
# Line 527  public class StationList extends ListAct Line 558  public class StationList extends ListAct
558                          dialog.dismiss();                          dialog.dismiss();
559                                                    
560                                                    
561                          if (success) {                                                    if (stations != null) {                        
562                                  if (stationProvider.getStations().size() == 0) {                                  if (stations.entries.size() == 0) {
563                                          showMessageAndClose(getString(stationlist_nostations));                                          showMessageAndClose(getString(stationlist_nostations));
564                                  }                                  }
565                                  stations = stationProvider.getStations();  
566                                    StationList.this.getListView().invalidateViews();
567                                  adapter.setStations( stations );                                                                  adapter.setStations( stations );                                
568                                                                    
569                                    
570                          } else { //communication or parse errors                          } else { //communication or parse errors
571                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                                                  AlertDialog.Builder builder = new AlertDialog.Builder(StationList.this);                                                
572                                  builder.setMessage(getString(stationlist_nearbyerror));                                                          builder.setMessage(getString(stationlist_fetcherror));                          
573                                  builder.setCancelable(true);                                  builder.setCancelable(true);
574                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {                                  builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {
575                                          public void onClick(DialogInterface dialog, int id) {                                          public void onClick(DialogInterface dialog, int id) {
576                                                  dialog.dismiss();                                                  dialog.dismiss();
577                                                                                                    
578                                                  stationsFetched.post( new Runnable() {                                                  Runnable runner = null;
579                                                          @Override                                                  switch (method) {
580                                                          public void run() {                                                  case ByLocation:
581                                                                  startLocatorTask();                                                                                                                      runner = new Runnable() {
582                                                          }                                                                  @Override
583                                                  });                                                                  public void run() {
584                                                                            startLocatorTask();                                                            
585                                                                    }
586                                                            };
587                                                            break;
588                                                    case ByName:
589                                                            runner = new Runnable() {
590                                                                    @Override
591                                                                    public void run() {
592                                                                            startNameSearch( FindStationsTask.this.name );
593                                                                    }
594                                                            };
595                                                            break;
596                                                    case ByList:
597                                                            runner = new Runnable() {
598                                                                    @Override
599                                                                    public void run() {
600                                                                            startFavoriteLookup();
601                                                                    }
602                                                            };
603                                                            break;
604                                                    }
605                                                    
606                                                    stationsFetched.post( runner );
607                                          }                                          }
608                                  });                                  });
609                                  builder.setNegativeButton(getString(generic_cancel), new DialogInterface.OnClickListener() {                                  builder.setNegativeButton(getString(generic_cancel), new DialogInterface.OnClickListener() {
610                                          public void onClick(DialogInterface dialog, int id) {                                          public void onClick(DialogInterface dialog, int id) {
611                                                  dialog.dismiss();                                                  dialog.dismiss();
612                                                    StationList.this.finish();
613                                          }                                                                                                }                                                      
614                                  });                                                                                                                              });
615                                  builder.show();                                                          
616                                    builder.show();
617                          }                          }
618                  }                  }
619          }          }
# Line 573  public class StationList extends ListAct Line 631  public class StationList extends ListAct
631                                                                                                    
632                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;                          AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;
633                          selectedPosition = info.position;                          selectedPosition = info.position;
634                          int stationID = stations.get(selectedPosition).getId();                          int stationID = stations.entries.get(selectedPosition).getId();
635    
636                          if (!favorites.contains(stationID)) {                          if (!favorites.contains(stationID)) {
637                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );                                  menu.add(0, FAVORITES_ADD, 0, getString(stationlist_addfavorite) );
# Line 584  public class StationList extends ListAct Line 642  public class StationList extends ListAct
642                  }                  }
643                                    
644                  public void onContextItemSelected(MenuItem item) {                  public void onContextItemSelected(MenuItem item) {
645                          StationBean sb = stations.get(selectedPosition);                          StationEntry sb = stations.entries.get(selectedPosition);
646                                                    
647                          int stationID = sb.getId();                          int stationID = sb.getId();
648                          if (item.getItemId() == FAVORITES_ADD) {                          if (item.getItemId() == FAVORITES_ADD) {
# Line 597  public class StationList extends ListAct Line 655  public class StationList extends ListAct
655                                                                    
656                                                                    
657                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {                                  if (listType.equals( WelcomeScreen.ListType.ListFavorites) ) {
658                                          stations.remove(selectedPosition);                                          stations.entries.remove(selectedPosition);
659                                          adapter.notifyDataSetChanged();                                          adapter.notifyDataSetChanged();
660                                  }                                  }
661                          }                          }

Legend:
Removed from v.566  
changed lines
  Added in v.1142

  ViewVC Help
Powered by ViewVC 1.1.20