我遵循了本教程(http://www.startingandroid.com/how-to-use-sqlite-database-in-android/),因为我对Android开发相对较新,并希望了解SQL的工作原理。由于我希望将CardView和RecyclerView用于我正在开发的应用程序,因此该教程对于让我入门非常有帮助。
但是,我已经进一步实施了' Contextual Action Bar'能够“收藏”'或者'删除'选定的项目(我的代码可以在下面看到)。所以,我的问题是,如何检索所选项目的位置并从中提取SQL ID以及如何将多项选择与CAB结合使用?
@Override
public UserViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.user_row, parent, false);
UserViewHolder userViewHolder = new UserViewHolder(v);
v.setClickable(true);
v.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Snackbar.make(v, "CLICK", Snackbar.LENGTH_SHORT).show();
}
});
v.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
Snackbar.make(v, "LONG CLICK", Snackbar.LENGTH_SHORT).show();
if (mActionMode != null) {
return false;
}
v.startActionMode(new ActionMode.Callback() {
@Override
public boolean onCreateActionMode(ActionMode mode, Menu menu) {
MenuInflater inflater = mode.getMenuInflater();
inflater.inflate(R.menu.context, menu);
return true;
}
@Override
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
return false;
}
@Override
public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
//get number of selected items
switch (item.getItemId()) {
case R.id.context_favourite:
//SQL - Favourite Item
mode.finish();
case R.id.context_delete:
//SQL - Delete Item
mode.finish();
}
return false;
}
@Override
public void onDestroyActionMode(ActionMode mode) {
mActionMode = null;
}
});
return true;
}
});
return userViewHolder;
}
答案 0 :(得分:0)
我遇到了同样的问题,最终在取景器中保存了光标中的id。在createviewholder func中执行此操作