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

Diff of /android/TrainInfo/src/dk/thoerup/traininfo/provider/OfflineStationProvider.java

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

revision 1553 by torben, Fri Jul 8 11:56:58 2011 UTC revision 1628 by torben, Fri Nov 25 10:50:44 2011 UTC
# Line 1  Line 1 
1  package dk.thoerup.traininfo.provider;  package dk.thoerup.traininfo.provider;
2    
 import java.io.EOFException;  
3  import java.io.File;  import java.io.File;
4  import java.io.FileInputStream;  import java.io.FileInputStream;
5  import java.io.FileOutputStream;  import java.io.FileOutputStream;
6    import java.io.IOException;
7  import java.io.ObjectInputStream;  import java.io.ObjectInputStream;
8  import java.io.ObjectOutputStream;  import java.io.ObjectOutputStream;
9    import java.net.URLEncoder;
10  import java.util.Collections;  import java.util.Collections;
11  import java.util.Comparator;  import java.util.Comparator;
12  import java.util.LinkedList;  import java.util.LinkedList;
# Line 19  import android.util.Log; Line 20  import android.util.Log;
20  import dk.thoerup.android.traininfo.common.StationBean;  import dk.thoerup.android.traininfo.common.StationBean;
21  import dk.thoerup.android.traininfo.common.StationEntry;  import dk.thoerup.android.traininfo.common.StationEntry;
22  import dk.thoerup.genericjavautils.HttpUtil;  import dk.thoerup.genericjavautils.HttpUtil;
23    import dk.thoerup.traininfo.util.DownloadUtil;
24  import dk.thoerup.traininfo.util.IntSet;  import dk.thoerup.traininfo.util.IntSet;
25  import dk.thoerup.traininfo.util.XmlUtil;  import dk.thoerup.traininfo.util.XmlUtil;
26    
# Line 26  public class OfflineStationProvider impl Line 28  public class OfflineStationProvider impl
28                    
29          StationBean stations = new StationBean();          StationBean stations = new StationBean();
30    
31            public boolean hasStations() {
32                    return (stations != null && stations.entries.size() > 0);
33            }
34            
35    
36          public boolean loadStations(Context context) throws Exception {          public boolean loadStations(Context context) throws Exception {
37                  long start = System.currentTimeMillis();                  long start = System.currentTimeMillis();
38                                    
39                  stations.entries.clear(); //TODO: remove                  StationBean tmpStations = new StationBean();
40                                    
41                  File parent = context.getFilesDir();                  File parent = context.getFilesDir();
42                  File stationsFile = new File(parent, "stations.bin");                  File stationsFile = new File(parent, "stations.bin");
# Line 48  public class OfflineStationProvider impl Line 54  public class OfflineStationProvider impl
54                  stations = serializer.read(StationBean.class,  new String(data, "ISO-8859-1") );*/                  stations = serializer.read(StationBean.class,  new String(data, "ISO-8859-1") );*/
55                                    
56                                    
57                  try {  
58                          ObjectInputStream in = new ObjectInputStream( new FileInputStream(stationsFile) );                  ObjectInputStream in = new ObjectInputStream( new FileInputStream(stationsFile) );
59                          Object o;  
60                          StationEntry e = null;                  int length = in.readInt(); // first field is the length
61                          while ( (o=in.readObject()) != null ) {                  
62                                  e = (StationEntry) o;                  for (int i=0; i<length; i++) {                          
63                                  e.updateSearch();                          StationEntry entry = (StationEntry) in.readObject();
64                                  stations.entries.add( e );                          updateSearchStrings(entry);
65                          }                          tmpStations.entries.add( entry );
                         in.close();  
                 } catch (EOFException e) {  
                         //do nothing;  
66                  }                  }
67                                    
68                  Log.e("OFFLINE", "loaded" + stations.entries.size());                  in.close();
69    
70                    stations = tmpStations; // når indlæsningen er ok skifter vi over
71                    
72                    Log.e("OFFLINE", "loaded" + tmpStations.entries.size());
73                  logElapsedTime(start, "loadStations");                  logElapsedTime(start, "loadStations");
74                                    
75                  return true;                  return true;
76          }                }
77            
78            public void updateSearchStrings(StationEntry entry) {          
79                    entry.nameLower = entry.getName().toLowerCase();
80                    entry.nameInternational = entry.nameLower.replace("æ", "ae").replace("ø", "oe").replace("å", "aa");
81            }
82                    
83          public void downloadStations(Context context) throws Exception {          public void downloadStations(Context context) throws Exception {
84                  File parent = context.getFilesDir();                  File parent = context.getFilesDir();
# Line 75  public class OfflineStationProvider impl Line 87  public class OfflineStationProvider impl
87                                    
88                  byte data[] = HttpUtil.getContent(XmlUtil.SERVICE_BASE + "/LocateStations?dump=1", 5000);                  byte data[] = HttpUtil.getContent(XmlUtil.SERVICE_BASE + "/LocateStations?dump=1", 5000);
89                  Serializer serializer = new Persister();                  Serializer serializer = new Persister();
90                  stations = serializer.read(StationBean.class,  new String(data, "ISO-8859-1") );                  StationBean tmpStations = serializer.read(StationBean.class,  new String(data, "ISO-8859-1") );
91                                    
92                                    
93                  ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream(stationsFile) );                  ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream(stationsFile) );
94                  Log.e("OFFLINE", "data size" + data.length);                  Log.e("OFFLINE", "data size" + data.length);
95                                    
96                  for (StationEntry entry : stations.entries) {                  out.writeInt( tmpStations.entries.size() ); //start with writing the length of the dataset
97                    
98                    for (StationEntry entry : tmpStations.entries) {
99                            updateSearchStrings( entry ); //prepare name fields for byName search
100                          out.writeObject(entry);                          out.writeObject(entry);
101                  }                  }
102                                    
103                  out.close();                              out.close();
104                    
105                    stations = tmpStations; // når alt er ok skifter vi over til ny udgave
106          }          }
107                    
108                    
# Line 110  public class OfflineStationProvider impl Line 127  public class OfflineStationProvider impl
127          @Override          @Override
128          public StationBean lookupStationsByLocation(Location location) {          public StationBean lookupStationsByLocation(Location location) {
129                                    
130                    statsByLocation(location);
131                    
132                  long start = System.currentTimeMillis();                  long start = System.currentTimeMillis();
133                  Location tmpLoc = new Location("GPS");                  Location tmpLoc = new Location("GPS");
134                                    
# Line 138  public class OfflineStationProvider impl Line 157  public class OfflineStationProvider impl
157                  Collections.sort( entries, distanceComparator);                  Collections.sort( entries, distanceComparator);
158                                    
159                  StationBean tmpStations = new StationBean();                  StationBean tmpStations = new StationBean();
160                  for (int i = 0; i<8; i++) {                  for (int i = 0; i<8 && i<entries.size(); i++) {
161                          tmpStations.entries.add( entries.get(i) );                          tmpStations.entries.add( entries.get(i) );
162                  }                  }
163                                    
# Line 170  public class OfflineStationProvider impl Line 189  public class OfflineStationProvider impl
189    
190          @Override          @Override
191          public StationBean lookupStationsByIds(String ids) {          public StationBean lookupStationsByIds(String ids) {
192                    statsByIds(ids);
193                    
194                  IntSet idset = new IntSet();                  IntSet idset = new IntSet();
195                  idset.fromString(ids);                  idset.fromString(ids);
196                                    
# Line 182  public class OfflineStationProvider impl Line 203  public class OfflineStationProvider impl
203                                    
204                  return tmpStations;                  return tmpStations;
205          }          }
206            
207    
208            private void statsByLocation(Location location) {
209                    double lat = XmlStationProvider.roundToPlaces(location.getLatitude(), 4);
210                    double lng = XmlStationProvider.roundToPlaces(location.getLongitude(), 4);
211                    
212                    final String url = XmlUtil.SERVICE_BASE + "/LocateStations?latitude=" + lat + "&longitude=" + lng + "&dummy=1";
213                    Log.i("url", url);
214                    urlSender(url);
215            }
216            
217            private void statsByName(String name) {
218                    
219                    try {
220                            name = URLEncoder.encode(name, "ISO8859-1");    
221                    } catch (Exception e) {
222                            Log.e("lookupStations", "Encoding failed", e);//if encoding fails use original and hope for the best
223                    }
224                    
225                    String url = XmlUtil.SERVICE_BASE + "/LocateStations?name=" + name + "&dummy=1";
226                    Log.i("url", url);
227                    urlSender(url);
228            }
229            
230            private void statsByIds(String ids) {  
231                    final String url = XmlUtil.SERVICE_BASE + "/LocateStations?list=" + ids + "&dummy=1";
232                    Log.i("url", url);
233                    urlSender(url);
234            }
235            
236            private void urlSender(final String url) {
237                    Thread t = new Thread(new Runnable() {
238    
239                            @Override
240                            public void run() {
241                                    try {
242                                            DownloadUtil.getContentString(url, 15000, "ISO-8859-1");
243                                    } catch (IOException e) {
244                                            Log.e("TrainInfo", "stats failed");
245                                    }                              
246                            }                      
247                    });
248                    t.start();
249            }
250            
251    
252  }  }

Legend:
Removed from v.1553  
changed lines
  Added in v.1628

  ViewVC Help
Powered by ViewVC 1.1.20