web-dev-qa-db-ja.com

私のAndroidプログラムで連絡先にアクセスする方法

テキストメッセージアプリケーションを作成していて、Androidアプリケーションの連絡先にアクセスしたい。

実際の連絡先リストのどこにあるかのように連絡先にアクセスしたい。選択したら、SMSをその人に送信できるアクティビティに戻る必要があります。または、連絡先が保存されているデータベースにアクセスすることはできますか?

私のコードを以下に示します。

String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
String name = cursor.getString(cursor.getColumnIndexOrThrow(ContactsContract.Contacts.DISPLAY_NAME)); 
String no = cursor.getString(cursor.getColumnIndexOrThrow(ContactsContract.CommonDataKinds.Phone.NUMBER));

私のLogCatは次のようになります。

09-07 12:46:15.458: DEBUG/AndroidRuntime(473): Shutting down VM
09-07 12:46:15.458: WARN/dalvikvm(473): threadid=1: thread exiting with uncaught exception (group=0x40015560)
09-07 12:46:15.478: ERROR/AndroidRuntime(473): FATAL EXCEPTION: main
09-07 12:46:15.478: ERROR/AndroidRuntime(473): Java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=0, result=-1, data=Intent { dat=content://com.Android.contacts/contacts/lookup/0r1-512D3F3D533B/1 flg=0x1 (has extras) }} to activity {task.list/task.list.Msgactivity}: Java.lang.IllegalArgumentException: column 'data1' does not exist
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread.deliverResults(ActivityThread.Java:2532)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread.handleSendResult(ActivityThread.Java:2574)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread.access$2000(ActivityThread.Java:117)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:961)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.os.Handler.dispatchMessage(Handler.Java:99)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.os.Looper.loop(Looper.Java:123)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread.main(ActivityThread.Java:3683)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Java.lang.reflect.Method.invokeNative(Native Method)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Java.lang.reflect.Method.invoke(Method.Java:507)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:839)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:597)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at dalvik.system.NativeStart.main(Native Method)
09-07 12:46:15.478: ERROR/AndroidRuntime(473): Caused by: Java.lang.IllegalArgumentException: column 'data1' does not exist
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.Java:314)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.Java:99)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at task.list.Msgactivity.onActivityResult(Msgactivity.Java:99)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.Activity.dispatchActivityResult(Activity.Java:3908)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     at Android.app.ActivityThread.deliverResults(ActivityThread.Java:2528)
09-07 12:46:15.478: ERROR/AndroidRuntime(473):     ... 11 more
09-07 12:46:15.489: WARN/ActivityManager(61):   Force finishing activity task.list/.Msgactivity

誰か助けてもらえますか?

8
sajith

このコードを使用して連絡先を選択します。

 Button button = (Button)findViewById(R.id.pickcontact);

    button.setOnClickListener(new OnClickListener() 
        {
            @Override
            public void onClick(View v) 
            {
                 Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI);
                 startActivityForResult(intent, PICK_CONTACT);
             }
         });



    @Override public void onActivityResult(int reqCode, int resultCode, Intent data){ super.onActivityResult(reqCode, resultCode, data);

    switch(reqCode)
    {
       case (PICK_CONTACT):
         if (resultCode == Activity.RESULT_OK)
         {
             Uri contactData = data.getData();
             Cursor c = managedQuery(contactData, null, null, null, null);
          if (c.moveToFirst())
          {
          String id = c.getString(c.getColumnIndexOrThrow(ContactsContract.Contacts._ID));

          String hasPhone =
          c.getString(c.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER));

          if (hasPhone.equalsIgnoreCase("1")) 
          {
         Cursor phones = getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,null, 
          ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ id,null, null);
            phones.moveToFirst();
            String cNumber = phones.getString(phones.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
           // Toast.makeText(getApplicationContext(), cNumber, Toast.LENGTH_SHORT).show();
            setCn(cNumber);
          }
         }
       }
    }
   }
14
swan
9
Vineet Shukla

このコードを試してください。これにより、すべての連絡先がArrayListに保存されます

ArrayList<HashMap<String,String>> contactData=new ArrayList<HashMap<String,String>>();
ContentResolver cr = getContentResolver();
 Cursor cursor = getContentResolver().query(ContactsContract.Contacts.CONTENT_URI,null, null, null, null);
 while (cursor.moveToNext()) {
     try{
     String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID)); 
     String name=cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
     String hasPhone = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER)); 
     if (Integer.parseInt(cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))) > 0) {
         Cursor phones = getContentResolver().query( ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId, null, null);
         while (phones.moveToNext()) { 
             String phoneNumber = phones.getString(phones.getColumnIndex( ContactsContract.CommonDataKinds.Phone.NUMBER));
             HashMap<String,String> map=new HashMap<String,String>();
             map.put("name", name);
             map.put("number", phoneNumber);
             contactData.add(map);
         } 
         phones.close(); 
     }
 }catch(Exception e){}
 }

特定の連絡先を保存する場合は、if条件を使用します。

2
Balaji.K

@ Balaji.Kの例を、いくつかの変更を加えて使用することができました。私が遭遇した主な問題はそれです

while (cursor.moveToNext()) {

最初の結果をスキップします。

また、「モバイル」としてマークされているものがない場合にユーザーが選択できる電話番号のリストを作成したいと思いました。検索する名前も渡します(この例では変数を置き換えます)が、「selection」と「selection_args」をnullに置き換え、「contacts」のすべてを繰り返し処理することで、このコードを変更してコレクションを構築できます。 「電話」。これが私が(Kotlinで)最終的に得たものです:

val selection = "lower(${ContactsContract.Contacts.DISPLAY_NAME_PRIMARY}) LIKE ?"
val selectionArgs = arrayOf("<SEARCH_TERM>")
selectionArgs[0] = "%<SEARCH_TERM>%"

// Query contacts for someone with a matching name
val contacts = contentResolver.query(ContactsContract.Contacts.CONTENT_URI,
        null, selection, selectionArgs, null)
contacts!!.moveToFirst()
if (contacts.count > 1) {
    // TODO: Disambiguate and move to the correct position
}
val contactId = contacts.getString(contacts.getColumnIndex(
        ContactsContract.Contacts._ID))

// Check if contact has at least one phone number
if (contacts.getString(contacts.getColumnIndex(
                ContactsContract.CommonDataKinds.Phone.HAS_PHONE_NUMBER)) == "1") {

    val sel = "${ContactsContract.CommonDataKinds.Email.CONTACT_ID} = ?"
    val selArgs = arrayOf(name)
    val sort = "${ContactsContract.CommonDataKinds.Email.LAST_TIME_CONTACTED} DESC"
    selArgs[0] = contactId

    val phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, sel, selArgs, sort)
    phones!!.moveToFirst()

    // Iterate through phone numbers if multiple
    if (phones.count > 1) {
        val phoneNumbers = mutableMapOf<Int, ContactData>()
        var loop = true
        var mobileIndex: Int? = null
        while (loop) {
            val phoneType = phones.getInt(phones.getColumnIndex(ContactsContract.CommonDataKinds.Phone.TYPE))
            val phoneName = ContactsContract.CommonDataKinds.Phone.getTypeLabel(resources, phoneType, null).toString()
            phoneNumbers[phones.position] = ContactData(phoneName, phones.getString(phones.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER)))
            // Remember what position the mobile number was in
            if (phoneType == ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE) {
                mobileIndex = phones.position
            }
            loop = phones.moveToNext()
        }
        phones.moveToPosition(mobileIndex)
    }
}
0
Daniel McKnight