日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android帶清除按鈕、密碼可見小眼睛的輸入框

瀏覽:128日期:2022-09-21 10:30:32
前言

相信不少小伙伴在開發(fā)登錄功能時候,或多或少都會用到輸入框清除按鈕、密碼可見與隱藏小眼睛按鈕,我之前也是但寫這個功能,但是在找回密碼、忘記密碼里面還要重新寫一次很是麻煩,現在我把它只做了一個自定義控件,可以配置清除按鈕、密碼可見小眼睛是否顯示以及圖標,有漸隱漸顯和橫向移動動畫,不知道怎么上傳可以直接觀看的視頻,附上三張效果圖,可以點擊鏈接觀看視頻是否是你想要的效果。

Android帶清除按鈕、密碼可見小眼睛的輸入框 Android帶清除按鈕、密碼可見小眼睛的輸入框 Android帶清除按鈕、密碼可見小眼睛的輸入框

一、自定義控件ClearEditText

我的這個自帶清除、小眼睛的控件,是一個自定義控件,控件名稱ClearEditText.class,繼承RelativeLayout并有布局引用。在拷貝到項目里面后,使用時候只需要與普通輸入框控件一樣,進行相關的配置即可,部分屬性需要使用自定義屬性,具體見代碼。

二、使用步驟 1.拷貝ClearEditText.class

拷貝ClearEditText.class類到自己的項目里,再考拷貝它相關的布局文件、自定義屬性、默認圖片即可,下面貼出ClearEditText主要代碼:

