我选择了TextInputEditText作为我的密码字段,以使用切换密码功能。
这是我的xml代码:
<com.google.android.material.textfield.TextInputLayout
android:layout_width="@dimen/login_width"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="@dimen/password_margin_top"
app:hintEnabled="false"
app:passwordToggleDrawable="@drawable/password_toggle_drawable"
app:passwordToggleEnabled="true">
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/my_login_password"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fontFamily="sans-serif"
android:hint="@string/password"
android:inputType="textPassword"
android:nextFocusDown="@+id/my_login_login"
android:padding="@dimen/field_padding" />
</com.google.android.material.textfield.TextInputLayout>
我必须对切换密码进行其他一些布局更改。在TextInputLayout中有为此提供的任何回调吗?
答案 0 :(得分:0)
您可以在setEndIconOnClickListener
上致电TextInputLayout
:
textInputLayout.setEndIconOnClickListener { v ->
// Layout changes here
}
但是,这将删除负责切换密码转换方法的Click侦听器。我建议只复制PasswordToggleEndIconDelegate
中的点击侦听器代码,然后在顶部添加您自己的功能:
textInputLayout.setEndIconOnClickListener {
val editText: EditText? = textInputLayout.editText
// Store the current cursor position
val selection = editText?.selectionEnd ?: 0
// Check for existing password transformation
val hasPasswordTransformation = editText?.transformationMethod is PasswordTransformationMethod;
if (hasPasswordTransformation) {
editText?.transformationMethod = null
} else {
editText?.transformationMethod = PasswordTransformationMethod.getInstance()
}
// Restore the cursor position
editText?.setSelection(selection)
// Add additional functionality here
}
编辑:此方法仅在材料库版本1.1.0-alpha04
起可用,并且在撰写本文时,1.1.0
仍处于测试版。