Я реализовал адаптер синхронизации, и я хочу получить обратный вызов, когда он закончит в моей деятельности. Я пробовал использовать ContentResolver.addStatusChangeListener
, но я получаю только обратные вызовы, когда синхронизация находится в ожидании/активна. Вот какой-то соответствующий код из моей деятельности:
@Override
protected void onResume() {
super.onResume();
final int mask = ContentResolver.SYNC_OBSERVER_TYPE_ACTIVE | ContentResolver.SYNC_OBSERVER_TYPE_PENDING;
syncObserverHandle = ContentResolver.addStatusChangeListener(mask, syncStatusObserver);
}
@Override
protected void onPause() {
super.onPause();
if (syncObserverHandle != null) {
ContentResolver.removeStatusChangeListener(syncObserverHandle);
syncObserverHandle = null;
}
}
private SyncStatusObserver syncStatusObserver = new SyncStatusObserver() {
@Override
public void onStatusChanged(int which) {
AccountManager am = AccountManager.get(TodosActivity.this);
Account a = am.getAccountsByType(Const.ACCOUNT_TYPE)[0];
Log.d(Const.TAG, "Sync status changed: " + which);
if (!ContentResolver.isSyncActive(a, DataProvider.AUTHORITY) &&
!ContentResolver.isSyncPending(a, DataProvider.AUTHORITY)) {
Log.d(Const.TAG, "Sync finished, should refresh nao!!");
}
}
};
Однако if
в методе onStatusChanged
никогда не действует. Я привел этот пример из JumpNote demo, где он работает, вероятно, потому, что он также называется вручную в onResume()
, поэтому он, вероятно, никогда не назывался системой, когда синхронизация завершена. Или это, и я делаю что-то неправильно? Вот что я получаю в logcat:
D/MYAPP (10903): Sync status changed: 2
D/MYAPP (10903): Sync status changed: 2
D/MYAPP (10903): Sync status changed: 4
D/MYAPP (10981): --> DataSyncAdapter.onPerformSync()
D/MYAPP (10981): <-- DataSyncAdapter.onPerformSync()
D/MYAPP (10903): Sync status changed: 4
Итак, кажется, что я могу полагаться на второе изменение статуса SYNC_OBSERVER_TYPE_ACTIVE
(4), чтобы обновить мои данные, но это кажется действительно уродливым. Любые идеи?