Skip to content

Latest commit

 

History

History
171 lines (120 loc) · 6.04 KB

DRAGDROPLIST.md

File metadata and controls

171 lines (120 loc) · 6.04 KB

Cards Library-extra: CardListDragDropView

In this page you can find info about:

Intro

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.

Screen

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 to onItemMoved(int originalPosition, int newPosition).

Creating a base CardListDragDropView

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 Cards:

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:

  1. swipe action
  2. collapse/expand action

You can see an example in DragDropListFragment (source).

How to use an external adapter

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);
        }