如何在通话完成后读取通话记录并存储在日志中?

Ash*_*ava 5 android

我正在通话结束后阅读通话记录,根据此情况,如果呼叫已连接,则呼叫持续时间大于0.如果持续时间大于0,我会在2天后安排对该号码的下一次呼叫.如果通话时长为0,那么我会在1天后安排对该号码的下一次通话.

我的问题是,当呼叫连接然后它正确安排,但当呼叫未连接时,则显示前一个文本.有时它是正确的,有时是不正确的.

我从接收器打开这个活动.请提供更好的解决方案

以下是我的代码:

@Override
protected void onResume() {
     /**
      * this values only set when call maked from app then it w
      * ill set auto filled some of filled in follow up
      *
      */
    if(flag!=null && flag.equalsIgnoreCase("Followup")/*&& state!=true*/){
        if(SharedPrefs.getBoolean(this, SharedPrefs.PREFS_AUTH, SharedPrefs.
           KEY_SCHEDULE_NEXT_FOLLOWUP, false))
            {
             findViewById(R.id.rl_followUp).setVisibility(View.VISIBLE);
            } else {
             findViewById(R.id.rl_followUp).setVisibility(View.GONE);
            }
        getCallDetails();

        /*  
        String strDateFormat = "hh:mm a";
        SimpleDateFormat sdf = new SimpleDateFormat(strDateFormat);
        calendar=Calendar.getInstance();
        */
        if(callDuration > 0){
           tvDateText.setText(timeInMilies(2));
           etFUComments.setText("Call is done");
        } else {
           tvDateText.setText(timeInMilies(1));
           etFUComments.setText(getResources().
               getString(R.string.call_not_connected_detail));
        }
    }
    super.onResume();
}

private void getCallDetails() {
    StringBuffer sb = new StringBuffer();
    String strOrder = android.provider.CallLog.Calls.DATE + " DESC";
    /* Query the CallLog Content Provider */
    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);
    duration = managedCursor.getColumnIndex(CallLog.Calls.DURATION);
    sb.append("Call Log :");
    if  (managedCursor.moveToNext()) {
        phNum = managedCursor.getString(number);
        String callTypeCode = managedCursor.getString(type);
        String strcallDate = managedCursor.getString(date);
        callDate = new Date(Long.valueOf(strcallDate));
        callDuration =Integer.parseInt(managedCursor.getString(duration));
        String callType = null;
        int callcode = Integer.parseInt(callTypeCode);
        switch (callcode) {
            case CallLog.Calls.OUTGOING_TYPE:
                callType = "Outgoing";
                break;
            case CallLog.Calls.INCOMING_TYPE:
                callType = "Incoming";
                break;
            case CallLog.Calls.MISSED_TYPE:
                callType = "Missed";
                break;
        }
    }
    managedCursor.close();
}


public String timeInMilies(int day){
    Date date=new Date();//(86400000*2)
    long time= date.getTime();
    DateFormat formatter = new SimpleDateFormat("dd/MM/yyyy");
    Calendar calendar = Calendar.getInstance();
    calendar.setTimeInMillis(time + (86400000 * day));
    //etFUComments.setText(String.valueOf(formatter.format(calendar.getTime())));
    return String.valueOf(formatter.format(calendar.getTime()));
}
Run Code Online (Sandbox Code Playgroud)

小智 0

您可以延迟打开活动,因为在调用后您突然打开活动,并且在这段时间内没有当前日志。