Android ContactsContract:上次修改时间

时间:2015-02-06 08:11:33

标签: android android-contacts last-modified

我想将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)

1 个答案:

答案 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);