2013-03-10 5 views
1

Я делаю простой код, который позволяет пользователю получить свое текущее положение GPS, когда он нажимает какую-то кнопку. Итак, я создаю класс MainActivity и Asynctask, Asynctask реализует LocationListener, но переопределение onLocationChanged никогда не вызывает! (нет следа в LogCat ..) Затем я получаю данные gps, но он никогда не меняет, когда я нажимаю кнопку:/Asynctask реализует LocationListener: onLocationChanged никогда не вызывал

И если я покину приложение, если я заставляю процесс выходить с параметром опции Android и я снова запускайте мои приложения, данные gps сохраняются одинаково. Я этого не понимаю ... и почему метод переопределения никогда не вызывается.

Вот мой единственный файл:

общественного класс MainActivity расширяет активность {

public static Context context; 
    public Button push = null; 
    public getGPS tache_getGPS = null; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
     context = getApplication().getApplicationContext(); 

     push = (Button) findViewById(R.id.button); 
     push.setOnClickListener(new OnClickListener() { 

      @Override 
      public void onClick(View v) { 
       Log.i("T: onClick", "debut"); 
       tache_getGPS = new getGPS(); 
       tache_getGPS.execute(); 
       Log.i("T: onClick", "fin"); 
       // TODO Auto-generated method stub 
      } 
     }); 
    } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.main, menu); 
     return true; 
    } 

} 

class getGPS extends AsyncTask<Void, Integer, Location> implements 
     LocationListener { 

    final long REFRESH = 5 * 1000; 
    private Location location; 
    private LocationManager lm; 

    protected void onPreExecute() { 
     Log.i("T: onPreExcute", "debut"); 
     Criteria crit = new Criteria(); 
     crit.setAccuracy(Criteria.ACCURACY_FINE); 

     // Configure location manager - I'm using just the network provider in 
     // this example 
     lm = (LocationManager) MainActivity.context 
       .getSystemService(Context.LOCATION_SERVICE); 

     String best = lm.getBestProvider(crit, false); 
     Log.i("T: onPreExecute", "best : " + best); 

     lm.requestLocationUpdates(best, 0, 1, this); 
     location = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER); 
     // nearProgress.setVisibility(View.VISIBLE); 
     Log.i("T: onPreExcute", "fin"); 
    } 

    protected Location doInBackground(Void... params) { 
     Log.i("T: doInBackground", "debut"); 

     // Try to use the last known position 
     Location lastLocation = lm 
       .getLastKnownLocation(LocationManager.GPS_PROVIDER); 
       /* 
     // If it's too old, get a new one by location manager 
     if (System.currentTimeMillis() - lastLocation.getTime() > REFRESH) { 
      while (location == null) 
       try { 
        Thread.sleep(100); 
       } catch (Exception ex) { 
       } 

      return location; 
     } 
       */ 
     Log.i("T: doInBackground", "fin"); 
     return lastLocation; 
    } 

    protected void onPostExecute(Location location) { 
     Log.i("T: onPostExecute", "debut"); 
     // nearProgress.setVisibility(View.GONE); 

     lm = (LocationManager) MainActivity.context 
       .getSystemService(Context.LOCATION_SERVICE); 
     lm.removeUpdates(this); 

     Log.i("T: onPostExecute", 
       "Altitude : " + String.valueOf(location.getAltitude())); 
     Log.i("T: onPostExecute", 
       "Longitude : " + String.valueOf(location.getLongitude())); 
     Log.i("T: onPostExecute", 
       "Latitude : " + String.valueOf(location.getLatitude())); 
     Log.i("T: onPostExecute", 
       "Precision(mètre) : " + String.valueOf(location.getAccuracy())); 
     Log.i("T: onPostExecute", "fin"); 

     Toast.makeText(
       MainActivity.context, 
       "Altitude : " + String.valueOf(location.getAltitude()) + "\n" 
         + "Longitude : " 
         + String.valueOf(location.getLongitude()) + "\n" 
         + "Latitude : " 
         + String.valueOf(location.getLatitude()) + "\n" 
         + "Precision(mètre) : " 
         + String.valueOf(location.getAccuracy()), 
       Toast.LENGTH_SHORT).show(); 

     return; 
    } 

    @Override 
    public void onLocationChanged(Location newLocation) { 
     Log.i("T: onLocationChanged", "debut"); 
     location = newLocation; 
     Log.i("T: onLocationChanged", "fin"); 
    } 

    @Override 
    public void onProviderDisabled(String provider) { 
     Log.i("T: onProviderDisabled", provider); 
    } 

    @Override 
    public void onProviderEnabled(String provider) { 
     Log.i("T: onProviderEnabled", provider); 
    } 

    @Override 
    public void onStatusChanged(String provider, int status, Bundle extras) { 
     Log.i("T: onStatusChanged", "provider : " + provider); 
     Log.i("T: onStatusChanged", "status : " + status); 
     Log.i("T: onStatusChanged", "extras : " + extras.toString()); 
    } 

} 

