Added in API level 24

DateIntervalFormat


open class DateIntervalFormat : UFormat
kotlin.Any
   ↳ java.text.Format
   ↳ android.icu.text.UFormat
   ↳ android.icu.text.DateIntervalFormat

DateIntervalFormat is a class for formatting and parsing date intervals in a language-independent manner. Only formatting is supported. Parsing is not supported.

Date interval means from one date to another date, for example, from "Jan 11, 2008" to "Jan 18, 2008". We introduced class DateInterval to represent it. DateInterval is a pair of UDate, which is the standard milliseconds since 24:00 GMT, Jan 1, 1970.

DateIntervalFormat formats a DateInterval into text as compactly as possible. For example, the date interval format from "Jan 11, 2008" to "Jan 18,. 2008" is "Jan 11-18, 2008" for English. And it parses text into DateInterval, although initially, parsing is not supported.

There is no structural information in date time patterns. For any punctuations and string literals inside a date time pattern, we do not know whether it is just a separator, or a prefix, or a suffix. Without such information, so, it is difficult to generate a sub-pattern (or super-pattern) by algorithm. So, formatting a DateInterval is pattern-driven. It is very similar to formatting in SimpleDateFormat. We introduce class DateIntervalInfo to save date interval patterns, similar to date time pattern in SimpleDateFormat.

Logically, the interval patterns are mappings from (skeleton, the_largest_different_calendar_field) to (date_interval_pattern).

A skeleton

  1. only keeps the field pattern letter and ignores all other parts in a pattern, such as space, punctuations, and string literals.
  2. hides the order of fields.
  3. might hide a field's pattern letter length. For those non-digit calendar fields, the pattern letter length is important, such as MMM, MMMM, and MMMMM; EEE and EEEE, and the field's pattern letter length is honored. For the digit calendar fields, such as M or MM, d or dd, yy or yyyy, the field pattern length is ignored and the best match, which is defined in date time patterns, will be returned without honor the field pattern letter length in skeleton.

The calendar fields we support for interval formatting are: year, month, date, day-of-week, am-pm, hour, hour-of-day, minute, and second (though we do not currently have specific intervalFormat data for skeletons with seconds). Those calendar fields can be defined in the following order: year > month > date > hour (in day) > minute > second The largest different calendar fields between 2 calendars is the first different calendar field in above order. For example: the largest different calendar fields between "Jan 10, 2007" and "Feb 20, 2008" is year.

For other calendar fields, the compact interval formatting is not supported. And the interval format will be fall back to fall-back patterns, which is mostly "{date0} - {date1}".

There is a set of pre-defined static skeleton strings in DateFormat, There are pre-defined interval patterns for those pre-defined skeletons in locales' resource files. For example, for a skeleton YEAR_ABBR_MONTH_DAY, which is "yMMMd", in en_US, if the largest different calendar field between date1 and date2 is "year", the date interval pattern is "MMM d, yyyy - MMM d, yyyy", such as "Jan 10, 2007 - Jan 10, 2008". If the largest different calendar field between date1 and date2 is "month", the date interval pattern is "MMM d - MMM d, yyyy", such as "Jan 10 - Feb 10, 2007". If the largest different calendar field between date1 and date2 is "day", the date interval pattern is ""MMM d-d, yyyy", such as "Jan 10-20, 2007". For date skeleton, the interval patterns when year, or month, or date is different are defined in resource files. For time skeleton, the interval patterns when am/pm, or hour, or minute is different are defined in resource files.

If a skeleton is not found in a locale's DateIntervalInfo, which means the interval patterns for the skeleton is not defined in resource file, the interval pattern will falls back to the interval "fallback" pattern defined in resource file. If the interval "fallback" pattern is not defined, the default fall-back is "{date0} - {data1}".

For the combination of date and time, The rule to genearte interval patterns are:

  1. when the year, month, or day differs, falls back to fall-back interval pattern, which mostly is the concatenate the two original expressions with a separator between, For example, interval pattern from "Jan 10, 2007 10:10 am" to "Jan 11, 2007 10:10am" is "Jan 10, 2007 10:10 am - Jan 11, 2007 10:10am"
  2. otherwise, present the date followed by the range expression for the time. For example, interval pattern from "Jan 10, 2007 10:10 am" to "Jan 10, 2007 11:10am" is "Jan 10, 2007 10:10 am - 11:10am"

