Class MeasureFormat
- All Implemented Interfaces:
Serializable,Cloneable
- Direct Known Subclasses:
CurrencyFormat,TimeUnitFormat
IMPORTANT: New users are strongly encouraged to see if
NumberFormatter fits their use case. Although not deprecated, this
class, MeasureFormat, is provided for backwards compatibility only, and has
much more limited capabilities.
To format a Measure object, first create a formatter object using a MeasureFormat factory method. Then use that object's format or formatMeasures methods. Here is sample code:
MeasureFormat fmtFr = MeasureFormat.getInstance(ULocale.FRENCH, FormatWidth.SHORT);
Measure measure = new Measure(23, MeasureUnit.CELSIUS);
// Output: 23 °C
System.out.println(fmtFr.format(measure));
Measure measureF = new Measure(70, MeasureUnit.FAHRENHEIT);
// Output: 70 °F
System.out.println(fmtFr.format(measureF));
MeasureFormat fmtFrFull = MeasureFormat.getInstance(ULocale.FRENCH, FormatWidth.WIDE);
// Output: 70 pieds et 5,3 pouces
System.out.println(fmtFrFull.formatMeasures(new Measure(70, MeasureUnit.FOOT),
new Measure(5.3, MeasureUnit.INCH)));
// Output: 1 pied et 1 pouce
System.out.println(
fmtFrFull.formatMeasures(new Measure(1, MeasureUnit.FOOT), new Measure(1, MeasureUnit.INCH)));
MeasureFormat fmtFrNarrow = MeasureFormat.getInstance(ULocale.FRENCH, FormatWidth.NARROW);
// Output: 1′ 1″
System.out.println(fmtFrNarrow.formatMeasures(new Measure(1, MeasureUnit.FOOT),
new Measure(1, MeasureUnit.INCH)));
MeasureFormat fmtEn = MeasureFormat.getInstance(ULocale.ENGLISH, FormatWidth.WIDE);
// Output: 1 inch, 2 feet
fmtEn.formatMeasures(new Measure(1, MeasureUnit.INCH), new Measure(2, MeasureUnit.FOOT));
This class does not do conversions from one unit to another. It simply formats whatever units it is given
This class is immutable and thread-safe so long as its deprecated subclass, TimeUnitFormat, is never used. TimeUnitFormat is not thread-safe, and is mutable. Although this class has existing subclasses, this class does not support new sub-classes.
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic enumFormatting width enum.(package private) static class(package private) static class(package private) static classNested classes/interfaces inherited from class com.ibm.icu.text.UFormat
UFormat.SpanFieldNested classes/interfaces inherited from class java.text.Format
Format.Field -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final intprivate final MeasureFormat.FormatWidthprivate static final Map<MeasureUnit, Integer> private static final SimpleCache<ULocale, MeasureFormat.NumericFormatters> private static final int(package private) static final int(package private) static final int(package private) static final intprivate final NumberFormatprivate final LocalizedNumberFormatterprivate final MeasureFormat.NumericFormattersprivate final PluralRules(package private) static final longprivate static final int -
Constructor Summary
ConstructorsModifierConstructorDescription(package private)MeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth) (package private)MeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat numberFormat, PluralRules rules) privateMeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat numberFormat, PluralRules rules, MeasureFormat.NumericFormatters formatters) -
Method Summary
Modifier and TypeMethodDescription(package private) voidfinal booleanTwo MeasureFormats, a and b, are equal if and only if they have the same formatWidth, locale, and equal number formats.format(Object obj, StringBuffer toAppendTo, FieldPosition fpos) Able to format Collection<? extends Measure>, Measure[], and Measure by delegating to formatMeasures.private FormattedStringBuilderformatMeasure(Measure measure) private FormattedStringBuilderformatMeasureInteger(Measure measure) formatMeasurePerUnit(Measure measure, MeasureUnit perUnit, StringBuilder appendTo, FieldPosition pos) Formats a single measure per unit.final StringformatMeasures(Measure... measures) Format a sequence of measures.formatMeasures(StringBuilder appendTo, FieldPosition fpos, Measure... measures) Formats a sequence of measures.private voidformatMeasuresInternal(Appendable appendTo, FieldPosition fieldPosition, Measure... measures) private voidformatMeasuresSlowTrack(ListFormatter listFormatter, Appendable appendTo, FieldPosition fieldPosition, Measure... measures) private voidformatNumeric(Number[] hms, Appendable appendable) private static MeasureFormat.FormatWidthfromFormatWidthOrdinal(int ordinal) static MeasureFormatReturn a formatter for CurrencyAmount objects in the defaultFORMATlocale.static MeasureFormatgetCurrencyFormat(ULocale locale) Return a formatter for CurrencyAmount objects in the given locale.static MeasureFormatgetCurrencyFormat(Locale locale) Return a formatter for CurrencyAmount objects in the givenLocale.static MeasureFormatgetInstance(ULocale locale, MeasureFormat.FormatWidth formatWidth) Create a format from the locale, formatWidth, and format.static MeasureFormatgetInstance(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat format) Create a format from the locale, formatWidth, and format.static MeasureFormatgetInstance(Locale locale, MeasureFormat.FormatWidth formatWidth) Create a format from theLocaleand formatWidth.static MeasureFormatgetInstance(Locale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat format) Create a format from theLocale, formatWidth, and format.final ULocaleGet the locale of this instance.Get a copy of the number format.(package private) NumberFormatGet a copy of the number format without cloning.(package private) LocalizedNumberFormatterstatic StringgetRangeFormat(ULocale forLocale, MeasureFormat.FormatWidth width) Deprecated.This API is ICU internal only.Gets the display name of the specifiedMeasureUnitcorresponding to the current locale and format width.private LocalizedNumberFormattergetUnitFormatterFromCache(int type, MeasureUnit unit, MeasureUnit perUnit) getWidth()Get the format width this instance is using.final inthashCode()private static Stringprivate static MeasureFormat.NumericFormattersloadNumericFormatters(ULocale locale) parseObject(String source, ParsePosition pos) Parses text from a string to produce aMeasure.(package private) Objectprivate static Number[](package private) Object(package private) MeasureFormatwithLocale(ULocale locale) (package private) MeasureFormatwithNumberFormat(NumberFormat format) private ObjectMethods inherited from class java.text.Format
clone, format, formatToCharacterIterator, parseObject
-
Field Details
-
serialVersionUID
static final long serialVersionUID- See Also:
-
formatWidth
-
rules
-
numericFormatters
-
numberFormat
-
numberFormatter
-
localeToNumericDurationFormatters
private static final SimpleCache<ULocale,MeasureFormat.NumericFormatters> localeToNumericDurationFormatters -
hmsTo012
-
MEASURE_FORMAT
private static final int MEASURE_FORMAT- See Also:
-
TIME_UNIT_FORMAT
private static final int TIME_UNIT_FORMAT- See Also:
-
CURRENCY_FORMAT
private static final int CURRENCY_FORMAT- See Also:
-
NUMBER_FORMATTER_STANDARD
static final int NUMBER_FORMATTER_STANDARD- See Also:
-
NUMBER_FORMATTER_CURRENCY
static final int NUMBER_FORMATTER_CURRENCY- See Also:
-
NUMBER_FORMATTER_INTEGER
static final int NUMBER_FORMATTER_INTEGER- See Also:
-
formatter1
-
formatter2
-
formatter3
-
localeIdToRangeFormat
-
-
Constructor Details
-
MeasureFormat
MeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth) -
MeasureFormat
private MeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat numberFormat, PluralRules rules, MeasureFormat.NumericFormatters formatters) -
MeasureFormat
MeasureFormat(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat numberFormat, PluralRules rules)
-
-
Method Details
-
getInstance
Create a format from the locale, formatWidth, and format.- Parameters:
locale- the locale.formatWidth- hints how long formatted strings should be.- Returns:
- The new MeasureFormat object.
-
getInstance
Create a format from theLocaleand formatWidth.- Parameters:
locale- theLocale.formatWidth- hints how long formatted strings should be.- Returns:
- The new MeasureFormat object.
-
getInstance
public static MeasureFormat getInstance(ULocale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat format) Create a format from the locale, formatWidth, and format.- Parameters:
locale- the locale.formatWidth- hints how long formatted strings should be.format- This is defensively copied.- Returns:
- The new MeasureFormat object.
-
getInstance
public static MeasureFormat getInstance(Locale locale, MeasureFormat.FormatWidth formatWidth, NumberFormat format) Create a format from theLocale, formatWidth, and format.- Parameters:
locale- theLocale.formatWidth- hints how long formatted strings should be.format- This is defensively copied.- Returns:
- The new MeasureFormat object.
-
format
Able to format Collection<? extends Measure>, Measure[], and Measure by delegating to formatMeasures. If the pos argument identifies a NumberFormat field, then its indices are set to the beginning and end of the first such field encountered. MeasureFormat itself does not supply any fields. Calling aformatMeasuresmethod is preferred over calling this method as they give better performance. -
parseObject
Parses text from a string to produce aMeasure.- Specified by:
parseObjectin classFormat- Throws:
UnsupportedOperationException- Not supported.- See Also:
-
formatMeasures
Format a sequence of measures. Uses the ListFormatter unit lists. So, for example, one could format “3 feet, 2 inches”. Zero values are formatted (eg, “3 feet, 0 inches”). It is the caller’s responsibility to have the appropriate values in appropriate order, and using the appropriate Number values. Typically the units should be in descending order, with all but the last Measure having integer values (eg, not “3.2 feet, 2 inches”).- Parameters:
measures- a sequence of one or more measures.- Returns:
- the formatted string.
-
formatMeasurePerUnit
public StringBuilder formatMeasurePerUnit(Measure measure, MeasureUnit perUnit, StringBuilder appendTo, FieldPosition pos) Formats a single measure per unit. An example of such a formatted string is "3.5 meters per second."- Parameters:
measure- the measure object. In above example, 3.5 meters.perUnit- the per unit. In above example, it is MeasureUnit.SECONDappendTo- formatted string appended here.pos- The field position.- Returns:
- appendTo.
-
formatMeasures
public StringBuilder formatMeasures(StringBuilder appendTo, FieldPosition fpos, Measure... measures) Formats a sequence of measures. If the fieldPosition argument identifies a NumberFormat field, then its indices are set to the beginning and end of the first such field encountered. MeasureFormat itself does not supply any fields.- Parameters:
appendTo- the formatted string appended here.fpos- Identifies a field in the formatted text.measures- the measures to format.- Returns:
- appendTo.
- See Also:
-
formatMeasuresInternal
private void formatMeasuresInternal(Appendable appendTo, FieldPosition fieldPosition, Measure... measures) -
getUnitDisplayName
Gets the display name of the specifiedMeasureUnitcorresponding to the current locale and format width.- Parameters:
unit- The unit for which to get a display name.- Returns:
- The display name in the locale and width specified in
getInstance(com.ibm.icu.util.ULocale, com.ibm.icu.text.MeasureFormat.FormatWidth), or null if there is no display name available for the specified unit.
-
equals
Two MeasureFormats, a and b, are equal if and only if they have the same formatWidth, locale, and equal number formats. -
hashCode
public final int hashCode() -
getWidth
Get the format width this instance is using. -
getLocale
Get the locale of this instance. -
getNumberFormat
Get a copy of the number format. -
getNumberFormatInternal
NumberFormat getNumberFormatInternal()Get a copy of the number format without cloning. Internal method. -
getCurrencyFormat
Return a formatter for CurrencyAmount objects in the given locale.- Parameters:
locale- desired locale- Returns:
- a formatter object
-
getCurrencyFormat
Return a formatter for CurrencyAmount objects in the givenLocale.- Parameters:
locale- desiredLocale- Returns:
- a formatter object
-
getCurrencyFormat
Return a formatter for CurrencyAmount objects in the defaultFORMATlocale.- Returns:
- a formatter object
- See Also:
-
withLocale
-
withNumberFormat
-
loadNumericFormatters
-
getUnitFormatterFromCache
private LocalizedNumberFormatter getUnitFormatterFromCache(int type, MeasureUnit unit, MeasureUnit perUnit) -
clearCache
void clearCache() -
getNumberFormatter
LocalizedNumberFormatter getNumberFormatter() -
formatMeasure
-
formatMeasureInteger
-
formatMeasuresSlowTrack
private void formatMeasuresSlowTrack(ListFormatter listFormatter, Appendable appendTo, FieldPosition fieldPosition, Measure... measures) -
loadNumericDurationFormat
-
toHMS
-
formatNumeric
-
toTimeUnitProxy
Object toTimeUnitProxy() -
toCurrencyProxy
Object toCurrencyProxy() -
writeReplace
- Throws:
ObjectStreamException
-
fromFormatWidthOrdinal
-
getRangeFormat
Deprecated.This API is ICU internal only.Return a formatter (compiled SimpleFormatter pattern) for a range, such as "{0}–{1}".- Parameters:
forLocale- locale to get the format forwidth- the format width- Returns:
- range formatter, such as "{0}–{1}"
-