Class DecimalFormatFilter

  • All Implemented Interfaces:
    Serializable, Cloneable, DataFilter, DataSource, DataTarget, RawDataSource

    public class DecimalFormatFilter
    extends NumberFormatFilter
    A filter that formats the numeric value from a data source to a string representation using the decimal number system as base.

    This filter will format java.lang.Number objects using a java.text.DecimalFormat to create the string representation for the date obtained from the datasource.

    If the object read from the datasource is no date, the NullValue defined by setNullValue(Object) is returned.

    Author:
    Thomas Morgner
    See Also:
    NumberFormat, Number, Serialized Form
    • Constructor Detail

      • DecimalFormatFilter

        public DecimalFormatFilter()
        DefaultConstructor, this object is initialized using a DecimalFormat with the default pattern for this locale.
    • Method Detail

      • getDecimalFormat

        public DecimalFormat getDecimalFormat()
        Returns the format for the filter. The DecimalFormatParser has only DecimalFormat objects assigned.
        Returns:
        the formatter.
        Throws:
        NullPointerException - if the given format is null
      • setDecimalFormat

        public void setDecimalFormat​(DecimalFormat format)
        Sets the format for the filter.
        Parameters:
        format - the format.
        Throws:
        NullPointerException - if the given format is null
      • getFormatString

        public String getFormatString()
        Synthesizes a pattern string that represents the current state of this Format object.
        Returns:
        the pattern string of the format object contained in this filter.
      • setFormatString

        public void setFormatString​(String format)
        Applies a format string to the internal DecimalFormat instance.
        Parameters:
        format - the format string.
      • getLocalizedFormatString

        public String getLocalizedFormatString()
        Synthesizes a localized pattern string that represents the current state of this Format object.
        Returns:
        the localized pattern string of the format-object.
      • setLocalizedFormatString

        public void setLocalizedFormatString​(String format)
        Applies a localised format string to the internal DecimalFormat instance.
        Parameters:
        format - the format string.
      • isKeepState

        public boolean isKeepState()
        Defines, whether the filter should keep its state, if a locale change is detected. This will effectivly disable the locale update.
        Returns:
        true, if the locale should not update the DateSymbols, false otherwise.
      • setKeepState

        public void setKeepState​(boolean keepState)
        Defines, whether the filter should keep its state, if a locale change is detected. This will effectivly disable the locale update.
        Parameters:
        keepState - set to true, if the locale should not update the DateSymbols, false otherwise.
      • getValue

        public Object getValue​(ExpressionRuntime runtime,
                               ReportElement element)
        Returns the formatted string. The value is read using the data source given and formated using the formatter of this object. The formating is guaranteed to completly form the object to an string or to return the defined NullValue.

        If format, datasource or object are null, the NullValue is returned.

        Specified by:
        getValue in interface DataSource
        Overrides:
        getValue in class FormatFilter
        Parameters:
        runtime - the expression runtime that is used to evaluate formulas and expressions when computing the value of this filter.
        element -
        Returns:
        The formatted value.
      • getFormatString

        public FormatSpecification getFormatString​(ExpressionRuntime runtime,
                                                   ReportElement element,
                                                   FormatSpecification formatSpecification)
        Description copied from interface: RawDataSource
        Returns information about the formatstring that was used to transform a raw-value into a formatted text. Not all elements will make use of a format-string. These elements will return .classic.core.filter.FormatSpecification#TYPE_UNDEFINED in that case.
        Specified by:
        getFormatString in interface RawDataSource
        Overrides:
        getFormatString in class NumberFormatFilter
        Parameters:
        runtime - the Expression runtime used to possibly compute the raw-value.
        element - the element to which this datasource is added.
        formatSpecification - the format specification (can be null). @return a filled format specififcation. If the formatSpecification parameter was not null, this given instance is reused.