If two dates are the same, the interval pattern is the single date pattern. For example, interval pattern from "Jan 10, 2007" to "Jan 10, 2007" is "Jan 10, 2007". Or if the presenting fields between 2 dates have the exact same values, the interval pattern is the single date pattern. For example, if user only requests year and month, the interval pattern from "Jan 10, 2007" to "Jan 20, 2007" is "Jan 2007".

DateIntervalFormat needs the following information for correct formatting: time zone, calendar type, pattern, date format symbols, and date interval patterns. It can be instantiated in several ways:

  1. create an instance using default or given locale plus given skeleton. Users are encouraged to created date interval formatter this way and to use the pre-defined skeleton macros, such as YEAR_NUM_MONTH, which consists the calendar fields and the format style.
  2. create an instance using default or given locale plus given skeleton plus a given DateIntervalInfo. This factory method is for powerful users who want to provide their own interval patterns. Locale provides the timezone, calendar, and format symbols information. Local plus skeleton provides full pattern information. DateIntervalInfo provides the date interval patterns.

For the calendar field pattern letter, such as G, y, M, d, a, h, H, m, s etc. DateIntervalFormat uses the same syntax as that of DateTime format.

Code Sample: general usage

// the date interval object which the DateIntervalFormat formats on
    // and parses into
    DateInterval dtInterval = new DateInterval(1000*3600*24L, 1000*3600*24*2L);
    DateIntervalFormat dtIntervalFmt = DateIntervalFormat.getInstance(
            DateFormat.YEAR_MONTH_DAY, new Locale("en", "GB", ""));
    StringBuffer result = new StringBuffer("");
    FieldPosition pos = new FieldPosition(-1);
    // formatting
    dtIntervalFmt.format(dtInterval, result, pos);
    assertEquals("interval", "1–2 January 1970", result.toString());
 
  

Code Sample: for powerful users who wants to use their own interval pattern

import android.icu.text.DateIntervalInfo;
      import android.icu.text.DateIntervalFormat;
      ....................
 
      // Get DateIntervalFormat instance using default locale
      DateIntervalFormat dtitvfmt = DateIntervalFormat.getInstance(YEAR_MONTH_DAY);
 
      // Create an empty DateIntervalInfo object, which does not have any interval patterns inside.
      dtitvinf = new DateIntervalInfo();
 
      // a series of set interval patterns.
      // Only ERA, YEAR, MONTH, DATE,  DAY_OF_MONTH, DAY_OF_WEEK, AM_PM,  HOUR, HOUR_OF_DAY,
      MINUTE, SECOND and MILLISECOND are supported.
      dtitvinf.setIntervalPattern("yMMMd", Calendar.YEAR, "'y ~ y'");
      dtitvinf.setIntervalPattern("yMMMd", Calendar.MONTH, "yyyy 'diff' MMM d - MMM d");
      dtitvinf.setIntervalPattern("yMMMd", Calendar.DATE, "yyyy MMM d ~ d");
      dtitvinf.setIntervalPattern("yMMMd", Calendar.HOUR_OF_DAY, "yyyy MMM d HH:mm ~ HH:mm");
 
      // Set fallback interval pattern. Fallback pattern is used when interval pattern is not found.
      // If the fall-back pattern is not set,  falls back to {date0} - {date1} if interval pattern is not found.
      dtitvinf.setFallbackIntervalPattern("{0} - {1}");
 
      // Set above DateIntervalInfo object as the interval patterns of date interval formatter
      dtitvfmt.setDateIntervalInfo(dtitvinf);
 
      // Prepare to format
      pos = new FieldPosition(0);
      str = new StringBuffer("");
 
      // The 2 calendars should be equivalent, otherwise,  IllegalArgumentException will be thrown by format()
      Calendar fromCalendar = (Calendar) dtfmt.getCalendar().clone();
      Calendar toCalendar = (Calendar) dtfmt.getCalendar().clone();
      fromCalendar.setTimeInMillis(....);
      toCalendar.setTimeInMillis(...);
 
      //Formatting given 2 calendars
      dtitvfmt.format(fromCalendar, toCalendar, str, pos);
 
 
  

Synchronization

