android - 如何观察内容提供者的变化?安卓

标签 android android-contentprovider android-appwidget notify

我创建了一个 Contentprovide 并实现了它的 update() 方法,如下所示:

@Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
    final SQLiteDatabase db = mHelper.getWritableDatabase();
    int count = db.update(InslideDB.FOLDER_TABLE, values, selection, selectionArgs);

    /* To notify the observer */
    this.getContext().getContentResolver().notifyChange(URI, null);  
    return count;
}

如何在我的 appwidget 中收到通知?谢谢!

我正在尝试这个 Resolver 但没有日志(--------------------日期更改)打印:

class DataProviderObserver extends ContentObserver {
    private AppWidgetManager mAppWidgetManager;
    private ComponentName mComponentName;

    DataProviderObserver(AppWidgetManager mgr, ComponentName cn, Handler h) {
        super(h);
        mAppWidgetManager = mgr;
        mComponentName = cn;
    }

    @Override
    public void onChange(boolean selfChange) {
        super.onChange(selfChange);  //NOTE: Have to call this. dwy.

        // The data has changed, so notify the widget that the collection view needs to be updated.
        // In response, the factory's onDataSetChanged() will be called which will requery the
        // cursor for the new data.

        Log.d("PresenterWidgetProvider", "--------------------Date Changed");

        mAppWidgetManager.notifyAppWidgetViewDataChanged(
                mAppWidgetManager.getAppWidgetIds(mComponentName), R.id.inslide_grid);
    }
}


public class PresenterWidgetProvider extends AppWidgetProvider{

    private static final String AUTHORITY = "com.apps.slide";

    static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/folder");

    public static final String EXTRA_INSLIDE_PATH = "EXTRA_WIDGET_PATH";
    private static HandlerThread sWorkerThread;
    private static Handler sWorkerQueue;
    private static DataProviderObserver sDataObserver;

    public PresenterWidgetProvider () {

        // Start the worker thread to update Content Provider.
        sWorkerThread = new HandlerThread("PresenterWidgetProvider worker");
        sWorkerThread.start();
        sWorkerQueue = new Handler(sWorkerThread.getLooper());

    }

    @Override
    public void onEnabled(Context context) {
        // Register for external updates to the data to trigger an update of the widget.  When using
        // content providers, the data is often updated via a background service, or in response to
        // user interaction in the main app.  To ensure that the widget always reflects the current
        // state of the data, we must listen for changes and update ourselves accordingly.
        final ContentResolver r = context.getContentResolver();
        if (sDataObserver == null) {
            final AppWidgetManager mgr = AppWidgetManager.getInstance(context);
            final ComponentName cn = new ComponentName(context, PresenterWidgetProvider.class);
            sDataObserver = new DataProviderObserver(mgr, cn, sWorkerQueue);
            r.registerContentObserver(CONTENT_URI, true, sDataObserver);
            Log.d("PresenterWidgetProvider", "--------------------onEnabled. sDataObserver = " + sDataObserver);
        }
    }

所以,我最终通过4个步骤解决了它:

  1. 添加 this.getContext().getContentResolver().notifyChange(URI, null);

到 ContentProvider 的 updat() insert() delete() 回调。

  1. 创建一个新的观察者和新的线程来处理它。

  2. 在 Observer 的 onChange() 中调用 notifyAppWidgetViewDataChanged()。

  3. 删除小部件并放置一个新小部件。

就是这样。

最佳答案

您可以使用 ContentObserver类(class)。您只需实现该类并使用 getContentResolver().registerContentObserver() 方法注册观察者。

关于android - 如何观察内容提供者的变化?安卓,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11237971/

相关文章:

android - 转换为 Dalvik 格式失败 : Unable to execute dex: java. nio.BufferOverflowException

android - 将 Android 矢量绘图转换为启动器图标 PNG

android - 在 Android 上的 SQLite 中处理多个表 - 为什么这么复杂?

android - 多种小部件尺寸

android - 将外部依赖项上传到本地Maven存储库

android - 有没有办法在 Android 的 ListView 中禁用换行?

android - 我需要一个完整的 promise 内容提供者吗?

android - 从我自己的应用程序查询我自己的 ContentProvider 时获得权限拒绝

android - 设置 Activity 未启动

android - 如何在代码中将小部件添加到主屏幕