Class MeasureFormat
- java.lang.Object
-
- java.text.Format
-
- com.ibm.icu.text.UFormat
-
- com.ibm.icu.text.MeasureFormat
-
- All Implemented Interfaces:
Serializable,Cloneable
- Direct Known Subclasses:
TimeUnitFormat
public class MeasureFormat extends UFormat
A formatter for Measure objects.IMPORTANT: New users are strongly encouraged to see if
NumberFormatterfits 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.
- Author:
- Alan Liu
- See Also:
UFormat, Serialized Form- Status:
- Stable ICU 3.0.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classMeasureFormat.FormatWidthFormatting width enum.-
Nested classes/interfaces inherited from class com.ibm.icu.text.UFormat
UFormat.SpanField
-
Nested classes/interfaces inherited from class java.text.Format
Format.Field
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description booleanequals(Object other)Two MeasureFormats, a and b, are equal if and only if they have the same formatWidth, locale, and equal number formats.StringBufferformat(Object obj, StringBuffer toAppendTo, FieldPosition fpos)Able to format Collection<?StringBuilderformatMeasurePerUnit(Measure measure, MeasureUnit perUnit, StringBuilder appendTo, FieldPosition pos)Formats a single measure per unit.StringformatMeasures(Measure... measures)Format a sequence of measures.StringBuilderformatMeasures(StringBuilder appendTo, FieldPosition fpos, Measure... measures)Formats a sequence of measures.static MeasureFormatgetCurrencyFormat()Return 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.ULocalegetLocale()Get the locale of this instance.NumberFormatgetNumberFormat()Get a copy of the number format.static StringgetRangeFormat(ULocale forLocale, MeasureFormat.FormatWidth width)Deprecated.This API is ICU internal only.StringgetUnitDisplayName(MeasureUnit unit)Gets the display name of the specifiedMeasureUnitcorresponding to the current locale and format width.MeasureFormat.FormatWidthgetWidth()Get the format width this instance is using.inthashCode()MeasureparseObject(String source, ParsePosition pos)Parses text from a string to produce aMeasure.-
Methods inherited from class java.text.Format
clone, format, formatToCharacterIterator, parseObject
-
-
-
-
Method Detail
-
getInstance
public static MeasureFormat getInstance(ULocale locale, MeasureFormat.FormatWidth formatWidth)
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.
- Status:
- Stable ICU 53.
-
getInstance
public static MeasureFormat getInstance(Locale locale, MeasureFormat.FormatWidth formatWidth)
Create a format from theLocaleand formatWidth.- Parameters:
locale- theLocale.formatWidth- hints how long formatted strings should be.- Returns:
- The new MeasureFormat object.
- Status:
- Stable ICU 54.
-
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.
- Status:
- Stable ICU 53.
-
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.
- Status:
- Stable ICU 54.
-
format
public
-
-