Привет! Я использую FusedLocationClient для получения местоположения от пользователя. Это работает. Я могу периодически получать широту и долготу, но иногда расстояние, показывающее неправильное значение, например, может быть от 10,0 до 200,0 в секундах, а затем возвращаться к10,0.Я хотел бы показать пользователю, что он находится в 200 метрах от магазина.но даже если они всего в 10 метрах, приложение иногда показывает, что они в 200 метрах от магазина.
Могу ли я что-нибудь сделать, чтобы улучшить точность определения местоположения Клиента.
class LocServices : Service() {
private val TAG = ""
private val UPDATE_INTERVAL_IN_MILLISECONDS: Long = 5000
private val FASTEST_UPDATE_INTERVAL_IN_MILLISECONDS = UPDATE_INTERVAL_IN_MILLISECONDS / 2
private var mLocationRequest: LocationRequest? = null
private var mFusedLocationClient: FusedLocationProviderClient? = null
private var mLocationCallback: LocationCallback? = null
private var mLocation: Location? = null
var existLongitude: String? = null
var existLatitude: String? = null
var sharedPrefs: SharedPreferences? = null
override fun onCreate() {
mFusedLocationClient = LocationServices.getFusedLocationProviderClient(this)
mLocationCallback = object : LocationCallback() {
override fun onLocationResult(locationResult: LocationResult?) {
super.onLocationResult(locationResult)
onNewLocation(locationResult!!.lastLocation)
}
}
createLocationRequest()
getLastLocation()
requestLocationUpdates()
}
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
Log.i(TAG, "Service started")
return Service.START_STICKY
}
override fun onBind(intent: Intent): IBinder? {
return null
}
private fun requestLocationUpdates() {
sharedPrefs = this.getSharedPreferences("GEO", Context.MODE_PRIVATE)
if (sharedPrefs != null) {
existLatitude = sharedPrefs!!.getString("LAT", null)
existLongitude = sharedPrefs!!.getString("LONG", null)
}
if (existLatitude != null && existLongitude != null) {
Log.i(TAG, "Requesting location updates")
setRequestingLocationUpdates(this, true)
try {
mFusedLocationClient!!.requestLocationUpdates(mLocationRequest, mLocationCallback!!, Looper.myLooper())
} catch (unlikely: SecurityException) {
setRequestingLocationUpdates(this, false)
Log.e(TAG, "Lost location permission. Could not request updates. $unlikely")
}
}
}
private fun getLastLocation() {
try {
mFusedLocationClient!!.lastLocation
.addOnCompleteListener { task ->
if (task.isSuccessful && task.result != null) {
mLocation = task.result
} else {
Log.w(TAG, "Failed to get location.")
}
}
} catch (unlikely: SecurityException) {
Log.e(TAG, "Lost location permission.$unlikely")
}
}
private fun onNewLocation(location: Location) {
Log.i(TAG, "New location: $location")
mLocation = location
if (existLatitude != null && existLongitude != null) {
val selected_location = Location("locationA")
selected_location.latitude = existLatitude!!.toDouble()
selected_location.longitude = existLongitude!!.toDouble()
val near_locations = Location("locationB")
near_locations.latitude = mLocation!!.latitude
near_locations.longitude = mLocation!!.longitude
val distance = selected_location.distanceTo(near_locations)
Toast.makeText(this, distance.toString(), Toast.LENGTH_SHORT).show()
if (distance > 53.0) {
Toast.makeText(this, "You are outside $distance", Toast.LENGTH_SHORT).show()
}
}
}
private fun createLocationRequest() {
mLocationRequest = LocationRequest()
mLocationRequest!!.interval = UPDATE_INTERVAL_IN_MILLISECONDS
mLocationRequest!!.fastestInterval = FASTEST_UPDATE_INTERVAL_IN_MILLISECONDS
mLocationRequest!!.priority = LocationRequest.PRIORITY_HIGH_ACCURACY
}
companion object {
val KEY_REQUESTING_LOCATION_UPDATES = "requesting_locaction_updates"
fun setRequestingLocationUpdates(context: Context, requestingLocationUpdates: Boolean) {
PreferenceManager.getDefaultSharedPreferences(context)
.edit()
.putBoolean(KEY_REQUESTING_LOCATION_UPDATES, requestingLocationUpdates)
.apply()
}
}
}