[设置提示时,EditText不会展开

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

所以我在EditText中有一个简单的ConstraintLayout。我想要的是让用户开始键入内容,并让EditText展开以适合他们的输入,此操作按预期进行,直到我添加提示为止。然后视图似乎被限制为提示的宽度,而输入则完全没有变化。

感谢您的帮助,如果有人需要,我将在下面发布完整的布局文件!

<?xml version="1.0" encoding="utf-8"?>
<ScrollView 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">

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/add_menu_item_toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:layout_constraintTop_toTopOf="parent"
            app:title="@string/add_menu_item_title" />

        <EditText
            android:inputType="textCapWords"
            android:id="@+id/add_menu_item_name"
            style="@style/BlockListItem"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="@dimen/margin"
            android:layout_marginTop="@dimen/margin"
            android:layout_marginEnd="@dimen/margin"
            android:textColorHint="@android:color/darker_gray"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@id/add_menu_item_toolbar" />

        <View
            android:id="@+id/add_menu_item_stock_frame"
            android:layout_width="0dp"
            android:layout_height="0dp"
            android:layout_marginStart="@dimen/margin"
            android:layout_marginTop="@dimen/margin"
            android:layout_marginEnd="@dimen/margin"
            android:background="@drawable/frame_border"
            app:layout_constraintBottom_toBottomOf="@id/add_menu_item_frame_margin"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@id/add_menu_item_name" />

        <LinearLayout
            android:id="@+id/add_menu_item_stock_container"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginTop="@dimen/margin"
            android:orientation="vertical"
            app:layout_constraintEnd_toEndOf="@id/add_menu_item_stock_frame"
            app:layout_constraintStart_toStartOf="@id/add_menu_item_stock_frame"
            app:layout_constraintTop_toTopOf="@id/add_menu_item_stock_frame" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/add_menu_item_add_stock"
            style="@style/Widget.MaterialComponents.Button.TextButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="@dimen/margin"
            android:layout_marginEnd="@dimen/margin"
            android:text="@string/add_menu_item_add_stock"
            app:icon="@drawable/baseline_add_24"
            app:layout_constraintBottom_toBottomOf="@id/add_menu_item_stock_frame"
            app:layout_constraintEnd_toEndOf="@id/add_menu_item_stock_frame"
            app:layout_constraintTop_toBottomOf="@id/add_menu_item_stock_container" />

        <Space
            android:id="@+id/add_menu_item_frame_margin"
            android:layout_width="match_parent"
            android:layout_height="@dimen/margin"
            app:layout_constraintTop_toBottomOf="@id/add_menu_item_add_stock" />

        <com.google.android.material.textfield.TextInputLayout
            android:id="@+id/add_menu_item_price_container"
            style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginStart="@dimen/margin"
            android:layout_marginTop="@dimen/margin"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@id/add_menu_item_stock_frame"
            app:layout_goneMarginTop="@dimen/margin">

            <com.google.android.material.textfield.TextInputEditText
                android:id="@+id/add_menu_item_price"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:ems="6"
                android:hint="@string/menu_add_price_hint"
                android:inputType="numberDecimal" />
        </com.google.android.material.textfield.TextInputLayout>

        <TextView
            android:id="@+id/add_menu_item_suggested_price"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginStart="@dimen/margin"
            app:layout_constraintBottom_toBottomOf="@id/add_menu_item_price_container"
            app:layout_constraintStart_toEndOf="@id/add_menu_item_price_container"
            app:layout_constraintTop_toTopOf="@id/add_menu_item_price_container" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/add_menu_item_add"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginEnd="@dimen/margin"
            android:text="@string/menu_add_add"
            app:layout_constraintBottom_toBottomOf="@id/add_menu_item_price_container"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@id/add_menu_item_price_container" />

    </androidx.constraintlayout.widget.ConstraintLayout>

</ScrollView>
android xml android-layout android-edittext android-constraintlayout
2个回答
0
投票

似乎一开始这只是一个愚蠢的错误,因为未在视图上设置wrap_content,因为它应该是应该的!


0
投票

只要您在edittext中有字符串,您就可以简单地删除并重置提示:

add_menu_item_name.addTextChangedListener(object : TextWatcher {
            val hintText = "myHint"
            override fun afterTextChanged(s: Editable?) {}
            override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {}
            override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {
                add_menu_item_name.hint =
                    when(count) {
                        0 -> hintText
                        else -> null
                    }
            }
        }
)
© www.soinside.com 2019 - 2024. All rights reserved.