如何定义垂直堆叠和水平对齐其引用视图的 Flow 虚拟布局?
How to define a Flow virtual layout which vertically stacks and horizontally aligns its referenced views?
我已经定义了一个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_horizontalAlign
的值为 start
,但是这会使视图水平居中,如下所示:
有谁知道如何 start/left 对齐引用的视图?
将 app:flow_horizontalBias="0"
添加到 Flow 小部件将使视图与 start
对齐。
您还可以为 Flow 小部件设置 android:orientation="vertical"
,在 app:flow_wrapMode
中使用默认模式 none
,然后 flow_horizontalAlign="start"
应该会按预期工作。
我已经定义了一个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_horizontalAlign
的值为 start
,但是这会使视图水平居中,如下所示:
有谁知道如何 start/left 对齐引用的视图?
将 app:flow_horizontalBias="0"
添加到 Flow 小部件将使视图与 start
对齐。
您还可以为 Flow 小部件设置 android:orientation="vertical"
,在 app:flow_wrapMode
中使用默认模式 none
,然后 flow_horizontalAlign="start"
应该会按预期工作。