按部分电话号码显示联系人姓名

时间:2012-01-15 21:22:52

标签: android android-contacts phone-number

我有一个函数,它接受一个数字并将其搜索到手机联系人中,但之后会返回联系人姓名。

public String[] getContactDisplayNameByNumber(String number) {
        Uri uri = Uri.withAppendedPath(ContactsContract.PhoneLookup.CONTENT_FILTER_URI, Uri.encode(number));
        String name = "?";
        String[] nameStr = {};

        ContentResolver contentResolver = getContentResolver();
        Cursor contactLookup = contentResolver.query(uri, new String[] {BaseColumns._ID,ContactsContract.PhoneLookup.DISPLAY_NAME }, null, null, null);

        try {
            while (contactLookup != null && contactLookup.getCount() != 0 && !contactLookup.isLast()) {
                contactLookup.moveToNext();
                nameStr = insertElement(nameStr,contactLookup.getString(contactLookup.getColumnIndex(ContactsContract.Data.DISPLAY_NAME)));
                //String contactId = contactLookup.getString(contactLookup.getColumnIndex(BaseColumns._ID));
            }
        } finally {
            if (contactLookup != null) {
                contactLookup.close();
            }
        }

        return nameStr;
    }

我需要修改哪些内容才能搜索数字的一部分? 如果号码是:0729587347,我想搜索0729。 如果有很多联系人从这个号码开始,我想要全部(这就像MYSQL%变量%search ...)! 怎么办? 谢谢!

1 个答案:

答案 0 :(得分:0)

ContentResolver.query(...)可以使用WHERE子句参数。

具体来说,请使用以下内容:

Cursor c = getContentResolver().query(Data.CONTENT_URI,
      new String[] {Data._ID, Phone.NUMBER, Phone.TYPE, Phone.LABEL},
      Phone.NUMBER + " like ?",
      new String[] {"%"+String.valueOf(userInput) +"%"}, null);

有关更多示例,请参阅ContactsContract.Data javadoc。

此外,这类似于previous question