すべての着信、発信、および不在着信の通話ログを取得するアプリを作成しています。どうやってやるの?
37300 次
6 に答える
8
于 2011-09-21T11:50:45.663 に答える
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 に答える