Created
January 22, 2019 14:43
-
-
Save nadar71/01ad3dea73f743468d3f94e7af9df479 to your computer and use it in GitHub Desktop.
Map use location with marker activity, one with deprecated FusedLocationApi, the other updated.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
public class MapLocationActivity extends AppCompatActivity | |
implements OnMapReadyCallback, | |
GoogleApiClient.ConnectionCallbacks, | |
GoogleApiClient.OnConnectionFailedListener, | |
LocationListener { | |
GoogleMap mGoogleMap; | |
SupportMapFragment mapFrag; | |
LocationRequest mLocationRequest; | |
GoogleApiClient mGoogleApiClient; | |
Location mLastLocation; | |
Marker mCurrLocationMarker; | |
@Override | |
protected void onCreate(Bundle savedInstanceState) | |
{ | |
super.onCreate(savedInstanceState); | |
setContentView(R.layout.activity_main); | |
getSupportActionBar().setTitle("Map Location Activity"); | |
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 (mGoogleApiClient != null) { | |
LocationServices.FusedLocationApi.removeLocationUpdates(mGoogleApiClient, this); | |
} | |
} | |
@Override | |
public void onMapReady(GoogleMap googleMap) | |
{ | |
mGoogleMap=googleMap; | |
mGoogleMap.setMapType(GoogleMap.MAP_TYPE_HYBRID); | |
//Initialize Google Play Services | |
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 | |
buildGoogleApiClient(); | |
mGoogleMap.setMyLocationEnabled(true); | |
} else { | |
//Request Location Permission | |
checkLocationPermission(); | |
} | |
} | |
else { | |
buildGoogleApiClient(); | |
mGoogleMap.setMyLocationEnabled(true); | |
} | |
} | |
protected synchronized void buildGoogleApiClient() { | |
mGoogleApiClient = new GoogleApiClient.Builder(this) | |
.addConnectionCallbacks(this) | |
.addOnConnectionFailedListener(this) | |
.addApi(LocationServices.API) | |
.build(); | |
mGoogleApiClient.connect(); | |
} | |
@Override | |
public void onConnected(Bundle bundle) { | |
mLocationRequest = new LocationRequest(); | |
mLocationRequest.setInterval(1000); | |
mLocationRequest.setFastestInterval(1000); | |
mLocationRequest.setPriority(LocationRequest.PRIORITY_BALANCED_POWER_ACCURACY); | |
if (ContextCompat.checkSelfPermission(this, | |
Manifest.permission.ACCESS_FINE_LOCATION) | |
== PackageManager.PERMISSION_GRANTED) { | |
LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, mLocationRequest, this); | |
} | |
} | |
@Override | |
public void onConnectionSuspended(int i) {} | |
@Override | |
public void onConnectionFailed(ConnectionResult connectionResult) {} | |
@Override | |
public void onLocationChanged(Location location) | |
{ | |
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(MapLocationActivity.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) { | |
if (mGoogleApiClient == null) { | |
buildGoogleApiClient(); | |
} | |
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 | |
} | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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) { | |
List<Location> locationList = locationResult.getLocations(); | |
if (locationList.size() > 0) { | |
//The last location in the list is the newest | |
Location location = locationList.get(locationList.size() - 1); | |
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 | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment