我在blog entry中读到,在ConstraintLayout
2.0.0中引入了一种创建视图流的方法。我确切想要实现的目标:
我有几个TextView
,它们彼此固定大小。根据屏幕尺寸,一些TextView
应该被推到下一行。
在大屏幕上有六个TextViews
的示例:
[AAA] [BBB] [CCC] [DDD]
[EEE] [FFF]
在具有六个TextViews
的小屏幕上的示例:
[AAA] [BBB]
[CCC] [DDD]
[EEE] [FFF]
我已经看到this个建议使用FlexboxLayout
的Stackoverflow问题,但是有一条评论说,现在可以使用ConstraintLayout
来实现相同的目的。
任何人都可以给我一个示例,说明如何使用ConstraintLayout
实现所需的行为?我找不到关于此的任何说明。预先感谢。
答案 0 :(得分:0)
您可以通过在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>
使用app:flow_
属性来更改文本视图的排列方式,例如对齐方式,边距等。
最终结果应如下所示,具体取决于您的屏幕尺寸。