本篇文章為大家展示了Android中怎么通過自定義EditText實現淘寶登錄功能,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
整體布局UI:
<com.example.zdyedittext.ClearEditText android:id="@+id/editText1" android:layout_width="fill_parent" android:layout_height="35dp" android:layout_alignTop="@+id/imageView1" android:layout_marginLeft="17dp" android:layout_toRightOf="@+id/imageView1" android:background="@android:color/white" android:ems="10" android:hint="手機號" android:padding="8dp" android:singleLine="true" /> <com.example.zdyedittext.ClearEditText android:id="@+id/et_pass_word" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="密碼" android:background="@android:color/white" android:password="true" android:padding="8dp" android:singleLine="true" />
自定義EditText類
由于自定義EditText理所當然要集成EditText
public class ClearEditText extends EditText
然后添加構造方法,是為了能在XML中能夠引用。
public ClearEditText(Context context, AttributeSet attrs) { this(context, attrs, android.R.attr.editTextStyle); }
接下來就是設置自己的EditText的樣式,添加自己想要的樣式。具體是在init()方法中實現。
public ClearEditText(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); init(); }
init()方法的實現過程:[2]參數為:dr.mDrawableRight,定義刪除按鈕是在EditText的右邊,設置圖標的左上右下:mClearDrawable.setBounds(0, 0, mClearDrawable.getIntrinsicWidth(), mClearDrawable.getIntrinsicHeight());
private void init() { // 獲取EditText的DrawableRight,假如沒有設置我們就使用默認的圖片 mClearDrawable = getCompoundDrawables()[2]; if (mClearDrawable == null) { mClearDrawable = getResources().getDrawable(R.drawable.del);//R.drawable.del刪除圖標的圖片 } mClearDrawable.setBounds(0, 0, mClearDrawable.getIntrinsicWidth(), mClearDrawable.getIntrinsicHeight()); //設置圖標的左上右下 // 默認設置隱藏圖標 setClearIconVisible(false); // 設置焦點改變的監聽 setOnFocusChangeListener(this); // 設置輸入框里面內容發生改變的監聽 addTextChangedListener(this); }
由于不能直接給EditText設置監聽事件,所以采用記錄點擊位置來模擬點擊事件,只記錄了魚圖標的左右點擊。
public boolean onTouchEvent(MotionEvent event) { if (event.getAction() == MotionEvent.ACTION_UP) { if (getCompoundDrawables()[2] != null) { boolean touchable = event.getX() > (getWidth() - getTotalPaddingRight()) && (event.getX() < ((getWidth() - getPaddingRight()))); if (touchable) { this.setText(""); } } } return super.onTouchEvent(event); }
判斷輸入框中是否有文字,動態設置刪除圖標的顯示和隱藏。
public void onFocusChange(View v, boolean hasFocus) { this.hasFoucs = hasFocus; if (hasFocus) { setClearIconVisible(getText().length() > 0); } else { setClearIconVisible(false); } }
如果輸入框中有文字 那么久繪制刪除圖標
protected void setClearIconVisible(boolean visible) { Drawable right = visible ? mClearDrawable : null; setCompoundDrawables(getCompoundDrawables()[0], getCompoundDrawables()[1], right, getCompoundDrawables()[3]); }
當輸入框內容發生變化的時候動態改變刪除圖標
public void onTextChanged(CharSequence s, int start, int count, int after) { if (hasFoucs) { setClearIconVisible(s.length() > 0); } }
至此就完成了:當屬框中沒有文本的時候 刪除圖標隱藏 當有文本輸入的時候,刪除圖標顯示,點擊刪除圖標,清空文本內容。
自定義InputType返回為”*”
設置密碼樣式要繼承PasswordTransformationMethod這個類然后實現CharSequence方法去修改CharAt的返回值為“*”即可。
private class PasswordCharSequence implements CharSequence { private CharSequence mSource; public PasswordCharSequence(CharSequence source) { mSource = source; // Store char sequence } 這里用于修改InputType的返回樣式 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 } }
然后在主程序中初始化控件,在布局中設置android:password=”true”這一行代碼,以便在代碼中動態設置密碼輸入的返回樣式。
et_pass_word = (ClearEditText) findViewById(R.id.et_pass_word); et_pass_word.setTransformationMethod(new EditTextBgToStar());
上述內容就是Android中怎么通過自定義EditText實現淘寶登錄功能,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。