我想使用微调器作为菜单来选择锻炼的名称,一旦选择,TextView
s(x4)将填充与该名称相关的练习。
目前,Spinner加载了锻炼名称,并且已经将第一次锻炼加载到每个TextView
的{{1}}中。
启动应用程序时没有错误,但是当选择新的锻炼名称时,其他行不会加载到TextViews中。我只能假设我在逻辑中出错了。
问题:如果逻辑中出现错误,有人可以识别它并指出我的方向吗?
begin.java
onCreation
DataHelper.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) {
}
});
答案 0 :(得分:1)
首先,您需要将选定的锻炼名称传递给loadTextView()
,以便将其传递给getExercises()
并根据该名称查询数据库,其他代码看起来很好,
1-将参数workoutName
添加到getExercises()
,并在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-从spinner的setOnItemSelectedListener()
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
loadTextView(databaseR.getSelectedItem().toString());
}
现在,当选择项目时,会调用loadTextView()
,告诉方法选择了哪个锻炼,并查询数据库以获取与该锻炼名称相关的记录。