- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在构建一个 android 应用程序,我正在创建动态 EditText
View 。我需要在顶部 TextView
上显示所有 EditText
的总和。我找不到办法做到这一点,任何人都可以帮我解决这个问题。
而且我也不明白,当我点击添加按钮时,只有一个动态 View 似乎是实时的,其余的似乎在 sleep ....(这只是我程序的一部分...)
提前致谢。
这是我的 XML
<LinearLayout
android:id="@+id/linearBelowBoard"
android:orientation="vertical"
android:layout_below="@+id/button2"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</LinearLayout>
<Button
android:text="Add"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/button2"
android:layout_below="@+id/totalText"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_marginLeft="111dp"
android:layout_marginStart="111dp" />
<TextView
android:text="Sum"
android:textStyle="bold"
android:textSize="40dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/totalText"
android:layout_alignParentTop="true"
android:layout_alignRight="@+id/button2"
android:layout_alignEnd="@+id/button2" />
行.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="number"
android:ems="10"
android:id="@+id/editText"
android:textColor="#000000"
android:layout_toLeftOf="@+id/button"
android:layout_toStartOf="@+id/button" />
<Button
android:text="Delete"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:id="@+id/button" />
</RelativeLayout>
</LinearLayout>
这是我的 Java 文件
package com.example.rajiv.aaaplusbutton;
import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
EditText edt1;
Button but_add, but_remove;
TextView txtSum;
LinearLayout linearBelowBoard;
int e1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
linearBelowBoard = (LinearLayout) findViewById(R.id.linearBelowBoard);
txtSum=(TextView)findViewById(R.id.totalText);
but_add = (Button) findViewById(R.id.button2);
but_add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
LayoutInflater layoutInflater =
(LayoutInflater) getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
final View addView = layoutInflater.inflate(R.layout.row, null);
edt1 = (EditText) addView.findViewById(R.id.editText);
edt1.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before,
int count) {
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
if (s.length() > 0) {
}
}
@Override
public void afterTextChanged(Editable s) {
calCheck();
}
});
Button but_remove = (Button) addView.findViewById(R.id.button);
final View.OnClickListener thisListener = new View.OnClickListener() {
@Override
public void onClick(View v) {
((LinearLayout) addView.getParent()).removeView(addView);
}
};
but_remove.setOnClickListener(thisListener);
linearBelowBoard.addView(addView);
}
});
}
public void calCheck() {
try {
e1 = Integer.parseInt(edt1.getText().toString());
txtSum.setText(Integer.toString(" What to Do? "));
} catch (Exception e) {
}
}
最佳答案
使用下面的代码来解决您的问题:我对您的代码做了一些更改试试这个:
package com.cj.myapplication;
import android.content.Context;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;
/**
* Created by CHETAN JOSHI on 3/6/2017.
*/
public class MainActivity extends AppCompatActivity {
EditText edt1;
Button but_add, but_remove;
TextView txtSum;
LinearLayout linearBelowBoard;
int e1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);
linearBelowBoard = (LinearLayout) findViewById(R.id.linearBelowBoard);
txtSum = (TextView) findViewById(R.id.totalText);
but_add = (Button) findViewById(R.id.button2);
but_add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
LayoutInflater layoutInflater =
(LayoutInflater) getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
final View addView = layoutInflater.inflate(R.layout.row, null);
edt1 = (EditText) addView.findViewById(R.id.editText);
edt1.addTextChangedListener(new MyTextWatcher(edt1));
Button but_remove = (Button) addView.findViewById(R.id.button);
final View.OnClickListener thisListener = new View.OnClickListener() {
@Override
public void onClick(View v) {
((LinearLayout) addView.getParent()).removeView(addView);
}
};
but_remove.setOnClickListener(thisListener);
linearBelowBoard.addView(addView);
}
});
}
private class MyTextWatcher implements TextWatcher {
EditText mEditText = null;
public MyTextWatcher(EditText mEditText) {
this.mEditText = mEditText;
}
@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) {
calCheck(mEditText);
}
}
public void calCheck(EditText editText) {
try {
if (linearBelowBoard != null) {
e1 =0;
for (int i = 0; i < linearBelowBoard.getChildCount(); i++) {
LinearLayout linearLayout = (LinearLayout)linearBelowBoard.getChildAt(i);
RelativeLayout relativeLayout = (RelativeLayout)linearLayout.getChildAt(0);
View view = relativeLayout.getChildAt(0);
EditText editText1 = null;
if (view instanceof EditText) {
editText1 = (EditText) view;
} else {
view = relativeLayout.getChildAt(1);
editText1 = (EditText) view;
}
String str = editText1.getText().toString();
if(str!=null && !str.equals("") && str.length()>0)
e1 = e1 + Integer.parseInt(editText1.getText().toString());
}
}
txtSum.setText("" + String.valueOf(e1));
} catch (Exception e) {
e.printStackTrace();
}
}
}
请检查我创建了另一种通过传递位置返回 EditText
的方法。因此,您需要将任何位置传递到 EditText
的添加计数,然后您将获得 EditText
并且您可以获取 Text().toString()。
更新 calCheck() 方法:
public void calCheck(EditText editText) {
try {
if (linearBelowBoard != null) {
e1 = 0;
for (int i = 0; i < linearBelowBoard.getChildCount(); i++) {
EditText editText1 = getEditTextFromPosition(i);
String str = editText1.getText().toString();
if (str != null && !str.equals("") && str.length() > 0)
e1 = e1 + Integer.parseInt(editText1.getText().toString());
}
}
txtSum.setText("" + String.valueOf(e1));
} catch (Exception e) {
e.printStackTrace();
}
}
使用下面的方法获取Edittext:
private EditText getEditTextFromPosition(int position){
EditText editText=null;
LinearLayout linearLayout = (LinearLayout)linearBelowBoard.getChildAt(position);
RelativeLayout relativeLayout = (RelativeLayout)linearLayout.getChildAt(0);
View view = relativeLayout.getChildAt(0);
if (view instanceof EditText) {
editText = (EditText) view;
} else {
view = relativeLayout.getChildAt(1);
editText = (EditText) view;
}
return editText;
}
关于android - 带有添加按钮的动态 View ,如何找到唯一的 edtxt ID 或其他任何东西,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42622504/
出现在 python 2.7.8 中。 3.4.1 不会发生这种情况。 示例: >>> id(id) 140117478913736 >>> id(id) 140117478913736 >>> id
好吧,我对动态创建的控件的 ID 很困惑。 Public Class TestClass Inherits Panel Implements INamingContainer
我收到下面的错误,说有堆栈溢出。发生这种情况是因为带有 IN (id, id, id...id) 的 SQL 语句有大量参数。有没有什么办法解决这一问题?这是在我使用 Eclipse 的本地环境中发生
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
为什么 CPython(对其他 Python 实现一无所知)有以下行为? tuple1 = () tuple2 = ()
非常简单的问题:当我有一个持久对象时,它通常有一个名为 ID 的属性(对于抽象类)。 那么..命名约定是ID还是Id? 例如。 public int ID { get; set; } 或 public
知道为什么我会收到此错误,我已经尝试了所有命名约定(小写/大写) 我正在使用 Vaadin,这是我的代码片段: public class Usercontainer extends BeanI
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
我需要改变表的所有主键 UPDATE TODO SET id = id + 1 但我做不到(Demo 来自 Ahmad Al-Mutawa 的回答)描述了原因。主键不能这样改。 我也不能根据这是 sq
我正在尝试列出与用户相关的讨论列表。 想象一下,如果你愿意的话: posts -------------------------------------------------------------
我有一个表,其中包含一些具有自己的 ID 和共享 SKU key 的文章。我尝试使用左连接进行查询,并使用组结果获取从查询返回的所有 id。 我的数据结构是这样的: id - name -
在下表People中: id name 1 James 2 Yun 3 Ethan 如果我想找到最大 ID,我可以运行此查询 select max(id) id from People; 结果是
我正在产品页面上创建评论模块,其中显示垃圾评论选项,并显示 onclick 显示和隐藏弹出窗口。现在它在单个评论中工作正常但是当评论是两个时它同时打开两个因为类是相同的。现在这就是为什么我想要获取父
根据 REST 哲学,PUT操作应该(取自维基百科): PUT http://example.com/resources/142 Update the address member of the co
我想知道如何在使用 PHP 或 JavaScript 进行身份验证后从 Google Analytics 获取 Property Id、View Id 和 Account Id?因为我希望能够将它们存
我想使用所选按钮的 ID 进行删除。但我不知道如何从中获取/获取 id。我尝试了 this.id 但不起作用。 这是我创建按钮的地方: var deleteEmployer= document.cre
我有一个具有以下结构的表“表” ID LinkedWith 12 13 13 12 14 13 15 14 16
请不要在未阅读问题的情况下将问题标记为重复。我确实发布了一个类似的问题,但 STACKOVERFLOW 社区成员要求我单独重新发布修改后的问题,因为考虑到一个小而微妙的修改,解决方案要复杂得多。 假设
在 Android Studio 中,我创建了一个 Person.java 类。我使用Generate 创建了getter 和setter 以及构造函数。 这是我的 Person.java 类: pu
如何在 jQuery 中制作这样的东西: //这是显示的主体 ID //当我悬停 #hover-id 时,我希望 #principal-id 消失并更改 。但是当我将光标放在 #this-id 上时
我是一名优秀的程序员,十分优秀!