Расположение макета с помощью помощника Constraint-Layout Flow в Android - PullRequest
1 голос
/ 17 февраля 2020

Я использую вспомогательный поток Constraint-Layout для создания пользовательского интерфейса, похожего на калькулятор.

У меня проблема с позиционированием ссылочных представлений, на которые ссылается мой объект Flow.

Пожалуйста, смотрите прикрепленное изображение мой макет потока pi c

Как видите, я хочу переместить одну нижнюю кнопку в верх макета. Как мне переместить его влево или вправо от макета, используя помощник Flow.

Вот код вспомогательного объекта Flow, который создает макет, который мне нужно изменить.

<androidx.constraintlayout.helper.widget.Flow
    android:id="@+id/flow"
    android:layout_width="0dp"
    android:layout_height="0dp"

    app:layout_constraintHeight_percent = "0.8"
    app:constraint_referenced_ids ="a,b,c,d,e"
    android:background="@drawable/my_own_drawable"
    android:padding="20dp"
    app:flow_verticalGap = "10dp"
    app:flow_horizontalGap = "10dp"
    app:flow_maxElementsWrap = "2"
    app:flow_wrapMode = "aligned"
    app:flow_verticalAlign="top" // I Thought this line would do the job, but it did not
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintTop_toBottomOf="@+id/mytextview"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    >
</androidx.constraintlayout.helper.widget.Flow>

1 Ответ

0 голосов
/ 14 апреля 2020

Будут созданы следующие кнопки:

 <Button
    android:id="@+id/e"
    android:layout_width = "0dp"
    android:layout_height = "0dp"
    app:layout_constraintHorizontal_weight="1"
    android:padding="20dp"
    app:layout_constraintHeight_percent = "0.1"
    android:text="17"
    tools:ignore="MissingConstraints"
    />

<Button
    android:id="@+id/no1"
    android:layout_width="0dp"
    android:layout_height = "0dp"
    app:layout_constraintHeight_percent = "0.1"
    app:layout_constraintHorizontal_weight="1"
    android:background="@android:color/transparent"
    android:enabled="false"
    tools:ignore="MissingConstraints"
    />

Обратите внимание, что они имеют одинаковый горизонтальный вес = 1. Также кнопка с id = no1 все еще видна, но имеет прозрачный фон и имеет значение false. Таким образом, пользователь не сможет щелкнуть по нему.

Мы можем переместить видимую кнопку (id = e) влево или вправо от макета со следующей строкой внутри объекта помощника Flow:

app:constraint_referenced_ids ="e,no1,a,b,c,d"  //will move button( id = e) to left side

app:constraint_referenced_ids ="no1,e,a,b,c,d"  //will move button( id = e) to right 
...