1

안녕하세요, 부름의 콘텐츠 제공 업체가 변경되었는지 알 수있는 방법이 있는지 알고 싶습니다. 내 전화를 걸거나 전화를 받으면 통화 기록에 새 로그가 추가 된 '깃발'을 반환하거나 안드로이드가 통화 정보를 저장하는 장소를 반환합니다.통화 내용 제공자가 변경된 사실을 알 수있는 방법

전화를 걸면 안드로이드는 번호, 연락처 이름 (존재하는 경우), 통화 시간, 기간, ㅋ ㅋ ㅋ ㅋ ㅋ를 콘텐츠 공급자에 저장합니다. 그래서 부름의 컨텐츠 제공자가 더 크다는 것을 나타내는 "플래그"를 포착 할 수있는 방법이 있습니다. 즉, 새로운 데이터가 컨텐츠 제공자 CallLog.Calls에 삽입되었음을 의미합니다. (업데이트)

그래서, 난 아직이 문제와 관련된 의심의 여지가. 나는 콘텐츠 관측자를 어디에 등록해야할지 모르겠다. 나의 의도는 CallLog 컨텐트 프로 바이더가 변경되었을 때 코드의 삽입 메소드가 사용될 때입니다.

새로운 데이터가 CallLog 콘텐츠 공급자에 추가되지 않는 한 코드는 아무 것도하지 않습니다. 일부 데이터가 CallLog 콘텐츠 공급자에 추가 된 경우 코드에서 새 데이터를 쿼리 한 다음 삽입합니다. Content observer와 함께 응용 프로그램이 응용 프로그램을 실행할 때마다 이미 삽입 된 데이터를 데이터베이스에 삽입했기 때문에이 작업을 수행하고 싶습니다.

여기 내 코드가 있습니다. 누군가가 어디에서 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

ContentResolver 클래스의 registerContentObserver() 메소드를 살펴보십시오. 이렇게하면 컨텐트 공급자 뒤의 데이터 집합이 변경되면 콜백을 등록 할 수 있습니다.

변경 내용에 대해 콘텐츠 제공 업체를 관찰하는 실제 예는 this blog posting을 참조하십시오.