Android CardView with RecyclerView
In the previous article, we learned to you about Android RecyclerView. Now in this article, we are going to learn Android CardView with RecyclerView.
CardView is the new control introduced in v7 Support Library. Its a FrameLayout with shadow, corner radius and elevation property after Android Lollipop.
CardView is mostly used for good looking UI with RecyclerView. Here we are using CardView in our previous article’s UI. We are going to our previous article sample code. Let’s start.
First open build.gradle file from app level and add a dependency for CardView: com.android.support:cardview-v7:27.0.2 and sync the project.
Change item_row.xml layout as below:
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:android='http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="8dp"
app:cardCornerRadius="6dp"
app:cardElevation="6dp"><LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="8dp"
android:orientation="vertical"><TextView
android:id="@+id/txtName"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="1dp"
android:textColor="@color/black"
android:textSize="18sp" /><TextView
android:id="@+id/txtDistance"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="1dp"
android:textColor="@color/black" /><TextView
android:id="@+id/txtGravity"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="1dp"
android:textColor="@color/black" /><TextView
android:id="@+id/txtDiameter"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="1dp"
android:textColor="@color/black" /></LinearLayout></android.support.v7.widget.CardView>
Remove this line from activity to remove divider between row. Because CardView has its own effect (we say elevation) for separation of two rows in RecyclerView.
recyclerView.addItemDecoration(new LineDividerItemDecoration(this, R.drawable.line_divider))
Remove RecyclerView background color (blue) from activity_main.xml
Now run the project and you can see below output:
Now we are going to make it more good looking with colours. Use app:cardBackgroundColor=”@color/light_blue” for change background colour of CardView. Use the only cardBackgroundColor, do not use backgroundColor.
Find source here.
More examples of CardView with RecyclerView are below: