我知道如何获取Android中的所有联系人以及如何获取他们的电话号码。
我似乎无法弄清楚如何通过电话号码联系...
这是我目前编写的一段代码,用于测试哪些电话号码可用:
// Create a cursor
Cursor cursor = Base.contentResover().query(Phone.CONTENT_URI, null, null,
null, null);
if (cursor.moveToNext()) {
Log.d("CALLOG", cursor.getString(cursor.getColumnIndexOrThrow(Phone.NUMBER)));
}
问题是我只收到了一些电话号码,而我希望得到所有电话号码......我做错了什么?
答案 0 :(得分:7)
我不认为您粘贴的代码段有任何问题。 尝试使用while循环记录所有电话号码。
关于通过电话号码获取联系人的要求。请尝试使用以下代码段
Uri uri = Uri.withAppendedPath(PhoneLookup.CONTENT_FILTER_URI, Uri.encode(phoneNumber));
resolver.query(uri, new String[]{PhoneLookup.DISPLAY_NAME,PhoneLookup._ID...
使用_ID确定联系人。
为什么要使用PhoneLookup而不是Phone?
PhoneLookup经过高度优化 就其搜索而言。
可以输入电话号码
使用“(”,“)”,“ - ”等填充程序与数据库联系。电话查询
有助于解耦这些填充物并仅比较电话号码。
比较电话中的值不会获取任何结果。
它提供各种其他手机 数字相关信息。 (HAS_PHONE_NUMBER,TIMES_CONTACTED,DISPLAY_NAME 等)
希望有所帮助。需要帮助请叫我。
答案 1 :(得分:1)
您可以使用此方法与name,_id and no.
进行所有联系。您可以在“活动”中调用此方法。
private void displayContacts() {
ContentResolver cr = getContentResolver();
Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI,
null, null, null, null);
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) {
Cursor pCur = cr.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = ?", new String[]{id}, null);
while (pCur.moveToNext()) {
String phoneNo = pCur.getString(pCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
System.out.println("name"+name+"ph no"+phoneNo);
Toast.makeText(this, "Name: " + name + ", Phone No: " + phoneNo, Toast.LENGTH_SHORT).show();
}
pCur.close();
}
}
}
}
答案 2 :(得分:0)
使用这种代码:
public void logCallLog(String number)
{
long dialed;
String columns[]=new String[] {
CallLog.Calls._ID,
CallLog.Calls.NUMBER,
CallLog.Calls.DATE,
CallLog.Calls.DURATION,
CallLog.Calls.TYPE};
String args[]=new String[1];
args[0]=number;
Cursor c;
c = this.managedQuery(Uri.parse("content://call_log/calls"),
columns, CallLog.Calls.NUMBER+"=?", args, "Calls._ID DESC"); //last record first
while (c.moveToNext())
{
dialed=c.getLong(c.getColumnIndex(CallLog.Calls.DATE));
if(Me.DEBUG)
Log.v("CallLog", "Call to number: "+number+", registered at: "+new Date(dialed).toString());
}
}