簡體   English   中英

如何在通話完成后讀取通話記錄並存儲在日志中?

[英]how to read call logs after call finished and stored in logs?

我正在通話結束后閱讀通話記錄,根據此情況,如果呼叫已連接,則呼叫持續時間大於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()));
}

您可以延遲打開活動,因為在通話后您突然打開活動並且在該時間內沒有當前日志。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM