我通过标记填充ListView的SQLite数据库表中的项目来创建用户选择的收藏夹列表。然后,这些标记的项目将填充收藏夹ListView。为了正确执行此操作,我需要从填充ListView的SQLite数据库表中获取rowId,以便可以添加标志。如何获取rowId?
这是我当前的代码:
OnItemClickListener:
mListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int
position, long id) {
String selected = (String)
mListView.getItemAtPosition(position);
mItemTextView = findViewById(R.id.itemWords);
mItemNumberTextView = findViewById(R.id.itemNumber);
mId = id;
mBookCopied =
mItemHeaderNameTextView.getText().toString();
mItemCategoryNumberCopied = Integer.toString(mCategorySelected + 1);
mItemNumberCopied =
mItemNumberTextView.getText().toString();
mPosition = position + 1;
mCopiedItemListItem = mItemCopied + " " +
mCategoryNumberCopied + ":" + mPosition + "\n\n" + selected;
showMenu(view);
}
});
ItemAdapter:
class ItemAdapter extends ArrayAdapter<String> {
public ItemAdapter(Context context, int resource1, List<String> items) {
super(context, resource1, items);
mContext = context;
mResource1 = resource1;
mItems= items;
}
@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
View listItem = convertView;
int pos = position + 1;
if (listItem == null) {
listItem = LayoutInflater.from(mContext).inflate(mResource1, parent, false);
}
mItemNumberTextView = (TextView) listItem.findViewById(R.id.itemNumber);
mItemumberTextView.setText(String.valueOf(pos) + " ");
mItemTextView = (TextView) listItem.findViewById(R.id.itemWords);
mItemTextView.setText(mItems.get(position));
}
return listItem;
}
}
我尝试使用onItemClickListener的“ long id”部分,但这只是返回ListView中的位置。我需要数据库表中的实际rowId。
我在这里想念什么?感谢您的帮助。
答案 0 :(得分:1)
您需要
使用CursorAdapater(然后 long id 将是 ID ,并指出id列必须称为 _id ({ {1}}),您可以创建一列以 rowid 作为别名的列,例如BaseColumns._ID
)。
rowid AS _id
使用class ItemAdapter extends ArrayAdapter....
使用包含id为class ItemAdapter extends CursorAdapter
但提取为ArrayList<String>
的ID NOT数据的源,并通过getItem(position)访问它,并使用适当的对象的方法提取ID。
建立一个互补数组,以便该职位可以访问 id 。