これは簡単なはずですが、私はそれで苦労しています。これまでのところ、私はこのコードを持っています。
public void onItemSelected(AdapterView<?> parent, View view, int position,
long id) {
// On selecting a spinner item
SpinnerFAQ = parent.getItemAtPosition(position).toString();
// Showing selected spinner item
Toast.makeText(parent.getContext(), "You selected: " + SpinnerFAQ,
Toast.LENGTH_LONG).show();
TextView tv = (TextView) findViewById(R.id.faq_answer);
ExerciseData question = new ExerciseData(this);
question.open();
String answer = question.getFaqAnswer();
question.close();
tv.setText(answer);
}
SpinnerFAQ はグローバル変数で、スピナーの値を文字列として格納します。
public String getFaqAnswer() {
// TODO Auto-generated method stub
String[] columns = new String[] { FAQ_ROWID, FAQ_QUESTION, FAQ_ANSWER};
Cursor c = ourDatabase.query(DATABASE_TABLE2, columns, null, null, null, null, null);
String result = "";
int iRow = c.getColumnIndex(FAQ_ROWID);
int iQuestion = c.getColumnIndex(FAQ_QUESTION);
int iAnswer = c.getColumnIndex(FAQ_ANSWER);
//c.getString(iRow) + " " +
for(c.moveToFirst(); !c.isAfterLast(); c.moveToNext())
{
if(FAQ.SpinnerFAQ == c.getString(iQuestion))
{
result = result + c.getString(iAnswer) + "\n";
break;
}
}
return result;
}
これは私が既に使用したコードに基づいていますが、基本的にはデータベース内の質問に対してスピナーをチェックし、それらが一致する場合はテキスト ビューを回答に変更したいと考えています。現在、FAQ.SpinnerFAQ は問題なく動作しますが、c.getString(iQuestion) は常にデータベースの最後の値として表示されます。このコードは「result = result + c.getString(iAnswer) + "\n";」if 文がなくても問題なく動作するので、「c.getString(iQuestion)」に問題がある理由がよくわかりません。どんな助けでも大歓迎です。