-
Notifications
You must be signed in to change notification settings - Fork 6.3k
Using the CardView
Android 5.0 introduces a new widget called CardView
which essentially can be thought of as a FrameLayout
with rounded corners and shadow based on its elevation. Note that a CardView wraps a layout and will often be the container used in a layout for each item within a ListView
or RecyclerView.
CardView
should be used when displaying heterogenous content. Using a list or a grid of tiles (non-cards) for homogenous content is preferred since the boundaries in a card can distract the user from quickly scanning a list.
Lets assume your layout looks something like this:
<FrameLayout
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<!-- Main Content View -->
<RelativeLayout>
...
</RelativeLayout>
</FrameLayout>
To create a card using this layout, first you need to import the support library in your build.gradle
file.
dependencies {
...
implementation 'com.android.support:cardview-v7:25.2.1'
//AndroidX
implementation "androidx.cardview:cardview:1.0.0"
}
Now replace the FrameLayout
with CardView
.
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<!-- Main Content View -->
<androidx.constraintlayout.widget.ConstraintLayout>
...
</androidx.constraintlayout.widget.ConstraintLayout>
</android.support.v7.widget.CardView>
Thats it! Using the support library ensures backward compatibility as well; although the visual treatment for cards are slightly different when running on versions prior to Android L. See Support on Older Platforms section for more details.
CardView
provides a default elevation and corner radius so that cards have a consistent appearance across the platforms. However, you may choose to customize these values if you desire to do so. We can also set the background color of the card.
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
card_view:cardBackgroundColor="#E6E6E6"
card_view:cardCornerRadius="8dp"
card_view:cardElevation="8dp">
<!-- Main Content View -->
<androidx.constraintlayout.widget.ConstraintLayout>
...
</androidx.constraintlayout.widget.ConstraintLayout>
</android.support.v7.widget.CardView>
Note that the card_view:cardElevation
is used to determine the size and softness of the shadow so as to realistically depict the depth. These properties can be set programmatically as well:
CardView card = ...
card.setCardBackgroundColor(Color.parseColor("#E6E6E6"));
card.setMaxCardElevation(0.0);
card.setRadius(5.0);
See the CardView docs for additional properties.
By default, a CardView
is not tappable and it doesn't show any touch feedback. Touch feedback animations provide users with visual feedback when a CardView
is touched. To enable this behavior, add the following attributes to your CardView
.
<android.support.v7.widget.CardView
...
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground">
...
</android.support.v7.widget.CardView>
Using the android:foreground="?android:attr/selectableItemBackground"
property on a CardView
enables the ripple effect to originate from the touch origin.
On platforms before Android L, CardView
adds padding to support corner radius, since rounded corner clipping can be an expensive operation. Similarly, for shadows, before L, CardView adds content padding and draws shadows to that area. This content padding is based on the elevation, and as per the docs:
This padding amount is equal to maxCardElevation + (1 - cos45) * cornerRadius on the sides and maxCardElevation * 1.5 + (1 - cos45) * cornerRadius on top and bottom.
Thus, if you would like to specify custom padding on the content, you need to use a new attribute
card_view:contentPadding
.
Similarly, to change the background color of a CardView, you need to use a new attribute
card_view:cardBackgroundColor
.
Created by CodePath with much help from the community. Contributed content licensed under cc-wiki with attribution required. You are free to remix and reuse, as long as you attribute and use a similar license.
Finding these guides helpful?
We need help from the broader community to improve these guides, add new topics and keep the topics up-to-date. See our contribution guidelines here and our topic issues list for great ways to help out.
Check these same guides through our standalone viewer for a better browsing experience and an improved search. Follow us on twitter @codepath for access to more useful Android development resources.