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

Annotation of /android/TrainInfo/src/dk/thoerup/traininfo/TimetableList.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1027 - (hide annotations) (download)
Wed Sep 8 06:03:45 2010 UTC (13 years, 8 months ago) by torben
File size: 5542 byte(s)
Clean up the cache to avoid OutOfMemoryError exceptions
1 torben 362 package dk.thoerup.traininfo;
2    
3 torben 365
4 torben 630 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.timetablelist_fetchdata;
7     import static dk.thoerup.traininfo.R.string.timetablelist_fetcherror;
8     import static dk.thoerup.traininfo.R.string.timetablelist_nodata;
9    
10 torben 365 import java.util.ArrayList;
11     import java.util.List;
12    
13     import android.app.AlertDialog;
14     import android.app.Dialog;
15 torben 839 import android.app.ListActivity;
16 torben 365 import android.app.ProgressDialog;
17     import android.content.DialogInterface;
18 torben 364 import android.content.Intent;
19 torben 365 import android.os.AsyncTask;
20 torben 362 import android.os.Bundle;
21 torben 630 import android.util.Log;
22 torben 840 import android.view.View;
23     import android.widget.ListView;
24 torben 362 import android.widget.TextView;
25 torben 365 import dk.thoerup.traininfo.provider.ProviderFactory;
26     import dk.thoerup.traininfo.provider.TimetableProvider;
27     import dk.thoerup.traininfo.util.MessageBox;
28 torben 362
29 torben 839 public class TimetableList extends ListActivity {
30 torben 364
31 torben 365 private static final int DLG_PROGRESS = 8000;
32 torben 981 DepartureEntry departure;
33 torben 365 TimetableListAdapter adapter;
34     TimetableFetcher fetcher;
35     List<TimetableBean> timetables;
36 torben 1017 int commFailCounter = 0;
37 torben 364
38 torben 365 TimetableProvider provider;
39    
40     @SuppressWarnings("unchecked")
41 torben 362 @Override
42     protected void onCreate(Bundle savedInstanceState) {
43     super.onCreate(savedInstanceState);
44     setContentView(R.layout.timetablelist);
45 torben 364
46 torben 365 provider = ProviderFactory.getTimetableProvider();
47    
48 torben 839 adapter = new TimetableListAdapter(this);
49     setListAdapter(adapter);
50 torben 366
51 torben 839
52 torben 366
53 torben 364 Intent launchedBy = getIntent();
54 torben 981 departure = (DepartureEntry) launchedBy.getSerializableExtra("departure");
55 torben 364
56     ((TextView)findViewById(R.id.Train)).setText(departure.getTrainNumber());
57     ((TextView)findViewById(R.id.Status)).setText(departure.getStatus());
58 torben 398 ((TextView)findViewById(R.id.Location)).setText(departure.getLocation());
59 torben 364 ((TextView)findViewById(R.id.Note)).setText(departure.getNote());
60 torben 563 ((TextView)findViewById(R.id.Updated)).setText(departure.getLastUpdateString(this));
61 torben 366
62 torben 365
63     if (savedInstanceState == null) {
64     startTimetableFetcher();
65     } else {
66     timetables = (List<TimetableBean>) savedInstanceState.getSerializable("timetables");
67     adapter.setTimetable(timetables);
68     }
69 torben 362 }
70 torben 1027
71     @Override
72     protected void onStart() {
73     super.onStart();
74     ProviderFactory.purgeOldEntries();
75     }
76 torben 918
77     @Override
78     protected void onDestroy() {
79     super.onDestroy();
80    
81     if (fetcher != null) {
82     fetcher.cancel(true);
83     }
84     }
85 torben 365
86 torben 840 @Override
87     protected void onListItemClick(ListView l, View v, int position, long id) {
88     super.onListItemClick(l, v, position, id);
89    
90     TimetableBean tt = timetables.get(position);
91    
92     StationBean station = new StationBean();
93     station.setName( tt.getStation() );
94     station.setId( tt.getStationId() );
95     station.setRegional(true);
96    
97     Intent intent = new Intent(this, DepartureList.class);
98     intent.putExtra("stationbean", station);
99     startActivity(intent);
100    
101     }
102    
103    
104    
105     @Override
106 torben 365 public void onSaveInstanceState(Bundle outState)
107     {
108     dismissDialog(DLG_PROGRESS);
109     outState.putSerializable("timetables", (ArrayList<TimetableBean>) timetables);
110     }
111 torben 364
112 torben 365
113     @Override
114     protected void onPrepareDialog(int id, Dialog dialog) {
115     super.onPrepareDialog(id, dialog);
116    
117     switch (id) {
118     case DLG_PROGRESS:
119     //pgDialog = (ProgressDialog) dialog;
120     break;
121     }
122     }
123    
124     @Override
125     protected Dialog onCreateDialog(int id) {
126     switch (id) {
127     case DLG_PROGRESS:
128 torben 561 ProgressDialog dlg = new ProgressDialog(this);
129     dlg.setMessage( getString(timetablelist_fetchdata) );
130 torben 365 dlg.setCancelable(true);
131     return dlg;
132     default:
133     return super.onCreateDialog(id);
134     }
135     }
136    
137     void startTimetableFetcher() {
138     showDialog(DLG_PROGRESS);
139     fetcher = new TimetableFetcher();
140 torben 699 fetcher.execute(departure.getType(), departure.getTrainNumber());
141 torben 365 }
142    
143     class TimetableFetcher extends AsyncTask<String,Void,Void> {
144    
145    
146     @Override
147     protected void onPostExecute(Void result) {
148     super.onPostExecute(result);
149     dismissDialog(DLG_PROGRESS);
150    
151    
152 torben 1007 if (timetables != null) {
153 torben 1017 commFailCounter = 0;
154 torben 917 TimetableList.this.getListView().invalidateViews();
155 torben 365 adapter.setTimetable(timetables);
156     if (timetables.size() == 0) {
157 torben 906 MessageBox.showMessage(TimetableList.this, getString(timetablelist_nodata), true);
158 torben 365 }
159     } else { // communication or parse error
160 torben 1017 commFailCounter++;
161 torben 365 AlertDialog.Builder builder = new AlertDialog.Builder(TimetableList.this);
162 torben 561 builder.setMessage(getString(timetablelist_fetcherror));
163 torben 365 builder.setCancelable(true);
164 torben 1017 if (commFailCounter < 3) {
165     builder.setPositiveButton(getString(generic_retry), new DialogInterface.OnClickListener() {
166     public void onClick(DialogInterface dialog, int id) {
167     dialog.dismiss();
168     startTimetableFetcher();
169    
170     }
171     });
172     }
173 torben 561 builder.setNegativeButton(getString(generic_cancel), new DialogInterface.OnClickListener() {
174 torben 365 public void onClick(DialogInterface dialog, int id) {
175     dialog.dismiss();
176 torben 843 TimetableList.this.finish();
177 torben 365 }
178 torben 630 });
179    
180     try {
181     builder.show();
182     } catch (android.view.WindowManager.BadTokenException e) {
183     Log.i("TimetableList", "BadTokenException"); // this can happen if the user switched away from this activity, while doInBackground was running
184     }
185    
186 torben 365 }
187    
188     }
189    
190     @Override
191     protected Void doInBackground(String... arg0) {
192 torben 699 String type = arg0[0];
193     String trainID = arg0[1];
194 torben 1007 timetables = provider.lookupTimetable(type, trainID);
195 torben 365
196     return null;
197     }
198    
199     }
200 torben 362 }

  ViewVC Help
Powered by ViewVC 1.1.20