Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/195.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 如何停止焦点在ENTER上的EditText字段之间移动_Android - Fatal编程技术网

Android 如何停止焦点在ENTER上的EditText字段之间移动

Android 如何停止焦点在ENTER上的EditText字段之间移动,android,Android,我正在制作一个购物车应用程序,在添加物品时动态生成行。对于每个项目行,项目数量使用EditText字段,以便可以修改数量。由于计算量需要是整数,所以我使用parseInt转换从修改后的EditText抓取的文本,并在输入错误的情况下捕获任何NFE 当输入良好时,一切正常。当输入错误时,EditText将被设置回其先前的值(根据需要),但如果在其下方有另一行(动态生成),则焦点将转移到该较低行中的EditText。所需的行为是将焦点保留在用户希望更改的EditText中 关于专注于成功的改变会发生

我正在制作一个购物车应用程序,在添加物品时动态生成行。对于每个项目行,项目数量使用EditText字段,以便可以修改数量。由于计算量需要是整数,所以我使用parseInt转换从修改后的EditText抓取的文本,并在输入错误的情况下捕获任何NFE

当输入良好时,一切正常。当输入错误时,EditText将被设置回其先前的值(根据需要),但如果在其下方有另一行(动态生成),则焦点将转移到该较低行中的EditText。所需的行为是将焦点保留在用户希望更改的EditText中

关于专注于成功的改变会发生什么——虚拟键盘会随着成功而关闭,而没有任何东西能保持专注。在try/catch块中,我试图隐藏键盘,但这没有帮助。。。它在切换到较低的字段时保持打开状态

如果有助于形象化,这里有一个图像:

我读过其他关于使用requestFocus()的帖子,我在这里也用过,但似乎没有任何效果——可能是因为所有这些都是动态生成的?我还看到一些帖子说,动态生成的视图没有任何ID,您可以获取这些ID来更具体地确定应该获得焦点的内容,但在这种情况下,我可能不理解

那么,在处理NFE并重置该字段的值后,如何将焦点保持在用户想要编辑的字段中

以下是捕获NFE的特定代码:

try {
    quantity = Integer.parseInt(quantityCell.getText().toString());
    } catch (NumberFormatException nfe) {
    Toast.makeText(getApplicationContext(), "Please enter a valid number",
            Toast.LENGTH_LONG).show();
    imm.hideSoftInputFromWindow(quantityView.getWindowToken(), 0);
    quantityCell.setText("" + savedQuantity);
    quantityCell.requestFocus();

    return false;
}
。。。下面是动态生成EditText字段的所有代码:

// create quantity edittext and add to row
final EditText quantityView = new EditText(this);
quantityView.setLayoutParams(cellParams);
quantityView.setSingleLine();
quantityView.setPadding(5, 5, 5, 5);
quantityView.setText("" + theQuantity);
quantityView.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        // capture old value of quantity before changing it
        EditText et = (EditText)v;
        savedQuantity = Integer.parseInt(et.getText().toString());
        return false;
    }
});
quantityView.setOnKeyListener(new View.OnKeyListener() {
    @Override
    public boolean onKey(View v, int keyCode, KeyEvent event) {
        if (event.getAction() == KeyEvent.ACTION_DOWN)
            if (keyCode == KeyEvent.KEYCODE_ENTER) {
                int quantity;
                InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);

                TableRow theRow = (TableRow) v.getParent();
                TextView nameCell = (TextView) theRow.getChildAt(0);
                String name = nameCell.getText().toString();
                EditText quantityCell = (EditText) theRow.getChildAt(1);
                try {
                    quantity = Integer.parseInt(quantityCell.getText().toString());
                } catch (NumberFormatException nfe) {
                    Toast.makeText(getApplicationContext(), "Please enter a valid number",
                            Toast.LENGTH_LONG).show();
                    imm.hideSoftInputFromWindow(quantityView.getWindowToken(), 0);
                    quantityCell.setText("" + savedQuantity);
                    quantityCell.requestFocus();

                    return false;
                }
                TextView unitCell = (TextView) theRow.getChildAt(2);
                double unit = Double.parseDouble(unitCell.getText().toString().substring(1));
                TextView totalCell = (TextView) theRow.getChildAt(3);
                double total = Double.parseDouble(totalCell.getText().toString().substring(1));

                totalPrice -= total;
                totalQuantity -= quantity;
                cartDB.changeQuantity(name, quantity, unit);
                removeAllRows();
                writeOrderTable();

                imm.hideSoftInputFromWindow(quantityView.getWindowToken(), 0);
                return true;
            }
        return false;
    }
});
// set length of edittext line
productRow.addView(quantityView);
编辑: 看看catch子句中的代码,我猜如果所需字段首先保留了任何焦点,那么隐藏虚拟键盘的行将不会起多大作用,因此我可能应该删除它。它存在的原因是我试图这样做(隐藏虚拟键盘)只是为了移除任何焦点,但这种方法不起作用。下面的区域仍然占据焦点,键盘仍然打开

另一编辑: 这种情况不会发生在物理键盘上——至少当计算机键盘与Genymotion虚拟设备一起使用时(不能使用内置AVD,我有一个AMD cpu)。当同一模拟器设置为使用虚拟键盘时,问题就会出现

最终编辑: 我将try/catch块改为这个,它可以按需要工作。更改出现在catch子句中:

try {
    quantity = Integer.parseInt(quantityCell.getText().toString());
} catch (NumberFormatException nfe) {
    Toast.makeText(getApplicationContext(), "Please enter a valid number",
        Toast.LENGTH_LONG).show();
    quantity = savedQuantity;
}

当用户输入错误数据时,上面较大块中的一些代码会处理重置字段。我猜发生这种情况的原因是我试图用旧代码中的setText()方法还原旧值。

我在这里看到了一个可能的答案:

其想法是覆盖键盘输入,以便用户无法使用“回车”键的正常功能

顺便说一句,您可以在xml中设置android:inputType=“number”,以便在编辑文本字段中只能输入数字

class MyTextView extends EditText
{
...
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event)
    {
        if (keyCode==KeyEvent.KEYCODE_ENTER) 
        {
            // Just ignore the [Enter] key
            return true;
        }
        // Handle all other keys in the default way
        return super.onKeyDown(keyCode, event);
    }
}

翻译完这一页后,从我在文档中看到的关于使用onKeyDown陷阱的内容来看,它在虚拟键盘上不可靠,而且大多数键盘在捕捉
ENTER
时都没有实现它。这一切都是在没有XML的情况下生成的,但是这是一个好主意。我添加了这一行:quantityView.setInputType(InputType.TYPE\u CLASS\u NUMBER);它确实限制用户输入数字,但仍然可以提交空值,焦点仍然会移动。。。这几乎是一个解决方案。将此标记为已回答。。。多亏了你的帖子@VoidExplorer,我才知道发生了什么