如何更改TextInputEditText中drawable的位置?

问题描述

我在具有属性android:drawableStart的TextInputEditText中设置了一个可绘制对象,它看起来像这样:

drawable default

但是实际上,我需要这样写:

The drawable in the way I want

似乎在xml中没有属性可以执行此操作,我查看了属性,但似乎没有什么适合我想要的。 另外,我一直在互联网上寻找一段时间,但没有获得实现此目的所需的信息。 任何想法?

解决方法

在Internet上继续搜索之后,我找到了解决方案。首先,在此post处,它表明了无法接受的答案,即无法将图标放置在顶部,但是,您必须将EditText包装在LinearLayout中,然后将其放置在LinearLayout中。 下面的示例代码:

<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="200dp"
android:background="@android:drawable/edit_text"
android:orientation="horizontal">

<ImageView
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:src="@android:drawable/ic_menu_send"
    android:scaleType="fitStart"
    android:contentDescription="message icon"
    />

<EditText
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:background="@null"
    android:padding="4dp"
    android:text="Message"
    android:inputType="textMultiLine"
    android:gravity="top"
    android:layout_weight="1" />

我接受了这个想法,并通过将TextInputLayout内部的图标与封装在LinearLayout中的FrameLayout重叠来实现。我的代码如下:

        <LinearLayout
        android:layout_marginTop="28dp"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <FrameLayout
            android:background="@drawable/edt_bg_selector_fafa_orange"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="start">

            <com.google.android.material.textfield.TextInputLayout
                android:id="@+id/tilComentReporte"
                android:gravity="top|start"
                app:errorTextColor="@color/colorRojo"
                app:errorEnabled="true"
                android:maxLines="10"
                android:background="@drawable/edt_bg_selector_fafa_orange"
                android:layout_width="match_parent"
                android:layout_height="wrap_content">

                <com.google.android.material.textfield.TextInputEditText
                    android:id="@+id/etComentReporte"
                    android:paddingBottom="10dp"
                    android:background="@null"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:lines="5"
                    android:gravity="top|start"
                    android:singleLine="false"
                    android:inputType="textMultiLine|textAutoComplete"
                    android:drawablePadding="15dp"
                    android:fontFamily="@font/lato"
                    android:hint="@string/sign_describe_tu_problema"
                    android:paddingStart="20dp"
                    android:textSize="16sp" />
            </com.google.android.material.textfield.TextInputLayout>

            <ImageView
                android:paddingTop="10dp"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:scaleType="fitStart"
                android:src="@drawable/ic_contacto_nar" />
        </FrameLayout>
    </LinearLayout>

在设备上看起来像这样:

The view now