The format methods of DateIntervalFormat may be used concurrently from multiple threads. Functions that alter the state of a DateIntervalFormat object (setters) may not be used concurrently with any other functions.

Summary

Nested classes

An immutable class containing the result of a date interval formatting operation.

Public methods
open Any

Clone this Format object polymorphically.

StringBuffer!
format(fromCalendar: Calendar!, toCalendar: Calendar!, appendTo: StringBuffer!, pos: FieldPosition!)

Format 2 Calendars to produce a string.

StringBuffer!
format(dtInterval: DateInterval!, appendTo: StringBuffer!, fieldPosition: FieldPosition!)

Format a DateInterval to produce a string.

StringBuffer!
format(obj: Any!, appendTo: StringBuffer!, fieldPosition: FieldPosition!)

Format an object to produce a string.

open DateIntervalFormat.FormattedDateInterval!
formatToValue(fromCalendar: Calendar!, toCalendar: Calendar!)

Format 2 Calendars to produce a FormattedDateInterval.

open DateIntervalFormat.FormattedDateInterval!

Format a DateInterval to produce a FormattedDateInterval.

open DisplayContext!

[icu] Get the formatter's DisplayContext value for the specified DisplayContext.

open DateFormat!

Gets the date formatter

open DateIntervalInfo!

Gets the date time interval patterns.

static DateIntervalFormat!
getInstance(skeleton: String!)

Construct a DateIntervalFormat from skeleton and the default FORMAT locale.

static DateIntervalFormat!
getInstance(skeleton: String!, dtitvinf: DateIntervalInfo!)

Construct a DateIntervalFormat from skeleton DateIntervalInfo, and the default FORMAT locale.

static DateIntervalFormat!
getInstance(skeleton: String!, locale: ULocale!)

Construct a DateIntervalFormat from skeleton and a given locale.

static DateIntervalFormat!
getInstance(skeleton: String!, locale: ULocale!, dtitvinf: DateIntervalInfo!)

Construct a DateIntervalFormat from skeleton a DateIntervalInfo, and the given locale.

static DateIntervalFormat!
getInstance(skeleton: String!, locale: Locale!)

Construct a DateIntervalFormat from skeleton and a given locale.

static DateIntervalFormat!
getInstance(skeleton: String!, locale: Locale!, dtitvinf: DateIntervalInfo!)

Construct a DateIntervalFormat from skeleton a DateIntervalInfo, and the given locale.

open TimeZone!

Get the TimeZone

open Unit

[icu] Set a particular DisplayContext value in the formatter, such as CAPITALIZATION_FOR_STANDALONE.

open Unit

Set the date time interval patterns.

open Unit

Set the TimeZone for the calendar used by this DateIntervalFormat object.

Public methods

clone

Added in API level 24
open fun clone(): Any

Clone this Format object polymorphically.

Return
Any A copy of the object.
Exceptions
java.lang.CloneNotSupportedException if the object's class does not support the Cloneable interface. Subclasses that override the clone method can also throw this exception to indicate that an instance cannot be cloned.

format

Added in API level 24
fun format(
    fromCalendar: Calendar!,
    toCalendar: Calendar!,
    appendTo: StringBuffer!,
    pos: FieldPosition!
): StringBuffer!

Format 2 Calendars to produce a string.

Parameters
fromCalendar Calendar!: calendar set to the from date in date interval to be formatted into date interval string
toCalendar Calendar!: calendar set to the to date in date interval to be formatted into date interval string
appendTo StringBuffer!: Output parameter to receive result. Result is appended to existing contents.
pos FieldPosition!: On input: an alignment field, if desired. On output: the offsets of the alignment field. There may be multiple instances of a given field type in an interval format; in this case the fieldPosition offsets refer to the first instance.
Return
StringBuffer! Reference to 'appendTo' parameter.
Exceptions
java.lang.IllegalArgumentException if the two calendars are not equivalent.

format

Added in API level 24
fun format(
    dtInterval: DateInterval!,
    appendTo: StringBuffer!,
    fieldPosition: FieldPosition!
): StringBuffer!

Format a DateInterval to produce a string.

