Asynctask实现了LocationListener:onLocationChanged从未调用过

时间:2013-03-10 15:46:25

标签: android

我制作了一个简单的代码,允许用户在按下某个按钮时获取当前的GPS位置。 因此,我创建了一个MainActivity和一个Asynctask类,Asynctask实现了LocationListener,但是覆盖onLocationChanged永远不会调用! (LogCat中没有跟踪..) 然后,我得到gps数据,但是当我按下按钮时他永远不会改变:/

如果我离开应用程序,如果我强制进程退出参数选项Android并再次启动我的应用程序,则gps数据保持不变。我不明白......以及为什么永远不会调用override方法。

这是我唯一的文件:

公共类MainActivity扩展了Activity {

    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());
    }

}

感谢您的帮助,对不起我糟糕的英文写作x)

NEW CODE(在advises =之后),没有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());
    }

}

1 个答案:

答案 0 :(得分:0)

requestLocationUpdates中,您指定1作为minDistance(minDistance是通知的最小距离间隔,以米为单位)。尝试将其设置为0.