0

以下for循环x根据项目的大小添加行数:

for (int i = 0; i < shoppingQuantityAndItems.size(); i++) {
    TableRow label = new TableRow(this);

    EditText quantity = new EditText(this);
    quantity.setInputType(InputType.TYPE_CLASS_NUMBER);
    quantity.setText(shoppingQuantityAndItems.get(i).get(0));
    System.out.println("Size: "
            + shoppingQuantityAndItems.get(i).get(0));
    label.addView(quantity);

    TextView items = new TextView(this);
    items.setText(shoppingQuantityAndItems.get(i).get(1));
    System.out.println("Item: "
            + shoppingQuantityAndItems.get(i).get(1));
    label.addView(items);

    price = new EditText(this);
    price.setId(i);
    price.setInputType(InputType.TYPE_CLASS_NUMBER
            | InputType.TYPE_NUMBER_FLAG_DECIMAL);
    price.setText("");
    label.addView(price);
    updatePrice(price.getId());

    CheckBox ch = new CheckBox(this);
    ch.setChecked(false);
    label.addView(ch);

    table.addView(label);
}

因为我希望每个不同的价格EditText字段在用户输入它们时具有不同的值,所以我使用它们的唯一 ID 调用一个方法:

public void updatePrice(int id){
    updatedPrice = (EditText) price.findViewById(id);
    updatedPrice.addTextChangedListener(new TextWatcher() {

        private String current = "";

        @Override
        public void onTextChanged(CharSequence s, int start, int before, int count) {
            if (!s.toString().equals(current)) {
                updatedPrice.removeTextChangedListener(this);
                String cleanString = s.toString().replaceAll("[£,.]", "");
                double parsed = Double.parseDouble(cleanString);           
                String formated = NumberFormat.getCurrencyInstance()
                        .format((parsed/100));          
                current = formated;
                updatedPrice.setText(formated);
                updatedPrice.setSelection(formated.length());
                updatedPrice.addTextChangedListener(this);
            }
        }

我只是想知道是否有人可以告诉我如何确保当我在这些文本字段中输入一个数字时,只有那个值会改变,而其他值不会改变。

4

1 回答 1

0

您使用了错误的EditText小部件。

updatedPrice大概是您班级的数据成员。这不是一个好主意,因为您没有这些EditText小部件之一。

此外,您onTextChanged()假设updatedPrice将指向正确的EditText小部件 - 用户碰巧正在输入的小部件 - 从统计上讲,这不太可能。

假设其余代码实际上是您想要的,那么您需要更改:

updatedPrice = (EditText) price.findViewById(id);

成为:

final EditText updatedPrice = (EditText) price.findViewById(id);

这将导致您的TextWatcher匿名内部类使用updatedPrice您在调用时检索到的,而不是您在类的数据成员中拥有的updatePrice()一些随机数。EditText

或者,你可以自己TextWatcherfindViewById()。无论哪种方式都应该有效。

我建议您只删除updatedPrice数据成员并修复其余代码,因为您可能还有其他类似的错误。

于 2013-03-08T00:32:32.033 回答