Skip to content

A Custom EditText implementation that allows formatting of currency-based numeric inputs

Notifications You must be signed in to change notification settings

dinukapj/ATM-EditText

Repository files navigation

ATM-EditText

A Custom EditText implementation that allows formatting of currency-based numeric inputs Edit Add topics.

Alt text

Usage

compile 'com.github.dinukapj:ATM-EditText:1.7.3'

Implementation Sample

XML

<com.earthling.atminput.ATMEditText
        android:id="@+id/etInput"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:inputType="number"
        android:hint="Type value"/>

Code

ATMEditText etInput;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    etInput = (ATMEditText) findViewById(R.id.etInput);
    etInput.setCurrency(Currency.MALAYSIA);
    etInput.setDelimiter(false);
    etInput.setSpacing(false);
    etInput.setDecimals(true);
    //Make sure that Decimals is set as false if a custom Separator is used
    etInput.setSeparator(".");
}

Customizing

The following attributes can be manipulated:

  • Currency by specifying the country
  • Spacing between currency and value
  • Delimeter
  • Decimals
  • Thousands Separator Symbol

Currency

Specify the currency by setting the country of your choice.

etInput.Currency = Currency.MALAYSIA;

Currency can also be disabled by:

etInput.Currency = Currency.NONE;

Custom Currency/Symbol

If a custom symbol that is not included in the library is required, any string value can be used since the the Currency attribute expects a String value.

etInput.Currency = "TEST";

Which produces:

TEST 450.00

Note: Currency is set to your app's Local currency by default.

Spacing

The spacing between the currency and the value can be specified by:

etInput.Spacing = true;

Note: Spacing is false by default.

Delimeter

The delimeter attribute allows the addition of a . symbol after displaying the currency.

Rs.100

Rp.100

Note: Delimeter is false by default.

Decimals

Decimals can be turned off for the EditText using:

etInput.Decimals = false;

This outputs the following:

$100,000

Separator

The Thousands Separator can be customized as required with any custom symbol to suit the currency formats of different countries. Example: Indonesia -> 12.000.000 (Using . instead of , as the separator)

NOTE: Decimals must be set as false in order avoid conflicts in getting a clean Double or Integer output

Getting Clean Output

A Double value without Commas, Currency and Decimal places can be retrieved using:

double cleanOutput = etInput.getCleanDoubleValue();

An Integer value without Commas, Currency and Decimal places can be retrieved using:

int cleanOutput = etInput.getCleanIntValue();

About

A Custom EditText implementation that allows formatting of currency-based numeric inputs

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages