From 44cb251cde66e0a3bd02eb11cc432caccbb32d7a Mon Sep 17 00:00:00 2001 From: PeratX <1215714524@qq.com> Date: Sun, 9 Apr 2017 14:50:57 +0800 Subject: [PATCH] Implemented ClearAutoCompleteTextView based on https://github.com/MrFuFuFu/ClearEditText/blob/master/app/src/main/java/mrfu/clearedittext/view/ClearEditText.java --- README.md | 8 +- .../view/ClearAutoCompleteTextView.java | 119 ++++++++++++++++++ .../main/res/layout/activity_server_test.xml | 2 +- 3 files changed, 126 insertions(+), 3 deletions(-) create mode 100644 app/src/main/java/org/itxtech/daedalus/view/ClearAutoCompleteTextView.java diff --git a/README.md b/README.md index f2f6685..6683875 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,7 @@ Daedalus ============== -__Through [CuteDNS!](https://www.cutedns.cn) to see the world outside.__ +__See the world outside through [CuteDNS!](https://www.cutedns.cn).__ This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -35,4 +35,8 @@ __各位 dalao 见笑了!__ Get Daedalus ------------- -__[Releases](https://github.com/iTXTech/Daedalus/releases)__ \ No newline at end of file +__[Releases](https://github.com/iTXTech/Daedalus/releases)__ + +Acknowledgements +------------- +* __[ClearEditText](https://github.com/MrFuFuFu/ClearEditText)__ by *[MrFuFuFu](https://github.com/MrFuFuFu)* \ No newline at end of file diff --git a/app/src/main/java/org/itxtech/daedalus/view/ClearAutoCompleteTextView.java b/app/src/main/java/org/itxtech/daedalus/view/ClearAutoCompleteTextView.java new file mode 100644 index 0000000..fe73d76 --- /dev/null +++ b/app/src/main/java/org/itxtech/daedalus/view/ClearAutoCompleteTextView.java @@ -0,0 +1,119 @@ +package org.itxtech.daedalus.view; + +import android.content.Context; +import android.graphics.drawable.Drawable; +import android.support.v4.content.ContextCompat; +import android.support.v4.graphics.drawable.DrawableCompat; +import android.text.Editable; +import android.text.TextWatcher; +import android.util.AttributeSet; +import android.view.MotionEvent; +import android.view.View; +import android.widget.AutoCompleteTextView; +import org.itxtech.daedalus.R; + +/** + * Daedalus Project + * + * @author iTXTech + * @link https://itxtech.org + *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, version 3.
+ */
+public class ClearAutoCompleteTextView extends AutoCompleteTextView implements View.OnTouchListener, View.OnFocusChangeListener, TextWatcher {
+
+ private Drawable mClearTextIcon;
+ private OnFocusChangeListener mOnFocusChangeListener;
+ private OnTouchListener mOnTouchListener;
+
+ public ClearAutoCompleteTextView(final Context context) {
+ super(context);
+ init(context);
+ }
+
+ public ClearAutoCompleteTextView(final Context context, final AttributeSet attrs) {
+ super(context, attrs);
+ init(context);
+ }
+
+ public ClearAutoCompleteTextView(final Context context, final AttributeSet attrs, final int defStyleAttr) {
+ super(context, attrs, defStyleAttr);
+ init(context);
+ }
+
+ private void init(final Context context) {
+ final Drawable drawable = ContextCompat.getDrawable(context, R.mipmap.ic_clear_grey600_18dp);
+ final Drawable wrappedDrawable = DrawableCompat.wrap(drawable); //Wrap the drawable so that it can be tinted pre Lollipop
+ DrawableCompat.setTint(wrappedDrawable, getCurrentHintTextColor());
+ mClearTextIcon = wrappedDrawable;
+ mClearTextIcon.setBounds(0, 0, mClearTextIcon.getIntrinsicHeight(), mClearTextIcon.getIntrinsicHeight());
+ setClearIconVisible(false);
+ super.setOnTouchListener(this);
+ super.setOnFocusChangeListener(this);
+ addTextChangedListener(this);
+ }
+
+ @Override
+ public void setOnFocusChangeListener(OnFocusChangeListener l) {
+ mOnFocusChangeListener = l;
+ }
+
+ @Override
+ public void setOnTouchListener(OnTouchListener l) {
+ mOnTouchListener = l;
+ }
+
+ @Override
+ public void onFocusChange(View v, boolean hasFocus) {
+ if (hasFocus) {
+ setClearIconVisible(getText().length() > 0);
+ } else {
+ setClearIconVisible(false);
+ }
+ if (mOnFocusChangeListener != null) {
+ mOnFocusChangeListener.onFocusChange(v, hasFocus);
+ }
+ }
+
+ @Override
+ public boolean onTouch(View view, MotionEvent motionEvent) {
+ final int x = (int) motionEvent.getX();
+ if (mClearTextIcon.isVisible() && x > getWidth() - getPaddingRight() - mClearTextIcon.getIntrinsicWidth()) {
+ if (motionEvent.getAction() == MotionEvent.ACTION_UP) {
+ setError(null);
+ setText("");
+ }
+ return true;
+ }
+ return mOnTouchListener != null && mOnTouchListener.onTouch(view, motionEvent);
+ }
+
+ @Override
+ public final void onTextChanged(CharSequence text, int start, int lengthBefore, int lengthAfter) {
+ if (isFocused()) {
+ setClearIconVisible(text.length() > 0);
+ }
+ }
+
+ @Override
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+
+ }
+
+ @Override
+ public void afterTextChanged(Editable s) {
+
+ }
+
+ private void setClearIconVisible(final boolean visible) {
+ mClearTextIcon.setVisible(visible, false);
+ final Drawable[] compoundDrawables = getCompoundDrawables();
+ setCompoundDrawables(
+ compoundDrawables[0],
+ compoundDrawables[1],
+ visible ? mClearTextIcon : null,
+ compoundDrawables[3]);
+ }
+}
\ No newline at end of file
diff --git a/app/src/main/res/layout/activity_server_test.xml b/app/src/main/res/layout/activity_server_test.xml
index 271bc9f..1597061 100644
--- a/app/src/main/res/layout/activity_server_test.xml
+++ b/app/src/main/res/layout/activity_server_test.xml
@@ -32,7 +32,7 @@
android:layout_alignParentStart="true" android:layout_marginTop="10dp"
android:id="@+id/textView_test_info"
android:textSize="18sp"/>
-