mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 12:23:58 +01:00 
			
		
		
		
	Merge pull request #287 from misaochan/cancel-asynctask
Fix crash with Nearby when back button pressed or no network
This commit is contained in:
		
						commit
						c04dc99105
					
				
					 2 changed files with 21 additions and 4 deletions
				
			
		|  | @ -109,6 +109,15 @@ public class NearbyListFragment extends ListFragment implements TaskListener { | |||
|         super.onDetach(); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public void onDestroy() { | ||||
|         super.onDestroy(); | ||||
| 
 | ||||
|         if(nearbyAsyncTask != null && nearbyAsyncTask.getStatus() != AsyncTask.Status.FINISHED) { | ||||
|             nearbyAsyncTask.cancel(true); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private class NearbyAsyncTask extends AsyncTask<Void, Integer, List<Place>> { | ||||
| 
 | ||||
|         private final TaskListener listener; | ||||
|  | @ -138,6 +147,11 @@ public class NearbyListFragment extends ListFragment implements TaskListener { | |||
|         @Override | ||||
|         protected void onPostExecute(List<Place> result) { | ||||
|             super.onPostExecute(result); | ||||
| 
 | ||||
|             if(isCancelled()) { | ||||
|                 return; | ||||
|             } | ||||
| 
 | ||||
|             progressBar.setVisibility(View.GONE); | ||||
| 
 | ||||
|             mAdapter = new NearbyAdapter(getActivity(), places); | ||||
|  | @ -304,10 +318,12 @@ public class NearbyListFragment extends ListFragment implements TaskListener { | |||
|             ); | ||||
|         } | ||||
| 
 | ||||
|         for(int i = 0; i < 500; i++) { | ||||
|             Place place = places.get(i); | ||||
|             String distance = formatDistanceBetween(mLatestLocation, place.location); | ||||
|             place.setDistance(distance); | ||||
|         if (places.size() > 0) { | ||||
|             for (int i = 0; i < 100; i++) { | ||||
|                 Place place = places.get(i); | ||||
|                 String distance = formatDistanceBetween(mLatestLocation, place.location); | ||||
|                 place.setDistance(distance); | ||||
|             } | ||||
|         } | ||||
|         return places; | ||||
|     } | ||||
|  |  | |||
|  | @ -26,6 +26,7 @@ public class NearbyPlaces { | |||
|                 StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); | ||||
|                 StrictMode.setThreadPolicy(policy); | ||||
| 
 | ||||
| 
 | ||||
|                 URL file = new URL("https://tools.wmflabs.org/wiki-needs-pictures/data/data.csv"); | ||||
| 
 | ||||
|                 BufferedReader in = new BufferedReader(new InputStreamReader(file.openStream())); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Josephine Lim
						Josephine Lim