Как узнать, что контент-провайдер звонков изменился - PullRequest
1 голос
/ 08 декабря 2010

Привет, я хотел бы знать, есть ли способ узнать, изменился ли поставщик контента для вызовов.Я имею в виду, что если я звоню или отвечаю на звонок, он возвращает «флаг» о том, что новый журнал был добавлен в журнал звонков, или место, где Android хранит информацию о звонках.

Потому чтоКогда я звоню, Android сохраняет номер, имя контакта (если существует), час вызова, продолжительность, бла-бла-бла, все в поставщике контента.Итак, есть ли способ зафиксировать этот «флаг», который говорит, что поставщик контента для вызовов больше, я имею в виду, что в контент-провайдера CallLog.Calls были вставлены новые данные.)

Итак, у меня все еще есть много сомнений, связанных с этой проблемой.Я не знаю, где зарегистрировать обозреватель контента.Мое намерение состоит в том, что когда что-то изменится в поставщике контента CallLog, будет использован метод вставки кода.

Я имею в виду, что код ничего не сделает, если только новые данные не будут добавлены в контент-провайдер CallLog.Если некоторые данные были добавлены к поставщику контента CallLog, то код запросит новые данные, а затем вставит.Я хочу сделать это, потому что с помощью обозревателя контента приложение вставляло данные в базу данных, которая уже была вставлена ​​при каждом запуске приложения, понял?

Так вот мой код.Если кто-то может сказать мне, где поставить registerContentObserver и все остальное необходимо, я благодарю вас.

package com.psyhclo;

import java.text.DateFormat;
import java.util.ArrayList;
import java.util.Date;

import com.psyhclo.R;
import com.psyhclo.CallDataHelper.OpenHelper;

import android.app.Activity;
import android.app.ListActivity;
import android.database.ContentObserver;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.os.Handler;
import android.provider.ContactsContract.RawContacts;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import android.content.ContentValues;
import android.content.Context;
import android.content.ContentProvider;

public class RatedCalls extends ListActivity {

private SQLiteDatabase db;
private CallDataHelper dh = null;
StringBuilder sb = new StringBuilder();
OpenHelper openHelper = new OpenHelper(RatedCalls.this);

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    Cursor cursor = getContentResolver().query(
            android.provider.CallLog.Calls.CONTENT_URI, null, null, null,
            android.provider.CallLog.Calls.DATE + " DESC ");

    dh = new CallDataHelper(this);
    db = openHelper.getWritableDatabase();

    startManagingCursor(cursor);
    int numberColumnId = cursor
            .getColumnIndex(android.provider.CallLog.Calls.NUMBER);
    int durationId = cursor
            .getColumnIndex(android.provider.CallLog.Calls.DURATION);
    int contactNameId = cursor
            .getColumnIndex(android.provider.CallLog.Calls.CACHED_NAME);
    int dateId = cursor.getColumnIndex(android.provider.CallLog.Calls.DATE);
    int numTypeId = cursor
            .getColumnIndex(android.provider.CallLog.Calls.CACHED_NUMBER_TYPE);

    Date dt = new Date();
    int hours = dt.getHours();
    int minutes = dt.getMinutes();
    int seconds = dt.getSeconds();
    String currTime = hours + ":" + minutes + ":" + seconds;

    ArrayList<String> callList = new ArrayList<String>();
    if (cursor.moveToFirst()) {

        do {

            String contactNumber = cursor.getString(numberColumnId);
            String contactName = cursor.getString(contactNameId);
            String duration = cursor.getString(durationId);
            String callDate = DateFormat.getDateInstance().format(dateId);
            String numType = cursor.getString(numTypeId);

            ContentValues values = new ContentValues();

            values.put("contact_id", 1);
            values.put("contact_name", contactName);
            values.put("number_type", numType);
            values.put("contact_number", contactNumber);
            values.put("duration", duration);
            values.put("date", callDate);
            values.put("current_time", currTime);
            values.put("cont", 1);

            this.db.insert(CallDataHelper.TABLE_NAME, null, values);

            Toast.makeText(getBaseContext(), "Inserted!", Toast.LENGTH_LONG);
            callList.add("Contact Number: " + contactNumber
                    + "\nContact Name: " + contactName + "\nDuration: "
                    + duration + "\nDate: " + callDate);

        } while (cursor.moveToNext());
    }
    setListAdapter(new ArrayAdapter<String>(this, R.layout.listitem,
            callList));
    ListView lv = getListView();
    lv.setTextFilterEnabled(true);

    lv.setOnItemClickListener(new android.widget.AdapterView.OnItemClickListener() {

        @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {

            Toast.makeText(getApplicationContext(),
                    ((TextView) view).getText(), Toast.LENGTH_SHORT).show();

        }
    });
}
}

1 Ответ

1 голос
/ 08 декабря 2010

Посмотрите на метод registerContentObserver () в классе ContentResolver.Это позволяет зарегистрировать обратный вызов, если изменяется набор данных за поставщиком контента.

См. Также это сообщение в блоге для рабочего примера того, как наблюдать поставщика контента за изменениями.

...