Я использую службу Android для получения местоположения через API слияния местоположения и API модификации для обновления местоположения в течение определенного промежутка времени.
Все работает нормально, когда приложение открыто / на переднем плане. Но когда приложение находится в фоновом режиме / закрыто, все работает, кроме запроса на модификацию.
Модифицированные обратные вызовы получают ошибку с сообщением «Не удалось подключиться». Когда приложение открывается снова, все работает отлично.
Модификация 2 Обратный вызов onResponse в фоновом потоке или Сервисы всегда onFailure
Любая помощь будет очень ценной. Спасибо
Эта служба запускается с TimeTask:
public class SendLocationService extends IntentService {
private static final String TAG = "SendLocationService";
private Context mContext = null;
private APIInterface apiInterface;
public SendLocationService() {
super("SendLocationService");
}
@Override
protected void onHandleIntent(@Nullable Intent intent) {
mContext = getApplicationContext();
Log.e(TAG, "**************************************");
Log.e(TAG, "Location Update Time Interval");
Log.e(TAG, "**************************************");
Login login = (Login) CommonMethods.retrieveObject(mContext, PreferenceConnector.LOGIN, new Login());
if (login == null)
return;
List<LocationData> locationData = DatabaseHelper.getInstance(mContext).getAllLocation();
Log.i(TAG, "Time to hit the APIs: " + DatabaseHelper.getInstance(mContext).getAllLocation().size());
JSONArray jsonArray = new JSONArray();
List<TrackedLocation> trackedLocations = new ArrayList<TrackedLocation>();
for (LocationData data : locationData) {
try {
jsonArray.put(new JSONObject(data.getData()));
Gson gson = new Gson();
TrackedLocation obj = gson.fromJson(data.getData(), TrackedLocation.class);
trackedLocations.add(obj);
} catch (Exception e) {
e.printStackTrace();
}
}
HashMap<String, Object> hashMap = new HashMap<String, Object>();
hashMap.put("EmpId", login.getMessage().getID());
hashMap.put("MapTrack", trackedLocations);
if (apiInterface == null) {
apiInterface = APIClient.getClientInstance().create(APIInterface.class);
}
apiInterface.postMapTrackingDetails(hashMap).enqueue(new Callback<Message>() {
@Override
public void onResponse(Call<Message> call, Response<Message> response) {
try {
DatabaseHelper.getInstance(mContext).deleteLocationData();
PreferenceConnector.resetLocationCounter(mContext);
response.body();
Log.e("response:", response.body().getMessage());
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public void onFailure(Call<Message> call, Throwable t) {
try {
Log.e("response:", t.getLocalizedMessage());
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
}