Android GridLayout 单个 CardView 占据所有屏幕

Android GridLayout single CardView takes all screen

我想实现 2x2 GridLayout,这样我就可以显示 4 个卡片视图。我的问题是单个 Card View 占用了所有 space。当我添加第二个(第 0 行,第 1 列)时,它位于屏幕外(右侧)。

这是我的布局代码

<?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:layout_width="match_parent"
    android:layout_height="match_parent">

<androidx.gridlayout.widget.GridLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:columnCount="2"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:rowCount="2">

    <androidx.cardview.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_row="0"
        app:layout_column="0" />

    <androidx.cardview.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_row="0"
        app:layout_column="1" />
</androidx.gridlayout.widget.GridLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

将两个 cardview 的 layout_width 用作 wrap_content 而不是

两个 CardView 都匹配父级的宽度,这就是为什么你只能看到一个 你可以这样改

android:layout_width="wrap_content"
app:layout_columnWeight="1"

使用 app:layout_columnWeight 将确保两张卡片具有相同的宽度,无论其内容如何