public abstract class Precision extends Object
To create a Precision, use one of the factory methods.
NumberFormatter
Modifier and Type | Class and Description |
---|---|
static class |
Precision.BogusRounder
Deprecated.
This API is ICU internal only.
|
Modifier and Type | Field and Description |
---|---|
static Precision.BogusRounder |
BOGUS_PRECISION
Deprecated.
ICU internal only.
|
Modifier and Type | Method and Description |
---|---|
abstract void |
apply(com.ibm.icu.impl.number.DecimalQuantity value)
Deprecated.
ICU 60 This API is ICU internal only.
|
static CurrencyPrecision |
currency(Currency.CurrencyUsage currencyUsage)
Show numbers rounded and padded according to the rules for the currency unit.
|
static FractionPrecision |
fixedFraction(int minMaxFractionPlaces)
Show numbers rounded if necessary to a certain number of fraction places (numerals after the
decimal separator).
|
static Precision |
fixedSignificantDigits(int minMaxSignificantDigits)
Show numbers rounded if necessary to a certain number of significant digits or significant
figures.
|
static Precision |
increment(BigDecimal roundingIncrement)
Show numbers rounded if necessary to the closest multiple of a certain rounding increment.
|
static FractionPrecision |
integer()
Show numbers rounded if necessary to the nearest integer.
|
static FractionPrecision |
maxFraction(int maxFractionPlaces)
Show numbers rounded if necessary to a certain number of fraction places (numerals after the
decimal separator).
|
static Precision |
maxSignificantDigits(int maxSignificantDigits)
Show numbers rounded if necessary to a certain number of significant digits/figures.
|
static FractionPrecision |
minFraction(int minFractionPlaces)
Always show at least a certain number of fraction places after the decimal separator, padding with
zeros if necessary.
|
static FractionPrecision |
minMaxFraction(int minFractionPlaces,
int maxFractionPlaces)
Show numbers rounded if necessary to a certain number of fraction places (numerals after the
decimal separator); in addition, always show at least a certain number of places after the decimal
separator, padding with zeros if necessary.
|
static Precision |
minMaxSignificantDigits(int minSignificantDigits,
int maxSignificantDigits)
Show numbers rounded if necessary to a certain number of significant digits/figures; in addition,
always show at least a certain number of significant digits, padding with zeros if necessary.
|
static Precision |
minSignificantDigits(int minSignificantDigits)
Always show at least a certain number of significant digits/figures, padding with zeros if
necessary.
|
Precision |
trailingZeroDisplay(NumberFormatter.TrailingZeroDisplay trailingZeroDisplay)
Configure how trailing zeros are displayed on numbers.
|
static Precision |
unlimited()
Show all available digits to full precision.
|
Precision |
withMode(MathContext mathContext)
Deprecated.
This API is ICU internal only.
|
@Deprecated public static final Precision.BogusRounder BOGUS_PRECISION
public static Precision unlimited()
NOTE: When formatting a double, this method, along with
minFraction(int)
and minSignificantDigits(int)
, will trigger complex algorithm similar to
Dragon4 to determine the low-order digits and the number of digits to display based on
the value of the double. If the number of fraction places or significant digits can be bounded,
consider using maxFraction(int)
or maxSignificantDigits(int)
instead to maximize performance.
For more information, read the following blog post.
http://www.serpentine.com/blog/2011/06/29/here-be-dragons-advances-in-problems-you-didnt-even-know-you-had/
NumberFormatter
public static FractionPrecision integer()
NumberFormatter
public static FractionPrecision fixedFraction(int minMaxFractionPlaces)
Example output with minMaxFractionPlaces = 3:
87,650.000
8,765.000
876.500
87.650
8.765
0.876
0.088
0.009
0.000 (zero)
This method is equivalent to minMaxFraction(int, int)
with both arguments equal.
minMaxFractionPlaces
- The minimum and maximum number of numerals to display after the decimal separator
(rounding if too long or padding with zeros if too short).IllegalArgumentException
- if the input number is too big or smaller than 0.NumberFormatter
public static FractionPrecision minFraction(int minFractionPlaces)
NOTE: If you are formatting doubles, see the performance note in
unlimited()
.
minFractionPlaces
- The minimum number of numerals to display after the decimal separator (padding with
zeros if necessary).IllegalArgumentException
- if the input number is too big or smaller than 0.NumberFormatter
public static FractionPrecision maxFraction(int maxFractionPlaces)
maxFractionPlaces
- The maximum number of numerals to display after the decimal mark (rounding if
necessary).IllegalArgumentException
- if the input number is too big or smaller than 0.NumberFormatter
public static FractionPrecision minMaxFraction(int minFractionPlaces, int maxFractionPlaces)
minFractionPlaces
- The minimum number of numerals to display after the decimal separator (padding with
zeros if necessary).maxFractionPlaces
- The maximum number of numerals to display after the decimal separator (rounding if
necessary).IllegalArgumentException
- if the input number is too big or smaller than 0.NumberFormatter
public static Precision fixedSignificantDigits(int minMaxSignificantDigits)
This method is equivalent to minMaxSignificantDigits(int, int)
with both arguments equal.
minMaxSignificantDigits
- The minimum and maximum number of significant digits to display (rounding if too long
or padding with zeros if too short).IllegalArgumentException
- if the input number is too big or smaller than 1.NumberFormatter
public static Precision minSignificantDigits(int minSignificantDigits)
NOTE: If you are formatting doubles, see the performance note in
unlimited()
.
minSignificantDigits
- The minimum number of significant digits to display (padding with zeros if too short).IllegalArgumentException
- if the input number is too big or smaller than 1.NumberFormatter
public static Precision maxSignificantDigits(int maxSignificantDigits)
maxSignificantDigits
- The maximum number of significant digits to display (rounding if too long).IllegalArgumentException
- if the input number is too big or smaller than 1.NumberFormatter
public static Precision minMaxSignificantDigits(int minSignificantDigits, int maxSignificantDigits)
minSignificantDigits
- The minimum number of significant digits to display (padding with zeros if necessary).maxSignificantDigits
- The maximum number of significant digits to display (rounding if necessary).IllegalArgumentException
- if the input number is too big or smaller than 1.NumberFormatter
public static Precision increment(BigDecimal roundingIncrement)
In order to ensure that numbers are padded to the appropriate number of fraction places, set the scale on the rounding increment BigDecimal. For example, to round to the nearest 0.5 and always display 2 numerals after the decimal separator (to display 1.2 as "1.00" and 1.3 as "1.50"), you can run:
Precision.increment(new BigDecimal("0.50"))
For more information on the scale of Java BigDecimal, see BigDecimal.scale()
.
roundingIncrement
- The increment to which to round numbers.IllegalArgumentException
- if the rounding increment is null or non-positive.NumberFormatter
public static CurrencyPrecision currency(Currency.CurrencyUsage currencyUsage)
Precision.fixedFraction(2)
,
Precision.integer()
, and Precision.increment(0.05)
for cash transactions
("nickel rounding").
The exact rounding details will be resolved at runtime based on the currency unit specified in the NumberFormatter chain. To round according to the rules for one currency while displaying the symbol for another currency, the withCurrency() method can be called on the return value of this method.
currencyUsage
- Either STANDARD (for digital transactions) or CASH (for transactions where the rounding
increment may be limited by the available denominations of cash or coins).IllegalArgumentException
- if currencyUsage is null.NumberFormatter
public Precision trailingZeroDisplay(NumberFormatter.TrailingZeroDisplay trailingZeroDisplay)
trailingZeroDisplay
- Option to configure the display of trailing zeros.@Deprecated public Precision withMode(MathContext mathContext)
@Deprecated public abstract void apply(com.ibm.icu.impl.number.DecimalQuantity value)
Copyright © 2016 Unicode, Inc. and others.