GPS не работает в Async Task
Я реализовал простую программу GPS, которая выбирает координаты и отображает их на экране. Когда я попытался улучшить этот дизайн и реализовать асинхронную задачу, GPS, похоже, не работает по той или иной причине. Есть ли проблема с использованием асинхронной задачи с GPS? Вот мой код:
<code>private class DownloadTask extends AsyncTask<String, Void, Object> { protected Object doInBackground(String... args) { Log.i("MyApp", "Background thread starting"); LocationManager mLocationManager; Gpslistener Gpslistener; Gpslistener = new Gpslistener(); try{ mLocationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); mLocationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0,Gpslistener); }catch (Exception e) { test_gps = true; } return null; } protected void onPostExecute(Object result) { if(test_gps == true){ if (ParkingActivity.this.progressDialog != null) { ParkingActivity.this.progressDialog.dismiss(); } AlertMessage("GPS Error", "Unable to get location"); } public class Gpslistener implements LocationListener { @Override public void onLocationChanged(Location loc) { loc.getLatitude(); loc.getLongitude(); } @Override public void onProviderDisabled(String provider) { } @Override public void onProviderEnabled(String provider) { } @Override public void onStatusChanged(String provider, int status, Bundle extras) { } } </code>
Каждый раз, когда я запускаю его, он всегда ловит исключение. Разрешения GPS установлены в манифесте, и я всегда использую другое приложение, чтобы гарантировать, что соединение GPS подключено к сети, поэтому я устранил их как возможные ошибки. Честно говоря, я не могу думать ни о чем другом, без асинхронной задачи это работает отлично! Любая помощь высоко ценится, спасибо!
Edited Мое исключение logcat:
<code>05-09 22:56:20.199: E/EXCEPTION:(8874): java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 05-09 22:56:20.199: E/EXCEPTION:(8874): java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.os.Handler.<init>(Handler.java:121) 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.location.LocationManager$ListenerTransport$1.<init>(LocationManager.java:173) 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.location.LocationManager$ListenerTransport.<init>(LocationManager.java:173) 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.location.LocationManager._requestLocationUpdates(LocationManager.java:579) 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.location.LocationManager.requestLocationUpdates(LocationManager.java:446) 05-09 22:56:20.199: E/EXCEPTION:(8874): at stefan.testservice.ParkingActivity$DownloadTask.doInBackground(ParkingActivity.java:163) 05-09 22:56:20.199: E/EXCEPTION:(8874): at stefan.testservice.ParkingActivity$DownloadTask.doInBackground(ParkingActivity.java:1) 05-09 22:56:20.199: E/EXCEPTION:(8874): at android.os.AsyncTask$2.call(AsyncTask.java:185) 05-09 22:56:20.199: E/EXCEPTION:(8874): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306) 05-09 22:56:20.199: E/EXCEPTION:(8874): at java.util.concurrent.FutureTask.run(FutureTask.java:138) 05-09 22:56:20.199: E/EXCEPTION:(8874): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088) 05-09 22:56:20.199: E/EXCEPTION:(8874): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581) 05-09 22:56:20.199: E/EXCEPTION:(8874): at java.lang.Thread.run(Thread.java:1019) </code>