我试图将存储为SQLite数据库中的BLOB数据的图像存储到用于列表活动的行中的Imageview中。从数据库表到列表视图的BLOB图像
这是我的两个方法我采用拉常规文本数据代码:
private void fillData() {
// TODO Auto-generated method stub
String[] from = new String[] { BorrowMeTable.COLUMN_NAME, BorrowMeTable.COLUMN_DATE };
int[] to = new int[] { R.id.people_list_name, R.id.people_list_borrowed };
getLoaderManager().initLoader(0, null, this);
adapter = new SimpleCursorAdapter(this, R.layout.people_row, null, from,
to, 0);
setListAdapter(adapter);
}
// -----------------------------------------------------------
@Override
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
BorrowMeContentProvider.distinctSwitch = true;
String[] projection = { BorrowMeTable.COLUMN_ID, BorrowMeTable.COLUMN_NAME, BorrowMeTable.COLUMN_DATE };
CursorLoader cursorLoader = new CursorLoader(this,
BorrowMeContentProvider.CONTENT_URI, projection, null, null, null);
return cursorLoader;
}
我有另一列,BorrowMeTable.COLUMN_IMAGE我想加载到我的ImageView(R.id.pic_of_image )。我无法将其添加到我的投影中,因为它无法转换为字符串。要使用单个光标拉它,我会使用代码:
byte[] imageByteArray = databaseCursor.getBlob(databaseCursor
.getColumnIndex(BorrowMeTable.COLUMN_IMAGE));
ByteArrayInputStream imageStream = new ByteArrayInputStream(
imageByteArray);
bmp = BitmapFactory.decodeStream(imageStream);
window.setImageBitmap(bmp);
正如我在另一部分程序中所做的那样。任何人都可以帮助我如何做这项工作?
谢谢!
你的错误是什么?并把logcat,所以我们可以帮助你。 – Riser
@Segi我真的在问我如何修改我的fillData以适应我的图像。当我尝试将存储我的BLOB数据的列添加到投影时,我得到的数据不能转换为String错误。我将使用Cursor loader将blob数据加载到图像中,就像读取其他列中的文本一样。 – Vince