No good example about RecyclerView and StaggeredGridLayoutManager in Android Docs

AndroidAndroid RecyclerviewStaggered Gridview

Android Problem Overview


I couldn't find any better example for using RecyclerView with StaggeredGridLayoutManager. Not even in Android Docs.

>Q1. I need some examples which can give proper explanation about how to use RecyclerView with StaggeredGridLayoutManager. > >Q2. Can anyone tell me if it is possible to create following layout using RecyclerView with StaggeredGridLayoutManager

example

So far i have found this link which is not at all useful.

I also found this link for cardslib but it is too much complex in implementation and has too much dependencies which will increase my app size unnecessarily.

Android Solutions


Solution 1 - Android

For those who are still landing up on this question.

You could modify the following code as per your needs:
First add dependency libraries for Android RecyclerView and CardView

compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.android.support:cardview-v7:23.4.0'
compile 'com.android.support:recyclerview-v7:23.4.0'

Your main activity layout activity_main.xml will simply be like

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="7dp"
    tools:context=".MainActivity">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="vertical" />

</RelativeLayout>


Define layout of a card in a layout file named book_list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/card_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
card_view:cardUseCompatPadding="true">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:orientation="vertical">

    <TextView
        android:id="@+id/BookName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="5dp"
        android:textColor="@android:color/black"
        android:textSize="16sp" />

    <TextView
        android:id="@+id/AuthorName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_below="@+id/country_photo"
        android:background="#1976D2"
        android:gravity="center_horizontal"
        android:paddingBottom="8dp"
        android:paddingTop="8dp"
        android:text="@string/hello_world"
        android:textColor="#ffffff"
        android:textSize="13sp" />
</LinearLayout>

</android.support.v7.widget.CardView> 


Define this layout as a class ItemObject.java

public class ItemObject
{
    private String _name;
    private String _author;

    public ItemObject(String name, String auth)
    {
        this._name = name;
        this._author = auth;
    }

    public String getName()
    {
        return _name;
    }

    public void setName(String name)
    {
        this._name = name;
    }

    public String getAuthor()
    {
        return _author;
    }

    public void setAuthor(String auth)
    {
        this._author = auth;
    }
}


Define a custom adapter SampleRecyclerViewAdapter to populate the cards

public class SampleRecyclerViewAdapter extends RecyclerView.Adapter<SampleViewHolders>
{
    private List<ItemObject> itemList;
    private Context context;

    public SampleRecyclerViewAdapter(Context context,
		List<ItemObject> itemList)
    {
	    this.itemList = itemList;
	    this.context = context;
    }

    @Override
    public SampleViewHolders onCreateViewHolder(ViewGroup parent, int viewType)
    {
	    View layoutView = LayoutInflater.from(parent.getContext()).inflate(
			R.layout.book_list_item, null);
        SampleViewHolders rcv = new SampleViewHolders(layoutView);
	    return rcv;
    }

    @Override
    public void onBindViewHolder(SampleViewHolders holder, int position)
    {
	    holder.bookName.setText(itemList.get(position).getName());
	    holder.authorName.setText(itemList.get(position).getAuthor());
    }

    @Override
    public int getItemCount()
    {
	    return this.itemList.size();
    }
}


We would also need a viewholder for each ItemObject. So define a class SampleViewHolders

public class SampleViewHolders extends RecyclerView.ViewHolder implements
	View.OnClickListener
{
    public TextView bookName;
    public TextView authorName;

    public SampleViewHolders(View itemView)
    {
	    super(itemView);
	    itemView.setOnClickListener(this);
	    bookName = (TextView) itemView.findViewById(R.id.BookName);
	    authorName = (TextView) itemView.findViewById(R.id.AuthorName);
    }

    @Override
    public void onClick(View view)
    {
	    Toast.makeText(view.getContext(),
			"Clicked Position = " + getPosition(), Toast.LENGTH_SHORT)
			.show();
    }
}

Now in MainActivity, assign an instance of StaggeredGridLayoutManager to recycler_view to define how the components will appear.
Also populate the cards using instance of SampleRecyclerViewAdapter, as follows

public class MainActivity extends AppCompatActivity
{
    private StaggeredGridLayoutManager _sGridLayoutManager;

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

	    RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
	    recyclerView.setHasFixedSize(true);

	    _sGridLayoutManager = new StaggeredGridLayoutManager(2,
            StaggeredGridLayoutManager.VERTICAL);
	    recyclerView.setLayoutManager(_sGridLayoutManager);

	    List<ItemObject> sList = getListItemData();

	    SampleRecyclerViewAdapter rcAdapter = new SampleRecyclerViewAdapter(
			MainActivity.this, sList);
	    recyclerView.setAdapter(rcAdapter);
    }

    private List<ItemObject> getListItemData()
    {
	    List<ItemObject> listViewItems = new ArrayList<ItemObject>();
	    listViewItems.add(new ItemObject("1984", "George Orwell"));
	    listViewItems.add(new ItemObject("Pride and Prejudice", "Jane Austen"));
	    listViewItems.add(new ItemObject("One Hundred Years of Solitude", "Gabriel Garcia Marquez"));
	    listViewItems.add(new ItemObject("The Book Thief", "Markus Zusak"));
		listViewItems.add(new ItemObject("The Hunger Games", "Suzanne Collins"));
	    listViewItems.add(new ItemObject("The Hitchhiker's Guide to the Galaxy", "Douglas Adams"));
	    listViewItems.add(new ItemObject("The Theory Of Everything", "Dr Stephen Hawking"));

	    return listViewItems;
    }
}

Output will look something like this Two Colums Output

For your requirement, you can incorporate an ImageView in book_list_item.xml and populate it accordingly in SampleViewHolders
Also note, to change number of columns from 2 to 3.

You could change declaration in MainActivity as

_sGridLayoutManager = new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL);
recyclerView.setLayoutManager(_sGridLayoutManager);

Which will give an output like this Three Column Output

Here's another simple tutorial

Solution 2 - Android

Assuming that you've already created an adapter and initialized the RecyclerView, the following code should do what you're looking for.

StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL);
recyclerView.setLayoutManager(staggeredGridLayoutManager);

For further reference and documentation please check the following link: https://developer.android.com/reference/android/support/v7/widget/StaggeredGridLayoutManager.html

Solution 3 - Android

Our friends "Henry" have a good and simple explain here.

And I think below constructor is suitable for most uses :

StaggeredGridLayoutManager(num , LinearLayoutManager.VERTICAL)
// where 'num' is your columns count
// LinearLayoutManager.VERTICAL = 1

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionAmrut BidriView Question on Stackoverflow
Solution 1 - Androidg4thView Answer on Stackoverflow
Solution 2 - AndroidJ-meView Answer on Stackoverflow
Solution 3 - AndroidABSView Answer on Stackoverflow