ОК, вот как я это делаю:
row.xml (используется для каждой строки в представлении списка):
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="4px"
>
<LinearLayout
android:id="@+id/LinearLayout01"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center_vertical"
android:textStyle="bold"
android:singleLine="true"
android:ellipsize="end"
android:id="@+id/itemDescription"/>
<TextView
android:text="@+id/TextView01"
android:id="@+id/Category"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
</TextView>
</LinearLayout>
<LinearLayout
android:id="@+id/LinearLayout01"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="fill_parent"
android:text="@+id/TextView01"
android:gravity="center_vertical"
android:layout_weight="1"
android:singleLine="true"
android:ellipsize="end"
android:id="@+id/itemManufacturer"
android:layout_height="wrap_content">
</TextView>
<TextView
android:text="@+id/TextView01"
android:id="@+id/EAN"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
</TextView>
</LinearLayout>
</LinearLayout>
Я расширяю CursorAdapter
, чтобы создать или повторно-использовать существующие ListActivity
строки (предоставленные ListActivity
), определенные в row.xml.bindView
используется, если Android хочет, чтобы вы повторно использовали существующий ресурс строки, newView
используется, если хочет, чтобы вы создали новый:
class BarcodeAdapter extends CursorAdapter {
BarcodeAdapter(Cursor c) {
super(kitchenListInventoryActivity.this, c);
}
@Override
public void bindView(View row, Context ctxt,
Cursor c) {
BarcodeHolder holder=(BarcodeHolder)row.getTag();
holder.populateFrom(c, helper);
}
@Override
public View newView(Context ctxt, Cursor c,
ViewGroup parent) {
LayoutInflater inflater=getLayoutInflater();
View row = null;
row = inflater.inflate(R.layout.row, parent, false);
BarcodeHolder holder=new BarcodeHolder(row);
row.setTag(holder);
return(row);
}
}
BarcodeHolder
- это просто вспомогательный классдля хранения Java-представления строки, которую я связываю с элементом ListActivity
с setTag
выше.Не обязательно самый элегантный способ, но он упрощает вещи.: * 10101 *
static class BarcodeHolder {
private TextView description=null;
private TextView manufacturer=null;
private TextView EAN = null;
private TextView category = null;
private View row=null;
BarcodeHolder(View row) {
this.row=row;
description=(TextView)row.findViewById(R.id.itemDescription);
manufacturer=(TextView)row.findViewById(R.id.itemManufacturer);
EAN=(TextView)row.findViewById(R.id.EAN);
category = ( TextView )row.findViewById(R.id.Category);
}
void populateFrom(Cursor c, BarcodeHelper helper) {
Cursor invCursor = helper.getByInventoryEAN(helper.getBarcode(c));
Cursor dbCursor = helper.getByEAN(helper.getBarcode(c));
dbCursor.moveToFirst();
invCursor.moveToFirst();
int qty = helper.getQuantity ( invCursor );
String desc = helper.getDescription(dbCursor) + " (" + String.valueOf( qty ) + ")" ;
description.setText( desc );
manufacturer.setText(helper.getManufacturer(dbCursor));
category.setText(helper.getCategory(dbCursor));
}
}
Чтобы собрать все это вместе, я называю initList
в моем onCreate
из ListActivity
:
private void initList ( ) {
if ( model != null ) {
stopManagingCursor(model);
model.close();
}
model = helper.getAllInventory();
startManagingCursor(model);
adapter = new BarcodeAdapter(model);
setListAdapter(adapter);
}
model
- это Cursor
, а adapter
- это экземпляр BarcodeAdapter
, который я показал выше.Я говорю ListActivity
использовать этот адаптер, чтобы я мог правильно заполнять строки.getAllInventory
является членом BarcodeHelper
, который переопределяет SQLiteOpenHelper
:
public Cursor getAllInventory( ) {
String sql = "SELECT _id, EAN, quantity FROM Inventory ORDER BY EAN";
return(getReadableDatabase().rawQuery(sql, null));
}
Вспомогательный объект просто содержит набор вспомогательных функций.
Все это основано на 1040 * превосходное учебное пособие по Android от CommonsWare, которое я не могу порекомендовать, но здесь должно быть достаточно, чтобы начать работу.