java - Android:使用来自 itemOnSelected Spinner 的行结果 (sqlite) 填充 TextView

标签 java android sqlite textview spinner

我想使用微调器作为菜单来选择锻炼的名称,选择后 TextViews (x4) 将填充与该名称相关的锻炼。 目前,Spinner 会加载锻炼名称,并且已将第一个锻炼加载到每个 TextViewonCreation 中。

应用程序启动时没有错误,但是当选择新的锻炼名称时,其他行不会加载到 TextViews 中。只能假设我在逻辑上犯了错误。

问题:如果是逻辑上的错误,有人可以识别它并指出方向吗?

开始.java

    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_begin);

    loadSpinnerData();
    refreshTextView();



}

   public void loadTextView(){
    DataHelper dataHelper = new DataHelper(this);
    ArrayList<String> exercises = dataHelper.getExercises();



          ((TextView) findViewById(R.id.exercise1)).setText(exercises.get(0));

          ((TextView) findViewById(R.id.exercise2)).setText(exercises.get(1));

          ((TextView) findViewById(R.id.exercise3)).setText(exercises.get(2));

          ((TextView) findViewById(R.id.exercise4)).setText(exercises.get(3));


  }
    public void refreshTextView(){
    Spinner databaseR = (Spinner) findViewById(R.id.databaseR);
    databaseR.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            loadTextView();

        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {
        }
    });

数据助手.java

  public  String Create_ex="CREATE TABLE ExerciserEasy"
        + " (ID INTEGER PRIMARY KEY AUTOINCREMENT, Workout VARCHAR, ExerciseOne VARCHAR,"
        +"ExerciseTwo VARCHAR, ExerciseThree VARCHAR, ExerciseFour VARCHAR );"

   public ArrayList<String> getExercises(){
    ArrayList<String> list = new ArrayList<String>();
    SQLiteDatabase db = this.getReadableDatabase();
    db.beginTransaction();
    try {
        String selectQuery = " Select * from " + Table_ex1;
        Cursor cursor = db.rawQuery(selectQuery, null);
        if(cursor.moveToFirst()){
            do{
                list.add(cursor.getString(2));
                list.add(cursor.getString(3));
                list.add(cursor.getString(4));
                list.add(cursor.getString(5));
                Log.d("HIITtimer", ""+cursor.getCount());

            }while(cursor.moveToNext());
        }
        db.setTransactionSuccessful();
    }catch (Exception e){
        e.printStackTrace();
    }finally {

        db.endTransaction();
        db.close();


    }
    return list;


}

最佳答案

首先,您需要将选定的锻炼名称传递给 loadTextView(),这样您就可以将它传递给 getExercises() 并根据该名称查询数据库,其他代码看起来不错,

1-在getExercises()中添加参数workoutName,并在WHERE子句中使用

public ArrayList<String> getExercises(String workoutName){
    //codes ...
    String selectQuery = " Select * from " + Table_ex1 + " WHERE Workout ='" workoutName + "'";
    //codes ...
}

注意:您可能想使用 SQLiteDatabase#query() 而不是行查询?

2-将参数workoutName添加到loadTextView(),并将其传递给getExercises():

public void loadTextView(String workoutName){
    //code ...
    ArrayList<String> exercises = dataHelper.getExercises(workoutName);
    //code ...
}

3- 从微调器的 setOnItemSelectedListener() 中选择的锻炼:

@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
    loadTextView(databaseR.getSelectedItem().toString());
}

现在当项目被选中时,loadTextView() 被调用,告诉方法选择了哪个锻炼,并查询数据库以获取与该锻炼名称相关的记录。

关于java - Android:使用来自 itemOnSelected Spinner 的行结果 (sqlite) 填充 TextView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36109757/

相关文章:

java - 在给定的数据上循环一个特征文件

java - 为 JFreeChart 动态格式化带小数的轴

java - Android,如何在通过蓝牙发送数据时更新UI

java - 奇怪的目录没有提供任何解释

java - 如何使用 Java 编辑 MS Word 文档?

android - 在应用程序打开时加载所有 fragment

android - PhoneGap 和 Titanium4j Mobile 的区别

sqlite - 如何从SQLite的表中删除多行

mysql - ActiveRecord 选择帐户中有 3 列的不同记录

python - 我可以将 python 字典 pickle 到 sqlite3 文本字段中吗?