3

我正在制作一个应用程序,我想在其中获取所有来电、去电和未接电话的通话记录。我怎样才能做到这一点?

4

6 回答 6

8

请参考以下链接:

以编程方式获取 Android 电话通话记录/日志

如果您对上述链接有任何疑问,请单击此处

于 2011-09-21T11:50:45.663 回答
8

这里的所有答案都在使用managedQuery现在已弃用的答案。它应该被替换为getContext().getContentResolver().query()方法,如此处所述并此处演示。

以下是基于这些示例的简短示例代码:

String[] projection = new String[] {
                CallLog.Calls.CACHED_NAME,
                CallLog.Calls.NUMBER,
                CallLog.Calls.TYPE,
                CallLog.Calls.DATE
        };
// String sortOrder = ContactsContract.Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC";

 Cursor cursor =  mContext.getContentResolver().query(CallLog.Calls.CONTENT_URI, projection, null, null, null);
 while (cursor.moveToNext()) {
    String name = cursor.getString(0);
    String number = cursor.getString(1);
    String type = cursor.getString(2); // https://developer.android.com/reference/android/provider/CallLog.Calls.html#TYPE
    String time = cursor.getString(3); // epoch time - https://developer.android.com/reference/java/text/DateFormat.html#parse(java.lang.String
    }
cursor.close();
于 2018-03-04T16:13:14.150 回答
3

这段代码对我有用:

private void getCallDetails() {

    StringBuffer sb = new StringBuffer();
    Cursor managedCursor = managedQuery(CallLog.Calls.CONTENT_URI, null, null, null, null);
    int number = managedCursor.getColumnIndex(CallLog.Calls.NUMBER);
    int type = managedCursor.getColumnIndex(CallLog.Calls.TYPE);
    int date = managedCursor.getColumnIndex(CallLog.Calls.DATE);
    int duration = managedCursor.getColumnIndex(CallLog.Calls.DURATION);
    sb.append("Call Details :");
    while (managedCursor.moveToNext()) {
        String phNumber = managedCursor.getString(number); // mobile number
        String callType = managedCursor.getString(type); // call type
        String callDate = managedCursor.getString(date); // call date
        Date callDayTime = new Date(Long.valueOf(callDate)); 
        String callDuration = managedCursor.getString(duration);
        String dir = null;
        int dircode = Integer.parseInt(callType);
        switch (dircode) {
            case CallLog.Calls.OUTGOING_TYPE:
                dir = "OUTGOING";
                break;

            case CallLog.Calls.INCOMING_TYPE:
                dir = "INCOMING";
                break;

            case CallLog.Calls.MISSED_TYPE:
                dir = "MISSED";
                break;
        }
        sb.append("\nPhone Number:--- " + phNumber + " \nCall Type:--- " + dir + " \nCall Date:--- " + callDayTime + " \nCall duration in sec :--- " + callDuration);
        sb.append("\n----------------------------------");
    }
    managedCursor.close();
    miss_cal.setText(sb);
    Log.e("Agil value --- ", sb.toString());
}

注意:如果您想获取特定的调用类型,请使用以下代码。例如,如果我只想要收入电话,那么命令/删除开关中的相同代码:

case beneath

然后,在收入调用案例中使用以下代码:

sb.append("\nPhone Number:--- " + phNumber + " \nCall Type:--- " + dir + " \nCall Date:--- " + callDayTime + " \nCall duration in sec :--- " + callDuration);               
sb.append("\n-----Agil----------------------------------");
于 2016-12-12T07:18:25.467 回答
0
public class MainActivity extends Activity 
{
TextView textView = null;


int callcode;
String callType ;
String phNum;
Date callDate;
String callTypeCode;
String strcallDate;
String callDuration;
String currElement;
static boolean ring = false;
static boolean callReceived = false;


StringBuffer sb = new StringBuffer();

@Override
protected void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    textView = (TextView) findViewById(R.id.textview_call);


                SmsManager sms = SmsManager.getDefault();
                String strOrder = android.provider.CallLog.Calls.DATE + " DESC";

                /* Query the CallLog Content Provider */
                @SuppressWarnings("deprecation")
                Cursor managedCursor = managedQuery(CallLog.Calls.CONTENT_URI, null,
                        null, null, strOrder);

                int number = managedCursor.getColumnIndex(CallLog.Calls.NUMBER);

                int type = managedCursor.getColumnIndex(CallLog.Calls.TYPE);

                int date = managedCursor.getColumnIndex(CallLog.Calls.DATE);

                int duration = managedCursor.getColumnIndex(CallLog.Calls.DURATION);

                sb.append("Call Log :");



