首页 > 解决方案 > 如何定义垂直堆叠和水平对齐其引用视图的 Flow 虚拟布局?

问题描述

我已经定义了一个ConstraintLayout包含一个Flow虚拟布局,它紧紧地包裹并垂直堆叠三个视图,如下所示:

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <View
        android:id="@+id/view1"
        android:layout_width="150dp"
        android:layout_height="50dp"
        android:background="@android:color/black" />

    <View
        android:id="@+id/view2"
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:background="@android:color/black" />

    <View
        android:id="@+id/view3"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="@android:color/black" />

    <androidx.constraintlayout.helper.widget.Flow
        android:id="@+id/flow"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:constraint_referenced_ids="view1,view2,view3"
        app:flow_horizontalAlign="start"
        app:flow_horizontalStyle="packed"
        app:flow_maxElementsWrap="1"
        app:flow_verticalAlign="top"
        app:flow_verticalGap="8dp"
        app:flow_verticalStyle="packed"
        app:flow_wrapMode="chain"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>

尽管有 的flow_horizontalAlignstart,但这会将视图呈现为水平居中,如下所示:

在此处输入图像描述

有谁知道我可以如何开始/左对齐引用的视图?

标签: android-constraintlayout

解决方案


添加app:flow_horizontalBias="0"到您的 Flow 小部件将使视图与start.

您还可以为android:orientation="vertical"Flow 小部件设置,使用默认模式noneapp:flow_wrapMode然后flow_horizontalAlign="start"应该按预期工作。


推荐阅读