ConstraintLayout Flow帮助程序示例

Ben*_*Tec 7 xml layout android android-constraintlayout

我在一个博客条目中读到,在ConstraintLayout2.0.0中引入了一种创建视图流的方法。我真正想要实现的是:我有几个TextView彼此固定大小的。根据屏幕大小,一些TextView应当推入下一行。

大屏幕上有六个示例TextViews

[AAA] [BBB] [CCC] [DDD]

[EEE] [FFF]

在具有六个小屏幕的示例TextViews

[AAA] [BBB]

[CCC] [DDD]

[EEE] [FFF]

我已经看到了这个#1问题的提出使用FlexboxLayout,但有一个评论说,同样的事情现在可以使用来实现ConstraintLayout

任何人都可以给我一个例子,说明如何使用来实现所需的行为ConstraintLayout?我找不到关于此的任何说明。提前致谢。

Yas*_*aka 8

您可以通过在中添加androidx.constraintlayout.helper.widget.Flow虚拟视图androidx.constraintlayout.widget.ConstraintLayout并使用app:constraint_referenced_ids属性引用所有文本视图来实现此目的。

以下示例显示了我是如何实现的。

<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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/text1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[AAAAAAAA]"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/text2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[BBBBBBBB]"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/text3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[CCCCCCCC]"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/text4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[DDDDDDDD]"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/text5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[EEEEEEEE]"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/text6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="[FFFFFFFF]"
        tools:ignore="MissingConstraints" />

    <androidx.constraintlayout.helper.widget.Flow
        android:id="@+id/flow1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:padding="10dp"
        app:constraint_referenced_ids="text1,text2,text3,text4,text5,text6"
        app:flow_horizontalBias="0"
        app:flow_horizontalGap="10dp"
        app:flow_horizontalStyle="packed"
        app:flow_verticalBias="0"
        app:flow_wrapMode="chain"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
Run Code Online (Sandbox Code Playgroud)

app:flow_尝试使用属性来更改文本视图的排列方式,例如对齐方式,边距等。

最终结果应如下所示,具体取决于您的屏幕尺寸。

结果

  • 我认为在这种情况下 wrap_aligned 的 wrapMode 很好,因为这会将它变成列 https://developer.android.com/reference/android/support/constraint/helper/Flow#wrap_aligned (4认同)