我是完成数字偏好验证程序的一小步
我替换了ClickListener上的EditTextPrefernce OK按钮,以防止在条目不是数字时离开对话框。
我使用TextWatcher.afterTextChanged检查条目是否为数字,并将有效的评估放在EditText标记上。
一切运行正常,当输入无效时按OK确认不离开对话框,当输入有效时按OK确定...这里我需要调用原来的OK按钮onClick ,但是我没有找到怎么做。
有查看函数callOnClick()和performOnClick(),但我查看了他们的代码,他们打算调用已安装的侦听器,而不是原始侦听器。
@Override
public void onCreate(Bundle savedInstanceState) {
Log.d(TAG, "+ onCreate(savedInstanceState:" + savedInstanceState + ")");
super.onCreate(savedInstanceState);
...
prefMaxLogs = (EditTextPreference) findPreference(getText(R.string.pref_maxLogs_key));
prefMaxLogsEt = prefMaxLogs.getEditText();
prefMaxLogsEt.setSingleLine();
prefMaxLogsEt.setOnFocusChangeListener(ofcl);
prefMaxLogsEt.addTextChangedListener(tw);
...
Log.d(TAG, "- onCreate()");
}
private OnFocusChangeListener ofcl = new OnFocusChangeListener() {
@Override
public void onFocusChange(View v, boolean hasFocus) {
Log.d(TAG, "+ onFocusChange(v:" + v + ", hasFocus:" + hasFocus + ")");
if( hasFocus ) {
prefMaxLogsEt.selectAll();
Dialog dialog = prefMaxLogs.getDialog();
if( dialog != null ) {
dialog.findViewById(android.R.id.button1).setOnClickListener(ocl);
}
}
Log.d(TAG, "- onFocusChange()");
}
};
private OnClickListener ocl = new OnClickListener() {
@Override
public void onClick(View v) {
Log.d(TAG, "+ onClick(v:" + v + ")");
Boolean valid = !(Boolean) prefMaxLogsEt.getTag(R.string.invalidEntry);
if( valid ) {
Log.d(TAG, "Valid et");
}
Log.d(TAG, "- onClick()");
}
};
private TextWatcher tw = 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) {}
@Override
public void afterTextChanged(Editable s) {
Log.d(TAG, "+ afterTextChanged(s:" + s + ")");
String source = s.toString();
//prefMaxLogsEt.removeTextChangedListener(this);
if( !source.matches("^[0-9]+$") ) {
prefMaxLogsEt.getBackground().setColorFilter(getResources().getColor(R.color.invalid), Mode.SRC_IN);
prefMaxLogsEt.invalidate();
prefMaxLogsEt.setError(getText(R.string.invalidEntry));
prefMaxLogsEt.selectAll();
prefMaxLogsEt.setTag(R.string.invalidEntry, true);
} else {
prefMaxLogsEt.setError(null);
prefMaxLogsEt.getBackground().clearColorFilter();
prefMaxLogsEt.invalidate();
prefMaxLogsEt.setTag(R.string.invalidEntry, false);
}
//prefMaxLogsEt.addTextChangedListener(this);
Log.d(TAG, "- afterTextChanged()");
}
};
当EditText获得焦点时,onClickListener被设置,因为我知道对话框已经显示 onClickListener阻止对话框关闭无效条目
答案 0 :(得分:1)
我找到了另一种验证EditTextPreference的方法。设置OnPreferenceChangeListener并实现onPreferenceChange。
@Override
public boolean onPreferenceChange(Preference preference, Object newValue) {
Log.d(TAG, "+ onPreferenceChange(preference:" + preference + ", newValue:" + newValue + ")");
Boolean rv = true;
if( preference.equals(prefMaxLogs) ) {
String source = newValue.toString();
if( !source.matches("^[0-9]+$") ) {
rv = false;
}
}
Log.d(TAG, "- onPreferenceChange()");
return rv;
}
此函数的优点是返回一个布尔值,如果接受更改,则返回true;如果拒绝,则返回false。
我删除了onFocusListener和onClickListener以获得OK按钮,这种方式更简单
我仍然使用setColorFilter和afterTextChanged来警告用户无效的条目。如果用户按下OK,对话框将关闭,但只接受有效值。
为每个首选项单独设置此侦听器,因此这是我在onCreate()
中的初始化 prefMaxLogs = (EditTextPreference) findPreference(getText(R.string.pref_maxLogs_key));
prefMaxLogsEt = prefMaxLogs.getEditText();
prefMaxLogsEt.setSingleLine();
prefMaxLogsEt.addTextChangedListener(tcl);
prefMaxLogs.setOnPreferenceClickListener(this);