28

召しのコンテンツ提供者が変わったかどうかを知る方法があるかどうか知りたいです。つまり、電話をかけるか、電話に出ると、新しいログが通話ログ、または 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();
            }
        });
    }
}
4

2 に答える 2

42

これが答えです。このメソッドでコンテンツ オブザーバーを登録することを忘れないでください。

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
    }
}
于 2010-12-14T02:55:11.630 に答える
1

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 を使用してコンテンツの変更に対応する

于 2016-04-11T09:05:06.020 に答える