大家好!android - 顯示項目點擊到由SQLite填充的列表視圖
我是新來的android編程,努力如何將_id數據庫附加到列表視圖適配器。它幾乎消耗整個試圖找出如何做到這一點。
這裏的代碼清單:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
overridePendingTransition(R.anim.fadein, R.anim.fadeout);
setContentView(R.layout.activity_dictionarylist);
filterText = (EditText)findViewById(R.id.txtsearch);
ListView itemList = (ListView)findViewById(R.id.listView);
DBHelper dbHelper = new DBHelper(Dictionarylist.this);
String[] terms = dbHelper.dictionaryWords();
listAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1, android.R.id.text1,terms);
itemList.setAdapter(listAdapter);
itemList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
Toast.makeText(getApplicationContext(), "Position " + position, Toast.LENGTH_LONG).show();
Intent intent = new Intent(Dictionarylist.this, DictionaryActvity.class);
intent.putExtra("DICTIONARY_ID", position);
startActivity(intent);
}
});
filterText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
Dictionarylist.this.listAdapter.getFilter().filter(s);
}
@Override
public void afterTextChanged(Editable s) {
}
});
}
下面是數據庫助手代碼:
public class DBHelper extends DBCon {
public DBHelper(Context context){
super(context);
}
public String[] dictionaryWords(){
String query = "Select * from main_dictionary";
Cursor cursor = this.getdbconnection().rawQuery(query, null);
ArrayList<String> wordterms = new ArrayList<String>();
if(cursor.moveToFirst()){
do{
String word = cursor.getString(cursor.getColumnIndexOrThrow("main_word"));
wordterms.add(word);
}
while (cursor.moveToNext());
}
cursor.close();
String[] dictionaryWords = new String[wordterms.size()];
dictionaryWords = wordterms.toArray(dictionaryWords);
return dictionaryWords;
}
public Quizzer getQuizById(int quizId){
Quizzer quizzer = null;
String query = "select * from main_dictionary where _id =" + quizId;
Cursor cursor = this.getdbconnection().rawQuery(query, null);
if(cursor.moveToFirst()){
do{
String word = cursor.getString(cursor.getColumnIndexOrThrow("main_word"));
String tagdef = cursor.getString(cursor.getColumnIndexOrThrow("tag_definition"));
String engdef = cursor.getString(cursor.getColumnIndexOrThrow("eng_defintion"));
String sample = cursor.getString(cursor.getColumnIndexOrThrow("example"));
quizzer = new Quizzer(word, tagdef, engdef, sample);
}
while(cursor.moveToNext());
}
cursor.close();
return quizzer;
}
我希望得到任何幫助。
從數據庫獲得'attach _id'的位置? –
沒有。我想將數據庫的_id附加到列表視圖中,所以當我們點擊listview上的項目時,它應該顯示來自數據庫_id的信息。 –
該應用程序是一種字典。 –