TextInputLayout标签位于EditText的左侧drawable之上

ica*_*uds 9 android android-textinputlayout

当用户在EditText中聚焦或键入时,是否可以使TextInputLayout标签垂直显示在EditText的左侧drawable上方.

这是EditText的xml:

 <android.support.design.widget.TextInputLayout
                android:id="@+id/completion_date_layout2"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginLeft="5dp"
                android:layout_marginRight="5dp"
                android:layout_weight="1"
                android:orientation="horizontal">

                <EditText
                    android:id="@+id/etTaskDate"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:hint="@string/title_completion_date"
                    android:inputType="text"
                    android:drawableLeft="@drawable/ic_date"
                    android:paddingBottom="15dp"
                    android:drawablePadding="5dp"
                    android:textSize="@dimen/fields_text_size"/>
            </android.support.design.widget.TextInputLayout>
Run Code Online (Sandbox Code Playgroud)

这是所需的输出:

在此输入图像描述

这是我得到的输出:

在此输入图像描述

Mik*_*ail 7

感谢Java的成员访问模型和谷歌的开发人员留下了一个小漏洞,可以通过一个简单的子类来实现,它重复了最少的原始代码:

package android.support.design.widget;

import android.content.Context;
import android.graphics.Rect;
import android.util.AttributeSet;

public final class TextInputLayoutEx extends TextInputLayout {

    private final int mDefaultPadding = __4DP__;
    private final Rect mTmpRect = new Rect();

    public TextInputLayoutEx(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
        super.onLayout(changed, left, top, right, bottom);
        if (isHintEnabled() && mEditText != null) {
            final Rect rect = mTmpRect;
            ViewGroupUtils.getDescendantRect(this, mEditText, rect);
            mCollapsingTextHelper.setCollapsedBounds(
                rect.left + mDefaultPadding, getPaddingTop(),
                rect.right - mDefaultPadding, bottom - top - getPaddingBottom());
            mCollapsingTextHelper.recalculate();
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

在这里,我们将一个新类放到同一个包中,该类打开对mCollapsingTextHelper包级别可见性的访问,然后从onLayout管理字段名称定位的原始方法重复部分代码.该__4DP__值4DP值转换为像素,我敢肯定,每个人都有这种的实用方法.

在你的xml布局中只需切换android.support.design.widget.TextInputLayout到,android.support.design.widget.TextInputLayoutEx所以你的布局如下所示:

<android.support.design.widget.TextInputLayoutEx
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="Mobile">
    <android.support.design.widget.TextInputEditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:drawableLeft="@drawable/ic_phone_black_24dp"
        android:drawablePadding="4dp"/>
</android.support.design.widget.TextInputLayoutEx>
Run Code Online (Sandbox Code Playgroud)

结果是

崩溃和扩大的状态

目前它的工作原理 com.android.support:design:25.3.1

  • @AuxanoServices 它们是来自基类的包私有字段。随着迁移到 AndroidX,他们已将名称更改为“collapsingTextHelper”和“editText”。 (2认同)