每5秒更新一次GPS Listener

时间:2011-08-19 09:29:44

标签: android gps

我应该每隔5秒更新一次监听器。但事实并非如此。我的代码有什么问题?

非常感谢您的帮助!

package com.example.android.lbs;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.sql.Date;
import java.text.SimpleDateFormat;

import android.app.Activity;
import android.content.Context;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

public class LbsGeocodingActivity extends Activity {

    public static final String LOG_TAG = "<<< ------------ >>> GeocodingActivity <<< ------------ >>>";

    TextView tv;
    int ScreenOutputCount;
    String newTrip;

    private static final long MINIMUM_DISTANCE_CHANGE_FOR_UPDATES = 0; // in Meters
    private static final long MINIMUM_TIME_BETWEEN_UPDATES = 5000; // in Milliseconds, 5 secconds

    protected LocationManager lm;
    MyLocationListener locationL = new MyLocationListener();

    protected Button retrieveLocationButton;
    //Log.e(LOG_TAG, e.toString());

    @Override
    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState); 
        setContentView(R.layout.main);

        try {
            View.OnClickListener handler = new View.OnClickListener(){
                public void onClick(View v) {
                    //we will use switch statement and just
                    //get thebutton's id to make things easier
                    switch (v.getId()) {

                        case R.id.trip_start: 
                            tripStart();
                            break;
                        case R.id.trip_end: 
                            tripEnd();
                        break;
                    }
                }
            };

            //we will set the listeners
            findViewById(R.id.trip_start).setOnClickListener(handler);
            findViewById(R.id.trip_end).setOnClickListener(handler);

            }catch(Exception e){
                 Log.e("Android Button Tutorial", e.toString());
            }

    }    

    public void tripStart(){

        File originalDirectories = new File( Environment.getExternalStorageDirectory() + "/Android/GpsTracker/" );
        if( !originalDirectories.exists() ){
            originalDirectories.mkdirs();
        }

        LbsGeocodingActivity.this.newTrip = getNewFileName();
        LbsGeocodingActivity.this.ScreenOutputCount = 1;
        LbsGeocodingActivity.this.tv = (TextView) this.findViewById( R.id.thetext );
        LbsGeocodingActivity.this.tv.setText("Location Updates: \n");

        LbsGeocodingActivity.this.lm = (LocationManager) getSystemService(Context.LOCATION_SERVICE);

        LbsGeocodingActivity.this.lm.requestLocationUpdates(
                LocationManager.NETWORK_PROVIDER, 
                MINIMUM_TIME_BETWEEN_UPDATES, 
                MINIMUM_DISTANCE_CHANGE_FOR_UPDATES,
                this.locationL
        );

        Toast.makeText(getBaseContext(), "New Trip Started.", Toast.LENGTH_SHORT).show();

    }

    public String getNewFileName(){
        SimpleDateFormat sdfDateTime = new SimpleDateFormat("yyyyMMddHHmmss");
        return sdfDateTime.format(new Date(System.currentTimeMillis()));    
    }

    public void tripEnd(){
        LbsGeocodingActivity.this.lm.removeUpdates( this.locationL );
        Toast.makeText(getBaseContext(), "Trip Ended.", Toast.LENGTH_SHORT).show();
    }

    protected void showCurrentLocation() {
        try{
            Location location = LbsGeocodingActivity.this.lm.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);

            if (location != null) {
                String show_curent = "Longitude: " + location.getLongitude()
                                        + " | Latitude: " + location.getLatitude();

                //LbsGeocodingActivity.this.tv.append( show_curent );

                Toast.makeText(getBaseContext(), show_curent, Toast.LENGTH_SHORT).show();

                //LbsGeocodingActivity.this.ScreenOutputCount = LbsGeocodingActivity.this.ScreenOutputCount + 1;
            }else{
                Toast.makeText(getBaseContext(), "Last Know Location Not Found.", Toast.LENGTH_SHORT).show();
            }
        }catch( NullPointerException e){
            Log.e("Android Button Tutorial", e.toString() );
        }
    }   

    private class MyLocationListener implements LocationListener {

        public void onLocationChanged(Location location) {
            LbsGeocodingActivity.this.tv.append( LbsGeocodingActivity.this.ScreenOutputCount
                    + " | Longitude: " + location.getLongitude()
                    + " | Latitude: " + location.getLatitude() + "\n" );

            LbsGeocodingActivity.this.ScreenOutputCount = LbsGeocodingActivity.this.ScreenOutputCount + 1;

            logLocationUpdate( location.getLongitude(), location.getLatitude() );
        }

        public void logLocationUpdate( double longitude, double latitude){
            try {

                SimpleDateFormat sdfDateTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                String timestamp =  sdfDateTime.format(new Date(System.currentTimeMillis()));

                String logString = timestamp + "::" +
                                    longitude + "::" +
                                    latitude + "\n";

                String sdcard = Environment.getExternalStorageDirectory() + "/Android/GpsTracker/";

                //then write the file
                final String TESTSTRING = new String(logString);

                File gpxfile = new File(sdcard, LbsGeocodingActivity.this.newTrip + ".txt" );
                FileWriter gpxwriter = new FileWriter( gpxfile, true );
                BufferedWriter out = new BufferedWriter( gpxwriter );
                out.write(TESTSTRING);
                out.close();

            }catch(Exception e){
              Log.e("GPS Tracker", e.getMessage());
            }
        }
        public void onStatusChanged(String s, int i, Bundle b) {
            /*
            Toast.makeText(LbsGeocodingActivity.this, "Provider status changed",
                    Toast.LENGTH_LONG).show();
            */
        }

        public void onProviderDisabled(String s) {
            Toast.makeText(LbsGeocodingActivity.this,
                    "Provider disabled by the user. GPS turned off",
                    Toast.LENGTH_LONG).show();
        }

        public void onProviderEnabled(String s) {
            Toast.makeText(LbsGeocodingActivity.this,
                    "Provider enabled by the user. GPS turned on",
                    Toast.LENGTH_LONG).show();
        }

    }

}

2 个答案:

答案 0 :(得分:3)

通过将其设置为5000毫秒,这并不一定意味着您将每隔5秒获取一次该位置。时间或多或少是最好的情况。

  

minTime通知的最小时间间隔,以毫秒为单位。此字段仅用作节省电量的提示,位置更新之间的实际时间可能大于或小于此值。   http://developer.android.com/reference/android/location/LocationManager.html

您确定自己的活动在运行吗?如果您想在活动休眠时收到位置,则需要唤醒锁和服务。

例如在我创建的GPS应用程序中,我将0 ms用于尽快获取它但在调试和检查logcat时,我有时会每隔一分钟左右获取一次该位置,而不是每一秒。

答案 1 :(得分:3)

如David Olsson所述,MINIMUM_TIME_BETWEEN_UPDATES仅阻止过于频繁地请求监听器。如果您想定期requestLocationUpdates,则应使用TimerTimerTask并让requestLocationUpdates每5秒运行一次

schedule(TimerTask task, long delay, long period)
Schedules the specified task for repeated fixed-delay execution, beginning after the specified delay.