SimpleCursorAdapter с видимостью ListView - PullRequest
0 голосов
/ 03 января 2019

Здравствуйте. Я создал базу данных, в которой я пытаюсь перечислить имена этой базы данных в виде списка, но ничего не отображается.

Код для базы данных mty:

public class LockedInDatabaseHelper extends SQLiteOpenHelper {

    private static final String DB_NAME = "Locked In";
    private static final int DB_VERSION = 1;

    public LockedInDatabaseHelper(Context context) {

        super(context, DB_NAME, null, DB_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE ARTISTS (_id INTEGER PRIMARY KEY AUTOINCREMENT,"
                    + "NAME TEXT,"
                    + "INTRO TEXT,"
                    +"IMAGE_RESCOURCE_ID INT)");
        insertArtist(db, "Jinx Inkz", "An artist who specializes in portraits and custom pieces", R.drawable.jinx_profile);
        insertArtist(db, "Bazooka Zook", "An artist who specializes in clean line work and neo - traditional", R.drawable.zook_profile );

            }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }

    private static void insertArtist(SQLiteDatabase db, String name, String intro, int resourceId){
        ContentValues artistInfo = new ContentValues();
        artistInfo.put("NAME", name);
        artistInfo.put("INTRO", intro);
        artistInfo.put("IMAGE_RESOURCE_ID", resourceId);
        db.insert("ARTISTS",null, artistInfo);
    }

}

наконец, Java-код, где я хочу, чтобы информация появлялась:

public class ArtistsActivity extends AppCompatActivity {

private SQLiteDatabase db;
private Cursor cursor;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_artists);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    ListView listArtists = (ListView) findViewById(R.id.artistsLV);
    SQLiteOpenHelper lockedInDatabaseHelper = new LockedInDatabaseHelper(ArtistsActivity.this);
    try {
        db = lockedInDatabaseHelper.getReadableDatabase();
        cursor = db.query("ARTISTS",
                new String[]{"_id", "NAME"},
                null, null, null, null, null);
        SimpleCursorAdapter listAdapter = new SimpleCursorAdapter(ArtistsActivity.this,
                android.R.layout.simple_list_item_1,
                cursor,
                new String[]{"NAME"},
                new int[] {android.R.id.text1},
                0);
        listArtists.setAdapter(listAdapter);
    } catch (SQLiteException e) {

        Toast toast = Toast.makeText(this, "Database unavailable", Toast.LENGTH_LONG);
        toast.show();

    }

    //Create a listener for clicks on listview
    AdapterView.OnItemClickListener itemClickListener =
            new AdapterView.OnItemClickListener() {
        public void onItemClick(AdapterView<?> listArtists,
                                View itemView,
                                int position,
                                long id){
            //Pass tha artist user clicks on to artistActivity
            Intent intent = new Intent(ArtistsActivity.this, ArtistDetail.class);
            intent.putExtra(ArtistDetail.EXTRA_ARTISTID, (int) id);
            startActivity(intent);

        }
    };
    //Assign the listener to list view
    listArtists.setOnItemClickListener(itemClickListener);
    }

    @Override
    public void onDestroy(){
    super.onDestroy();
    cursor.close();
    db.close();
    }
}

Я много перебирал код, но не думаю, что это связано с ListView.Пожалуйста помоги!Я очень застрял, и я просто хочу список, в который я могу добавить onClickListener для продолжения приложения.

1 Ответ

0 голосов
/ 03 января 2019

Ваша проблема в том, что вы неправильно написали имя столбца IMAGE_RESOURCE_ID .То есть вы создаете таблицу, используя имя столбца IMAGE_RESCOURCE_ID , но пытаетесь вставить в столбец IMAGE_RESOURCE_ID .

Я бы предложил всегда использовать константы для имен таблиц и столбцов итаким образом, вы определяете их один раз, а затем используете одну и ту же константу для ссылки на элементы.

Поэтому я бы предложил заменить помощника по базам данных LockedInDatabaseHelper.java на: -

public class LockedInDatabaseHelper extends SQLiteOpenHelper {

    private static final String DB_NAME = "Locked In";
    private static final int DB_VERSION = 1;
    public static final String TBL_ARTISTS = "ARTISTS";
    public static final String COL_ID = BaseColumns._ID;
    public static final String COl_NAME = "NAME";
    public static final String COL_INTRO = "INTRO";
    public static final String COL_IMAGERESOURCEID = "IMAGE_RESOURCE_ID";

    public LockedInDatabaseHelper(Context context) {

        super(context, DB_NAME, null, DB_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE ARTISTS (" + COL_ID + " INTEGER PRIMARY KEY,"
                + COl_NAME + " TEXT,"
                + COL_INTRO + " TEXT,"
                + COL_IMAGERESOURCEID + " INT)");
        insertArtist(db, "Jinx Inkz", "An artist who specializes in portraits and custom pieces", R.drawable.jinx_profile);
        insertArtist(db, "Bazooka Zook", "An artist who specializes in clean line work and neo - traditional",R.drawable.zook_profile);

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }

    private static void insertArtist(SQLiteDatabase db, String name, String intro, int resourceId){
        ContentValues artistInfo = new ContentValues();
        artistInfo.put(COl_NAME, name);
        artistInfo.put(COL_INTRO, intro);
        artistInfo.put(COL_IMAGERESOURCEID, resourceId);
        db.insert(TBL_ARTISTS,null, artistInfo);
    }
}

Наряду с некоторыми изменениями в ArtistsActivity.java , чтобы также использовать константы, включающие в себя: -

cursor = db.query(LockedInDatabaseHelper.TBL_ARTISTS,
                    new String[]{LockedInDatabaseHelper.COL_ID, "NAME"},
                    null, null, null, null, null);
            SimpleCursorAdapter listAdapter = new SimpleCursorAdapter(ArtistsActivity.this,
                    android.R.layout.simple_list_item_1,
                    cursor,
                    new String[]{LockedInDatabaseHelper.COl_NAME},
                    new int[] {android.R.id.text1},
                    0);

Я считаю, что вышеприведенное сработает. Однако, так как вы изменяете структуру базы данных, вам следует выполнить 1 из следующих действий перед повторным запуском приложения : -

  1. Удалить / очистить данные приложения (это фактически удаляетбазы данных).
  2. Удалите приложение (это также эффективно удалит базу данных).
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...