連絡先ピッカーを呼び出して、人物の名前、電話番号、電子メールを文字列に変換し、インテントを使用して別のアクティビティに送信しようとしています。これまでのところこれは動作します:
Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI);
startActivityForResult(intent, 1);
// ...
@Override
public void onActivityResult(int reqCode, int resultCode, Intent data) {
super.onActivityResult(reqCode, resultCode, data);
if (resultCode == Activity.RESULT_OK) {
Uri contactData = data.getData();
Cursor c = managedQuery(contactData, null, null, null, null);
if (c.moveToFirst()) {
String name = c.getString(c.getColumnIndexOrThrow(ContactsContract.Contacts.DISPLAY_NAME));
Intent intent = new Intent(CurrentActivity.this, NewActivity.class);
intent.putExtra("name", name);
startActivityForResult(intent, 0);
}
}
}
しかし、私が追加する場合:
String number = c.getString(c.getColumnIndexOrThrow(ContactsContract.CommonDataKinds.Phone.NUMBER));
強制的に閉じる
多分彼らの番号を取得する別の方法がありますか?
電話番号
電話番号は独自のテーブルに格納されており、個別に照会する必要があります。電話番号テーブルを照会するには、SDK変数ContactsContract.CommonDataKinds.Phone.CONTENT_URIに格納されているURIを使用します。 WHERE条件を使用して、指定した連絡先の電話番号を取得します。
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);
while (pCur.moveToNext()) {
// Do something with phones
}
pCur.close();
}
Android contacts SQLiteデータベースに対して2番目のクエリを実行します。電話番号は、ContactsContract.CommonDataKinds.Phone.CONTENT_URIに格納されているURIに対してクエリされます。連絡先IDは、ContactsContractとして電話テーブルに格納されます。 CommonDataKinds.Phone.CONTACT_IDおよびWHERE句は、返されるデータを制限するために使用されます。
メールアドレス
メールアドレスのクエリは電話番号に似ています。データベースから電子メールアドレスを取得するには、クエリを実行する必要があります。 ContactsContract.CommonDataKinds.Email.CONTENT_URIに保存されているURIを照会して、電子メールアドレステーブルを照会します。
Cursor emailCur = cr.query(
ContactsContract.CommonDataKinds.Email.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = ?",
new String[]{id}, null);
while (emailCur.moveToNext()) {
// This would allow you get several email addresses
// if the email addresses were stored in an array
String email = emailCur.getString(
emailCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.DATA));
String emailType = emailCur.getString(
emailCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.TYPE));
}
emailCur.close();
電話クエリと同様に、電子メールテーブルのフィールド名もContactsContract.CommonDataKindsに保存されます。電子メールクエリはContactsContract.CommonDataKinds.Email.CONTENT_URIのURIで実行され、WHERE句はContactsContract.CommonDataKinds.Email.CONTACT_IDフィールドと一致する必要があります。複数の電子メールアドレスを保存できるため、カーソルで返されるレコードをループします。
その他のチュートリアル こちら
このメソッドには、Android APIバージョン5以降が必要です。
希望するメールアドレスに直接ジャンプし、連絡先の許可を必要としない場合は、受け入れられた回答に基づいて、次のようなものを使用します。
private static final int REQUEST_CODE_EMAIL = 1;
void startSelectingEmail() {
Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.CommonDataKinds.Email.CONTENT_URI);
startActivityForResult(intent, REQUEST_CODE_EMAIL);
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (resultCode == Activity.RESULT_OK && requestCode == REQUEST_CODE_EMAIL) {
Uri emailUri = data.getData();
Cursor emailCursor = getContext().getContentResolver().query(emailUri, null, null, null, null);
if (emailCursor != null) {
if (emailCursor.moveToFirst()) {
String email = emailCursor.getString(
emailCursor.getColumnIndexOrThrow(ContactsContract.CommonDataKinds.Email.DATA));
String emailType = emailCursor.getString(
emailCursor.getColumnIndexOrThrow(ContactsContract.CommonDataKinds.Email.TYPE));
Log.d(TAG, "Email: " + emailType + " " + email);
}
emailCursor.close();
}
}
}
上記の二重クエリメソッドのように、メールアドレスを読み取るために連絡先のアクセス許可は必要ありません。また、ユーザーが複数のメールを含む連絡先に適切なメールアドレスを選択するためのUIを記述する必要がないようにします。ユーザーは連絡先アプリで特定のメールを選択し、1つの結果のみを取得します。
表示名などのメールアドレスだけでなく、かなり多くの列がカーソルに戻りますが、これはAndroid M.