Как отметил Никос Хидаль go в комментарии к вашему вопросу, это распространенный вопрос, который задают при переполнении стека. Я наткнулся на четыре способа достижения sh общей ширины и / или общей высоты для набора видов. К сожалению, ни один из них не идеален.
Вот снимок экрана, показывающий три из четырех способов добраться до общих размеров. XML для этого экрана находится в конце этого сообщения.
Embedded LinearLayout
Это, наверное, самый простой способ. Поместите TextViews в горизонтальное LinearLayout , установив их высоту MATCH_PARENT . Установите высоту LinearLayout на WRAP_CONTENT , и все получится. Преимущество этого способа заключается в его простоте. К минусам относятся издержки вложенного макета и невозможность подключения любого из представлений в LinearLayout к любому представлению вне LinearLayout - они становятся островом.
Невидимые виды
Это, пожалуй, самый сложный способ ведения дел, но он может подойти в зависимости от макета. Основная проблема с установкой барьеров для регулировки высоты набора видов состоит в том, что размещение барьера зависит от высоты видов, а высота видов зависит от размещения барьера. Это ссылочное затруднение, которое не работает с текущей версией ConstraintLayout .
. Невидимое представление Решение состоит в дублировании представлений, для которых должна быть отрегулирована высота. как невидимые взгляды. Установите верхний и нижний барьер для этих невидимых видов. Установите высоту видимых видов на MATCH_CONSTRAINTS и соедините верхние части с верхним барьером, а нижние с нижним барьером.
Преимущество этого подхода заключается в том, что он полностью плоский и включает в себя просто ConstraintLayout . Недостатки в том, что он увеличивает количество представлений на количество настраиваемых представлений, его сложность и все, что влечет за собой сложность.
Помощник размера макета ограничения
Третий подход заключается в использовании пользовательского ConstraintHelper для изменения высоты представлений. Пользовательский ConstraintHelper вставляется в XML для макета, как и любой другой вид, и создается для ссылки на виды, подлежащие корректировке.
Преимущество этого подхода состоит в том, что все изменения держится в пределах XML. Отрицательно то, что пользовательский класс должен ссылаться и поддерживаться.
Прослушиватель обновления ширины / высоты
Этот последний подход заключается в пользовательском коде корректировки высоты с использованием глобального слушатель макета, слушатель макета или тому подобное. Это похоже на подход ConstraintHelper , но существует за пределами XML и может быть плохо инкапсулировано.
Также может быть возможным кодирование пользовательских представлений для установки высоты представлений для наибольшая высота либо с пользовательским ConstraintLayout , либо с пользовательским TextView .
Пример макета
<TextView
android:id="@+id/textView2_0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="16dp"
android:text="Embedded LinearLayout"
app:layout_constraintBottom_toTopOf="@+id/layout2"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_chainStyle="packed"
tools:ignore="HardcodedText" />
<LinearLayout
android:id="@+id/layout2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="16dp"
android:background="@android:color/holo_blue_bright"
app:layout_constraintBottom_toTopOf="@id/textView3_0"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2_0">
<TextView
android:id="@+id/textView2_1"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_marginStart="24dp"
android:layout_marginEnd="24dp"
android:layout_weight="1"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView2_2"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_marginEnd="24dp"
android:layout_weight="1"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView2_3"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_marginEnd="24dp"
android:layout_weight="1"
android:background="@android:color/white"
android:gravity="center"
android:text="This is the TextView that has the maximum height."
tools:ignore="HardcodedText" />
</LinearLayout>
<TextView
android:id="@+id/textView3_0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="16dp"
android:text="Invisible Views"
app:layout_constraintBottom_toTopOf="@id/textView3_2"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/layout2"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView3_1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="24dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintEnd_toStartOf="@+id/textView3_2"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/textView3_2"
tools:visibility="invisible"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView3_2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintBottom_toTopOf="@id/textView5_0"
app:layout_constraintEnd_toStartOf="@+id/textView3_3"
app:layout_constraintStart_toEndOf="@+id/textView3_1"
app:layout_constraintTop_toBottomOf="@id/textView3_0"
tools:visibility="invisible"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView3_3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="This is the TextView that has the maximum height."
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/textView3_2"
app:layout_constraintTop_toTopOf="@+id/textView3_2"
tools:visibility="invisible"
tools:ignore="HardcodedText" />
<androidx.constraintlayout.widget.Barrier
android:id="@+id/barrierTop"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:barrierDirection="top"
app:constraint_referenced_ids="textView3_1,textView3_2,textView3_3" />
<androidx.constraintlayout.widget.Barrier
android:id="@+id/barrierBottom"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:barrierDirection="bottom"
app:constraint_referenced_ids="textView3_1,textView3_2,textView3_3" />
<View
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@android:color/holo_blue_bright"
app:layout_constraintBottom_toTopOf="@id/barrierBottom"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/barrierTop" />
<TextView
android:id="@+id/textView4_1"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginStart="24dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintBottom_toTopOf="@id/barrierBottom"
app:layout_constraintEnd_toStartOf="@+id/textView4_2"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/barrierTop"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView4_2"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintBottom_toTopOf="@id/barrierBottom"
app:layout_constraintEnd_toStartOf="@+id/textView4_3"
app:layout_constraintStart_toEndOf="@+id/textView4_1"
app:layout_constraintTop_toBottomOf="@+id/barrierTop"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView4_3"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="This is the TextView that has the maximum height."
app:layout_constraintBottom_toTopOf="@id/barrierBottom"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/textView4_2"
app:layout_constraintTop_toBottomOf="@+id/barrierTop"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView5_0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:text="ConstraintLayout Size Helper"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/barrierBottom"
tools:ignore="HardcodedText" />
<View
android:id="@+id/view"
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@android:color/holo_blue_bright"
app:layout_constraintBottom_toBottomOf="@id/textView5_1"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@id/textView5_1" />
<TextView
android:id="@+id/textView5_1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="24dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintEnd_toStartOf="@+id/textView5_2"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/textView5_2"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView5_2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="TextView"
app:layout_constraintEnd_toStartOf="@+id/textView5_3"
app:layout_constraintStart_toEndOf="@+id/textView5_1"
app:layout_constraintTop_toBottomOf="@+id/textView5_0"
tools:ignore="HardcodedText" />
<TextView
android:id="@+id/textView5_3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="24dp"
android:background="@android:color/white"
android:gravity="center"
android:text="This is the TextView that has the maximum height."
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/textView5_2"
app:layout_constraintTop_toTopOf="@+id/textView5_2"
tools:ignore="HardcodedText" />
<com.example.constraintsizehelper.ConstraintSizeHelper
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:constraint_referenced_ids="textView5_1,textView5_2,textView5_3"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:setCommonWidth="true"
app:setCommonHeight="true"
tools:layout_height="120dp"/>
</androidx.constraintlayout.widget.ConstraintLayout>
Вот уменьшенная версия макета с использованием класса Constraint Size Helper (не предоставляется):
и его XML:
Activity_main. xml
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/label_zone1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_marginEnd="15dp"
android:gravity="center"
android:text="test 1"
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="18sp"
app:layout_constraintEnd_toStartOf="@+id/label_zone2"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintHorizontal_weight="1"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/coefficient_zone1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="text="
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="14sp"
app:layout_constraintEnd_toEndOf="@+id/label_zone1"
app:layout_constraintStart_toStartOf="@+id/label_zone1"
app:layout_constraintTop_toBottomOf="@+id/label_zone1" />
<TextView
android:id="@+id/consumption_zone1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:background="@drawable/input_border"
android:gravity="center|center_vertical"
android:text="0"
android:textColor="@color/orange"
android:textSize="24sp"
app:layout_constraintBottom_toBottomOf="@+id/barrier2"
app:layout_constraintEnd_toEndOf="@+id/coefficient_zone1"
app:layout_constraintStart_toStartOf="@+id/coefficient_zone1"
app:layout_constraintTop_toBottomOf="@+id/barrier" />
<TextView
android:id="@+id/label_zone2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="15dp"
android:gravity="center"
android:text="test 2"
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="18sp"
app:layout_constraintEnd_toStartOf="@+id/label_zone3"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintHorizontal_weight="1"
app:layout_constraintStart_toEndOf="@+id/label_zone1"
app:layout_constraintTop_toTopOf="@+id/label_zone1" />
<TextView
android:id="@+id/coefficient_zone2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="text="
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="14sp"
app:layout_constraintEnd_toEndOf="@+id/label_zone2"
app:layout_constraintStart_toStartOf="@+id/label_zone2"
app:layout_constraintTop_toBottomOf="@+id/label_zone2" />
<TextView
android:id="@+id/consumption_zone2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:background="@drawable/input_border"
android:gravity="center|center_vertical"
android:text="12345678"
android:textColor="@color/orange"
android:textSize="24sp"
app:layout_constraintBottom_toBottomOf="@+id/barrier2"
app:layout_constraintEnd_toEndOf="@+id/coefficient_zone2"
app:layout_constraintStart_toStartOf="@+id/coefficient_zone2"
app:layout_constraintTop_toBottomOf="@+id/barrier" />
<TextView
android:id="@+id/label_zone3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="10dp"
android:gravity="center"
android:text="test 3"
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintHorizontal_weight="1"
app:layout_constraintStart_toEndOf="@+id/label_zone2"
app:layout_constraintTop_toTopOf="@+id/label_zone2" />
<TextView
android:id="@+id/coefficient_zone3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="text="
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="14sp"
app:layout_constraintEnd_toEndOf="@+id/label_zone3"
app:layout_constraintStart_toStartOf="@+id/label_zone3"
app:layout_constraintTop_toBottomOf="@+id/label_zone3" />
<TextView
android:id="@+id/consumption_zone3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:background="@drawable/input_border"
android:gravity="center|center_vertical"
android:text="1234567890"
android:textColor="@color/orange"
android:textSize="24sp"
app:layout_constraintBottom_toBottomOf="@+id/barrier2"
app:layout_constraintEnd_toEndOf="@+id/coefficient_zone3"
app:layout_constraintStart_toStartOf="@+id/coefficient_zone3"
app:layout_constraintTop_toBottomOf="@+id/barrier" />
<androidx.constraintlayout.widget.Barrier
android:id="@+id/barrier"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:barrierDirection="bottom"
app:constraint_referenced_ids="coefficient_zone1,coefficient_zone2,coefficient_zone3" />
<androidx.constraintlayout.widget.Barrier
android:id="@+id/barrier2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:barrierDirection="bottom"
app:constraint_referenced_ids="consumption_zone1,consumption_zone2,consumption_zone3" />
<TextView
android:id="@+id/label_calculated_indicators"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:gravity="center"
android:text="title title title title"
android:textAllCaps="true"
android:textColor="@color/blue"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="@+id/label_zone3"
app:layout_constraintStart_toStartOf="@+id/label_zone1"
app:layout_constraintTop_toBottomOf="@+id/consumption_zone1" />
<com.example.myapplication.ConstraintSizeHelper
android:layout_width="wrap_content"
android:layout_height="wrap_content"
tools:layout_height="120dp"
app:setCommonWidth="false"
app:setCommonHeight="true"
app:constraint_referenced_ids="consumption_zone1,consumption_zone2,consumption_zone3"/>
</androidx.constraintlayout.widget.ConstraintLayout>