我想在按下状态下在EditText和InputTextLayout标签之间设置边距/填充。
这是我的形象 - desired design
主要Xml 代码 - “
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="56dp"
android:gravity="center_horizontal"
android:orientation="vertical"
android:paddingLeft="24dp"
android:paddingRight="24dp">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="24dp"
android:src="@drawable/headphones_3" />
<android.support.design.widget.TextInputLayout
android:id="@+id/textLabel"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginTop="8dp"
android:visibility="gone"
app:theme="@style/TextLabel">
<EditText
android:id="@+id/input_email"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Email"
android:inputType="textEmailAddress" />
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:id="@+id/password_label"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="gone"
app:theme="@style/TextLabel">
<EditText
android:id="@+id/input_password"
android:layout_width="match_parent"
android:layout_height="40dp"
android:background="@drawable/edit_text_style"
android:drawablePadding="@dimen/floating_hint_margin"
android:hint="Password"
android:inputType="textPassword"
android:paddingLeft="@dimen/floating_hint_margin" />
</android.support.design.widget.TextInputLayout>
</LinearLayout>
`
虽然现在我只将自定义主题应用于&#39;密码&#34; TextInputLayout!
以下是 edit_text_style
的代码<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- focused state -->
<item android:state_focused="true">
<shape android:shape="rectangle">
<solid android:color="#80FFFFFF" />
<stroke android:width=".5dp" android:color="@color/colorPrimary" />
<corners android:radius="6dp" />
</shape>
</item>
<!-- normal state -->
<item>
<shape>
<solid android:color="@android:color/transparent" />
<stroke android:width="2dp" android:color="@color/colorPrimary" />
<corners android:radius="22dp" />
</shape>
</item>
我得到的结果 - Resulted Image
正如您所看到的,Label向上移动到光标,Label和EditText背景之间没有填充。
如何将Label设置为EditText Background启动的位置(因为它现在位于光标顶部)?
(抱歉我的英语不好)
更新:让我解释一下 - 再次看到这些图片。我想在TextInputLayout标签之间设置填充(当你关注它时,这是密码)。你们所说的是在自定义drawable(这里是edit_text_style)光标和Label之间创建填充,但是我想要在我添加的drawable和Label(密码文本在聚焦状态下出现时)之间填充&amp;还希望设置标签位置,因为它向上移动到光标开始。!
答案 0 :(得分:0)
您可以将自定义样式应用于EditText(需要填充onPressedState
的那些):
<EditText
android:id="@+id/input_email"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Email"
android:inputType="textEmailAddress" />
风格:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_focused="true"
android:state_pressed="true"
android:drawable="@drawable/next_white">
<inset android:insetLeft=""YOUR_PADDING_IN_DP dp"/>
来源:android:drawableLeft margin and/or padding
对于边距,使用drawable不可能做到这一点,但你仍然可以定义一个可以解决问题的动画:
在res / anim中,创建 margin_animation.xml :
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_interpolator">
<translate android:fromYDelta="0" android:toYDelta="100%" />
</set>
来源:In Android, is it possible to set the margin from the drawable?
答案 1 :(得分:0)
@Ansh ....您将drawable设置为TextInputLayout并将padding设置为edittext和TextInputLayout .....
以你自己的方式工作得不好....如果你想用textinputlayout做你想做的事
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="56dp"
android:gravity="center_horizontal"
android:orientation="vertical"
android:paddingLeft="24dp"
android:paddingRight="24dp">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="24dp"
android:src="@mipmap/ic_launcher" />
<android.support.design.widget.TextInputLayout
android:id="@+id/textLabel"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginTop="8dp"
android:padding="10dp"
android:background="@drawable/edit_text_style"
android:visibility="visible">
<EditText
android:id="@+id/input_email"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@null"
android:hint="Email"
android:inputType="textEmailAddress"
android:padding="10dp" />
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:id="@+id/password_label"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/edit_text_style"
android:padding="10dp"
android:visibility="visible">
<EditText
android:id="@+id/input_password"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@null"
android:padding="10dp"
android:hint="Password"
android:inputType="textPassword"
/>
</android.support.design.widget.TextInputLayout>
</LinearLayout>
并且在您的drawable中只需要一个矩形或圆角以获得更好的视图