ConstraintLayout: как получить представление в половину ширины экрана и по центру?
TD; DR
Ширина вида должна быть точно равна половине экрана и центрирована. Использование ConstraintLayout.
обратите внимание, что вид не имеет внутренней ширины.
<View android:background="#ff0000" ... />
исходный вопрос
Я хотел бы достичь макета, где размер представления равен половине размера экрана и центрирован по горизонтали.
что-то вроде этого: |--view--|
Я не могу найти способ использовать ConstraintLayout. Лучший я найдено с помощью app:layout_constraintHorizontal_weight="1"
на 2 поддельных вида, расположенных на полный левый и полный правый соответственно, и app:layout_constraintHorizontal_weight="1.5"
на мой взгляд.
какой-нибудь лучший способ ?
4 ответов
С бета-версии вы можете использовать ширину в процентах. Если вы не можете использовать бета-версию, вы можете использовать два вертикальных руководства: одно на 25% ширины экрана и одно на 75% ширины. Вид с шириной 0dp
будет ограничено между этими двумя руководящими принципами. Эта настройка даст вам представление, которое составляет 1/2 ширины экрана, а также по центру.
следующий XML демонстрирует оба способа; один с помощью ConstraintLayout
бета-версия и второе использование функций доступно в текущем производственном выпуске.
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/activity_main_inference"
android:layout_width="match_parent"
android:layout_height="match_parent">
<View
android:id="@+id/viewTop"
android:layout_width="0dp"
android:layout_height="100dp"
android:layout_marginTop="16dp"
android:background="@android:color/darker_gray"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintWidth_default="percent"
app:layout_constraintWidth_percent="0.5" />
<android.support.constraint.Guideline
android:id="@+id/guidelineLeft"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.25" />
<View
android:layout_width="0dp"
android:layout_height="100dp"
android:layout_marginTop="16dp"
android:background="@android:color/darker_gray"
app:layout_constraintEnd_toStartOf="@id/guidelineRight"
app:layout_constraintStart_toEndOf="@id/guidelineLeft"
app:layout_constraintTop_toBottomOf="@id/viewTop" />
<android.support.constraint.Guideline
android:id="@+id/guidelineRight"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.75" />
</android.support.constraint.ConstraintLayout>
начиная с " ConstraintLayout1.1.0-beta1 " вы можете использовать процент для определения ширины и высоты.
android:layout_width="0dp"
app:layout_constraintWidth_default="percent"
app:layout_constraintWidth_percent=".4"
это определение с равной 40% от ширины экрана. Сочетание этого и рекомендаций в процентах позволяет создавать любой макет на основе процентов.
попробуйте это вертикальное деление
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.constraint.ConstraintLayout
android:id="@+id/clPart1"
android:layout_width="0dp"
android:layout_height="match_parent"
android:background="@color/white"
android:visibility="visible"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintHorizontal_chainStyle="spread"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toLeftOf="@+id/clPart2">
</android.support.constraint.ConstraintLayout>
<android.support.constraint.ConstraintLayout
android:id="@+id/clPart2"
android:layout_width="0dp"
android:layout_height="match_parent"
android:background="@color/black"
android:visibility="visible"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toRightOf="@+id/clPart1"
app:layout_constraintRight_toRightOf="parent">
</android.support.constraint.ConstraintLayout>
</android.support.constraint.ConstraintLayout>
результат
то, что вы должны сделать, это:
Просто добавьте это в свой XML
<View
android:id="@+id/viewV1"
android:layout_height="match_parent"
android:background="#ff0000"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
android:layout_width="match_parent"
/>
и это в вашем java.
сначала импортируйте их.
import android.graphics.Point;
import android.support.constraint.ConstraintLayout;
import android.view.Display;
import android.view.View;
затем добавьте эти строки в функцию onCreate вашего java-файла.
Display display = getWindowManager().getDefaultDisplay();
Point size = new Point();
display.getSize(size);
int width1 = size.x;
//int height = size.y;
View v = findViewById(R.id.viewV1);
ConstraintLayout.MarginLayoutParams params = (ConstraintLayout.MarginLayoutParams) v.getLayoutParams();
params.width = width1/2; params.leftMargin = width1/4; params.rightMargin = width1/4;
v.setLayoutParams(params);
вы также можете установить высоту с помощью этого метода. И да, этот вид использует половину ширины экрана, независимо от размера экрана.
как вы не хотите делать это через Java. Добавьте это в XML.
<android.support.constraint.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/guideline5"
app:layout_constraintGuide_begin="411dp"
android:orientation="vertical"
/>
выбрав это, переместите это руководство в конец экрана и обратите внимание на это значение app:layout_constraintGuide_begin="411dp"
. Теперь, независимо от значения, это ширина вашего экрана.
Добавить marginStart
и marginEnd
на ваш взгляд, как 411/4 dp. (вычислите это значение, XML этого не сделает).
Это сделает ваш вид в центре с половиной ширины в качестве родителя.
Помните, что не каждый экран с 411dp. Это не будет работать для каждого телефона размер экрана там.