-
Notifications
You must be signed in to change notification settings - Fork 310
/
Copy pathEditTextSearchAssist.java
174 lines (150 loc) · 4.31 KB
/
EditTextSearchAssist.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
package dev.assist;
import android.text.Editable;
import android.text.TextWatcher;
import android.widget.EditText;
import dev.utils.app.assist.DelayAssist;
/**
* detail: EditText 搜索辅助类
* @author Ttt
* <pre>
* 用于 EditText 输入实时搜索
* 降低每触发一次 {@link TextWatcher#onTextChanged} 进行一次查询频率
* <p></p>
* 使用:
* 第一种
* 在 {@link TextWatcher#onTextChanged} 中调用 {@link #post(CharSequence)}
* 第二种
* 调用 {@link #setCallback(SearchCallback, EditText)} 传入需要监听的 EditText
* 或使用 {@link #bindEditText(EditText)} 绑定 EditText 输入事件
* </pre>
*/
public class EditTextSearchAssist {
// 搜索回调
private SearchCallback mCallback;
// 延迟触发回调类
private final DelayAssist mDelayAssist = new DelayAssist(object -> {
if (mCallback != null && object instanceof CharSequence) {
mCallback.callback((CharSequence) object);
}
});
// ==========
// = 构造函数 =
// ==========
public EditTextSearchAssist() {
this(DelayAssist.DELAY_MILLIS, null);
}
public EditTextSearchAssist(long delayMillis) {
this(delayMillis, null);
}
public EditTextSearchAssist(SearchCallback callback) {
this(DelayAssist.DELAY_MILLIS, callback);
}
public EditTextSearchAssist(
long delayMillis,
SearchCallback callback
) {
mCallback = callback;
mDelayAssist.setDelayMillis(delayMillis);
}
/**
* detail: 搜索回调接口
* @author Ttt
*/
public interface SearchCallback {
/**
* 搜索回调
* @param content 搜索内容
*/
void callback(CharSequence content);
}
// =============
// = 对外公开方法 =
// =============
/**
* 移除消息
*/
public void remove() {
mDelayAssist.remove();
}
/**
* 发送消息 ( 功能由该方法实现 )
* @param text 输入内容
*/
public void post(final CharSequence text) {
mDelayAssist.post(text);
}
// =
/**
* 设置搜索延迟时间
* @param delayMillis 延迟时间
* @return {@link EditTextSearchAssist}
*/
public EditTextSearchAssist setDelayMillis(final long delayMillis) {
mDelayAssist.setDelayMillis(delayMillis);
return this;
}
/**
* 设置搜索回调接口
* @param callback {@link SearchCallback}
* @return {@link EditTextSearchAssist}
*/
public EditTextSearchAssist setCallback(final SearchCallback callback) {
mCallback = callback;
return this;
}
/**
* 设置搜索回调接口并监听 EditText 输入
* @param callback {@link SearchCallback}
* @param editText {@link EditText}
* @return {@link EditTextSearchAssist}
*/
public EditTextSearchAssist setCallback(
final SearchCallback callback,
final EditText editText
) {
bindEditText(editText);
return setCallback(callback);
}
/**
* 绑定 EditText 输入事件
* @param editText {@link EditText}
* @return {@link EditTextSearchAssist}
*/
public EditTextSearchAssist bindEditText(final EditText editText) {
if (editText != null) {
initTextWatcher();
editText.removeTextChangedListener(mTextWatcher);
editText.addTextChangedListener(mTextWatcher);
}
return this;
}
// ==========
// = 内部逻辑 =
// ==========
private TextWatcher mTextWatcher;
private void initTextWatcher() {
if (mTextWatcher != null) return;
mTextWatcher = new TextWatcher() {
@Override
public void onTextChanged(
CharSequence text,
int start,
int before,
int count
) {
post(text);
}
@Override
public void beforeTextChanged(
CharSequence text,
int start,
int count,
int after
) {
}
@Override
public void afterTextChanged(Editable text) {
}
};
}
}