android-constraintlayout - 如何定义垂直堆叠和水平对齐其引用视图的 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_horizontalAlign
值start
,但这会将视图呈现为水平居中,如下所示:
有谁知道我可以如何开始/左对齐引用的视图?
解决方案
添加app:flow_horizontalBias="0"
到您的 Flow 小部件将使视图与start
.
您还可以为android:orientation="vertical"
Flow 小部件设置,使用默认模式none
,app:flow_wrapMode
然后flow_horizontalAlign="start"
应该按预期工作。
推荐阅读
- python - 为什么这个类使用“self”作为位置参数?
- javascript - 每个测试文件的 Karma 运行时
- html - 如何将 div 居中,同时将 div 内的内容保持在原位
- reactjs - 如何使用 React Router 混合使用父子路由正确路由
- r - modCost 中的错误(obs = world_data,model = out):在 R 中找不到对象“world_data”
- python - 计算余弦相似度:ValueError: Input must be 1- or 2-d
- jboss - PersistenceException / HibernateException:事务在不同的线程中回滚
- python - int() 参数必须是字符串、类似字节的对象或数字,而不是 'NoneType' Django 表单
- laravel - 如何在windows中输入php artisan serve linux?
- r - plot.new() 中的错误:闪亮应用中的图形边距太大