我最近开始在android studio中使用ConstraintLayout(稍后可能会在我的应用程序中使用它)并且我想创建一个布局,其中一行有5个按钮,并且有10行5个按钮。我说得对,只是我希望按钮全部调整到相同的宽度,同时填充整行(按钮之间没有间隙)。
我当前的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中看到的另一件事是标签中的这条消息是“这个视图没有垂直约束:在运行时它会跳到左边,除非你添加一个垂直约束”
提前致谢。
编辑:
答案 0 :(得分:4)
以下是使用10dp
作为保证金的示例。我只创建了一行,但其他行将遵循相同的模式。这个模拟使用了一个水平链,其链式样式为&#34; spread&#34;。 (app:layout_constraintHorizontal_chainStyle="spread"
)按钮的宽度设置为&#34; 0dp&#34; (&#34;匹配约束&#34;)。开始和结束边距用于确保正确的间距。布局适用于纵向和横向以及不同的屏幕尺寸。
添加一个将每个按钮绑定到父顶部的约束来处理&#34;而不是垂直约束&#34;错误信息。视图必须水平和垂直约束。
<强>肖像强>
和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”