Skip to main content

How to set an ATM Input EditText

This tutorial will show you how to form an ATM Input EditText



Let's see how to do this

Create your xml with a EditText
<EditText
    android:id="@+id/id_edttext_amt"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="$0.00"
    android:gravity="center"
    android:inputType="number"/>

Now in you activity,

Implement TextWatcher for the EditText you need ATM type input

private String current = "";
edtAtm.addTextChangedListener(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) {
        if(!s.toString().equals(current)){
            edtAtm.removeTextChangedListener(this);

            String cleanString = s.toString().replaceAll("[$,.]", "");

            double parsed = Double.parseDouble(cleanString);
            String formatted = NumberFormat.getCurrencyInstance().format((parsed/100));

            current = formatted;
            edtAtm.setText(formatted);
            edtAtm.setSelection(formatted.length());

            edtAtm.addTextChangedListener(this);
        }
    }

    @Override
    public void afterTextChanged(Editable s) {
    }
});

To show different currency in EditText - do a trick

Create a xml like
<LinearLayout
    android:id="@+id/id_fee_lay"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/edittext_style"
    android:visibility="gone"
    android:layout_marginBottom="10dp">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
        android:text="₱"/>

    <EditText
        android:id="@+id/id_cancel_fee"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="5dp"
        android:singleLine="true"
        android:gravity="top|left"
        android:inputType="numberDecimal"
        android:background="@android:color/transparent"
        android:hint="0.00"/>

</LinearLayout>

Fix the currency symbol in TextView and do the remaining on EditText TextWatcher
Few changes in activity
private String current = "";
if(s.toString().length()>0) {
    if (!s.toString().equals(current)) {
        edtCanFee.removeTextChangedListener(this);

        String cleanString = s.toString().replaceAll("[ ,.]", "");

        double parsed = Double.parseDouble(cleanString);
        String formatted = NumberFormat.getCurrencyInstance().format((parsed/100));

        current = formatted;

        StringTokenizer tokens = new StringTokenizer(formatted, "$");
        String first = tokens.nextToken();

        edtCanFee.setText(first);
        edtCanFee.setSelection(first.length());

        edtCanFee.addTextChangedListener(this);
    }
}

The output will be like,

Another way to achieve Currency EditText

Using third-party library currency_edittext:
compile 'com.github.faranjit:currency-edittext:1.0.1'

How to use:
These lines formats simply your input for default locale

<faranjit.currency.edittext.CurrencyEditText
        android:id="@+id/edt_currency"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:inputType="numberDecimal"
        android:textColor="@android:color/black" />

For more
________________________________________________________________________________________
Happy Coding...



Comments

Popular posts from this blog

Zoom Image - Android Tutorial

Here we are going to see how to zoom an image in Imageview Will see it through a sample 1. Create xml with an ImageView <? xml version="1.0" encoding="utf-8" ?> < androidx.constraintlayout.widget.ConstraintLayout       xmlns:android="http://schemas.android.com/apk/res/android"     xmlns:app="http://schemas.android.com/apk/res-auto"     xmlns:tools="http://schemas.android.com/tools"     android:layout_width="match_parent"     android:layout_height="match_parent"     tools:context=".MainActivity" >     < LinearLayout         android:layout_width="200dp"         android:layout_height="200dp"         app:layout_constraintBottom_toBottomOf="parent"         app:layout_constraintLeft_toLeftOf="parent"         app:layout_constraintRight_toRightOf="parent"    ...

Multi language support

This post will help you yo learn how to make Multi language supported app in android. Why Multi language? In order to targeting global audience, it will be beneficial if you make your app localized. While localizing, you should think about text, audio, currency, numbers and graphics depending upon the region or country. But in this tutorial language only covered. Note: Whenever you are making any android application, Always declare text you want to use in your application in strings.xml only. <string name="hello">Hello World!</string> How String Localization Works? By default android considers English as primary language and loads the string resources from res >> values >> strings.xml . When you want to make Multilanguage supported app, you need to create a values folder by appending a Hyphen (-) and the ISO language code. For example for Hindi, values-hi named folder should be created and keep a strings.xml file in it wit...

Add custom font in Android using Calligraphy library

Are you fed up of Custom Views to set fonts? Or traversing the ViewTree to find TextViews? Sometime we want some other font for our Android application then you can add custom font in Android using Calligraphy library . Dependency Include the dependency Download (.aar) dependencies { compile ‘uk.co.chrisjenx:calligraphy:2.2.0’ } Add Fonts Add your custom fonts to assets/ . All font definitions are relative to this path. On Assets you should right-click New Directory, call it "fonts". In the finder put the .ttf  or .otf  font files in there. Create Class Create a class that extends Application and write this code public class App extends Application { @Override public void onCreate() { super.onCreate(); CalligraphyConfig.initDefault(new CalligraphyConfig.Builder() .setDefaultFontPath("your font path") .setFontAttrId(...