Android GridLayout 单个 CardView 占据所有屏幕

时间:2021-01-17 12:21:11

标签: android overflow cardview

我想实现一个 2x2 GridLayout,这样我就可以显示 4 个卡片视图。我的问题是单个卡片视图占用了所有空间。当我添加第二个(第 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>

2 个答案:

答案 0 :(得分:0)

使用两个 cardview 的 layout_width 代替 wrap_content

答案 1 :(得分:0)

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

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

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