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 бета-версия и второе использование функций доступно в текущем производственном выпуске.

enter image description here XML Layout

<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. Это не будет работать для каждого телефона размер экрана там.