как объединить DISPLAY_NAME и NUMBER в настроенном адаптере Cursor? - PullRequest
4 голосов
/ 05 декабря 2010

Я хочу загрузить все имена и телефонные номера моих контактов в адаптер AutoCompleteTextView. Как я могу этого достичь? например, когда я наберу «G», в его раскрывающемся списке будет показано «Хорошо, <111111>», «Хорошо, <222222>».

с помощью демоверсии API, я могу только поместить DISPLAY_NAME в курсор результата. Я не знаю, как объединить имена и цифры в один курсор. Спасибо!

коды из демоверсии API:

ContentResolver content = getContentResolver();
Cursor cursor = content.query(ContactsContract.Contacts.CONTENT_URI,  
    PEOPLE_PROJECTION, null, null, null);
ContactListAdapter adapter = new ContactListAdapter(this, cursor);
mAutoCompleteTextView.setAdapter(adapter);

private static class ContactListAdapter extends CursorAdapter implements Filterable {  
    private ContentResolver mCR;

    public ContactListAdapter(Context context, Cursor c) {  
        super(context, c);  
        mCR = context.getContentResolver();  
    }  

    @Override
    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        final LayoutInflater inflater = LayoutInflater.from(context);
        final TextView view = (TextView) inflater.inflate(
                android.R.layout.simple_dropdown_item_1line, parent, false);
        view.setText(cursor.getString(1));
        return view;
    }

    @Override
    public void bindView(View view, Context context, Cursor cursor) {  
        ((TextView) view).setText(cursor.getString(1));
    }

    @Override
    public String convertToString(Cursor cursor) {  
        return cursor.getString(1);
    }

    @Override
    public Cursor runQueryOnBackgroundThread(CharSequence constraint) {
        if (getFilterQueryProvider() != null) {
            return getFilterQueryProvider().runQuery(constraint);
        }
        StringBuilder buffer = null;
        String[] args = null;
        if (constraint != null) {
            buffer = new StringBuilder();
            buffer.append("UPPER(");
            buffer.append(ContactsContract.Contacts.DISPLAY_NAME);
            buffer.append(") GLOB ?");
            args = new String[] { constraint.toString().toUpperCase() + "*" };
        }
        return mCR.query(ContactsContract.Contacts.CONTENT_URI, PEOPLE_PROJECTION,
                buffer == null ? null : buffer.toString(), args, null);
    }
}

private static final String[] PEOPLE_PROJECTION = new String[] {  
    ContactsContract.Contacts._ID,
    ContactsContract.Contacts.DISPLAY_NAME,
    ContactsContract.Contacts.HAS_PHONE_NUMBER
};

1 Ответ

0 голосов
/ 18 февраля 2011

Числа уже должны быть частью курсора. Получить их так.

final long phoneNumber;// = c.getColumnIndex(People.NUMBER_KEY);
        if(Integer.parseInt(cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))) > 0){
            id = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
            int nameColumn = cursor.getColumnIndex(People.NAME);
            int numberKeyColumn = cursor.getColumnIndex(People.NUMBER_KEY);             
            phoneNumber = this.getPhoneNumbers(id); }           

Тогда метод getPhoneNumbers в том же классе, к несчастью, должен повторить итерацию. Не уверен, что есть лучший способ сделать это, привязав курсор (в новом API), но он работает.

        public Long getPhoneNumbers(String id) {
        Long number = new Long(0);
        ContentResolver cr = this.context.getContentResolver();
        Cursor pCur = cr.query(
                ContactsContract.CommonDataKinds.Phone.CONTENT_URI, 
                null, 
                ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = ?", 
                new String[]{id}, null);
        pCur.moveToFirst();
        if (pCur.getCount() > 0){
            String num = pCur.getString(pCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
            num = num.replaceAll("-", "");
            number = Long.parseLong(num);
        }
        pCur.close();
        return number;
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...