SSC
SSC

Reputation: 3008

EditText Hint Text and Icon

I am trying to create an EditText with the hint as icon and text both together. But hint text goes to the center but I want hint text to be left aligned so that there should only be a tab space (gap) between hint icon and hint text.

This is what I have tried:

<EditText
        android:id="@+id/emailAddressInput"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:ems="10"
        android:layout_marginTop ="20dp"
        android:layout_marginLeft ="20dp"
        android:layout_marginRight ="20dp"
        android:background="@drawable/rounded_edge"
        android:drawableLeft="@drawable/email_box"
        android:hint="e-mail address"
        android:gravity="left|center_vertical"
        android:maxLength="100"
        android:inputType="textEmailAddress" />

Any idea how can I achieve desired result?

Upvotes: 3

Views: 8170

Answers (3)

Felix.D
Felix.D

Reputation: 724

ImageSpan is the best way to do this.

But you got to do it through Java code.

ImageSpan imageHint = new ImageSpan(mContext, R.drawable.icon_hint);
SpannableString spannableString = new SpannableString("_I'm the hint");
spannableString.setSpan(imageHint, 0, 1, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
mEditor.setHint(spannableString);

Upvotes: 11

SSC
SSC

Reputation: 3008

Okay so after a little debugging, I found out that the image size was taking that much space, I have cropped the image to smaller size and it worked.

Upvotes: 3

Tushar
Tushar

Reputation: 8049

Add

android:gravity="top"

to your EditText.

Upvotes: 0

Related Questions