我在 Android 中做一个购物清单,为此我将产品存储在 SQLite 数据库中。
产品是可点击的,因此它们应该被删除。更新数据库工作正常,但删除线未在正确的项目上进行。/** * 从 DB 加载列表,将数据放入 Listview 并遍历非活动产品 */
public void loadListe()
{
//---get all titles---
meineListe.clear();
adapter.clear();
db.open();
Cursor c = db.getAllTitles();
ArrayList<String> strikedItems = new ArrayList<String>();
strikedItems.clear();
if (c.moveToFirst())
{
do {
if (c.getInt( 0 )==1) {
meineListe.add(c.getString( 1 ));
strikedItems.add( c.getString( 1 ) );
}
else meineListe.add( c.getString( 1 ));
} while (c.moveToNext());
}
db.close();
//Strike Through on inactive Items
list = this.getListView();
for (int i = 0; i < list.getChildCount(); i++) {
LinearLayout row = (LinearLayout) list.getChildAt( i );
TextView title;
title = (TextView) row.getChildAt( 0 );
//System.out.println("zeile "+i+ " "+title.getText());
if(strikedItems.contains( title.getText() ))
{
title.setPaintFlags( Paint.STRIKE_THRU_TEXT_FLAG | Paint.ANTI_ALIAS_FLAG);
System.out.println("zeile "+i+ " Title: "+title.getText());
title.setTextColor(0xFFFF0000); //black
}
}