public class ClearEditText extends RelativeLayout { private ImageView ivLeftIcon; private EditText myEdie; private ImageView ivEditClean; private ImageView ivEditEye; private boolean isChecked = true; private Context mContext; private TypedArray mTypedArray; private boolean showClean = true;//清空圖標是否顯示,true:顯示 private boolean showEye = false;//密碼可見圖標是否顯示,true:顯示 private int drawableLeft = -1;//是否顯示輸入框左側圖片 private int drawableEyeOpen = R.drawable.clear_icon_eye_open;//可以看見密碼小眼睛樣式 private int drawableEyeClose = R.drawable.clear_icon_eye_close;//不可見密碼小眼睛樣式 private int drawableClean = R.drawable.clear_icon_close;//清除按鈕圖片 private int cleanPadding = 0;//清除按鈕padding邊距 private String hintStr; private String textStr; private int mTextColorHint = Color.BLACK; private int mTextColor = Color.BLACK; private int mTextSize = -1; private int mMaxLength = 2000; private int mMaxLines = 1; private int mInputType = 0;//輸入類型,就做了不限制、數字、文本密碼三種 private boolean isInput = false;//輸入1個字符后更改狀態(tài)為true,保證小眼睛移動一次 private boolean isHideClean = false;//輸入字符后,清除了需要小眼睛歸為,清除按鈕隱藏 private int ivWidth = 45;//關閉按鈕的寬度 public ClearEditText(Context context) { super(context); mContext = context; initView(); } public ClearEditText(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); mContext = context; mTypedArray = mContext.obtainStyledAttributes(attrs, R.styleable.myEditText); initView(); } public ClearEditText(Context context, AttributeSet attrs) { super(context, attrs); mContext = context; mTypedArray = mContext.obtainStyledAttributes(attrs, R.styleable.myEditText); showClean = mTypedArray.getBoolean(R.styleable.myEditText_showClean, showClean); drawableClean = mTypedArray.getResourceId(R.styleable.myEditText_drawableClean, drawableClean); cleanPadding = mTypedArray.getDimensionPixelSize(R.styleable.myEditText_cleanPadding, cleanPadding); showEye = mTypedArray.getBoolean(R.styleable.myEditText_showEye, showEye); drawableLeft = mTypedArray.getResourceId(R.styleable.myEditText_drawableLeft, -1); drawableEyeClose = mTypedArray.getResourceId(R.styleable.myEditText_drawableEyeClose, drawableEyeClose); drawableEyeOpen = mTypedArray.getResourceId(R.styleable.myEditText_drawableEyeOpen, drawableEyeOpen); hintStr = mTypedArray.getString(R.styleable.myEditText_hint); textStr = mTypedArray.getString(R.styleable.myEditText_text); mTextColorHint = mTypedArray.getColor(R.styleable.myEditText_textColorHint, mTextColorHint); mTextColor = mTypedArray.getColor(R.styleable.myEditText_textColor, mTextColor); mTextSize = mTypedArray.getDimensionPixelSize(R.styleable.myEditText_textSize, mTextSize); mMaxLength = mTypedArray.getInteger(R.styleable.myEditText_maxLength, mMaxLength); mMaxLines = mTypedArray.getDimensionPixelSize(R.styleable.myEditText_maxLines, mMaxLines); mInputType = mTypedArray.getInteger(R.styleable.myEditText_inputType, mInputType); mTypedArray.recycle(); initView(); } // 初始化視圖 private void initView() { View view = View.inflate(getContext(), R.layout.clear_layout_view, null); ivLeftIcon = (ImageView) view.findViewById(R.id.iv_edit_left_icon); myEdie = (EditText) view.findViewById(R.id.view_edit_show); ivEditClean = (ImageView) view.findViewById(R.id.iv_edit_clean); ivEditEye = (ImageView) view.findViewById(R.id.iv_edit_eye); myEdie.setHint(hintStr); myEdie.setHintTextColor(mTextColorHint); myEdie.setText(textStr); myEdie.setTextColor(mTextColor); myEdie.setMaxLines(mMaxLines); myEdie.setFilters(new InputFilter[]{new InputFilter.LengthFilter(mMaxLength)}); if (mTextSize != -1) { myEdie.setTextSize(TypedValue.COMPLEX_UNIT_PX, mTextSize); } else { myEdie.setTextSize(15); } if (mInputType == 1) { myEdie.setInputType(InputType.TYPE_CLASS_NUMBER); } else if (mInputType == 2) { myEdie.setInputType(InputType.TYPE_TEXT_VARIATION_PASSWORD | InputType.TYPE_CLASS_TEXT); } else { myEdie.setInputType(InputType.TYPE_NUMBER_VARIATION_NORMAL | InputType.TYPE_CLASS_TEXT); } if (showEye) { myEdie.setTransformationMethod(new AsteriskPasswordTransformationMethod()); } if (showClean && showEye) { int left = myEdie.getPaddingLeft(); int top = myEdie.getPaddingTop(); int bottom = myEdie.getPaddingBottom(); myEdie.setPadding(left, top, Utils.dp2px(mContext, 90), bottom); } else if (!showClean && !showEye) { int left = myEdie.getPaddingLeft(); int top = myEdie.getPaddingTop(); int right = myEdie.getPaddingRight(); int bottom = myEdie.getPaddingBottom(); myEdie.setPadding(left, top, right, bottom); } else { int left = myEdie.getPaddingLeft(); int top = myEdie.getPaddingTop(); int bottom = myEdie.getPaddingBottom(); myEdie.setPadding(left, top, Utils.dp2px(mContext, 45), bottom); } myEdie.addTextChangedListener(new TextWatcher() { @Override public 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) { isHideClean = false; } } @Override public void afterTextChanged(Editable s) { if (s.length() > 0 && !isInput) {//輸入字符大于0且只有一個字符時候顯示清除按鈕動畫,小眼睛移動出位置給清除按鈕使用 showEditClean(); moveEditEye(); isInput = true; } else if (s.length() == 0) {//無字符小眼睛歸位 UndoEditEye(); } if (s.length() == 0 & !isHideClean) { hideEditClean(); isHideClean = true; isInput = false; } if (onEditInputListener != null) { onEditInputListener.input(getText()); } } }); setEditClean(showClean); ivEditClean.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { myEdie.setText(''); } }); ivEditClean.setImageResource(drawableClean); ivEditClean.setPadding(cleanPadding, cleanPadding, cleanPadding, cleanPadding); setEditEye(showEye); ivEditEye.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if (isChecked) { // 輸入一個對用戶可見的密碼 myEdie.setTransformationMethod(HideReturnsTransformationMethod.getInstance()); myEdie.setSelection(getText().length()); ivEditEye.setImageResource(drawableEyeOpen); isChecked = false; } else { // 輸入一個對用戶不可見的密碼 myEdie.setTransformationMethod(new AsteriskPasswordTransformationMethod()); myEdie.setSelection(getText().length()); ivEditEye.setImageResource(drawableEyeClose); isChecked = true; } } }); if (drawableLeft != -1) { ivLeftIcon.setVisibility(View.VISIBLE); ivLeftIcon.setImageResource(drawableLeft); } else { ivLeftIcon.setVisibility(View.GONE); } view.setLayoutParams(new LayoutParams(ViewPager.LayoutParams.MATCH_PARENT, ViewPager.LayoutParams.WRAP_CONTENT)); addView(view); } //密碼不可見時候,使用*替換密碼 public class AsteriskPasswordTransformationMethod extends PasswordTransformationMethod { @Override public CharSequence getTransformation(CharSequence source, View view) { return new PasswordCharSequence(source); } private class PasswordCharSequence implements CharSequence { private CharSequence mSource; public PasswordCharSequence(CharSequence source) { mSource = source; // Store char sequence } public char charAt(int index) { return ’*’; // This is the important part } public int length() { return mSource.length(); // Return default } public CharSequence subSequence(int start, int end) { return mSource.subSequence(start, end); // Return default } } } public String getText() { return myEdie.getText().toString().trim(); } public void setText(String text) { myEdie.setText(text); } //代碼設置是否顯示清除按鈕 public void setEditClean(boolean isCanClose) { showClean = isCanClose; } //代碼設置是否顯示小眼睛 public void setEditEye(boolean isCanSee) { showEye = isCanSee; if (showEye == true) { ivEditEye.setVisibility(View.VISIBLE); } else { ivEditEye.setVisibility(View.GONE); } } private void showEditClean() { if (showClean == true) { AnimationUtils.showAndHiddenCenterAnimation(ivEditClean, AnimationUtils.AnimationState.STATE_SHOW, 500); } } private void hideEditClean() { if (showClean == true) { AnimationUtils.showAndHiddenCenterAnimation(ivEditClean, AnimationUtils.AnimationState.STATE_HIDDEN, 500); } } private void moveEditEye() { if (showEye) { ObjectAnimator.ofFloat(ivEditEye, 'translationX', -Utils.dp2px(mContext, ivWidth)).setDuration(500).start(); } } private void UndoEditEye() { if (showEye) { ObjectAnimator.ofFloat(ivEditEye, 'translationX', 0).setDuration(500).start(); } } public OnEditInputListener onEditInputListener; public void setOnEditInputListener(OnEditInputListener listener) { onEditInputListener = listener; } //輸入監(jiān)聽 public interface OnEditInputListener { void input(String content); }}2.使用示例

下面是在xml布局時候,如何使用ClearEditText的示例,部分自定義屬性使用xmlns:app='http://schemas.android.com/apk/res-auto'引用調用。app:showEye屬性true-顯示小眼睛,false-關閉小眼睛。

<com.huaweixia.clear.ClearEditText android: android:layout_width='0dp' android:layout_height='45dp' android:layout_marginTop='30dp' android:background='@drawable/line_bg_white_only_bottom_d8' android:paddingLeft='10dp' app:hint='請輸入密碼' app:layout_constraintLeft_toLeftOf='@id/et_login_number' app:layout_constraintRight_toRightOf='@id/et_login_number' app:layout_constraintTop_toBottomOf='@id/et_login_number' app:showEye='true' app:textColor='@color/tv_black_333333' app:textColorHint='@color/tv_gray_999999' app:textSize='15sp' />總結

一開始我之前自己用的自帶清空、密碼可見的自定義輸入框,是沒有清除按鈕顯示,密碼可見按鈕移動動效,清除按鈕顯示比較僵硬,在清除按鈕隱藏時候小眼睛按鈕后面有一定空白,顯示看著比較別扭,加了動效后視覺上感覺更加順暢,希望對部分需要的小伙伴有空,下面附上 下載demo的鏈接 地址,有需要可以下載看看。

到此這篇關于Android帶清除按鈕、密碼可見小眼睛的輸入框的文章就介紹到這了,更多相關android密碼輸入框內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品二区不卡| 日韩欧美在线中字| 99国产精品视频免费观看一公开 | 日韩和欧美一区二区| 欧美精品九九| 欧美精品自拍| 午夜视频精品| 99在线精品免费视频九九视| 在线手机中文字幕| 久久男人av资源站| 女生影院久久| 99精品在线观看| 欧美.日韩.国产.一区.二区| 亚洲精品一区二区妖精| 国产亚洲精品精品国产亚洲综合| 奇米亚洲欧美| 国产精品一区高清| 91中文字幕精品永久在线| 日韩精品午夜| 男女男精品网站| 欧美在线首页| 美女性感视频久久| av在线资源| 久久久一二三| 日韩在线播放一区二区| 日本强好片久久久久久aaa| 国产女人18毛片水真多18精品| 麻豆精品视频在线观看| 中文字幕在线免费观看视频| 亚洲视频综合| 免费看黄色91| 国产日产精品_国产精品毛片| 麻豆精品在线视频| 日韩精品水蜜桃| 亚洲三级视频| 精品国产午夜肉伦伦影院| 精品亚洲美女网站| 免费观看久久久4p| 91成人精品在线| 综合日韩av| 一级欧美视频| 国产欧洲在线| 日韩一区二区三区精品| 久久97视频| 国产亚洲综合精品| 国产精品久久久久久模特| 韩国精品主播一区二区在线观看 | 久久精品72免费观看| 久久精品国产一区二区| 香蕉久久99| 婷婷精品在线| 麻豆精品蜜桃| 国产伦精品一区二区三区视频| 六月婷婷综合| 日韩精品91亚洲二区在线观看| 电影91久久久| 日韩在线a电影| 国产精品不卡| 亚洲精品乱码日韩| jizzjizz中国精品麻豆| 日韩中文字幕麻豆| 在线手机中文字幕| 亚洲欧美日韩一区在线观看| 欧美日韩亚洲一区三区| 丝袜av一区| 日本欧美大码aⅴ在线播放| 久久久久蜜桃| 麻豆91精品视频| 视频一区中文字幕| 国际精品欧美精品| 亚洲一级大片| 亚洲成人不卡| 国产精品羞羞答答在线观看| 1024精品久久久久久久久| 国产精品66| 亚洲午夜国产成人| 久久久五月天| 国产精品成人自拍| 亚洲一区久久| 少妇久久久久| 粉嫩av一区二区三区四区五区 | 久久午夜精品| 日韩理论视频| 国产精品qvod| 亚洲视频二区| 一区在线观看| 人人精品亚洲| 国产成人精选| 国产午夜久久av| 亚洲小说春色综合另类电影| 日韩综合精品| 麻豆精品国产91久久久久久| 亚洲精选成人| 99xxxx成人网| 99久久亚洲精品| 欧美日韩一区二区三区不卡视频| 亚洲欧美日韩视频二区| 欧美一级精品| 日韩欧美一区二区三区免费看| 免费在线日韩av| 日韩超碰人人爽人人做人人添| 国产视频一区三区| 免费精品国产| 视频福利一区| 欧美日韩精品免费观看视完整| 免费亚洲婷婷| 国产日韩欧美一区二区三区在线观看| 美女精品一区| 国产亚洲永久域名| 亚洲一区日韩在线| 一区久久精品| 欧美午夜不卡影院在线观看完整版免费| 理论片午夜视频在线观看| 国产极品久久久久久久久波多结野| 日韩精品视频一区二区三区| 一级欧美视频| 亚洲三级在线| 亚洲欧美日本国产| 日本亚洲不卡| 日本特黄久久久高潮| 日韩免费精品| 婷婷综合一区| 欧美一级全黄| 国产精品午夜一区二区三区| 国产精品亚洲成在人线| 国产精品自在| 久久精品国产久精国产| 国产精品毛片久久久| 日本久久二区| 国产探花在线精品一区二区| 欧美自拍一区| 国产毛片一区二区三区 | 中文字幕人成乱码在线观看| 麻豆精品蜜桃视频网站| 麻豆精品在线观看| 国产一区二区三区国产精品| 六月婷婷综合| 亚洲性视频h| 欧美一区=区| 午夜久久av| 国产精品最新| 高清av不卡| 欧美日韩国产一区二区三区不卡| 999在线观看精品免费不卡网站| 国产亚洲毛片在线| 日韩精品免费视频一区二区三区| 日本aⅴ精品一区二区三区| 国产伦精品一区二区三区视频| 久久精品999| 精品资源在线| 99精品网站| 亚洲午夜国产成人| 欧美交a欧美精品喷水| 91嫩草亚洲精品| 在线精品小视频| 日韩高清成人在线| 狠狠久久伊人中文字幕| 久久在线免费| 视频一区日韩精品| 久久99精品久久久野外观看| 在线看片国产福利你懂的| 精品中文一区| 视频一区日韩精品| 国产精品对白| 亚洲性图久久| 91成人小视频| 天堂网av成人| 四虎精品一区二区免费| 久久中文欧美| 最新国产拍偷乱拍精品| 日韩av中文在线观看| 精品日本视频| 亚洲深夜av| 国产激情久久| 黄色免费成人| 麻豆国产欧美一区二区三区| 不卡中文一二三区| 欧美性www| 欧美日韩国产观看视频| 丝袜脚交一区二区| 精品网站aaa| 久久电影一区| 免费在线成人| 国产美女精品| 成人国产精品| 亚洲精品成人一区| 欧美一区精品| 久久亚洲国产| 国产精品香蕉| 国产亚洲网站| 成人午夜网址| 亚洲精品免费观看| 免费一二一二在线视频| 亚洲精选久久| 久久婷婷av| 国产日韩一区二区三区在线 | 激情91久久| 成人国产精品久久| 亚洲va久久久噜噜噜久久| 激情亚洲影院在线观看|