Android 编辑范围内的文本值
我想输入1-60范围内的值。Android 编辑范围内的文本值,android,Android,我想输入1-60范围内的值。EditText不应接受像61,62…,或0,-1,-2 在android中,我们如何给出1-60到EditText的范围? 我在main.xml中做了如下工作 <EditText android:layout_height="wrap_content" android:id="@+id/editText1" android:layout_width="160dip" android:inputType="number">
EditText
不应接受像61,62…,或0,-1,-2
在android中,我们如何给出1-60到EditText
的范围?
我在main.xml中做了如下工作
<EditText android:layout_height="wrap_content"
android:id="@+id/editText1"
android:layout_width="160dip"
android:inputType="number">
</EditText>
您可以为您的
EditText
分配一个TextWatcher
,并在那里监听文本更改,例如:
public void afterTextChanged(Editable s) {
try {
int val = Integer.parseInt(s.toString());
if(val > 60) {
s.replace(0, s.length(), "60", 0, 2);
} else if(val < 1) {
s.replace(0, s.length(), "1", 0, 1);
}
} catch (NumberFormatException ex) {
// Do something
}
}
public void-afterextchanged(可编辑){
试一试{
int val=Integer.parseInt(s.toString());
如果(val>60){
s、 替换(0,s.长度(),“60”,0,2);
}else if(val<1){
s、 替换(0,s.长度(),“1”,0,1);
}
}捕获(NumberFormatException ex){
//做点什么
}
}
正如Devunwired所提到的,请注意对s.replace()
的调用将再次递归调用TextWatcher
典型的做法是通过检查布尔“编辑”标志来包装这些更改,这样递归调用会跳过并简单地返回来自内部的更改。试试这个
EditText.setOnEditorActionListener(new OnEditorActionListener()
{
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event)
{
//add your condtion here.
return false;
}
});
为什么不使用Seekbar而不是EditText? 这样,只能输入数字,并且可以根据需要指定/修改最大限制
public class SeekBar1 extends Activity implements SeekBar.OnSeekBarChangeListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
..
mSeekBar = (SeekBar)findViewById(R.id.seekBar);
mSeekBar.setOnSeekBarChangeListener(this);
..
}
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromTouch) {
//Do your Changes Here
}
public void onStartTrackingTouch(SeekBar seekBar) {
//On First Track Touch
}
public void onStopTrackingTouch(SeekBar seekBar) {
//On Stop Track Touch
}
}
对于数字输入类型值,Seekbar是最好的UI。尽管如此,它的精确度还是值得怀疑。这是一个非常有趣的问题 我想最好的方法是实现一个新的
inputType
,但是该方法会收到一个int。在这里没有什么可做的:(
在该方法中,它表示:
将内容的类型设置为
为inputType定义的常量。
这将负责更改
键侦听器,通过调用
setKeyListener(KeyListener),以匹配
给定的内容类型
非常好,您可以提供一个带有的keyListener
您可以扩展
android.text.method.DigitsKeyListener
来创建新的keyListener
,避免TextWatcher
的问题我没有足够的权限评论Ashok Felix的答案,但我想补充一点,我发现一些代码适合在首选项中显示SeekBar
它很容易使用(我不是作者)。请参阅Matthew Wiggins的SeekBarPreference代码:这是有效的,但不是实时的
editText.setOnFocusChangeListener(new OnFocusChangeListener() {
@Override
public void onFocusChange(View v, boolean hasFocus) {
try {
int val = Integer.parseInt(editText.getText()
.toString());
if (val > 2000) {
editText.setText("");
} else if (val < 100) {
editText.setText("");
}
} catch (NumberFormatException ex) {
}
}
});
editText.setOnFocusChangeListener(新的OnFocusChangeListener(){
@凌驾
public void onFocusChange(视图v,布尔hasFocus){
试一试{
int val=Integer.parseInt(editText.getText()
.toString());
如果(val>2000){
editText.setText(“”);
}否则如果(val<100){
editText.setText(“”);
}
}捕获(NumberFormatException ex){
}
}
});
我找到了一个简洁的解决方案:
我修正了Daniel Wilson的解决方案:
public class InputFilterMinMax implements InputFilter {
private int min, max;
public InputFilterMinMax(int min, int max) {
this.min = min;
this.max = max;
}
public InputFilterMinMax(String min, String max) {
this.min = Integer.parseInt(min);
this.max = Integer.parseInt(max);
}
@Override
public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
try {
//The commented line below only works if you append/modify the end of the text (not the beginning or middle)
//int input = Integer.parseInt(dest.toString() + source.toString());
//corrected solution below (3lines)
CharSequence part1 = dest.subSequence(0, dstart);
CharSequence part2 = dest.subSequence(dend, dest.length());
int input = Integer.parseInt(part1 + source.toString() + part2);
if (isInRange(min, max, input))
return null;
} catch (NumberFormatException nfe) { }
return "";
}
private boolean isInRange(int a, int b, int c) {
return b > a ? c >= a && c <= b : c >= b && c <= a;
}
}
+1:这是正确的处理方法,但需要注意的是,您在此处所做的更改通常会再次递归调用TextWatcher。通常使用布尔“编辑”复选框来包装这些更改标记,以便递归调用跳过,并在更改来自内部时简单返回。在多次阅读此问题后,不清楚您是希望在用户键入时验证和编辑输入,还是在用户退出字段后验证和编辑输入。下面有两个答案解决了这两种情况。此解决方案不适用于假设范围为5到35,因为它现在允许您输入11,因为单个1小于最小5。在谷歌搜索结果中仍然处于高位,因此希望让人们知道。我通过硬编码最小0并在休假时使用另一个检查来确认它是正确的。
mCentsEditText = (EditText)v.findViewById(R.id.cents_edit_text);
InputFilterMinMax filter = new InputFilterMinMax("0", "99") {};
mCentsEditText.setFilters(new InputFilter[]{filter});
public class InputFilterMinMax implements InputFilter {
private int min, max;
public InputFilterMinMax(int min, int max) {
this.min = min;
this.max = max;
}
public InputFilterMinMax(String min, String max) {
this.min = Integer.parseInt(min);
this.max = Integer.parseInt(max);
}
@Override
public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
try {
//The commented line below only works if you append/modify the end of the text (not the beginning or middle)
//int input = Integer.parseInt(dest.toString() + source.toString());
//corrected solution below (3lines)
CharSequence part1 = dest.subSequence(0, dstart);
CharSequence part2 = dest.subSequence(dend, dest.length());
int input = Integer.parseInt(part1 + source.toString() + part2);
if (isInRange(min, max, input))
return null;
} catch (NumberFormatException nfe) { }
return "";
}
private boolean isInRange(int a, int b, int c) {
return b > a ? c >= a && c <= b : c >= b && c <= a;
}
}
mCentsEditText = (EditText)findViewById(R.id.cents_edit_text);
InputFilterMinMax filter = new InputFilterMinMax("1", "60") {};
mCentsEditText.setFilters(new InputFilter[]{filter});