In this page you can find info about:
PAY ATTENTION: to use this feature you have to use the library-extra. for more info.
This feature is base on ListViewAnimation provided by Niek Haarman.
Check the build.gradle
to know the last version used.
The library-extra provides a @drawable/card_drag
icon kindly offered by Taylor Ling.
Migration from 1.8.0 (and previous releases) - to 1.9.0
The 1.9.0 may introduce a little breaking in the OnItemMovedListener listener due to a change in the ListViewAnimation lib. To migrate your code you have to:
- change the signature of
onItemMoved(int newPosition)
method toonItemMoved(int originalPosition, int newPosition)
.
Creating a CardListDragDropView
is pretty simple.
First, you need an XML layout that will display the CardListDragDropView
.
<it.gmariotti.cardslib.library.extra.dragdroplist.view.CardListDragDropView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="10dp"
android:id="@+id/carddemo_extra_list_dragdrop"
card:list_card_layout_resourceID="@layout/carddemo_extras_list_card_dragdrop_layout"/>
You have to customize the layout used for each item in ListView using the attr: card:list_card_layout_resourceID="@layout/my_layout
to provide an area or an image where the drag and drop feature is enable.
(You can use the same rules of CardListView. Check this link)
I suggest you using a ImageView with a "standard" drag and drop icon.
The library-extra provides a @drawable/card_drag
icon kindly offered by Taylor Ling.
Example:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:card="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<!-- Drag and Drop icon -->
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginRight="16dp"
android:layout_marginLeft="16dp"
android:src="@drawable/card_drag"/>
<!-- You can customize this layout.
You need to have in your layout a `CardView` with the ID `list_cardId` -->
<it.gmariotti.cardslib.library.view.CardView
android:id="@+id/list_cardId"
android:layout_width="match_parent"
android:layout_height="wrap_content"
style="@style/list_card.thumbnail"
card:card_layout_resourceID="@layout/carddemo_extras_card_thumbnail_layout"
/>
</LinearLayout>
Then create an Array of Card
s:
It is very important that cards have a stable Id.
ArrayList<Card> cards = new ArrayList<Card>();
//Create a Card
Card card = new Card(getContext());
//Card must have a stable Id.
card.setId("a"+i);
//Create a CardHeader
CardHeader header = new CardHeader(getContext());
....
//Add Header to card
card.addCardHeader(header);
cards.add(card);
Last create a CardDragDropArrayAdapter
, get a reference to the CardListDragDropView
from your code and set your adapter.
//Set the adapter
CardDragDropArrayAdapter mCardArrayAdapter = new CardDragDropArrayAdapter(getActivity(), cards);
CardListDragDropView mListView = (CardListDragDropView) getActivity().findViewById(R.id.carddemo_extra_list_dragdrop);
if (mListView != null) {
mListView.setAdapter(mCardArrayAdapter);
}
By default you can also enable the drag and drop feature with a long click on the cards. You can disable this feature using this method:
adapter.setEnableDragSupportOnLongClickOnCard(false);
You can set a listener to be notified when an item is dropped:
//Listener
mListView.setOnItemMovedListener(new DynamicListView.OnItemMovedListener() {
@Override
public void onItemMoved(int newPosition) {
Card card = mCardArrayAdapter.getItem(newPosition);
Toast.makeText(getActivity(),"Card "+card.getId() + " moved to position " + newPosition, Toast.LENGTH_SHORT ).show();
}
});
This kind of View, doesn't support these Card
features:
- swipe action
- collapse/expand action
You can see an example in DragDropListFragment
(source).
Some libraries use a own adapter as ListViewAnimations
In this case you can use this code:
mListView.setExternalAdapter(ownAdapter,mCardArrayAdapter);
Pay attention. You can use this method, if your ownAdapter calls the mCardArrayAdapter#getView() method.
Example with ListViewAnimations:
CardDragDropArrayAdapter mCardArrayAdapter = new CardDragDropArrayAdapter(getActivity(), cards);
CardListDragDropView mListView = (CardListDragDropView) getActivity().findViewById(R.id.carddemo_extra_list_dragdrop);
//Add an animator
AnimationAdapter animCardArrayAdapter = new SwingLeftInAnimationAdapter(mCardArrayAdapter);
animCardArrayAdapter.setAbsListView(staggeredView);
animCardArrayAdapter.setInitialDelayMillis(500);
if (mListView != null) {
mListView.setExternalAdapter(animCardArrayAdapter, mCardArrayAdapter);
}