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
将确保两张卡片具有相同的宽度,无论其内容如何
我想实现 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
将确保两张卡片具有相同的宽度,无论其内容如何