#android #indexoutofboundsexception
#Android #исключение indexoutofboundsexception
Вопрос:
Я пытаюсь получить имя и тип контактов, сохраненных в телефоне, но получаю это исключение. Я получал имена раньше, но получал исключение
android.database.Исключение CursorIndexOutOfBoundsException: запрашиваемый индекс -1 размером 10
при попытке получить имя и тип вместе. Пожалуйста, помогите. Заранее спасибо.
package application.test;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.provider.ContactsContract.CommonDataKinds.Phone;
import android.provider.ContactsContract.Contacts;
import android.util.Log;
public class TestActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
String[] projection = new String[] {ContactsContract.Contacts.DISPLAY_NAME};
String[] projection1=new String[]{Phone.TYPE};
String[] projection2=new String[]{ContactsContract.Contacts._ID};
ContentResolver cr = getContentResolver();
ContentResolver ncr=getContentResolver();
ContentResolver icr=getContentResolver();
Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI, projection,null, null, Contacts.DISPLAY_NAME " ASC");
Cursor ncur=ncr.query(ContactsContract.Data.CONTENT_URI, projection1, null, null,null);
Cursor icur = icr.query(ContactsContract.RawContacts.CONTENT_URI, projection2,null, null, Contacts._ID " ASC");
if (cur.getCount() >0 amp;amp; ncur.getCount()>0 amp;amp; icur.getCount()>0)
{
while (cur.moveToNext()amp;amp; ncur.moveToNext()amp;amp; icur.getCount()>0)
{
String id = icur.getString(cur.getColumnIndex(ContactsContract.Contacts._ID));
String name = cur.getString(cur.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
String type=ncur.getString(ncur.getColumnIndex(Phone.TYPE));
if (Integer.parseInt(cur.getString(cur.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))) > 0)
{
Cursor pCur = cr.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID " = ?",new String[]{id}, null);
Cursor typecur = ncr.query( ContactsContract.CommonDataKinds.Phone.CONTENT_URI,null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID " = ?", new String[]{id}, null)
while (pCur.moveToNext()amp;amp; typecur.moveToNext())
{
Log.d("names",name);
Log.d("types",type);
pCur.close();
}
}
}
}
}
}
Комментарии:
1. почему вы создаете три отдельных курсора?
2. потому что используются три разные проекции. Я пытаюсь использовать один, но получаю ошибку во время компиляции.
Ответ №1:
Когда вы создаете курсор перед его чтением. Переместите положение курсора на первое.
while (cur.moveToNext()amp;amp; ncur.moveToNext()amp;amp; icur.getCount()>0)
/* move icur to first position then read */
icur.moveFirst()
Это должно сработать
Комментарии:
1. cur.moveToNext() сделает это за вас, он будет действовать как cur.moveToFirst().
Ответ №2:
Вам не следует создавать три разных курсора и contextresolver, используйте один и тот же, но создайте условия в цикле, чтобы получить то, что вы хотите, я дам вам метод, который я написал сам. Это даст вам все контакты в вашем телефоне, у которых есть номер телефона, вы поймете, как реализовать свой:
public ArrayList<Contact> getSMSContacts(Context context){
ArrayList<Contact> contacts = new ArrayList<Contact>();
ContentResolver cr = context.getContentResolver();
Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI, null, null, null, ContactsContract.Contacts.DISPLAY_NAME " asc");
if (cur.getCount() > 0) {
while (cur.moveToNext()) {
String id = cur.getString(cur.getColumnIndex(ContactsContract.Contacts._ID));
String name = cur.getString(cur.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
if (Integer.parseInt(cur.getString(cur.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))) > 0) {
Contact c = new Contact();
c.setId(Integer.parseInt(id));
c.setName(name);
Cursor pCur = cr.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
null, ContactsContract.CommonDataKinds.Phone.CONTACT_ID " = ?",
new String[]{id}, null);
while (pCur.moveToNext()) {
String number = pCur.getString(
pCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
c.setNumber(number);
}
pCur.close();
contacts.add(c);
}
}
}
cur.close();
return contacts;
}
Комментарии:
1. здесь вы получаете только контакты, которые сохраняются в столбце contacts. Для типа это выглядит как Cursor ncur=ncr.query(ContactsContract.Data. CONTENT_URI, projection1, null, нуль, null); поскольку типы оцениваются в столбце данных. так же, как contact_id получает хранилище в столбце rawcontactid. кроме того, я получал исключение runtimeexception, используя один объект cursor и передавая ему проекцию.
2. Как я уже говорил вам, вы поймете идею, посмотрев мою реализацию, и, кстати, она отлично работает! Что вы подразумеваете под типом? Что вам нужно, кроме имени контактов.
3. Тип строки = pCur.getString(pCur.getColumnIndex(ContactsContract. Общие ссылки. Телефон. ВВЕДИТЕ));
Ответ №3:
После нескольких дней поиска я наконец получил ответы .. тип и имя сохраняются в таблице данных в столбце DATA2, поэтому я запросил data.content_uri и получил индекс столбца DATA2, и он просто отлично работает…Я получаю как имя, так и тип.