在Android活动中,我首先恢复EditText中的文本,然后向其中添加TextWatcher。
private static int WC = 0;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.e("TextWatcherTest", "onCreate:\t" +CLASS_NAME);
setContentView(R.layout.main);
EditText et = (EditText)findViewById(R.id.editText);
Log.e("TextWatcherTest", "Set text xyz");
et.setText("xyz");
et.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) { }
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { }
@Override
public void afterTextChanged(Editable s) {
Log.e("TextWatcherTest", "afterTextChanged:\t" +s.toString());
}
});
}
但是当我运行活动时,即使在设置文本后添加了Watcher本身,也会调用afterTextChanged方法。所以日志输出类似于
onCreate: LifecycleMain Set text xyz // screen rotation onCreate: LifecycleMain Set text xyz afterTextChanged: xyz 2
TextWatcher中的计数器显示被调用的观察者是在EditText中设置文本后添加的观察者。任何想法为什么会发生这种情况以及如何防止这种情况发生?
答案 0 :(得分:8)
解决方法是将addTextChangedListener移动到onPostCreate方法。一切都将得到解决。
答案 1 :(得分:1)
这绝对必须发生。当savedinstanceState不为null时(意味着保存了先前的对象状态),您正在设置文本。
我认为这是因为您在onCreate方法中将TextWatcher添加到EditText中,并且下次onCreate被调用(例如,在配置更改后),然后它发现TextWatcher已经添加到EditText。
如果您想检查这种情况,请将其放在您的条件之前:
if(savedInstanceState == null){
Log.e("savedInstance state is null", "no text");
et.setText("No text");
}
在这种情况下,如果在EditText上调用setText,则不会调用afterTextChanged(Editable s)。