/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* $Id: NumericProperty.java 1805173 2017-08-16 10:50:04Z ssteiner $ */

package org.apache.fop.fo.expr;

import java.awt.Color;

import org.apache.fop.apps.FOUserAgent;
import org.apache.fop.datatypes.Length;
import org.apache.fop.datatypes.Numeric;
import org.apache.fop.datatypes.PercentBaseContext;
import org.apache.fop.fo.properties.FixedLength;
import org.apache.fop.fo.properties.Property;
import org.apache.fop.util.CompareUtil;

A numeric property which hold the final absolute result of an expression calculations.
/** * A numeric property which hold the final absolute result of an expression * calculations. */
public class NumericProperty extends Property implements Numeric, Length { private double value; private int dim;
Construct a Numeric object by specifying one or more components, including absolute length, percent length, table units.
Params:
  • value – The value of the numeric.
  • dim – The dimension of the value. 0 for a Number, 1 for a Length (any type), >1, <0 if Lengths have been multiplied or divided.
/** * Construct a Numeric object by specifying one or more components, * including absolute length, percent length, table units. * @param value The value of the numeric. * @param dim The dimension of the value. 0 for a Number, 1 for a Length * (any type), &gt;1, &lt;0 if Lengths have been multiplied or divided. */
protected NumericProperty(double value, int dim) { this.value = value; this.dim = dim; }
Return the dimension. {@inheritDoc}
/** * Return the dimension. * {@inheritDoc} */
public int getDimension() { return dim; }
Return the value. {@inheritDoc}
/** * Return the value. * {@inheritDoc} */
public double getNumericValue() { return value; }
{@inheritDoc}
/** * {@inheritDoc} */
public double getNumericValue(PercentBaseContext context) { return value; }
Return true of the numeric is absolute. {@inheritDoc}
/** * Return true of the numeric is absolute. * {@inheritDoc} */
public boolean isAbsolute() { return true; }
{@inheritDoc}
/** {@inheritDoc} */
public Numeric getNumeric() { return this; }
{@inheritDoc}
/** {@inheritDoc} */
public Number getNumber() { return value; }
{@inheritDoc}
/** {@inheritDoc} */
public int getValue() { return (int) value; }
{@inheritDoc}
/** {@inheritDoc} */
public int getValue(PercentBaseContext context) { return (int) value; }
{@inheritDoc}
/** {@inheritDoc} */
public Length getLength() { if (dim == 1) { return this; } log.error("Can't create length with dimension " + dim); return null; }
{@inheritDoc}
/** {@inheritDoc} */
public Color getColor(FOUserAgent foUserAgent) { // TODO: try converting to numeric number and then to color return null; }
{@inheritDoc}
/** {@inheritDoc} */
public Object getObject() { return this; }
{@inheritDoc}
/** {@inheritDoc} */
public String toString() { if (dim == 1) { return (int) value + FixedLength.MPT; } else { return value + "^" + dim; } } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + dim; result = prime * result + CompareUtil.getHashCode(value); return result; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (!(obj instanceof NumericProperty)) { return false; } NumericProperty other = (NumericProperty) obj; return dim == other.dim && CompareUtil.equal(value, other.value); } }