在開(kāi)發(fā)APP的時(shí)候,如果需要一個(gè)cursor而沒(méi)有一個(gè)現(xiàn)成的cursor,那么可以實(shí)現(xiàn)一個(gè)虛擬的表,就是使用MatrixCursor,比如說(shuō)在使用ContentProvider的時(shí)候,數(shù)據(jù)源可以使用sqlite也可以使用SharePreference,但是ContentProvider的重載方法必須要返回一個(gè)cursor,那么這個(gè)時(shí)候就可以使用MatrixCursor。
實(shí)現(xiàn)步驟僅需3步,下面通過(guò)字符數(shù)組來(lái)說(shuō)明:
步驟1.首先創(chuàng)建一個(gè)字符數(shù)組,且字符數(shù)組的值對(duì)應(yīng)著表的字段,如下:
String[] COLUMN_NAME = { "_id", "name", "price" };
步驟2.利用MatrixCursor的構(gòu)造方法,構(gòu)造一個(gè)MatrixCursor,傳入的參數(shù)即是步驟1中創(chuàng)建的字段數(shù)組,如下:
MatrixCursormatrixCursor=newMatrixCursor(COLUMN_NAME);
也可以指定初始大小,如:
matrixCursor=newMatrixCursor( COLUMN_NAME, 10);
步驟3. 通過(guò)matrixCursor 的addRow方法添加一行值,相當(dāng)于向數(shù)據(jù)庫(kù)中插入一條記錄,如下:
matrixCursor.addRow(new Object[] { R.drawable.ic_launcher, "zhangsan",39 });
注:步驟3也可以通過(guò)構(gòu)造一個(gè)MatrixCursor.RowBuilder來(lái)實(shí)現(xiàn),也是相當(dāng)于向數(shù)據(jù)庫(kù)中插入一條記錄,如下:
MatrixCursor.RowBuilder builder1 = matrixCursor.newRow();
builder1.add(R.drawable.ic_launcher);
builder1.add("zhangsan");
builder1.add(39);
//builder1.add(399999);
通過(guò)上面三步即可完成MatrixCursor 的構(gòu)造。從MatrixCursor 中取出數(shù)據(jù)的過(guò)程與Cursor相同,不再贅述!