8

Chcę otrzymywać okresowe (np. Co 2 minuty) aktualizacje bieżącej lokalizacji do tego Śledzę oficjalną dokumentację, napisałem ten kod, ale nie podałem bieżących aktualizacji lokalizacji co dwie minuty określone w LocationRequest obiektu, który jestem przechodzącej w requestLocationUpdates(), oto kod:Jak uzyskać aktualną lokalizację w GoogleMap przy użyciu usługi FusedLocationProviderClient

public class MapsActivity extends FragmentActivity implements OnMapReadyCallback, 
    GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener{ 

private FusedLocationProviderClient FusedLocationClient; 
private GoogleApiClient mGoogleApiClient; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_maps); 
    if (mGoogleApiClient == null) { 
     mGoogleApiClient = new GoogleApiClient.Builder(this) 
       .addConnectionCallbacks(this) 
       .addOnConnectionFailedListener(this) 
       .addApi(LocationServices.API) 
       .build(); 
    } 

SupportMapFragment map = 
    getSupportFragmentManager().findFragmentById(R.id.map)); 

    map.getMapAsync(this); 

    FusedLocationClient LocationServices.getFusedLocationProviderClient(this); 
} 


@Override 
public void onConnected(Bundle bundle) { 
    FusedLocationClient.getLastLocation() 
      .addOnSuccessListener(this, new OnSuccessListener<Location>() { 
       @Override 
       public void onSuccess(Location location) { 

        if (location != null) { 
         Log.i("MainActivity ", "" + location.getLongitude()) 
        } 
       } 
      }); 
FusedLocationClient = LocationServices.getFusedLocationProviderClient(this); 
FusedLocationClient.requestLocationUpdates(requestLocation(), 
new LocationCallback(){ 
     @Override 
     public void onLocationResult(LocationResult locationResult) { 
      for (Location location : locationResult.getLocations()) { 
       Log.i("MainActivity ", "" + location.getLongitude()); 
       //not getting current location updates every 2 minutes 
      } 
     }; 

    },null); 

} 

@Override 
public void onConnectionSuspended(int i) {} 

@Override 
public void onConnectionFailed(ConnectionResult connectionResult) {} 

Odpowiedz

-1
private LocationRequest locationRequest; 

    public class MapsActivity extends FragmentActivity implements LocationListener{ 

    locationRequest = new LocationRequest(); 
    locationRequest.setInterval(60 * 1000); 
    locationRequest.setFastestInterval(15 * 1000); 
    locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY); 


@Override 
public void onLocationChanged(Location location) { 

    latitude = location.getLatitude(); 
    longitude = location.getLongitude(); 

} 

Wdrożenie zmień położenie słuchacza i będzie w stanie zastąpić OnLocation zmieniło ...

16

jest podobny do mojego other answer here, zaktualizowano do korzystania z niedawno wprowadzonej klasy FusedLocationProviderClient.

W celu wykorzystania FusedLocationProviderClient w połączeniu z mapą Google:

  1. poczekać, aż Google Map jest gotowy

  2. Prośba o pozwolenie na starcie Lokalizacja razie potrzeby

  3. Zamówienie aktualizacje lokalizacji po uzyskaniu pozwolenia

  4. Zaktualizuj Google Mapa raz lokalizacji użytkownika uzyskuje

Najpierw upewnij się, że używasz wersji 11 z usługi Google Play, jak starsze wersje nie mają klasę FusedLocationProviderClient:

dependencies { 
    compile 'com.google.android.gms:play-services-maps:11.8.0' 
    compile 'com.google.android.gms:play-services-location:11.8.0' 
    //........ 
} 

Oto pełna Klasa aktywności:

