Android ConstraintLayout Center使用多个按钮水平对齐

时间:2017-09-21 15:27:16

标签: android android-constraintlayout

我最近开始在android studio中使用ConstraintLayout(稍后可能会在我的应用程序中使用它)并且我想创建一个布局,其中一行有5个按钮,并且有10行5个按钮。我说得对,只是我希望按钮全部调整到相同的宽度,同时填充整行(按钮之间没有间隙)。

A example of the problem:

我当前的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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="lotterynumbergenerator.johnferrazlopez.com.southafricanlotteryguide.other.SaveNumbers">

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="01"
        android:textStyle="bold"
        app:layout_constraintHorizontal_chainStyle="spread_inside"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toLeftOf="@+id/button2"
        tools:layout_editor_absoluteY="16dp" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="02"
        android:textStyle="bold"
        app:layout_constraintLeft_toRightOf="@+id/button"
        app:layout_constraintRight_toLeftOf="@+id/button3"
        tools:layout_editor_absoluteY="16dp" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="03"
        android:textStyle="bold"
        app:layout_constraintLeft_toRightOf="@+id/button2"
        app:layout_constraintRight_toLeftOf="@+id/button4"
        tools:layout_editor_absoluteY="16dp" />

    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="04"
        android:textStyle="bold"
        app:layout_constraintLeft_toRightOf="@+id/button3"
        app:layout_constraintRight_toLeftOf="@+id/button5"
        tools:layout_editor_absoluteY="16dp" />

    <Button
        android:id="@+id/button5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="05"
        android:textStyle="bold"
        app:layout_constraintLeft_toRightOf="@+id/button4"
        app:layout_constraintRight_toRightOf="parent"
        tools:layout_editor_absoluteY="16dp" />

    <Button
        android:id="@+id/button6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="06"
        tools:layout_editor_absoluteY="64dp"
        app:layout_constraintRight_toLeftOf="@+id/button7"
        app:layout_constraintLeft_toLeftOf="parent" />

    <Button
        android:id="@+id/button7"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="07"
        tools:layout_editor_absoluteY="64dp"
        app:layout_constraintRight_toLeftOf="@+id/button8"
        app:layout_constraintLeft_toRightOf="@+id/button6" />

    <Button
        android:id="@+id/button8"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="08"
        tools:layout_editor_absoluteY="64dp"
        app:layout_constraintRight_toLeftOf="@+id/button9"
        app:layout_constraintLeft_toRightOf="@+id/button7" />

    <Button
        android:id="@+id/button9"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="09"
        tools:layout_editor_absoluteY="64dp"
        app:layout_constraintRight_toLeftOf="@+id/button10"
        app:layout_constraintLeft_toRightOf="@+id/button8" />

    <Button
        android:id="@+id/button10"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="10"
        tools:layout_editor_absoluteY="64dp"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintLeft_toRightOf="@+id/button9" />
</android.support.constraint.ConstraintLayout>

我在xml中看到的另一件事是标签中的这条消息是“这个视图没有垂直约束:在运行时它会跳到左边,除非你添加一个垂直约束”

提前致谢。

编辑:

How i want it to space out on a bigger scrn

3 个答案:

答案 0 :(得分:4)

以下是使用10dp作为保证金的示例。我只创建了一行,但其他行将遵循相同的模式。这个模拟使用了一个水平链,其链式样式为&#34; spread&#34;。 (app:layout_constraintHorizontal_chainStyle="spread")按钮的宽度设置为&#34; 0dp&#34; (&#34;匹配约束&#34;)。开始和结束边距用于确保正确的间距。布局适用于纵向和横向以及不同的屏幕尺寸。

添加一个将每个按钮绑定到父顶部的约束来处理&#34;而不是垂直约束&#34;错误信息。视图必须水平和垂直约束。

<强>肖像

enter image description here

<强>风景 enter image description here

和XML:

<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:layout_editor_absoluteX="0dp"
    tools:layout_editor_absoluteY="25dp">

    <Button
        android:id="@+id/button"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="10dp"
        android:layout_marginStart="10dp"
        android:layout_marginTop="8dp"
        android:text="01"
        android:textStyle="bold"
        app:layout_constraintEnd_toStartOf="@+id/button2"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="10dp"
        android:layout_marginTop="8dp"
        android:text="02"
        android:textStyle="bold"
        app:layout_constraintEnd_toStartOf="@+id/button3"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toEndOf="@+id/button"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button3"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="10dp"
        android:layout_marginTop="8dp"
        android:text="03"
        android:textStyle="bold"
        app:layout_constraintEnd_toStartOf="@+id/button4"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toEndOf="@+id/button2"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button4"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="10dp"
        android:layout_marginTop="8dp"
        android:text="04"
        android:textStyle="bold"
        app:layout_constraintEnd_toStartOf="@+id/button5"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toEndOf="@+id/button3"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button5"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="10dp"
        android:layout_marginTop="8dp"
        android:text="05"
        android:textStyle="bold"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toEndOf="@+id/button4"
        app:layout_constraintTop_toTopOf="parent" />

