Как я могу толкнуть все, кроме одного, в вертикальной цепочке вверх, а последний вид - вниз? - PullRequest
0 голосов
/ 06 июня 2018

У меня есть набор из трех кнопок в вертикальной цепочке в ConstraintLayout:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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">

    <Button
        android:id="@+id/button_1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 1"
        app:layout_constraintBottom_toTopOf="@+id/button_2"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0"
        app:layout_constraintVertical_chainStyle="packed" />

    <Button
        android:id="@+id/button_2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 2"
        app:layout_constraintBottom_toTopOf="@+id/button_3"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button_1" />

    <Button
        android:id="@+id/button_3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 3"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button_2" />

</android.support.constraint.ConstraintLayout>

Это выглядит так: 3 buttons incorrect

Как я могуиспользовать функции ConstraintLayout, чтобы он выглядел так, сохраняя при этом цепочку?3 buttons correct

Я пытался использовать различные настройки смещения, но они действуют только в режиме цепочки packed и только для всей цепочки.Можно ли индивидуально смещать позиции представлений в цепочке?

Ответы [ 4 ]

0 голосов
/ 06 июня 2018

Приведенная выше картина может быть вам полезна.

0 голосов
/ 06 июня 2018

Установите цепочку в стиле packed с вертикальным смещением 0.Это поместит три вида сверху.Чтобы переместить вид снизу на нижнюю часть экрана, вам необходимо установить верхнее поле на вид снизу.Так как поля будут различаться в зависимости от устройства и ориентации, вам нужно будет установить их программно.

К сожалению, если среднее представление может расширяться по вертикали как с многострочным EditText, который вы упомянули, тогда установите полевсе равно будет работать, но вам нужно будет внести коррективы по мере расширения среднего вида.Это все выполнимо, но немного запутано.

0 голосов
/ 06 июня 2018

Идея для достижения этой цели состоит в том, чтобы добавить вспомогательное представление Space как часть цепочки, которая будет занимать все оставшееся неиспользуемое пространство по мере необходимости.Пример XML:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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">

    <Button
        android:id="@+id/button_1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 1"
        app:layout_constraintBottom_toTopOf="@+id/button_2"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0"
        app:layout_constraintVertical_chainStyle="packed" />

    <Button
        android:id="@+id/button_2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 2"
        app:layout_constraintBottom_toTopOf="@+id/space"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button_1" />

    <android.support.v4.widget.Space
        android:id="@+id/space"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        app:layout_constraintBottom_toTopOf="@id/button_3"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@id/button_2" />

    <Button
        android:id="@+id/button_3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button 3"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/space" />

</android.support.constraint.ConstraintLayout>
0 голосов
/ 06 июня 2018

enter image description here Здесь ваша потребность, вы должны удалить ниже из button_3

app:layout_constraintTop_toBottomOf="@+id/button_2"

и добавить ниже

app:layout_constraintStart_toStartOf="parent"
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...