Создайте Barrier
с направлением start
и укажите все идентификаторы TextViews
справа. Ограничьте end
каждого индикатора выполнения до Barrier
. Barrier
будет выровнен по началу самого длинного TextView
.
Пример XML, как этого добиться:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.constraintlayout.widget.Barrier
android:id="@+id/barrier"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:barrierDirection="start"
app:constraint_referenced_ids="text1,text2"/>
<TextView
android:id="@+id/progress1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="ProgressBar"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintEnd_toStartOf="@id/barrier" />
<TextView
android:id="@+id/progress2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="ProgressBar"
app:layout_constraintTop_toBottomOf="@id/progress1"
app:layout_constraintEnd_toStartOf="@id/barrier" />
<TextView
android:id="@+id/text1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Text"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintEnd_toEndOf="parent" />
<TextView
android:id="@+id/text2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Longer Text"
app:layout_constraintTop_toBottomOf="@id/text1"
app:layout_constraintEnd_toEndOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
Результат:
Чтобы предотвратить наложение левого TextView
на другие Views
, необходимо ограничить его end
индикатором хода, установите горизонтальное смещение на 0
, чтобы оно соответствовало ограничению start
а также установите app:layout_constrainedWidth="true"
, чтобы его ограничения применялись, когда ширина установлена на wrap_content
. Это должно выглядеть так:
<TextView
android:id="@+id/foo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Foo"
app:layout_constrainedWidth="true"
app:layout_constraintHorizontal_bias="0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toStartOf="@id/progress1"
app:layout_constraintTop_toTopOf="parent" />
Это приведет к переносу текста на следующую строку, когда он достигнет индикатора выполнения. Вы можете добавить многоточие или ограничить TextView
максимум 1 строкой, если вы не хотите, чтобы текст был перенесен.
В качестве альтернативы, вы можете просто установить левую TextView's
ширину в 0
поэтому он занимает все доступное пространство слева от индикатора выполнения.