/*
 * 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: LengthPairProperty.java 1303891 2012-03-22 17:04:12Z vhennebert $ */

package org.apache.fop.fo.properties;

import org.apache.fop.datatypes.CompoundDatatype;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.expr.PropertyException;
import org.apache.fop.util.CompareUtil;

Superclass for properties wrapping a LengthPair value
/** * Superclass for properties wrapping a LengthPair value */
public class LengthPairProperty extends Property implements CompoundDatatype { private Property ipd; private Property bpd;
Inner class for creating instances of LengthPairProperty
/** * Inner class for creating instances of LengthPairProperty */
public static class Maker extends CompoundPropertyMaker {
Params:
  • propId – name of property for which this Maker should be created
/** * @param propId name of property for which this Maker should be created */
public Maker(int propId) { super(propId); }
Create a new empty instance of LengthPairProperty.
Returns:the new instance.
/** * Create a new empty instance of LengthPairProperty. * @return the new instance. */
public Property makeNewProperty() { return new LengthPairProperty(); }
{@inheritDoc}
/** * {@inheritDoc} */
public Property convertProperty(Property p, PropertyList propertyList, FObj fo) throws PropertyException { if (p instanceof LengthPairProperty) { return p; } return super.convertProperty(p, propertyList, fo); } }
Creates a new LengthPairProperty with empty values.
/** * Creates a new LengthPairProperty with empty values. */
public LengthPairProperty() { super(); }
Creates a new LengthPairProperty.
Params:
  • ipd – inline-progression-dimension
  • bpd – block-progression-dimension
/** * Creates a new LengthPairProperty. * @param ipd inline-progression-dimension * @param bpd block-progression-dimension */
public LengthPairProperty(Property ipd, Property bpd) { this(); this.ipd = ipd; this.bpd = bpd; }
Creates a new LengthPairProperty which sets both bpd and ipd to the same value.
Params:
  • len – length for both dimensions
/** * Creates a new LengthPairProperty which sets both bpd and ipd to the * same value. * @param len length for both dimensions */
public LengthPairProperty(Property len) { this(len, len); }
{@inheritDoc}
/** * {@inheritDoc} */
public void setComponent(int cmpId, Property cmpnValue, boolean bIsDefault) { if (cmpId == CP_BLOCK_PROGRESSION_DIRECTION) { bpd = cmpnValue; } else if (cmpId == CP_INLINE_PROGRESSION_DIRECTION) { ipd = cmpnValue; } }
{@inheritDoc}
/** * {@inheritDoc} */
public Property getComponent(int cmpId) { if (cmpId == CP_BLOCK_PROGRESSION_DIRECTION) { return getBPD(); } else if (cmpId == CP_INLINE_PROGRESSION_DIRECTION) { return getIPD(); } else { return null; // SHOULDN'T HAPPEN } }
Returns:Property holding the ipd length
/** * @return Property holding the ipd length */
public Property getIPD() { return this.ipd; }
Returns:Property holding the bpd length
/** * @return Property holding the bpd length */
public Property getBPD() { return this.bpd; }
{@inheritDoc}
/** {@inheritDoc} */
public String toString() { return "LengthPair[" + "ipd:" + getIPD().getObject() + ", bpd:" + getBPD().getObject() + "]"; }
Returns:this.lengthPair
/** * @return this.lengthPair */
public LengthPairProperty getLengthPair() { return this; }
Returns:this.lengthPair cast as an Object
/** * @return this.lengthPair cast as an Object */
public Object getObject() { return this; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + CompareUtil.getHashCode(bpd); result = prime * result + CompareUtil.getHashCode(ipd); return result; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (!(obj instanceof LengthPairProperty)) { return false; } LengthPairProperty other = (LengthPairProperty) obj; return CompareUtil.equal(bpd, other.bpd) && CompareUtil.equal(ipd, other.ipd); } }