Как реализовать ContentObserver для журналов вызовов
Я хотел бы знать, если есть способ узнать, изменился ли поставщик контента для вызовов. Я имею в виду, что если я звоню или отвечаю на звонок, он возвращает "флаг", что новый журнал был добавлен в журнал звонков, или место, где Android хранит информацию о звонках.
Потому что, когда я звоню, Android сохраняет номер, имя контакта (если существует), час вызова, продолжительность,..., все в поставщике контента. Итак, есть ли способ захватить этот "флаг", который говорит, что поставщик контента для вызовов больше, я имею в виду, что в контент-провайдер CallLog.Calls были вставлены новые данные.
Таким образом, у меня все еще есть много сомнений, связанных с этой проблемой. Я не знаю, где зарегистрировать обозреватель контента. Мое намерение состоит в том, чтобы, когда что-то изменяется в поставщике контента CallLog, будет использоваться метод вставки кода.
Я имею в виду, что код ничего не сделает, если новые данные не будут добавлены в контент-провайдер CallLog. Если некоторые данные были добавлены к поставщику контента CallLog, то код запросит новые данные, а затем вставит. Я хочу сделать это, потому что без наблюдателя контента приложение вставляло данные в базу данных, которая уже была вставлена каждый раз, когда я запускаю приложение, понял?
Так вот мой код. Если кто-то может сказать мне, где поставить registerContentObserver()
и все остальное, что нужно.
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();
}
});
}
}
2 ответа
Вот ответ. Не забудьте зарегистрировать обозреватель контента с помощью этого метода:
registerContentObserver (Uri uri, boolean notifyForDescendents, ContentObserver observer)
И тогда вы можете создать это так.
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.getApplicationContext()
.getContentResolver()
.registerContentObserver(
android.provider.CallLog.Calls.CONTENT_URI, true,
new MyContentObserver(handler));
}
class MyContentObserver extends ContentObserver {
public MyContentObserver(Handler h) {
super(h);
}
@Override
public boolean deliverSelfNotifications() {
return true;
}
@Override
public void onChange(boolean selfChange) {
Log.d(LOG_TAG, "MyContentObserver.onChange("+selfChange+")");
super.onChange(selfChange);
// here you call the method to fill the list
}
}
Просто создайте новый подкласс класса ContentObserver и переопределите его метод onChange(). Метод onChange() будет содержать весь код, который будет выполняться при изменении содержимого.
public class MyObserver extends ContentObserver {
public MyObserver(Handler handler) {
super(handler);
}
@Override
public void onChange(boolean selfChange) {
this.onChange(selfChange,null);
}
@Override
public void onChange(boolean selfChange, Uri uri) {
//Write your code here }
}
Затем все, что вам нужно сделать, это зарегистрировать вашего поставщика контента в URI.
getContentResolver().registerContentObserver(YourURI,true,myObserver);
Не забудьте отменить регистрацию объекта обозревателя контента, иначе это может привести к утечке памяти.
Источник: используйте Android ContentObserver, чтобы реагировать на изменения содержимого