public class MapsActivity extends AppCompatActivity 
     implements OnMapReadyCallback { 

    GoogleMap mGoogleMap; 
    SupportMapFragment mapFrag; 
    LocationRequest mLocationRequest; 
    Location mLastLocation; 
    Marker mCurrLocationMarker; 
    FusedLocationProviderClient mFusedLocationClient; 

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

     getSupportActionBar().setTitle("Map Location Activity"); 

     mFusedLocationClient = LocationServices.getFusedLocationProviderClient(this); 

     mapFrag = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map); 
     mapFrag.getMapAsync(this); 
    } 

    @Override 
    public void onPause() { 
     super.onPause(); 

     //stop location updates when Activity is no longer active 
     if (mFusedLocationClient != null) { 
      mFusedLocationClient.removeLocationUpdates(mLocationCallback); 
     } 
    } 

    @Override 
    public void onMapReady(GoogleMap googleMap) 
    { 
     mGoogleMap=googleMap; 
     mGoogleMap.setMapType(GoogleMap.MAP_TYPE_HYBRID); 

     mLocationRequest = new LocationRequest(); 
     mLocationRequest.setInterval(120000); // two minute interval 
     mLocationRequest.setFastestInterval(120000); 
     mLocationRequest.setPriority(LocationRequest.PRIORITY_BALANCED_POWER_ACCURACY); 

     if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { 
      if (ContextCompat.checkSelfPermission(this, 
        Manifest.permission.ACCESS_FINE_LOCATION) 
        == PackageManager.PERMISSION_GRANTED) { 
       //Location Permission already granted 
       mFusedLocationClient.requestLocationUpdates(mLocationRequest, mLocationCallback, Looper.myLooper()); 
       mGoogleMap.setMyLocationEnabled(true); 
      } else { 
       //Request Location Permission 
       checkLocationPermission(); 
      } 
     } 
     else { 
      mFusedLocationClient.requestLocationUpdates(mLocationRequest, mLocationCallback, Looper.myLooper()); 
      mGoogleMap.setMyLocationEnabled(true); 
     } 
    } 

    LocationCallback mLocationCallback = new LocationCallback(){ 
     @Override 
     public void onLocationResult(LocationResult locationResult) { 
      for (Location location : locationResult.getLocations()) { 
       Log.i("MapsActivity", "Location: " + location.getLatitude() + " " + location.getLongitude()); 
       mLastLocation = location; 
       if (mCurrLocationMarker != null) { 
        mCurrLocationMarker.remove(); 
       } 

       //Place current location marker 
       LatLng latLng = new LatLng(location.getLatitude(), location.getLongitude()); 
       MarkerOptions markerOptions = new MarkerOptions(); 
       markerOptions.position(latLng); 
       markerOptions.title("Current Position"); 
       markerOptions.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_MAGENTA)); 
       mCurrLocationMarker = mGoogleMap.addMarker(markerOptions); 

       //move map camera 
       mGoogleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(latLng, 11)); 
      } 
     }; 

    }; 

    public static final int MY_PERMISSIONS_REQUEST_LOCATION = 99; 
    private void checkLocationPermission() { 
     if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) 
       != PackageManager.PERMISSION_GRANTED) { 

      // Should we show an explanation? 
      if (ActivityCompat.shouldShowRequestPermissionRationale(this, 
        Manifest.permission.ACCESS_FINE_LOCATION)) { 

       // Show an explanation to the user *asynchronously* -- don't block 
       // this thread waiting for the user's response! After the user 
       // sees the explanation, try again to request the permission. 
       new AlertDialog.Builder(this) 
         .setTitle("Location Permission Needed") 
         .setMessage("This app needs the Location permission, please accept to use location functionality") 
         .setPositiveButton("OK", new DialogInterface.OnClickListener() { 
          @Override 
          public void onClick(DialogInterface dialogInterface, int i) { 
           //Prompt the user once explanation has been shown 
           ActivityCompat.requestPermissions(MapsActivity.this, 
             new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 
             MY_PERMISSIONS_REQUEST_LOCATION); 
          } 
         }) 
         .create() 
         .show(); 


      } else { 
       // No explanation needed, we can request the permission. 
       ActivityCompat.requestPermissions(this, 
         new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 
         MY_PERMISSIONS_REQUEST_LOCATION); 
      } 
     } 
    } 

    @Override 
    public void onRequestPermissionsResult(int requestCode, 
              String permissions[], int[] grantResults) { 
     switch (requestCode) { 
      case MY_PERMISSIONS_REQUEST_LOCATION: { 
       // If request is cancelled, the result arrays are empty. 
       if (grantResults.length > 0 
         && grantResults[0] == PackageManager.PERMISSION_GRANTED) { 

        // permission was granted, yay! Do the 
        // location-related task you need to do. 
        if (ContextCompat.checkSelfPermission(this, 
          Manifest.permission.ACCESS_FINE_LOCATION) 
          == PackageManager.PERMISSION_GRANTED) { 

         mFusedLocationClient.requestLocationUpdates(mLocationRequest, mLocationCallback, Looper.myLooper()); 
         mGoogleMap.setMyLocationEnabled(true); 
        } 

       } else { 

        // permission denied, boo! Disable the 
        // functionality that depends on this permission. 
        Toast.makeText(this, "permission denied", Toast.LENGTH_LONG).show(); 
       } 
       return; 
      } 

      // other 'case' lines to check for other 
      // permissions this app might request 
     } 

    } 

} 

użytkownik zostanie poproszony o akceptację pozwolenie Lokalizacja:

enter image description here

lokalizacja będzie aktualizowana na uruchomienie aplikacji, a co dwie minuty:

enter image description here

+0

Dzięki, co jeśli chcemy uzyskać urządzenia aktualną pozycję co 10 kroków możemy poruszać, jak posuwamy się i coraz aktualizację lokalizacji w czasie rzeczywistym – blackHawk

+0

również jest niewielki zmiana współrzędnych jak pierwsza dostaję 25.3767231, a później 25.3756256, nawet jeśli lokalizacja urządzenia nie zostanie zmieniona również po uzyskaniu 2 aktualizacji opóźnienie rośnie – blackHawk

+0

@blackHawk Dla pierwszego komentarza możesz ustawić mniejszy interwał czasowy i użyć 'setSmallestDisplacement () 'metoda na żądanie LocationRequest: https://developers.google.com/android/reference/com/google/android/gms/location/LocationRequest.html # setSmallestDisplacement (float) –

2
mLocationCallback = new LocationCallback() { 
     @Override 
     public void onLocationResult(LocationResult locationResult) { 
      super.onLocationResult(locationResult); 
      currentLocation = locationResult.getLastLocation(); 

     } 
    }; 

to praca dla mnie.

0

Dla uproszczenia spróbuj z tą biblioteką https://github.com/mrmans0n/smart-location-lib. Będzie korzystać z Fused Location Provider.

Wystarczy umieścić ten kod

SmartLocation.with(context).location(new LocationBasedOnActivityProvider(callback)) 
    .start(new OnLocationUpdatedListener() { ... });