                if(managedCursor.moveToFirst())
                {
                    String phNum = managedCursor.getString(number);

                    String callTypeCode = managedCursor.getString(type);

                    String strcallDate = managedCursor.getString(date);

                    Date callDate = new Date(Long.valueOf(strcallDate));

                    String callDuration = managedCursor.getString(duration);

                    String callType = null;

                    int callcode = Integer.parseInt(callTypeCode);

                    switch (callcode) 
                    {
                    case CallLog.Calls.OUTGOING_TYPE:


                        callType = "Outgoing";



                        //sms.sendTextMessage(phNum, null, "Outgoing msg",  null, null);  


                        break;
                    case CallLog.Calls.INCOMING_TYPE:

                        callType = "Incoming";
                        //sms.sendTextMessage(phNum, null, "Incoming msg",  null, null);  


                        break;
                    case CallLog.Calls.MISSED_TYPE:

                        callType = "Missed";
                    //sms.sendTextMessage(phNum, null, "Missed msg",  null, null);  

                        break;
                    }
                    sb.append("\nPhone Number:--- " + phNum + " \nCall Type:--- "
                            + callType + " \nCall Date:--- " + callDate
                        + " \nCall duration in sec :--- " + callDuration);
                    sb.append("\n----------------------------------");
                }


                managedCursor.close();
            textView.setText(sb);

}

}    
于 2016-11-10T07:00:41.247 回答
0
 private void getLastNumber() {

       //this help you to get recent call
        Uri contacts = CallLog.Calls.CONTENT_URI;
        Cursor managedCursor = context.getContentResolver().query(contacts, null, null, 
                       null, android.provider.CallLog.Calls.DATE + " DESC limit 1;");
        int number = managedCursor.getColumnIndex(CallLog.Calls.NUMBER);
        int type = managedCursor.getColumnIndex(CallLog.Calls.TYPE);
        int date = managedCursor.getColumnIndex(CallLog.Calls.DATE);
        int duration = managedCursor.getColumnIndex(CallLog.Calls.DURATION);

        StringBuffer sb = new StringBuffer();
        managedCursor.moveToNext();
        String phNumber = managedCursor.getString(number);
        String callType = managedCursor.getString(type);
        String callDate = managedCursor.getString(date);
        String callDayTime = new Date(Long.valueOf(callDate)).toString();
        int callDuration = managedCursor.getInt(duration);
        managedCursor.close();

        int dircode = Integer.parseInt(callType);
       sb.append("Phone Number:--- " + phNumber + " ,Call Date:--- " + callDayTime + " ,Call duration in sec :--- " + callDuration);
        sb.append("\n----------------------------------");
        Log.d("calllogs", "getLastNumber: "+"Phone Number:--- " + phNumber + " ,Call Date:--- " + callDayTime + " ,Call duration in sec :--- " + callDuration);
    }
于 2020-07-14T07:17:44.970 回答
0

你可以试试这个

private void getCallLogWithDuration() {
    StringBuffer sb = new StringBuffer();
    Uri contacts = CallLog.Calls.CONTENT_URI;
    Cursor managedCursor = this.getContentResolver().query(contacts, null, null, null, null);
    int name = managedCursor.getColumnIndex(CallLog.Calls.CACHED_NAME);
    int number = managedCursor.getColumnIndex(CallLog.Calls.NUMBER);
    int type = managedCursor.getColumnIndex(CallLog.Calls.TYPE);
    int date = managedCursor.getColumnIndex(CallLog.Calls.DATE);
    int duration = managedCursor.getColumnIndex(CallLog.Calls.DURATION);
    sb.append("Call Details :");
    while (managedCursor.moveToNext()) {

        HashMap rowDataCall = new HashMap<String, String>();

        String mName = managedCursor.getString(name);
        String phNumber = managedCursor.getString(number);
        String callType = managedCursor.getString(type);
        String callDate = managedCursor.getString(date);
        String callDayTime = new SimpleDateFormat("EEEE dd MMM yyyy HH:mm:s").format(new Date(Long.parseLong(callDate)));
        // long timestamp = convertDateToTimestamp(callDayTime);
        String callDuration = managedCursor.getString(duration);
        String dir = null;
        int dircode = Integer.parseInt(callType);
        switch (dircode) {
            case CallLog.Calls.OUTGOING_TYPE:
                dir = "OUTGOING";
                break;

            case CallLog.Calls.INCOMING_TYPE:
                dir = "INCOMING";
                break;

            case CallLog.Calls.MISSED_TYPE:
                dir = "MISSED";
                break;
        }
        sb.append("\nName:--- " + mName + "\nPhone Number:--- " + phNumber + " \nCall Type:--- " + dir + " \nCall Date:--- " + callDayTime + " \nCall duration in sec :--- " + callDuration);
        sb.append("\n----------------------------------");


    }
    managedCursor.close();
    System.out.println(sb);
    Log.i("CallLog", sb.toString());
}
于 2022-01-18T16:54:35.383 回答