/*
 * 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: PDFNameTreeNode.java 986203 2010-08-17 06:56:46Z jeremias $ */

package org.apache.fop.pdf;


Class representing a PDF name tree node.
/** * Class representing a PDF name tree node. */
public class PDFNameTreeNode extends PDFDictionary { private static final String KIDS = "Kids"; private static final String NAMES = "Names"; private static final String LIMITS = "Limits";
create a named destination
/** * create a named destination */
public PDFNameTreeNode() { /* generic creation of PDF object */ super(); }
Sets the Kids array.
Params:
  • kids – the Kids array
/** * Sets the Kids array. * @param kids the Kids array */
public void setKids(PDFArray kids) { put(KIDS, kids); }
Returns the Kids array.
Returns:the Kids array
/** * Returns the Kids array. * @return the Kids array */
public PDFArray getKids() { return (PDFArray)get(KIDS); }
Sets the Names array.
Params:
  • names – the Names array
/** * Sets the Names array. * @param names the Names array */
public void setNames(PDFArray names) { put(NAMES, names); }
Returns the Names array.
Returns:the Names array
/** * Returns the Names array. * @return the Names array */
public PDFArray getNames() { return (PDFArray)get(NAMES); }
Sets the lower limit value of the Limits array.
Params:
  • key – the lower limit value
/** * Sets the lower limit value of the Limits array. * @param key the lower limit value */
public void setLowerLimit(String key) { PDFArray limits = prepareLimitsArray(); limits.set(0, key); }
Returns the lower limit value of the Limits array.
Returns:the lower limit value
/** * Returns the lower limit value of the Limits array. * @return the lower limit value */
public String getLowerLimit() { PDFArray limits = prepareLimitsArray(); return (String)limits.get(0); }
Sets the upper limit value of the Limits array.
Params:
  • key – the upper limit value
/** * Sets the upper limit value of the Limits array. * @param key the upper limit value */
public void setUpperLimit(String key) { PDFArray limits = prepareLimitsArray(); limits.set(1, key); }
Returns the upper limit value of the Limits array.
Returns:the upper limit value
/** * Returns the upper limit value of the Limits array. * @return the upper limit value */
public String getUpperLimit() { PDFArray limits = prepareLimitsArray(); return (String)limits.get(1); } private PDFArray prepareLimitsArray() { PDFArray limits = (PDFArray)get(LIMITS); if (limits == null) { limits = new PDFArray(this, new Object[2]); put(LIMITS, limits); } if (limits.length() != 2) { throw new IllegalStateException("Limits array must have 2 entries"); } return limits; } }