Спасибо за помощь и извините за мой плохой английский пишущие х)

НОВОГО КОДА (после того, как советует =)), без учета Asinctask

public class MainActivity extends Activity implements LocationListener{ 

    public static Context context; 
    public Button push = null; 
    public getGPS tache_getGPS = null; 

    private Location location; 
    private LocationManager lm; 
    final long REFRESH = 5 * 1000; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
     context = getApplication().getApplicationContext(); 

     push = (Button) findViewById(R.id.button); 
     push.setOnClickListener(new OnClickListener() { 

      @Override 
      public void onClick(View v) { 
       Log.i("T: onClick", "debut"); 
       location = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER); 
       Location lastLocation = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER); 
       if (System.currentTimeMillis() - lastLocation.getTime() > REFRESH) { 
        while (location == null) 
         try { Thread.sleep(100); } catch (Exception ex) { } 
        Log.i("FINAL : location", location.toString()); 
        Toast.makeText(MainActivity.context, "location : "+location.toString(), Toast.LENGTH_SHORT).show(); 
        return; 
       } 
       Log.i("FINAL : lastlocation", lastLocation.toString()); 
       Toast.makeText(MainActivity.context, "lastLocation : "+lastLocation.toString(), Toast.LENGTH_SHORT).show(); 
       Log.i("T: onClick", "fin"); 
      } 
     }); 
    } 

    @Override 
    protected void onResume(){ 
     super.onResume(); 
     Criteria crit = new Criteria(); 
     crit.setAccuracy(Criteria.ACCURACY_FINE); 
     lm = (LocationManager) MainActivity.context.getSystemService(Context.LOCATION_SERVICE); 

     String best = lm.getBestProvider(crit, false); 
     Log.i("T: onPreExecute", "best : " + best); 

     lm.requestLocationUpdates(best, 1, 1, this); 
    } 

    @Override 
    protected void onPause(){ 
     super.onPause(); 
     lm.removeUpdates(this); 
    } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.main, menu); 
     return true; 
    } 

    @Override 
    public void onLocationChanged(Location newLocation) { 
     Toast.makeText(context, "onLocationChanged", Toast.LENGTH_SHORT).show(); 
     Log.i("T: onLocationChanged", "debut"); 
     location = newLocation; 
     Log.i("T: onLocationChanged", "fin"); 
    } 

    @Override 
    public void onProviderDisabled(String provider) { 
     Log.i("T: onProviderDisabled", provider); 
    } 

    @Override 
    public void onProviderEnabled(String provider) { 
     Log.i("T: onProviderEnabled", provider); 
    } 

    @Override 
    public void onStatusChanged(String provider, int status, Bundle extras) { 
     Log.i("T: onStatusChanged", "provider : " + provider); 
     Log.i("T: onStatusChanged", "status : " + status); 
     Log.i("T: onStatusChanged", "extras : " + extras.toString()); 
    } 

} 
+0

В чем причина, по которой вы применили его в AsyncTask? Вы можете сделать это, вы знаете, что можете сделать это в своей деятельности. –

+0

AsyncTask не будет вызывать ваши методы. Он вызывает 1. onPreExecute 2. doInBackground 3. onProgressUpdate 4. onPostExecute. Вы должны использовать поток для своих изменений или в своей деятельности. – staaar

+0

Thx =) Я попробую с Thread .. вы можете быстро объяснить, что я делаю? Никогда не используйте Thread (Android Beginner ^^) – user2137454

ответ

0

В requestLocationUpdates вы указали 1 как minDistance (minDistance - минимальный интервал расстояния для уведомлений, в метрах). Попробуйте установить его в 0.

+0

Я пытаюсь, но проблема не устраняется:/ – user2137454

+0

Для получения точного местоположения от GPS может потребоваться некоторое время (вы можете попробовать с ACCURACY_COARSE для более быстрого обновления). Кроме того, вам действительно нужно использовать задачу Async? Что делать, если активность непосредственно реализует «LocationListener»? – Houf

+0

для изучения работы Asynctask =) Я стараюсь с ACCURACY_COARSE, той же проблемой .. Но thx действительно за вашу помощь – user2137454

Смежные вопросы