0
ドラッグビューでリスト内の位置を変更できるフラグメント内のカードビューを作成したいと思っています(ナビゲーションドロウラー)。ドラッグアンドドロップによるAndroidカードビューの変更
私のレイアウトファイルの構造:
FrameLayout{
LinearLayout{
cardview_1
card_view_2}}
ドラッグビューでリスト内の位置を変更できるフラグメント内のカードビューを作成したいと思っています(ナビゲーションドロウラー)。ドラッグアンドドロップによるAndroidカードビューの変更
私のレイアウトファイルの構造:
FrameLayout{
LinearLayout{
cardview_1
card_view_2}}
はrecyclerViewを使用すると、ルートビューとしてcardViewでrowItemLayout.xmlまたはcolumnItemLayout.xmlを作ります。 次に、recyclerViewの機能を使用します。
ItemTouchHelper itemTouchHelper = new ItemTouchHelper(createHelperCallback());
itemTouchHelper.attachToRecyclerView(recyclerView);
private ItemTouchHelper.Callback createHelperCallback() {
ItemTouchHelper.SimpleCallback simpleItemTouchCallback =
new ItemTouchHelper.SimpleCallback(ItemTouchHelper.UP | ItemTouchHelper.DOWN,
ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT) {
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder,
RecyclerView.ViewHolder target) {
moveItem(viewHolder.getAdapterPosition(), target.getAdapterPosition());
return true;
}
@Override
public void onSwiped(final RecyclerView.ViewHolder viewHolder, int swipeDir) {
deleteItem(viewHolder.getAdapterPosition());
}
};
return simpleItemTouchCallback;
}
private void moveItem(int oldPos, int newPos) {
ListItem item = (ListItem) listData.get(oldPos);
listData.remove(oldPos);
listData.add(newPos, item);
adapter.notifyItemMoved(oldPos, newPos);
}
private void deleteItem(final int position) {
listData.remove(position);
adapter.notifyItemRemoved(position);
}