В FCM пытается узнать широту и долготу человека, где бы он / она не получали уведомление ему / ей в андроиде
Я использую FCM и тоже получаю уведомление, пытаясь узнать широту и долготу человека, где бы он или она ни получали уведомление, не входя в приложение в Android, но получая 0.0 по широте и долготе.
Я ничего не сделал в MainActivity, потому что получить местоположение в фоновом режиме и отправить его на сервер
Ниже приведен мой код MyFirebaseMessagingService:
public class MyFirebaseMessagingService extends FirebaseMessagingService implements PowerConnectionReciever.BatteryCallback
{
LocationTrack locationTrack;
private double longitude,latitude;
Context context=this;
IntentFilter intentfilter;
private PowerConnectionReciever powerConnectionReciever=new
PowerConnectionReciever();
private String batterystatus;
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
// ...
Log.wtf(TAG, "From: " + remoteMessage.getFrom());
// Check if message contains a data payload.
if (remoteMessage.getData().size() > 0) {
Log.wtf(TAG, "Message data payload: " + remoteMessage.getData());
if (/* Check if data needs to be processed by long-running job */ true) {
// For long-running tasks (10 seconds or more) use Firebase Job Dispatcher.
// scheduleJob();
} else {
// Handle message within 10 seconds
// handleNow();
}
}
// Check if message contains a notification payload.
if (remoteMessage.getNotification() != null) {
Log.wtf(TAG, "Message Notification Body: " +
remoteMessage.getNotification().getBody());
Log.wtf("Status","Message arrived");
intentfilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
locationTrack = new LocationTrack(context);
if (locationTrack.canGetLocation()) {
longitude = locationTrack.getLongitude();
latitude = locationTrack.getLatitude();
context.registerReceiver(powerConnectionReciever, intentfilter);
Toast.makeText(this, "Locatin"+latitude+","+locationTrack, Toast.LENGTH_SHORT).show();
} else {
locationTrack.showSettingsAlert();
}
}
// Also if you intend on generating your own notifications as a result of a received FCM
// message, here is where that should be initiated. See sendNotification method below.
}
@Override
public void batteryInfo(boolean isCharging, boolean status, int percent) {
Toast.makeText(getApplicationContext(), "Longitude:" + Double.toString(longitude) + "\nLatitude:" + Double.toString(latitude) + "\nBattery status:" + percent+"%", Toast.LENGTH_SHORT).show();
batterystatus = "isCharging: " + isCharging + "\n" + "\n" +
"isCharged:" + status + "\n" + "\n" +
"Percent: " + percent + "\n";
Log.wtf("BStatus", batterystatus);
}
}
Код класса LocationTrack:
public class LocationTrack extends Service implements LocationListener {
private final Context mContext;
boolean checkGPS = false;
boolean checkNetwork = false;
boolean canGetLocation = false;
Location loc;
double latitude;
double longitude;
private static final long MIN_DISTANCE_CHANGE_FOR_UPDATES = 10;
private static final long MIN_TIME_BW_UPDATES = 1000 * 60 * 1;
protected LocationManager locationManager;
public LocationTrack(Context mContext) {
this.mContext = mContext;
getLocation(mContext);
}
private Location getLocation(Context mContext) {
try {
locationManager = (LocationManager) mContext
.getSystemService(LOCATION_SERVICE);
// get GPS status
checkGPS = locationManager
.isProviderEnabled(LocationManager.GPS_PROVIDER);
// get network provider status
checkNetwork = locationManager
.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
if (!checkGPS && !checkNetwork) {
Toast.makeText(mContext, "No Service Provider is available", Toast.LENGTH_SHORT).show();
} else {
this.canGetLocation = true;
// if GPS Enabled get lat/long using GPS Services
if (checkGPS) {
if (ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
// TODO: Consider calling
// ActivityCompat#requestPermissions
// here to request the missing permissions, and then overriding
// public void onRequestPermissionsResult(int requestCode, String[] permissions,
// int[] grantResults)
// to handle the case where the user grants the permission. See the documentation
// for ActivityCompat#requestPermissions for more details.
}
locationManager.requestLocationUpdates(
LocationManager.GPS_PROVIDER,
MIN_TIME_BW_UPDATES,
MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
if (locationManager != null) {
loc = locationManager
.getLastKnownLocation(LocationManager.GPS_PROVIDER);
if (loc != null) {
latitude = loc.getLatitude();
longitude = loc.getLongitude();
}
}
}
if (checkNetwork) {
if (ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
// TODO: Consider calling
// ActivityCompat#requestPermissions
// here to request the missing permissions, and then overriding
// public void onRequestPermissionsResult(int requestCode, String[] permissions,
// int[] grantResults)
// to handle the case where the user grants the permission. See the documentation
// for ActivityCompat#requestPermissions for more details.
}
locationManager.requestLocationUpdates(
LocationManager.NETWORK_PROVIDER,
MIN_TIME_BW_UPDATES,
MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
if (locationManager != null) {
loc = locationManager
.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
}
if (loc != null) {
latitude = loc.getLatitude();
longitude = loc.getLongitude();
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return loc;
}
public double getLongitude() {
if (loc != null) {
longitude = loc.getLongitude();
}
return longitude;
}
public double getLatitude() {
if (loc != null) {
latitude = loc.getLatitude();
}
return latitude;
}
public boolean canGetLocation() {
return this.canGetLocation;
}
public void showSettingsAlert() {
AlertDialog.Builder alertDialog = new AlertDialog.Builder(mContext);
alertDialog.setTitle("GPS is not Enabled!");
alertDialog.setMessage("Do you want to turn on GPS?");
alertDialog.setPositiveButton("Yes", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
mContext.startActivity(intent);
}
});
alertDialog.setNegativeButton("No", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.cancel();
}
});
alertDialog.show();
}
public void stopListener() {
if (locationManager != null) {
if (ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
// TODO: Consider calling
// ActivityCompat#requestPermissions
// here to request the missing permissions, and then overriding
// public void onRequestPermissionsResult(int requestCode, String[] permissions,
// int[] grantResults)
// to handle the case where the user grants the permission. See the documentation
// for ActivityCompat#requestPermissions for more details.
return;
}
locationManager.removeUpdates(LocationTrack.this);
}
}
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onLocationChanged(Location location) {
}
@Override
public void onStatusChanged(String s, int i, Bundle bundle) {
}
@Override
public void onProviderEnabled(String s) {
}
@Override
public void onProviderDisabled(String s) {
}
}
1 ответ
Причина, по которой вы не получаете длинную широту, когда приложение находится в фоновом режиме:
- >> Вы отправляете сообщение с консоли Firebase
- >> Сообщение содержит полезную нагрузку уведомления.
- >> Если приложение находится в фоновом режиме, уведомление FCM отображается в области уведомлений, но onMessageReceived()
не вызывается и никогда не извлекает LocationTrack
,
- >> Результаты в 0.0
Решение состоит в том, чтобы отправлять только данные с сообщениями FCM с сервера, поскольку вы не можете отправить сообщение только с данными из консоли Firebase. В таком случае onMessageReceived()
будет вызываться, даже если приложение находится в фоновом режиме.
Если вы хотите отправить данные только для определенного идентификатора устройства, отправьте JSON как:
{
"message":
{
"token":"yourDeviceToken",
"data":
{
"keyFoo":"valueBar"
},
"android":
{
"priority":"high"
"ttl":"3600s"
}
}
}