0

私は、次を使用して不在着信を表示する Android アプリに取り組んでいます。

String[] projection = new String[]{
    CallLog.Calls.NUMBER,
    CallLog.Calls.TYPE,
    CallLog.Calls.DURATION,
    CallLog.Calls.CACHED_NAME,
    CallLog.Calls._ID
};

String where = CallLog.Calls.TYPE + "=" + CallLog.Calls.MISSED_TYPE + " AND " + CallLog.Calls.NEW + "=1" ;         
Cursor c = context.getContentResolver().query(
    CallLog.Calls.CONTENT_URI,
    projection,
    where,
    null,
    null
 );
c.moveToFirst();    
if (c.getCount() > 0) newCountersObj.missedCallCounter = c.getCount();

Androidリストビューで不在着信を確認した後、Android DBで既読としてマークしたいと思います。どうやってやるの?

次のリンクで質問を更新します。

android.database.SQLite の不在着信エラーをクリアする

4

1 に答える 1

3

is_readフラグを trueに設定する。参照: http://developer.android.com/reference/android/provider/CallLog.Calls.html#IS_READ

例 ( ClearMissedCallsServiceから):

    // Clear the list of new missed calls.
    ContentValues values = new ContentValues();
    values.put(Calls.NEW, 0);
    values.put(Calls.IS_READ, 1);
    StringBuilder where = new StringBuilder();
    where.append(Calls.NEW);
    where.append(" = 1 AND ");
    where.append(Calls.TYPE);
    where.append(" = ?");
    context.getContentResolver().update(Calls.CONTENT_URI, values, where.toString(),
            new String[]{ Integer.toString(Calls.MISSED_TYPE) });
于 2013-05-15T09:25:57.237 に答える