我希望现在还不算太晚,或者其他人可以提供帮助。
棘手的事情在这里。每次查询 contentProvider 时,您都必须创建一个新游标,因此我有我的项目列表,每次查询内容提供者时,我都会使用包含新项目的支持项目列表构建一个新游标。
为什么我必须这样做?否则你会得到一个异常,因为 CursorLoader 试图在已经有一个的游标内注册一个观察者。请注意,在 api 级别 19 及更高级别中允许在 CursorMatrix 中构建新行的方式,但您有其他方式,但涉及更多无聊的代码。
public class MyContentProvider extends ContentProvider {
List<Item> items = new ArrayList<Item>();
@Override
public boolean onCreate() {
// initial list of items
items.add(new Item("Coffe", 3f));
items.add(new Item("Coffe Latte", 3.5f));
items.add(new Item("Macchiato", 4f));
items.add(new Item("Frapuccion", 4.25f));
items.add(new Item("Te", 3f));
return true;
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) {
MatrixCursor cursor = new MatrixCursor(new String[] { "name", "price"});
for (Item item : items) {
RowBuilder builder = cursor.newRow();
builder.add("name", item.name);
builder.add("price", item.price);
}
cursor.setNotificationUri(getContext().getContentResolver(),uri);
return cursor;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
items.add(new Item(values.getAsString("name"),values.getAsFloat("price")))
//THE MAGIC COMES HERE !!!! when notify change and its observers registred make a requery so they are going to call query on the content provider and now we are going to get a new Cursor with the new item
getContext().getContentResolver().notifyChange(uri, null);
return uri;
}