首先,創(chuàng)建一個用于顯示一個item的layout,名為item.xml
<TextView
android:id="@+id/name"
android:layout_width="120dp"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/phone"
android:layout_width="150dp"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/amount"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</LinearLayout>
接下來便是進(jìn)行數(shù)據(jù)的綁定,總共分為三種方法:
private void show2() {//此方法需要一個結(jié)果集中的Cursor,要求Cursor中需要有一個名稱為_id的字段;所以添加一個獲取Cursor的方法如下!
Cursor cursor = ps.getCursorScollData(0, 10);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,R.layout.item, cursor,
new String[] { "name", "phone", "amount" }, new int[] {R.id.name, R.id.phone, R.id.amount });
listview.setAdapter(adapter);
}
public Cursor getCursorScollData(int offest, int maxResult) {
SQLiteDatabase db = dbOpenHelper.getReadableDatabase();//因?yàn)橐蠼Y(jié)果集中要有一個名為_id的字,所以SQL語句如下!
Cursor cursor = db.rawQuery("select personid as _id,name,phone,amount from person order by personid asc limit ?,?",
new String[] { String.valueOf(offest),String.valueOf(maxResult) });
// db.query(table, columns, selection, selectionArgs, groupBy, having,orderBy, limit);
return cursor;
}
private void show3() {
List persons = ps.getScollData(0, 10);// PersonAdapter見下一章節(jié)自定義適配器
PersonAdapter adapter = new PersonAdapter(getApplicationContext(),persons, R.layout.item);
listview.setAdapter(adapter);
}
private final class ItemClickListener implements OnItemClickListener {
@Override//此方法中第一個參數(shù)為顯示數(shù)據(jù)(item項(xiàng))的控件,在此例子中即為ListView;第三個參數(shù)為點(diǎn)擊項(xiàng)的位置,
public void onItemClick(AdapterView<?> parent, View arg1, int position,long arg3) {
ListView lview = (ListView) parent;
// show3()方法對應(yīng)的處理方法
// Person person = (Person) lview.getItemAtPosition(position);
// Toast.makeText(getApplicationContext(),person.getId().toString(),1).show();
// show2()方法對應(yīng)的處理方法
// show2方法中,adapter返回的是Cursor,
// Cursor cursor = (Cursor) lview.getItemAtPosition(position);
// int personid = cursor.getInt(cursor.getColumnIndex("_id"));
// Toast.makeText(getApplicationContext(), personid + "", 1).show();
// show1()方法對應(yīng)的處理方法
// show1方法中,adapter返回的是Map,再對Map進(jìn)行操作取出相應(yīng)的id值
HashMap<String, Object> item = (HashMap<String, Object>) lview.getItemAtPosition(position);
int personid = (Integer) item.get("id");
Toast.makeText(getApplicationContext(), personid + "", 1).show();
}
}
新聞熱點(diǎn)
疑難解答
圖片精選