/* * 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$ */ package org.apache.fop.render.intermediate.extensions; import java.awt.Point; import org.xml.sax.ContentHandler; import org.xml.sax.SAXException; import org.xml.sax.helpers.AttributesImpl; import org.apache.fop.util.XMLUtil; /** * Action class which represents a "go-to" action to an absolute coordinate on a page. */ public class GoToXYAction extends AbstractAction implements DocumentNavigationExtensionConstants { private int pageIndex = -1; private Point targetLocation; /** * Creates a new instance with yet unknown location. * @param id the identifier for this action */ public GoToXYAction(String id) { this(id, -1, null); } /** * Creates a new instance. * @param id the identifier for this action * @param pageIndex the index (0-based) of the target page, -1 if the page index is * still unknown * @param targetLocation the absolute location on the page (coordinates in millipoints), * or null, if the position isn't known, yet */ public GoToXYAction(String id, int pageIndex, Point targetLocation) { setID(id); if (pageIndex < 0 && targetLocation != null) { throw new IllegalArgumentException( "Page index may not be null if target location is known!"); } setPageIndex(pageIndex); setTargetLocation(targetLocation); } /** * Sets the index of the target page. * @param pageIndex the index (0-based) of the target page */ public void setPageIndex(int pageIndex) { this.pageIndex = pageIndex; } /** * Returns the page index of the target page. * <p> * This function will always return a valid value for safety. Use * {@link #isComplete()} to check if the link is actually complete. * * @return the page index (0-based) */ public int getPageIndex() { if (this.pageIndex >= 0) { return this.pageIndex; } else { return 0; } } /** * Returns the absolute coordinates of the target location on the page. * <p> * This function will always return a valid value for safety. Use * {@link #isComplete()} to check if the link is actually complete. * * @return the target location (coordinates in millipoints) */ public Point getTargetLocation() { if (this.targetLocation == null) { return new Point(0, 0); } else { return this.targetLocation; } } /** * Sets the absolute coordinates of the target location on the page. * @param location the location (coordinates in millipoints) */ public void setTargetLocation(Point location) { this.targetLocation = location; } private boolean isCompleteExceptTargetLocation() { return (getPageIndex() >= 0); } /** {@inheritDoc} */ public boolean isComplete() { return this.isCompleteExceptTargetLocation() && (this.targetLocation != null); } /** {@inheritDoc} */ public boolean isSame(AbstractAction other) { if (other == null) { throw new NullPointerException("other must not be null"); } if (!(other instanceof GoToXYAction)) { return false; } GoToXYAction otherAction = (GoToXYAction)other; if (this.pageIndex != otherAction.pageIndex) { return false; } if (this.targetLocation == null || otherAction.targetLocation == null) { return false; } if (!getTargetLocation().equals(otherAction.getTargetLocation())) { return false; } return true; } /** {@inheritDoc} */ public void toSAX(ContentHandler handler) throws SAXException { AttributesImpl atts = new AttributesImpl(); if (this.isCompleteExceptTargetLocation()) { final Point reportedTargetLocation = this.getTargetLocation(); atts.addAttribute("", "id", "id", XMLUtil.CDATA, getID()); atts.addAttribute("", "page-index", "page-index", XMLUtil.CDATA, Integer.toString(pageIndex)); atts.addAttribute("", "x", "x", XMLUtil.CDATA, Integer.toString(reportedTargetLocation.x)); atts.addAttribute("", "y", "y", XMLUtil.CDATA, Integer.toString(reportedTargetLocation.y)); } else { atts.addAttribute("", "idref", "idref", XMLUtil.CDATA, getID()); } handler.startElement(GOTO_XY.getNamespaceURI(), GOTO_XY.getLocalName(), GOTO_XY.getQName(), atts); handler.endElement(GOTO_XY.getNamespaceURI(), GOTO_XY.getLocalName(), GOTO_XY.getQName()); } /** {@inheritDoc} */ public String toString() { return "GoToXY: ID=" + getID() + ", page=" + getPageIndex() + ", loc=" + getTargetLocation() + ", " + (isComplete() ? "complete" : "INCOMPLETE"); } }