[英]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.