Parameters
dtInterval DateInterval!: DateInterval to be formatted.
appendTo StringBuffer!: Output parameter to receive result. Result is appended to existing contents.
fieldPosition FieldPosition!: On input: an alignment field, if desired. On output: the offsets of the alignment field. There may be multiple instances of a given field type in an interval format; in this case the fieldPosition offsets refer to the first instance.
Return
StringBuffer! Reference to 'appendTo' parameter.

format

Added in API level 24
fun format(
    obj: Any!,
    appendTo: StringBuffer!,
    fieldPosition: FieldPosition!
): StringBuffer!

Format an object to produce a string. This method handles Formattable objects with a DateInterval type. If a the Formattable object type is not a DateInterval, IllegalArgumentException is thrown.

Parameters
obj Any!: The object to format. Must be a DateInterval.
toAppendTo where the text is to be appended
pos A FieldPosition identifying a field in the formatted text
appendTo StringBuffer!: Output parameter to receive result. Result is appended to existing contents.
fieldPosition FieldPosition!: On input: an alignment field, if desired. On output: the offsets of the alignment field. There may be multiple instances of a given field type in an interval format; in this case the fieldPosition offsets refer to the first instance.
Return
StringBuffer! Reference to 'appendTo' parameter.
Exceptions
java.lang.NullPointerException if toAppendTo or pos is null
java.lang.IllegalArgumentException if the formatted object is not DateInterval object

formatToValue

Added in API level 31
open fun formatToValue(
    fromCalendar: Calendar!,
    toCalendar: Calendar!
): DateIntervalFormat.FormattedDateInterval!

Format 2 Calendars to produce a FormattedDateInterval. The FormattedDateInterval exposes field information about the formatted string.

Parameters
fromCalendar Calendar!: calendar set to the from date in date interval to be formatted into date interval string
toCalendar Calendar!: calendar set to the to date in date interval to be formatted into date interval string
Return
DateIntervalFormat.FormattedDateInterval! A FormattedDateInterval containing the format result.

formatToValue

Added in API level 31
open fun formatToValue(dtInterval: DateInterval!): DateIntervalFormat.FormattedDateInterval!

Format a DateInterval to produce a FormattedDateInterval. The FormattedDateInterval exposes field information about the formatted string.

Parameters
dtInterval DateInterval!: DateInterval to be formatted.
Return
DateIntervalFormat.FormattedDateInterval! A FormattedDateInterval containing the format result.

getContext

Added in API level 33
open fun getContext(type: DisplayContext.Type!): DisplayContext!

[icu] Get the formatter's DisplayContext value for the specified DisplayContext.Type, such as CAPITALIZATION.

Parameters
type DisplayContext.Type!: the DisplayContext.Type whose value to return
Return
DisplayContext! the current DisplayContext setting for the specified type

getDateFormat

Added in API level 24
open fun getDateFormat(): DateFormat!

Gets the date formatter

Return
DateFormat! a copy of the date formatter associated with this date interval formatter.

getDateIntervalInfo

Added in API level 24
open fun getDateIntervalInfo(): DateIntervalInfo!

Gets the date time interval patterns.

Return
DateIntervalInfo! a copy of the date time interval patterns associated with this date interval formatter.

getInstance

Added in API level 24
static fun getInstance(skeleton: String!): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton and the default FORMAT locale. This is a convenient override of getInstance(String skeleton, ULocale locale) with the value of locale as default FORMAT locale.

Parameters
skeleton String!: the skeleton on which interval format based.
Return
DateIntervalFormat! a date time interval formatter.

getInstance

Added in API level 24
static fun getInstance(
    skeleton: String!,
    dtitvinf: DateIntervalInfo!
): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton DateIntervalInfo, and the default FORMAT locale. This is a convenient override of getInstance(String skeleton, ULocale locale, DateIntervalInfo dtitvinf) with the locale value as default FORMAT locale.

Parameters
skeleton String!: the skeleton on which interval format based.
dtitvinf DateIntervalInfo!: the DateIntervalInfo object to be adopted.
Return
DateIntervalFormat! a date time interval formatter.

getInstance

Added in API level 24
static fun getInstance(
    skeleton: String!,
    locale: ULocale!
): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton and a given locale.

In this factory method, the date interval pattern information is load from resource files. Users are encouraged to created date interval formatter this way and to use the pre-defined skeleton macros.

