SimpleCursorAdapter によってデータをロードしているカスタム リストがあります。リストには、リストの各行ごとにイメージを変更するイメージビューがあります。viewbilnder を使用しましたが、何も取得しませんでした。これは myadapter です。コード
private void getData() {
try {
// obtain a list of from DB
db = SQLiteDatabase.openDatabase(ClubCP.DbPath,null,SQLiteDatabase.CREATE_IF_NECESSARY);
String TABLE_NAME = "cat";
String COLUMN_ID = "_id";
String COLUMN_POET_ID = "poet_id";
String COLUMN_TEXT = "text";
String COLUMN_PARENT_ID = "parent_id";
String [] columns ={COLUMN_ID,COLUMN_TEXT,COLUMN_POET_ID};
String mySQL = "SELECT DISTINCT id as _id "+","+COLUMN_POET_ID+","+COLUMN_TEXT+","+COLUMN_PARENT_ID
+ " from "+TABLE_NAME
+ " where " + COLUMN_PARENT_ID+"= 0 "
+ " order by " + COLUMN_POET_ID+"= 0 ";
// String mySQL="SELECT DISTINCT id as _id,poet_id,text,parent_id from cat where parent_id=0 order by poet_id";
//Cursor c = db.query(TABLE_NAME,columns,COLUMN_PARENT_ID+"= 0", null, null, null, COLUMN_POET_ID);
Cursor c = db.rawQuery(mySQL, null);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.list_item, c,
columns, new int[] {R.id.list_item_text_sub,R.id.list_item_text_main,R.id.list_item_text_id}, 0);
adapter.setViewBinder(new CustomViewBinder());
ListView list = (ListView) findViewById(R.id.list_poet_name);
list.setAdapter(adapter);
} catch (Exception e) {
Toast.makeText(this, e.getMessage(), 1).show();
}
}
これはビューバインダーです
public class CustomViewBinder implements ViewBinder {
@Override
public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
if (columnIndex == cursor.getColumnIndex(ClubCP.KEY_POET_ID)) {
// If the column is IS_STAR then we use custom view.
int poet_id = cursor.getInt(columnIndex);
String path = ClubCP.SDcardPath + "/temp/"+poet_id+".jpg";
File imgFile = new File(path);
ImageView img=(ImageView)findViewById(R.id.list_item_img);
if(imgFile.exists())
{
Bitmap myBitmap = BitmapFactory.decodeFile(imgFile.getAbsolutePath());
img.setImageBitmap(myBitmap);
}
else
Toast.makeText(Read.this,"no IMAGE IS PRESENT'",Toast.LENGTH_SHORT).show();
img.setImageResource(R.drawable.music_album_header_vinyl);
}
/// if (poet_id != 6) {
//TextView verse = (TextView)findViewById(R.id.poem_verse_list_item_01);
// verse.setGravity(Gravity.LEFT);
// } else {
// }
// return true;
// }
return false;
}
}
誰かがこれについて私を助けることができますか? データベースから画像をロードする方法を検索して見つけましたが、SDカードから画像をロードしたいのですが、画像の名前のみがデータベースからのものです
私はたくさん検索しましたが、私の問題を解決する解決策が見つかりません...誰もこれについて私を助けることができませんか?