ConstraintLayout 中的layout_constraintHorizontal_weight = 1 不起作用

问题描述 投票:0回答:2

enter image description here我想要以下结果:

enter image description herexml代码是:

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <com.google.android.material.textfield.TextInputLayout android:id="@+id/tilFirstName1" style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginEnd="8dp" android:layout_marginLeft="8dp" android:layout_marginRight="8dp" android:layout_marginStart="8dp" android:layout_marginTop="32dp" app:layout_constraintHorizontal_weight="1" app:boxBackgroundMode="outline" app:endIconMode="clear_text" app:hintEnabled="false" app:layout_constraintEnd_toStartOf="@+id/tilLastName1" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent"> <com.google.android.material.textfield.TextInputEditText android:id="@+id/etFirstName1" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/custom_edittext_input" android:hint="First Name" android:inputType="textPersonName" /> </com.google.android.material.textfield.TextInputLayout> <com.google.android.material.textfield.TextInputLayout android:id="@+id/tilLastName1" style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginEnd="8dp" android:layout_marginRight="8dp" android:layout_marginStart="8dp" android:layout_marginLeft="8dp" android:layout_marginTop="32dp" app:boxBackgroundMode="outline" app:endIconMode="clear_text" app:hintEnabled="false" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintHorizontal_weight="1" app:layout_constraintTop_toTopOf="parent"> <com.google.android.material.textfield.TextInputEditText android:id="@+id/etLastName1" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/custom_edittext_input" android:hint="Last Name" android:inputType="textPersonName" /> </com.google.android.material.textfield.TextInputLayout> </androidx.constraintlayout.widget.ConstraintLayout>

我对你的代码做了一些修改才得到这个结果。技巧是将第一个 
android android-constraintlayout android-textinputlayout
2个回答
0
投票
的结尾限制到

lastName1

 的开头,并对 
lastName1
 执行相反的操作,并在边界处分配它们之间的边距。

enter image description here<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <com.google.android.material.textfield.TextInputLayout android:id="@+id/tilFirstName1" style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginStart="4dp" android:layout_marginTop="32dp" android:layout_marginEnd="8dp" app:boxBackgroundMode="outline" app:endIconMode="clear_text" app:hintEnabled="false" app:layout_constraintEnd_toStartOf="@+id/tilLastName1" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent"> <com.google.android.material.textfield.TextInputEditText android:id="@+id/etFirstName1" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/custom_edittext_input" android:hint="First Name" android:inputType="textPersonName" /> </com.google.android.material.textfield.TextInputLayout> <com.google.android.material.textfield.TextInputLayout android:id="@+id/tilLastName1" style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginStart="4dp" android:layout_marginTop="32dp" android:layout_marginEnd="8dp" app:boxBackgroundMode="outline" app:endIconMode="clear_text" app:hintEnabled="false" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/tilFirstName1" app:layout_constraintTop_toTopOf="parent"> <com.google.android.material.textfield.TextInputEditText android:id="@+id/etLastName1" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/custom_edittext_input" android:hint="Last Name" android:inputType="textPersonName" /> </com.google.android.material.textfield.TextInputLayout> </androidx.constraintlayout.widget.ConstraintLayout>

我放弃了

0
投票
,而是使用按钮之间的指导线。

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline_center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.50" />

然后您可以将 TextInput 限制为该
@id/guideline_center
。通过指定 0dp 宽度,它将填充参考线的区域。

    <com.google.android.material.textfield.TextInputLayout
        android:id="@+id/tilFirstName1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        ...
        app:layout_constraintEnd_toStartOf="@id/guideline_center"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        ...


最新问题
© www.soinside.com 2019 - 2025. All rights reserved.