I\'m adding a listener to an EditText field to appropriately format the number to currency in real time.
loanText.addTextChangedListener(new TextWatc
I found this class that works great for me: http://www.java2s.com/Code/Android/UI/ConvertinputvaluetoCurrencyinTextWatcher.htm
hope that will save you guys some time.
The problem is that your TextWatcher
sees that you are "clearing" the text, and therefore sends off a request to its callback methods(afterTextChanged
, beforeTextChanged
, etc).
What i've done is to simply remove the TextWatcher
, clear the text, and add the TextWatcher
back to the EditText
. That way, nothing is listening to my EditText
changes.
You will probably have to hold on to an instance of the TextWatcher
instead of inlining it like you did. That way you don't have to create one every time you want to clear the EditText
loanText.removeTextChangedListener(yourTextWatcherObject);
loanText.setText("");
loanText.addTextChangedListener(yourTextWatcherObject);
Try to use
afterTextChanged
instead. I also had many problems with the other one.
You can check whether Text is empty in onTextChanged as follows and do nothing if it is empty
s.toString().isEmpty()
public void onTextChanged(CharSequence s, int start, int before, int count) {
if(!s.toString().equals(current) && !s.toString().isEmpty()){
String cleanString = s.toString().replaceAll("[$,.]", "");
double parsed = Double.parseDouble(cleanString);
String formated = NumberFormat.getCurrencyInstance().format((parsed/100));
current = formated;
loanText.setText(formated);
loanText.setSelection(formated.length());
}
}
public class MainActivity extends Activity {
EditText et;
TextWatcher tw;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
et=(EditText) findViewById(R.id.et);
tw=new TextWatcher(){
@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) {
et.removeTextChangedListener(tw);
et.setText(Math.random()+"");//add your logic here
et.addTextChangedListener(tw);
}};
et.addTextChangedListener(tw);
}
} This is a Simple solution.