问题描述
我想实现一个 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>
解决方法
使用两个 cardview 的 layout_width
代替 wrap_content
两个 CardViews 都匹配父级的宽度,这就是为什么,你只能看到一个 你可以这样改
android:layout_width="wrap_content"
app:layout_columnWeight="1"
使用 app:layout_columnWeight
将确保两张卡片的宽度相同,无论其内容如何