Отображать имена контактов по части номера телефона - PullRequest
1 голос
/ 16 января 2012

У меня есть функция, которая берет число и ищет его в контактах телефона, но после этого возвращает имя контакта.

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% variable% search ...)!Что делать?Спасибо!

1 Ответ

0 голосов
/ 17 января 2012

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.

Кроме того, это похоже на предыдущий вопрос .

...