我有一个使用 contraintlayout 的 recyclerview,它在预览中看起来像我想要的,但在运行它时,约束表现得很有趣。似乎每个列表项都有自己的宽度。
我尝试将 android:minWidth=150dp
添加到 constraintlayout 标签和 ID 为 listItemSubject 的标签,但都没有帮助。
注意:此应用不适用于较新的手机,但可以在 Nexus 5X 上运行。
这是 xml:
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:layout_marginStart="5dp"
android:layout_marginEnd="5dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
>
<TextView
android:id="@+id/listItemSubject"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Subject: "
android:textSize="15pt"
app:fontFamily="sans-serif-medium"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/listItemText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Content: "
android:textSize="12pt"
app:fontFamily="sans-serif-condensed-light"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/listItemSubject" />
<TextView
android:id="@+id/listItemLikes"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Yums: "
android:textSize="12pt"
app:fontFamily="sans-serif-light"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/likeImage" />
<TextView
android:id="@+id/listItemYucks"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Yucks: "
android:textSize="12pt"
app:fontFamily="sans-serif-light"
app:layout_constraintEnd_toEndOf="@+id/YuckImage"
app:layout_constraintTop_toBottomOf="@+id/YuckImage" />
<ImageButton
android:id="@+id/likeImage"
android:layout_width="53dp"
android:layout_height="55dp"
android:layout_gravity="center"
app:layout_constraintLeft_toLeftOf="@+id/listItemSubject"
app:layout_constraintStart_toStartOf="parent"
app:srcCompat="@drawable/yum_emoji" />
<ImageButton
android:id="@+id/YuckImage"
android:layout_width="53dp"
android:layout_height="55dp"
android:layout_gravity="center"
android:padding="0dp"
android:scaleType="fitCenter"
app:srcCompat="@drawable/puke_emoji"
app:layout_constraintRight_toRightOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
最佳答案
使用下面的代码,它看起来是您预期的输出
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content" // Use wrap_content for single item
android:layout_marginStart="5dp" // Remove gravity centre
android:layout_marginEnd="5dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp">
<TextView
android:id="@+id/listItemSubject"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Subject: "
android:textSize="15pt"
app:fontFamily="sans-serif-medium"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/listItemText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Content: "
android:textSize="12pt"
app:fontFamily="sans-serif-condensed-light"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/listItemSubject" />
<TextView
android:id="@+id/listItemLikes"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Yums: "
android:textSize="12pt"
app:fontFamily="sans-serif-light"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/likeImage" />
<TextView
android:id="@+id/listItemYucks"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Yucks: "
android:textSize="12pt"
app:fontFamily="sans-serif-light"
app:layout_constraintEnd_toEndOf="@+id/YuckImage"
app:layout_constraintTop_toBottomOf="@+id/YuckImage" />
<ImageButton
android:id="@+id/likeImage"
android:layout_width="53dp"
android:layout_height="55dp"
android:layout_gravity="center"
app:layout_constraintLeft_toLeftOf="@+id/listItemSubject"
app:layout_constraintStart_toStartOf="parent" // Constraint are missing
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/yum_emoji" />
<ImageButton
android:id="@+id/YuckImage"
android:layout_width="53dp"
android:layout_height="55dp"
android:layout_gravity="center"
android:padding="0dp"
android:scaleType="fitCenter"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" // Constraint are missing
app:srcCompat="@drawable/puke_emoji" />
</androidx.constraintlayout.widget.ConstraintLayout>
关于android - 即使与父级匹配,ConstraintLayout 列表项的长度也不相同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58357449/