</android.support.constraint.ConstraintLayout>

答案 1 :(得分:0)

如果您将每行的所有第一个按钮链接到一个垂直链中,您将删除错误消息,并且线条的高度也会自动调整大小。尝试0dp或固定值,例如40dp@dimen/buttonHeight,以优化按钮的高度。

基于您的代码和Cheticamp的代码,您可以执行以下操作:

    <Button
    android:id="@+id/button"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="10dp"
    android:layout_marginTop="8dp"
    android:layout_marginBottom="5dp"
    android:text="01"
    android:textStyle="bold"
    app:layout_constraintEnd_toStartOf="@+id/button2"
    app:layout_constraintHorizontal_chainStyle="spread"
    app:layout_constraintVertical_chainStyle="spread"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent" 
    app:layout_constraintBottom_toTopOf="@+id/button6"
    />

<Button
    android:id="@+id/button2"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="02"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button"
    app:layout_constraintEnd_toStartOf="@+id/button3"
    app:layout_constraintTop_toTopOf="@+id/button"
    app:layout_constraintBottom_toBottomOf="@+id/button"
    />

<Button
    android:id="@+id/button3"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="03"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button2"
    app:layout_constraintEnd_toStartOf="@+id/button4"
    app:layout_constraintTop_toTopOf="@+id/button"
    app:layout_constraintBottom_toBottomOf="@+id/button"
    />

<Button
    android:id="@+id/button4"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="04"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button3"
    app:layout_constraintEnd_toStartOf="@+id/button5"
    app:layout_constraintTop_toTopOf="@+id/button"
    app:layout_constraintBottom_toBottomOf="@+id/button"
    />

<Button
    android:id="@+id/button5"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="10dp"
    android:layout_marginStart="5dp"
    android:text="05"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button4"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintTop_toTopOf="@+id/button"
    app:layout_constraintBottom_toBottomOf="@+id/button"
    />

<Button
    android:id="@+id/button6"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="10dp"
    android:layout_marginTop="5dp"
    android:layout_marginBottom="5dp"
    android:text="06"
    android:textStyle="bold"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toStartOf="@+id/button7"
    app:layout_constraintTop_toBottomOf="@+id/button" 
    app:layout_constraintBottom_toTopOf="@+id/button11"
    />

<Button
    android:id="@+id/button7"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="07"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button6"
    app:layout_constraintEnd_toStartOf="@+id/button8"
    app:layout_constraintTop_toTopOf="@+id/button6"
    app:layout_constraintBottom_toBottomOf="@+id/button6"
    />

<Button
    android:id="@+id/button8"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="08"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button7"
    app:layout_constraintEnd_toStartOf="@+id/button9"
    app:layout_constraintTop_toTopOf="@+id/button6"
    app:layout_constraintBottom_toBottomOf="@+id/button6"
    />

<Button
    android:id="@+id/button9"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="09"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button8"
    app:layout_constraintEnd_toStartOf="@+id/button10"
    app:layout_constraintTop_toTopOf="@+id/button6"
    app:layout_constraintBottom_toBottomOf="@+id/button6"
    />

<Button
    android:id="@+id/button10"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="10dp"
    android:layout_marginStart="5dp"
    android:text="10"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button9"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintTop_toTopOf="@+id/button6"
    app:layout_constraintBottom_toBottomOf="@+id/button6"
    />

<Button
    android:id="@+id/button11"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="10dp"
    android:layout_marginTop="5dp"
    android:layout_marginBottom="8dp"
    android:text="11"
    android:textStyle="bold"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toStartOf="@+id/button7"
    app:layout_constraintTop_toBottomOf="@+id/button6" 
    app:layout_constraintBottom_toBottomOf="parent"
    />

<Button
    android:id="@+id/button12"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="12"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button11"
    app:layout_constraintEnd_toStartOf="@+id/button13"
    app:layout_constraintTop_toTopOf="@+id/button11"
    app:layout_constraintBottom_toBottomOf="@+id/button11"
    />

<Button
    android:id="@+id/button13"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="13"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button12"
    app:layout_constraintEnd_toStartOf="@+id/button14"
    app:layout_constraintTop_toTopOf="@+id/button11"
    app:layout_constraintBottom_toBottomOf="@+id/button11"
    />

<Button
    android:id="@+id/button14"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="5dp"
    android:layout_marginStart="5dp"
    android:text="14"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button13"
    app:layout_constraintEnd_toStartOf="@+id/button14"
    app:layout_constraintTop_toTopOf="@+id/button11"
    app:layout_constraintBottom_toBottomOf="@+id/button11"
    />

<Button
    android:id="@+id/button15"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_marginEnd="10dp"
    android:layout_marginStart="5dp"
    android:text="15"
    android:textStyle="bold"
    app:layout_constraintStart_toEndOf="@+id/button14"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintTop_toTopOf="@+id/button11"
    app:layout_constraintBottom_toBottomOf="@+id/button11"
    />

答案 2 :(得分:0)

app:layout_constraintEnd_toEndOf =“ parent” app:layout_constraintStart_toStartOf =“ parent”