在使用App的时候,首次登录都需要用户输入密码的,有些朋友为了安全起见密码设置的比较长,导致很多次密码都输入错误,严重影响了用户体验效果。这一点移动开发者做好了准备工作,因为手机的私密性比较强,在输入密码的时候,可以显示输入,增强准确性,提升用户体验度。这当然要付出代价的,需要额外的代码编写功能。下面通过本文给大家介绍如何编写密码明文显示的功能,仅供参考。
本文源码的GitHub下载地址
要点
(1) 重写EditText, 添加提示密码显示和隐藏的图片.
(2) 判断点击位置, 切换EditText的密码显示状态.
(3) 在屏幕旋转或配置改变时, 保留图片的状态信息.
实现只有一个类和两个图片资源, 大家可以自由定制.
1. 布局样式
两种密码的显示样式, 一种是常规显示, 一种是TextInputLayout显示.
<LinearLayoutandroid:id="@+id/main_ll_container_1"android:layout_width="match_parent"android:layout_height="40dp"android:gravity="center"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="密码:"android:textSize="20sp"/><me.chunyu.spike.wcl_password_input_demo.PasswordEditTextandroid:id="@+id/main_pet_password"android:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center"android:hint="请输入密码"/></LinearLayout><android.support.design.widget.TextInputLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:layout_below="@+id/main_ll_container_1"><me.chunyu.spike.wcl_password_input_demo.PasswordEditTextandroid:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center"android:hint="请输入密码"/></android.support.design.widget.TextInputLayout>
效果
2. 提示图标
初始化资源和布局, 获取密码图片的资源, 监听EditText, 有文字时显示图标, 没有文字时隐藏图标.
// 初始化布局public void initFields(AttributeSet attrs, int defStyleAttr) {if (attrs != null) {// 获取属性信息TypedArray styles = getContext().getTheme().obtainStyledAttributes(attrs, R.styleable.PasswordEditText, defStyleAttr, 0);try {// 根据参数, 设置IconmShowPwdIcon = styles.getResourceId(R.styleable.PasswordEditText_pet_iconShow, mShowPwdIcon);mHidePwdIcon = styles.getResourceId(R.styleable.PasswordEditText_pet_iconHide, mHidePwdIcon);} finally {styles.recycle();}}// 密码状态setInputType(EditorInfo.TYPE_CLASS_TEXT | EditorInfo.TYPE_TEXT_VARIATION_PASSWORD);addTextChangedListener(new TextWatcher() {@Overridepublic void beforeTextChanged(CharSequence s, int start, int count, int after) {}@Override public void onTextChanged(CharSequence s, int start, int before, int count) {if (s.length() > 0) {// 有文字时显示指示器showPasswordVisibilityIndicator(true);} else {mIsShowPwdIcon = false;restorePasswordIconVisibility(mIsShowPwdIcon);showPasswordVisibilityIndicator(false); // 隐藏指示器}}@Override public void afterTextChanged(Editable s) {}});}
setInputType设置密码状态, TYPE_TEXT_VARIATION_PASSWORD密文状态.
通过pet_iconShow属性, 可以选择自定义密码提示图片.
3. 监听事件
点击图片, 切换显示或隐藏密码, 获取点击位置, 和图片位置进行比较, 判断事件.
@Override public boolean onTouchEvent(MotionEvent event) {if (mDrawableSide == null) {return super.onTouchEvent(event);}final Rect bounds = mDrawableSide.getBounds();final int x = (int) event.getRawX(); // 点击的位置int iconX = (int) getTopRightCorner().x;// Icon的位置int leftIcon = iconX - bounds.width();Log.e(TAG, "x: " + x + ", leftIcon: " + leftIcon);// 大于Icon的位置, 才能触发点击if (x >= leftIcon) {togglePasswordIconVisibility(); // 变换状态event.setAction(MotionEvent.ACTION_CANCEL);return false;}return super.onTouchEvent(event);}
切换明文或密文的密码
// 设置密码指示器的状态private void restorePasswordIconVisibility(boolean isShowPwd) {if (isShowPwd) {// 可视密码输入setInputType(EditorInfo.TYPE_CLASS_TEXT | EditorInfo.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);} else {// 非可视密码状态setInputType(EditorInfo.TYPE_CLASS_TEXT | EditorInfo.TYPE_TEXT_VARIATION_PASSWORD);}// 移动光标setSelection(getText().length());}
4. 保存状态
重写SavedState, 在旋转屏幕时, 保存和恢复显示图片信息.
// 存储密码状态, 显示Icon的位置protected static class PwdSavedState extends BaseSavedState {private final boolean mShowingIcon;private PwdSavedState(Parcelable superState, boolean showingIcon) {super(superState);mShowingIcon = showingIcon;}private PwdSavedState(Parcel in) {super(in);mShowingIcon = in.readByte() != 0;}public boolean isShowingIcon() {return mShowingIcon;}@Overridepublic void writeToParcel(Parcel destination, int flags) {super.writeToParcel(destination, flags);destination.writeByte((byte) (mShowingIcon ? 1 : 0));}public static final Parcelable.Creator<PwdSavedState> CREATOR = new Creator<PwdSavedState>() {public PwdSavedState createFromParcel(Parcel in) {return new PwdSavedState(in);}public PwdSavedState[] newArray(int size) {return new PwdSavedState[size];}};}
动画效果
现在可以把类复制到应用中, 更换图片资源, 替换显示密码框, 给用户更好的移动端体验. 永远追求极致, 追求不凡.
关于Android程序开发之防止密码输入错误 密码明文显示功能的相关知识就给大家介绍到这里,希望对大家有所帮助!
新闻热点
疑难解答
图片精选