Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/217.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/google-app-engine/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 编辑范围内的文本值_Android - Fatal编程技术网

Android 编辑范围内的文本值

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">

我想输入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>

您可以为您的
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});