我想将Android Contacts Phone克隆到我自己的SQLite数据库中。为了节省时间,应在Android系统中新创建或更新单个联系人时触发克隆。因此,我希望每个联系人都有“最后修改时间”。
对于API级别18或以上,似乎我会通过使用ContactsContract.Contacts.CONTACT_LAST_UPDATED_TIMESTAMP获得单个人联系的最后修改时间。但是对于API级别17或更低级别,似乎之前有一些讨论建议使用“ContactsContract.RawContacts.VERSION”或“CONTACT_STATUS_TIMESTAMP”。
对于“CONTACT_STATUS_TIMESTAMP”,它始终返回ZERO或null。对于“ContactsContract.RawContacts.VERSION”,当我更新一个人的联系人的照片,电话号码或电子邮件时,版本保持不变。
如果有人能指出我所犯的错误,我很高兴......
参考: How to get the last modification date for Contacts list (Add/Delete/Modify)
答案 0 :(得分:4)
使用ContentObserver 更改时,您会收到通知。然后,您需要自己检索正确的联系人。当然,这意味着必须在联系人更改或(更合理地)运行后台服务时打开您的应用程序。
在您的服务中,创建一个内容观察者:
var a1 = ["abc", "abc", "bcd", "efg"];
var a2 = ["bcd", "efg", "abc", "abc"]
var allIndexExist = true;
for (var i = 0; i < a1.length; i++) {
var index = a2.indexOf(a1[i]);
if (index == -1) {
allIndexExist = false;
break;
} else {
a2.splice(index, 1);
}
}
if (a2.length > 0 || !allIndexExist) {
console.log("Array is not equal");
} else {
console.log("Array is equal");
}
您使用dirty的建议并不是一个好的解决方案,因为这只是暂时表明应该更新聚合联系人(所有者),因为RawContact中的某些内容发生了变化。这意味着如果在您的应用程序打开之前联系人已同步,则脏已经为假(0)。
另请注意,the column的文档提到它已在API 18中添加,因此您知道,只需要低于18,您就需要一种解决方法。所以第一步是确保你可以在
时使用该列myObserver = new ContentObserver(new Handler()) {
@Override
public void onChange(boolean selfChange) {
super.onChange(selfChange);
if (!selfChange) {
//Note: when this (older) callback is used you need to loop through
//and find the contact yourself (by using the dirty field)
}
}
@Override
public void onChange(boolean selfChange, Uri uri) {
super.onChange(selfChange, uri);
if (!selfChange) {
//Note: if you receive a uri, it has contact id
long rawContactId = ContentUris.parseId(uri);
//Note: be careful which thread you are on here (dependent on handler)
}
}
};
//NOTE: Then you need to remember to register and unregister the observer.
//getContentResolver().registerContentObserver(ContactsContract.Contacts.CONTENT_URI, true, myObserver);
//getContentResolver().unregisterContentObserver(myObserver);