There are pre-defined skeletons in DateFormat, such as MONTH_DAY, YEAR_MONTH_WEEKDAY_DAY etc. Those skeletons have pre-defined interval patterns in resource files. Users are encouraged to use them. For example: DateIntervalFormat.getInstance(DateFormat.MONTH_DAY, false, loc); The given Locale provides the interval patterns. For example, for en_GB, if skeleton is YEAR_ABBR_MONTH_WEEKDAY_DAY, which is "yMMMEEEd", the interval patterns defined in resource file to above skeleton are: "EEE, d MMM, yyyy - EEE, d MMM, yyyy" for year differs, "EEE, d MMM - EEE, d MMM, yyyy" for month differs, "EEE, d - EEE, d MMM, yyyy" for day differs,

Parameters
skeleton String!: the skeleton on which interval format based.
locale ULocale!: the given locale
Return
DateIntervalFormat! a date time interval formatter.

getInstance

Added in API level 24
static fun getInstance(
    skeleton: String!,
    locale: ULocale!,
    dtitvinf: DateIntervalInfo!
): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton a DateIntervalInfo, and the given locale.

In this factory method, user provides its own date interval pattern information, instead of using those pre-defined data in resource file. This factory method is for powerful users who want to provide their own interval patterns.

There are pre-defined skeleton in DateFormat, such as MONTH_DAY, YEAR_MONTH_WEEKDAY_DAY etc. Those skeletons have pre-defined interval patterns in resource files. Users are encouraged to use them. For example: DateIntervalFormat.getInstance(DateFormat.MONTH_DAY, false, loc,itvinf); the DateIntervalInfo provides the interval patterns. User are encouraged to set default interval pattern in DateIntervalInfo as well, if they want to set other interval patterns ( instead of reading the interval patterns from resource files). When the corresponding interval pattern for a largest calendar different field is not found ( if user not set it ), interval format fallback to the default interval pattern. If user does not provide default interval pattern, it fallback to "{date0} - {date1}"

Parameters
skeleton String!: the skeleton on which interval format based.
locale ULocale!: the given locale
dtitvinf DateIntervalInfo!: the DateIntervalInfo object to be adopted.
Return
DateIntervalFormat! a date time interval formatter.

getInstance

Added in API level 24
static fun getInstance(
    skeleton: String!,
    locale: Locale!
): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton and a given locale. This is a convenient override of getInstance(String skeleton, ULocale locale)

Example code:

Parameters
skeleton String!: the skeleton on which interval format based.
locale Locale!: the given locale
Return
DateIntervalFormat! a date time interval formatter.

getInstance

Added in API level 24
static fun getInstance(
    skeleton: String!,
    locale: Locale!,
    dtitvinf: DateIntervalInfo!
): DateIntervalFormat!

Construct a DateIntervalFormat from skeleton a DateIntervalInfo, and the given locale. This is a convenient override of getInstance(String skeleton, ULocale locale, DateIntervalInfo dtitvinf)

Example code:

Parameters
skeleton String!: the skeleton on which interval format based.
locale Locale!: the given locale
dtitvinf DateIntervalInfo!: the DateIntervalInfo object to be adopted.
Return
DateIntervalFormat! a date time interval formatter.

getTimeZone

Added in API level 24
open fun getTimeZone(): TimeZone!

Get the TimeZone

Return
TimeZone! A copy of the TimeZone associated with this date interval formatter.

setContext

Added in API level 33
open fun setContext(context: DisplayContext!): Unit

[icu] Set a particular DisplayContext value in the formatter, such as CAPITALIZATION_FOR_STANDALONE. This causes the formatted result to be capitalized appropriately for the context in which it is intended to be used, considering both the locale and the type of field at the beginning of the formatted result.

Parameters
context DisplayContext!: The DisplayContext value to set.

setDateIntervalInfo

Added in API level 24
open fun setDateIntervalInfo(newItvPattern: DateIntervalInfo!): Unit

Set the date time interval patterns.

Parameters
newItvPattern DateIntervalInfo!: the given interval patterns to copy.

setTimeZone

Added in API level 24
open fun setTimeZone(zone: TimeZone!): Unit

Set the TimeZone for the calendar used by this DateIntervalFormat object.

Parameters
zone TimeZone!: The new TimeZone, will be cloned for use by this DateIntervalFormat.