Les applications doivent souvent afficher les données dans des conteneurs de style similaire, tels que
contenant des informations
sur les éléments d'une liste. Le système fournit
l'API CardView
pour vous permettre
afficher les informations dans des fiches cohérentes sur l'ensemble de la plate-forme. Pour
Par exemple, les fiches ont une élévation par défaut au-dessus du groupe de vues parent.
le système dessine des ombres en dessous d'elles. Les cartes permettent de contenir un groupe
tout en offrant un style cohérent au conteneur.
Ajouter les dépendances
Le widget CardView
fait partie d'AndroidX. Pour l'utiliser dans
votre projet, ajoutez la dépendance suivante au fichier build.gradle
de votre module d'application
:
Groovy
dependencies { implementation "androidx.cardview:cardview:1.0.0" }
Kotlin
dependencies { implementation("androidx.cardview:cardview:1.0.0") }
Créer des fiches
Pour utiliser un élément CardView
, ajoutez-le à votre fichier de mise en page. Utilisez-le comme groupe de vues pour
contiennent d'autres vues. Dans l'exemple suivant, CardView
contient un
ImageView
et quelques TextViews
pour présenter des informations à l'utilisateur:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:padding="16dp"
android:background="#E0F7FA"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.cardview.widget.CardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<androidx.constraintlayout.widget.ConstraintLayout
android:padding="4dp"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/header_image"
android:layout_width="match_parent"
android:layout_height="200dp"
android:src="@drawable/logo"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/title"
style="@style/TextAppearance.MaterialComponents.Headline3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="4dp"
android:text="I'm a title"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/header_image" />
<TextView
android:id="@+id/subhead"
style="@style/TextAppearance.MaterialComponents.Subtitle2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="4dp"
android:text="I'm a subhead"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/title" />
<TextView
android:id="@+id/body"
style="@style/TextAppearance.MaterialComponents.Body1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="4dp"
android:text="I'm a supporting text. Very Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/subhead" />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.cardview.widget.CardView>
</androidx.constraintlayout.widget.ConstraintLayout>
L'extrait de code précédent produit quelque chose de semblable à ce qui suit, en supposant que vous devez utiliser la même image du logo Android:
Dans cet exemple, la carte est dessinée à l'écran avec une élévation par défaut, ce qui
le système dessine
une ombre en dessous. Vous pouvez définir une élévation personnalisée
pour une carte avec l'attribut card_view:cardElevation
. Une carte à un débit supérieur
une élévation plus prononcée a une ombre plus prononcée, et une carte à une altitude plus faible a une
une ombre plus claire. CardView
utilise l'élévation réelle et les ombres dynamiques sur Android.
5.0 (niveau d'API 21) ou version ultérieure.
Utilisez les propriétés suivantes pour personnaliser l'apparence du widget CardView
:
- Pour définir l'arrondi d'angle dans vos mises en page, utilisez la propriété
card_view:cardCornerRadius
. - Pour définir l'arrondi d'angle dans votre code, utilisez la méthode
CardView.setRadius
. - Pour définir la couleur d'arrière-plan d'une fiche, utilisez
card_view:cardBackgroundColor
. .