org.apache.fop.render.intermediate.extensions.GoToXYAction Maven / Gradle / Ivy
Show all versions of org.apache.fop Show documentation
/*
* 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: GoToXYAction.java 1844636 2018-10-23 11:56:21Z ssteiner $ */
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.render.intermediate.PageIndexContext;
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 PageIndexContext ifContext;
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, 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, PageIndexContext ifContext) {
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);
this.ifContext = ifContext;
}
/**
* 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.
*
* 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.
*
* 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));
if (ifContext != null && pageIndex >= 0) {
int pageIndexRelative = pageIndex - ifContext.getPageIndex();
if (pageIndexRelative < 0) {
atts.addAttribute("", "page-index-relative", "page-index-relative",
XMLUtil.CDATA, Integer.toString(pageIndexRelative));
}
}
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");
}
}