android - 即使与父级匹配,ConstraintLayout 列表项的长度也不相同?

标签 android xml android-layout android-constraintlayout

我有一个使用 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>

Here is what it should like it:

And here is output:

最佳答案

使用下面的代码,它看起来是您预期的输出

<?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/

相关文章:

c# - 在 C# 中使用 Regex 提取 XML 值

android - 如何 float View 查看所有 Activity

java - 删除下载目录中的文件

java - 使用 Jackson XML 绑定(bind)将列表映射到 Pojo

java - Android 应用程序 - 删除多余的填充

python - 奥杜 8 : How can I send context to python method?

android - 当键盘打开时,布局应该在 android 中移动到上方

android-layout - 如何从 android studio 的单个可绘制文件夹中检测多个分辨率图像

java - 使用aidl调用另一个应用程序中的服务方法

android - 如何为特定应用添加特定 CSS