#java #android #android-studio #geolocation #location
Вопрос:
Есть ли способ постоянно обновлять широту и долготу без запуска приложения Google MAPS в фоновом режиме эмуляторов. Я хотел бы получать обновленные широту и долготу с устройства пользователя. Код получает широту и долготу только после того, как я переключусь между приложениями или настрою маршрут движения и нажму кнопку. Я хотел бы обновлять каждые X раз.
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import android.Manifest;
import android.annotation.SuppressLint;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationManager;
import android.os.Bundle;
import android.provider.Settings;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import com.google.android.gms.location.FusedLocationProviderClient;
import com.google.android.gms.location.LocationCallback;
import com.google.android.gms.location.LocationRequest;
import com.google.android.gms.location.LocationResu<
import com.google.android.gms.location.LocationServices;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
public class MainActivity extends AppCompatActivity {
Button bt_Location;
TextView tv_nearStopName, tv_nextBusIDtoNearStop;
EditText txtinput_busID;
FusedLocationProviderClient fusedLocationProviderClient;
LocationHelper locationHelper;
User user;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//assign variables
bt_Location = findViewById(R.id.bt_checkIN);
tv_nearStopName = findViewById(R.id.tv_stopName);
tv_nextBusIDtoNearStop = findViewById(R.id.tv_nextBusID);
fusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(MainActivity.this);
txtinput_busID = findViewById(R.id.txtinput_busID);
//if not get location permissions...
if (ActivityCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED
amp;amp; ActivityCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_COARSE_LOCATION) == PackageManager.PERMISSION_GRANTED){
user = new User(0.0,0.0);
getCurrentLocation();
}else {
ActivityCompat.requestPermissions(MainActivity.this, new String[] {Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.ACCESS_COARSE_LOCATION}, 1000);
}
bt_Location.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
getCurrentLocation()
}
});
}//end onCreate
@Override
protected void onStart() {
super.onStart();
if (ActivityCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED
amp;amp; ActivityCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_COARSE_LOCATION) == PackageManager.PERMISSION_GRANTED){
getCurrentLocation();
}else {
ActivityCompat.requestPermissions(MainActivity.this, new String[] {Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.ACCESS_COARSE_LOCATION}, 1000);
}
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (requestCode == 100 amp;amp; grantResults.length > 0 amp;amp; (grantResults[0] grantResults[1] == PackageManager.PERMISSION_GRANTED)) {
getCurrentLocation();
} else {
Toast.makeText(getApplicationContext(), "Permission denied.", Toast.LENGTH_SHORT).show();
}
}
@SuppressLint("MissingPermission")
private void getCurrentLocation() {
LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
if (locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER) || locationManager.isProviderEnabled(LocationManager.NETWORK_PROVIDER)){
fusedLocationProviderClient.getLastLocation().addOnCompleteListener(new OnCompleteListener<Location>() {
@Override
public void onComplete(@NonNull Task<Location> task) {
Location location = task.getResult();
//check condition
if (location != null){
//initialize user object
user.setLongitude(location.getLongitude());
user.setLatitude(location.getLatitude());
tv_nextBusIDtoNearStop.setText(String.valueOf(user.getLongitude()));
}else {
LocationRequest locationRequest = new LocationRequest().setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY).setInterval(1000).setFastestInterval(100).setNumUpdates(1);
LocationCallback locationCallback = new LocationCallback() {
@Override
public void onLocationResult(LocationResult locationResult) {
Log.d("DEBUGGING: ", "onLocationResult executing....");
Location location1 = locationResult.getLastLocation();
user.setLatitude(location1.getLatitude());
user.setLongitude(location1.getLongitude());
// tvLatitude.setText(String.valueOf(user.getLatitude()));
tv_nextBusIDtoNearStop.setText(String.valueOf(user.getLongitude()));
}
};
locationReqeuest, locaitoncallback, Looper.MyLooper()
fusedLocationProviderClient.removeLocationUpdates(locationCallback);
}
}
});
}else {
startActivity(new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS).setFlags(Intent.FLAG_ACTIVITY_NEW_TASK));
}
}//end getCurrentLocation
}
Комментарии:
1.
in emulators background.
Иfrom the users device.
? Непонятно, чего ты хочешь и где.2. Игнорируя часть «эмулятор», вы должны запросить обновления местоположения, если хотите постоянно обновлять местоположение.
getLastLocation()
Просто возвращает то, что является последним известным местоположением, и никоим образом не запускает процесс обновления данных о местоположении. Карты Google, работающие в фоновом режиме, запрашивают обновления местоположения, что делает «последнее известное местоположение» чем-то значимым.