aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/org/apache/fop/apps/CommandLine.java122
-rw-r--r--src/org/apache/fop/apps/Driver.java215
-rw-r--r--src/org/apache/fop/apps/ErrorHandler.java4
-rw-r--r--src/org/apache/fop/apps/FOPException.java16
-rw-r--r--src/org/apache/fop/apps/Version.java18
-rw-r--r--src/org/apache/fop/apps/XTCommandLine.java78
-rw-r--r--src/org/apache/fop/datatypes/ColorType.java136
-rw-r--r--src/org/apache/fop/datatypes/Length.java88
-rw-r--r--src/org/apache/fop/fo/ElementMapping.java6
-rw-r--r--src/org/apache/fop/fo/FONode.java110
-rw-r--r--src/org/apache/fop/fo/FOText.java80
-rw-r--r--src/org/apache/fop/fo/FOTreeBuilder.java204
-rw-r--r--src/org/apache/fop/fo/FObj.java57
-rw-r--r--src/org/apache/fop/fo/FObjMixed.java49
-rw-r--r--src/org/apache/fop/fo/Property.java41
-rw-r--r--src/org/apache/fop/fo/PropertyList.java41
-rw-r--r--src/org/apache/fop/fo/PropertyListBuilder.java120
-rw-r--r--src/org/apache/fop/fo/StandardElementMapping.java52
-rw-r--r--src/org/apache/fop/fo/flow/Block.java192
-rw-r--r--src/org/apache/fop/fo/flow/DisplayGraphic.java132
-rw-r--r--src/org/apache/fop/fo/flow/DisplayRule.java88
-rw-r--r--src/org/apache/fop/fo/flow/DisplaySequence.java52
-rw-r--r--src/org/apache/fop/fo/flow/Flow.java59
-rw-r--r--src/org/apache/fop/fo/flow/InlineSequence.java35
-rw-r--r--src/org/apache/fop/fo/flow/ListBlock.java143
-rw-r--r--src/org/apache/fop/fo/flow/ListItem.java144
-rw-r--r--src/org/apache/fop/fo/flow/ListItemBody.java54
-rw-r--r--src/org/apache/fop/fo/flow/ListItemLabel.java49
-rw-r--r--src/org/apache/fop/fo/flow/PageNumber.java66
-rw-r--r--src/org/apache/fop/fo/flow/StaticContent.java54
-rw-r--r--src/org/apache/fop/fo/flow/Table.java183
-rw-r--r--src/org/apache/fop/fo/flow/TableBody.java137
-rw-r--r--src/org/apache/fop/fo/flow/TableCell.java122
-rw-r--r--src/org/apache/fop/fo/flow/TableColumn.java34
-rw-r--r--src/org/apache/fop/fo/flow/TableRow.java155
-rw-r--r--src/org/apache/fop/fo/pagination/LayoutMasterSet.java50
-rw-r--r--src/org/apache/fop/fo/pagination/PageSequence.java138
-rw-r--r--src/org/apache/fop/fo/pagination/RegionAfter.java54
-rw-r--r--src/org/apache/fop/fo/pagination/RegionBefore.java53
-rw-r--r--src/org/apache/fop/fo/pagination/RegionBody.java50
-rw-r--r--src/org/apache/fop/fo/pagination/Root.java61
-rw-r--r--src/org/apache/fop/fo/pagination/SequenceSpecification.java66
-rw-r--r--src/org/apache/fop/fo/pagination/SequenceSpecifier.java13
-rw-r--r--src/org/apache/fop/fo/pagination/SequenceSpecifierAlternating.java65
-rw-r--r--src/org/apache/fop/fo/pagination/SequenceSpecifierRepeating.java61
-rw-r--r--src/org/apache/fop/fo/pagination/SequenceSpecifierSingle.java59
-rw-r--r--src/org/apache/fop/fo/pagination/SimplePageMaster.java89
-rw-r--r--src/org/apache/fop/image/BmpBwImage.java108
-rw-r--r--src/org/apache/fop/image/BmpColImage.java126
-rw-r--r--src/org/apache/fop/image/FopImage.java24
-rw-r--r--src/org/apache/fop/image/FopImageFactory.java47
-rw-r--r--src/org/apache/fop/image/GifJpegImage.java120
-rw-r--r--src/org/apache/fop/image/ImageArea.java57
-rw-r--r--src/org/apache/fop/layout/AlternatingPageMasterFactory.java41
-rw-r--r--src/org/apache/fop/layout/Area.java103
-rw-r--r--src/org/apache/fop/layout/AreaContainer.java32
-rw-r--r--src/org/apache/fop/layout/AreaTree.java40
-rw-r--r--src/org/apache/fop/layout/BlockArea.java132
-rw-r--r--src/org/apache/fop/layout/Box.java9
-rw-r--r--src/org/apache/fop/layout/DisplaySpace.java18
-rw-r--r--src/org/apache/fop/layout/FontInfo.java77
-rw-r--r--src/org/apache/fop/layout/FontMetric.java17
-rw-r--r--src/org/apache/fop/layout/FontState.java61
-rw-r--r--src/org/apache/fop/layout/InlineArea.java38
-rw-r--r--src/org/apache/fop/layout/InlineSpace.java23
-rw-r--r--src/org/apache/fop/layout/LineArea.java401
-rw-r--r--src/org/apache/fop/layout/Page.java91
-rw-r--r--src/org/apache/fop/layout/PageMaster.java66
-rw-r--r--src/org/apache/fop/layout/PageMasterFactory.java20
-rw-r--r--src/org/apache/fop/layout/Region.java20
-rw-r--r--src/org/apache/fop/layout/RepeatingPageMasterFactory.java37
-rw-r--r--src/org/apache/fop/layout/RuleArea.java59
-rw-r--r--src/org/apache/fop/layout/SinglePageMasterFactory.java34
-rw-r--r--src/org/apache/fop/layout/Space.java4
-rw-r--r--src/org/apache/fop/pdf/PDFDocument.java305
-rw-r--r--src/org/apache/fop/pdf/PDFFont.java67
-rw-r--r--src/org/apache/fop/pdf/PDFInfo.java44
-rw-r--r--src/org/apache/fop/pdf/PDFObject.java59
-rw-r--r--src/org/apache/fop/pdf/PDFPage.java78
-rw-r--r--src/org/apache/fop/pdf/PDFPages.java70
-rw-r--r--src/org/apache/fop/pdf/PDFResources.java83
-rw-r--r--src/org/apache/fop/pdf/PDFRoot.java53
-rw-r--r--src/org/apache/fop/pdf/PDFStream.java77
-rw-r--r--src/org/apache/fop/pdf/PDFXObject.java100
-rw-r--r--src/org/apache/fop/render/Renderer.java58
-rw-r--r--src/org/apache/fop/render/pdf/Font.java20
-rw-r--r--src/org/apache/fop/render/pdf/FontSetup.java167
-rw-r--r--src/org/apache/fop/render/pdf/PDFRenderer.java426
-rw-r--r--src/org/apache/fop/render/xml/XMLRenderer.java276
-rw-r--r--src/org/apache/fop/svg/Graphic.java8
-rw-r--r--src/org/apache/fop/svg/Line.java81
-rw-r--r--src/org/apache/fop/svg/LineGraphic.java34
-rw-r--r--src/org/apache/fop/svg/Rect.java81
-rw-r--r--src/org/apache/fop/svg/RectGraphic.java34
-rw-r--r--src/org/apache/fop/svg/SVG.java176
-rw-r--r--src/org/apache/fop/svg/SVGArea.java45
-rw-r--r--src/org/apache/fop/svg/SVGElementMapping.java15
-rw-r--r--src/org/apache/fop/svg/SVGLength.java77
-rw-r--r--src/org/apache/fop/svg/Text.java95
-rw-r--r--src/org/apache/fop/svg/TextGraphic.java29
100 files changed, 0 insertions, 8258 deletions
diff --git a/src/org/apache/fop/apps/CommandLine.java b/src/org/apache/fop/apps/CommandLine.java
index ffba2f695..67101ccb3 100644
--- a/src/org/apache/fop/apps/CommandLine.java
+++ b/src/org/apache/fop/apps/CommandLine.java
@@ -50,245 +50,123 @@
*/
package org.apache.fop.apps;
-
-
// SAX
-
import org.xml.sax.Parser;
-
import org.xml.sax.InputSource;
-
import org.xml.sax.SAXException;
-
import org.xml.sax.SAXParseException;
-
-
// Java
-
import java.io.FileReader;
-
import java.io.File;
-
import java.io.FileWriter;
-
import java.io.PrintWriter;
-
import java.io.IOException;
-
import java.io.FileNotFoundException;
-
import java.net.URL;
-
-
/**
-
* mainline class.
-
*
-
* Gets input and output filenames from the command line.
-
* Creates a SAX Parser (defaulting to XP).
-
*
-
*/
-
public class CommandLine {
-
-
/**
-
* creates a SAX parser, using the value of org.xml.sax.parser
-
* defaulting to com.jclark.xml.sax.Driver
-
*
-
* @return the created SAX parser
-
*/
-
static Parser createParser() {
-
String parserClassName =
-
System.getProperty("org.xml.sax.parser");
-
if (parserClassName == null) {
-
parserClassName = "com.jclark.xml.sax.Driver";
-
}
-
System.err.println("using SAX parser " + parserClassName);
-
-
try {
-
return (Parser)
-
Class.forName(parserClassName).newInstance();
-
} catch (ClassNotFoundException e) {
-
System.err.println("Could not find " + parserClassName);
-
} catch (InstantiationException e) {
-
System.err.println("Could not instantiate "
-
+ parserClassName);
-
} catch (IllegalAccessException e) {
-
System.err.println("Could not access " + parserClassName);
-
} catch (ClassCastException e) {
-
System.err.println(parserClassName + " is not a SAX driver");
-
}
-
return null;
-
}
-
-
/**
-
* create an InputSource from a file name
-
*
-
* @param filename the name of the file
-
* @return the InputSource created
-
*/
-
protected static InputSource fileInputSource(String filename) {
-
-
/* this code adapted from James Clark's in XT */
-
File file = new File(filename);
-
String path = file.getAbsolutePath();
-
String fSep = System.getProperty("file.separator");
-
if (fSep != null && fSep.length() == 1)
-
path = path.replace(fSep.charAt(0), '/');
-
if (path.length() > 0 && path.charAt(0) != '/')
-
path = '/' + path;
-
try {
-
return new InputSource(new URL("file", null,
-
path).toString());
-
}
-
catch (java.net.MalformedURLException e) {
-
throw new Error("unexpected MalformedURLException");
-
}
-
}
-
-
/**
-
* mainline method
-
*
-
* first command line argument is input file
-
* second command line argument is output file
-
*
-
* @param command line arguments
-
*/
-
public static void main(String[] args) {
-
String version = Version.getVersion();
-
System.err.println(version);
-
-
if (args.length != 2) {
-
System.err.println("usage: java "
-
+ "org.apache.fop.apps.CommandLine "
-
+ "formatting-object-file pdf-file");
-
System.exit(1);
-
}
-
-
Parser parser = createParser();
-
-
if (parser == null) {
-
System.err.println("ERROR: Unable to create SAX parser");
-
System.exit(1);
-
}
-
-
try {
-
Driver driver = new Driver();
-
driver.setRenderer("org.apache.fop.render.pdf.PDFRenderer", version);
-
driver.addElementMapping("org.apache.fop.fo.StandardElementMapping");
-
driver.addElementMapping("org.apache.fop.svg.SVGElementMapping");
-
driver.setWriter(new PrintWriter(new FileWriter(args[1])));
-
driver.buildFOTree(parser, fileInputSource(args[0]));
-
driver.format();
-
driver.render();
-
} catch (Exception e) {
-
System.err.println("FATAL ERROR: " + e.getMessage());
-
System.exit(1);
-
}
-
}
-
}
-
diff --git a/src/org/apache/fop/apps/Driver.java b/src/org/apache/fop/apps/Driver.java
index e163405fb..bee187fed 100644
--- a/src/org/apache/fop/apps/Driver.java
+++ b/src/org/apache/fop/apps/Driver.java
@@ -50,431 +50,216 @@
*/
package org.apache.fop.apps;
-
-
// FOP
-
import org.apache.fop.fo.FOTreeBuilder;
-
import org.apache.fop.fo.ElementMapping;
-
import org.apache.fop.layout.AreaTree;
-
import org.apache.fop.layout.FontInfo;
-
import org.apache.fop.render.Renderer;
-
-
// DOM
-
import org.w3c.dom.Document;
-
import org.w3c.dom.Node;
-
import org.w3c.dom.NamedNodeMap;
-
import org.w3c.dom.Attr;
-
-
// SAX
-
import org.xml.sax.DocumentHandler;
-
import org.xml.sax.InputSource;
-
import org.xml.sax.Parser;
-
import org.xml.sax.SAXException;
-
import org.xml.sax.helpers.AttributeListImpl;
-
-
// Java
-
import java.io.PrintWriter;
-
import java.io.IOException;
-
-
public class Driver {
-
-
protected FOTreeBuilder treeBuilder;
-
protected AreaTree areaTree;
-
protected Renderer renderer;
-
protected PrintWriter writer;
-
-
public Driver() {
-
this.treeBuilder = new FOTreeBuilder();
-
}
-
-
public void setRenderer(Renderer renderer) {
-
this.renderer = renderer;
-
}
-
-
public void setRenderer(String rendererClassName, String producer) {
-
this.renderer = createRenderer(rendererClassName);
-
this.renderer.setProducer(producer);
-
}
-
-
protected Renderer createRenderer(String rendererClassName) {
-
System.err.println("using renderer " + rendererClassName);
-
-
try {
-
return (Renderer)
-
Class.forName(rendererClassName).newInstance();
-
} catch (ClassNotFoundException e) {
-
System.err.println("Could not find " + rendererClassName);
-
} catch (InstantiationException e) {
-
System.err.println("Could not instantiate "
-
+ rendererClassName);
-
} catch (IllegalAccessException e) {
-
System.err.println("Could not access " + rendererClassName);
-
} catch (ClassCastException e) {
-
System.err.println(rendererClassName + " is not a renderer");
-
}
-
return null;
-
}
-
-
public void addElementMapping(ElementMapping mapping) {
-
mapping.addToBuilder(this.treeBuilder);
-
}
-
-
public void addElementMapping(String mappingClassName) {
-
createElementMapping(mappingClassName).addToBuilder(this.treeBuilder);
-
}
-
-
protected ElementMapping createElementMapping(String mappingClassName) {
-
System.err.println("using element mapping " + mappingClassName);
-
-
try {
-
return (ElementMapping)
-
Class.forName(mappingClassName).newInstance();
-
} catch (ClassNotFoundException e) {
-
System.err.println("Could not find " + mappingClassName);
-
} catch (InstantiationException e) {
-
System.err.println("Could not instantiate "
-
+ mappingClassName);
-
} catch (IllegalAccessException e) {
-
System.err.println("Could not access " + mappingClassName);
-
} catch (ClassCastException e) {
-
System.err.println(mappingClassName + " is not an element mapping");
-
}
-
return null;
-
}
-
-
public DocumentHandler getDocumentHandler() {
-
return this.treeBuilder;
-
}
-
-
public void buildFOTree(Parser parser, InputSource source)
-
throws FOPException {
-
parser.setDocumentHandler(this.treeBuilder);
-
try {
-
parser.parse(source);
-
} catch (SAXException e) {
-
if (e.getException() instanceof FOPException)
-
throw (FOPException) e.getException();
-
else
-
throw new FOPException(e.getMessage());
-
} catch (IOException e) {
-
throw new FOPException(e.getMessage());
-
}
-
}
-
-
public void buildFOTree(Document document)
-
throws FOPException {
-
-
/* most of this code is modified from John Cowan's */
-
-
Node currentNode;
-
AttributeListImpl currentAtts;
-
-
/* temporary array for making Strings into character arrays */
-
char[] array = null;
-
-
currentAtts = new AttributeListImpl();
-
-
/* start at the document element */
-
currentNode = document;
-
-
try {
-
while (currentNode != null) {
-
switch (currentNode.getNodeType()) {
-
case Node.DOCUMENT_NODE:
-
this.treeBuilder.startDocument();
-
break;
-
case Node.CDATA_SECTION_NODE:
-
case Node.TEXT_NODE:
-
String data = currentNode.getNodeValue();
-
int datalen = data.length();
-
if (array == null || array.length < datalen) {
-
/* if the array isn't big enough, make a new
-
one */
-
array = new char[datalen];
-
}
-
data.getChars(0, datalen, array, 0);
-
this.treeBuilder.characters(array, 0, datalen);
-
break;
-
case Node.PROCESSING_INSTRUCTION_NODE:
-
this.treeBuilder.processingInstruction(
-
currentNode.getNodeName(),
-
currentNode.getNodeValue());
-
break;
-
case Node.ELEMENT_NODE:
-
NamedNodeMap map = currentNode.getAttributes();
-
currentAtts.clear();
-
for (int i = map.getLength() - 1; i >= 0; i--) {
-
Attr att = (Attr)(map.item(i));
-
currentAtts.addAttribute(att.getName(),
-
"CDATA",
-
att.getValue());
-
}
-
this.treeBuilder.startElement(
-
currentNode.getNodeName(), currentAtts);
-
break;
-
}
-
-
Node nextNode = currentNode.getFirstChild();
-
if (nextNode != null) {
-
currentNode = nextNode;
-
continue;
-
}
-
-
while (currentNode != null) {
-
switch (currentNode.getNodeType()) {
-
case Node.DOCUMENT_NODE:
-
this.treeBuilder.endDocument();
-
break;
-
case Node.ELEMENT_NODE:
-
this.treeBuilder.endElement(
-
currentNode.getNodeName());
-
break;
-
}
-
-
nextNode = currentNode.getNextSibling();
-
if (nextNode != null) {
-
currentNode = nextNode;
-
break;
-
}
-
-
currentNode = currentNode.getParentNode();
-
}
-
}
-
} catch (SAXException e) {
-
throw new FOPException(e.getMessage());
-
}
-
}
-
-
public void setWriter(PrintWriter writer) {
-
this.writer = writer;
-
}
-
-
public void format()
-
throws FOPException {
-
FontInfo fontInfo = new FontInfo();
-
this.renderer.setupFontInfo(fontInfo);
-
-
this.areaTree = new AreaTree();
-
this.areaTree.setFontInfo(fontInfo);
-
-
this.treeBuilder.format(areaTree);
-
}
-
-
public void render()
-
throws IOException {
-
this.renderer.render(areaTree, this.writer);
-
}
-
}
-
diff --git a/src/org/apache/fop/apps/ErrorHandler.java b/src/org/apache/fop/apps/ErrorHandler.java
index ea9d1e400..79c889897 100644
--- a/src/org/apache/fop/apps/ErrorHandler.java
+++ b/src/org/apache/fop/apps/ErrorHandler.java
@@ -50,9 +50,5 @@
*/
package org.apache.fop.apps;
-
-
/** not implemented yet */
-
public interface ErrorHandler {}
-
diff --git a/src/org/apache/fop/apps/FOPException.java b/src/org/apache/fop/apps/FOPException.java
index 07347278e..6b64166de 100644
--- a/src/org/apache/fop/apps/FOPException.java
+++ b/src/org/apache/fop/apps/FOPException.java
@@ -50,33 +50,17 @@
*/
package org.apache.fop.apps;
-
-
/**
-
* Exception thrown when FOP has a problem
-
*/
-
public class FOPException extends Exception {
-
-
/**
-
* create a new FOP Exception
-
*
-
* @param message descriptive message
-
*/
-
public FOPException(String message) {
-
super(message);
-
}
-
}
-
diff --git a/src/org/apache/fop/apps/Version.java b/src/org/apache/fop/apps/Version.java
index 7222db46d..a97e23501 100644
--- a/src/org/apache/fop/apps/Version.java
+++ b/src/org/apache/fop/apps/Version.java
@@ -50,37 +50,19 @@
*/
package org.apache.fop.apps;
-
-
/**
-
* class representing the version of FOP.
-
*
-
* added at the request of Stefano Mazzocchi for use by Fop.
-
*/
-
public class Version {
-
-
/**
-
* get the version of FOP
-
*
-
* @return the version string
-
*/
-
public static String getVersion() {
-
return "FOP 0.12.0pre5";
-
}
-
}
-
diff --git a/src/org/apache/fop/apps/XTCommandLine.java b/src/org/apache/fop/apps/XTCommandLine.java
index db3ab2927..21fa398de 100644
--- a/src/org/apache/fop/apps/XTCommandLine.java
+++ b/src/org/apache/fop/apps/XTCommandLine.java
@@ -50,157 +50,79 @@
*/
package org.apache.fop.apps;
-
-
import org.apache.fop.render.pdf.PDFRenderer;
-
import org.apache.fop.fo.StandardElementMapping;
-
import org.apache.fop.svg.SVGElementMapping;
-
-
// James Clark
-
import com.jclark.xsl.sax.XSLProcessor;
-
import com.jclark.xsl.sax.XSLProcessorImpl;
-
-
// SAX
-
import org.xml.sax.Parser;
-
import org.xml.sax.InputSource;
-
import org.xml.sax.SAXException;
-
import org.xml.sax.SAXParseException;
-
-
// Java
-
import java.io.FileReader;
-
import java.io.FileWriter;
-
import java.io.PrintWriter;
-
import java.io.IOException;
-
import java.io.FileNotFoundException;
-
import java.net.URL;
-
-
/**
-
* mainline class for full transformation (via XT) + formatting/rendering.
-
*
-
* gets input, stylesheet and output filenames from the command line
-
* creates an implementation of XSLProcessor, passing it the stylesheet
-
* treats XSLProcessor as SAXParser
-
*
-
*/
-
public class XTCommandLine extends CommandLine {
-
-
/**
-
* mainline method.
-
*
-
* first command line argument is XML input file
-
* second command line argument is XSL stylesheet file
-
* third command line argument is outputfile
-
*/
-
public static void main(String[] args) {
-
String version = Version.getVersion();
-
System.err.println(version);
-
-
if (args.length != 3) {
-
System.err.println("usage: java org.apache.fop.apps.XTCommandLine xml-file xsl-stylesheet pdf-file");
-
System.exit(1);
-
}
-
-
Parser parser = createParser();
-
-
if (parser == null) {
-
System.err.println("ERROR: Unable to create SAX parser");
-
System.exit(1);
-
}
-
-
XSLProcessor xslProcessor = new XSLProcessorImpl();
-
xslProcessor.setParser(parser);
-
-
try {
-
xslProcessor.loadStylesheet(fileInputSource(args[1]));
-
-
Driver driver = new Driver();
-
driver.setRenderer("org.apache.fop.render.pdf.PDFRenderer",
-
version);
-
driver.addElementMapping("org.apache.fop.fo.StandardElementMapping");
-
driver.addElementMapping("org.apache.fop.svg.SVGElementMapping");
-
driver.setWriter(new PrintWriter(new FileWriter(args[2])));
-
driver.buildFOTree(parser, fileInputSource(args[0]));
-
driver.format();
-
driver.render();
-
} catch (Exception e) {
-
System.err.println("FATAL ERROR: " + e.getMessage());
-
System.exit(1);
-
}
-
}
-
}
-
diff --git a/src/org/apache/fop/datatypes/ColorType.java b/src/org/apache/fop/datatypes/ColorType.java
index cbd7f03c6..2049a8f7c 100644
--- a/src/org/apache/fop/datatypes/ColorType.java
+++ b/src/org/apache/fop/datatypes/ColorType.java
@@ -50,273 +50,137 @@
*/
package org.apache.fop.datatypes;
-
-
/**
-
* a colour quantity in XSL
-
*/
-
public class ColorType {
-
-
/** the red component */
-
protected float red;
-
-
/** the green component */
-
protected float green;
-
-
/** the blue component */
-
protected float blue;
-
-
/**
-
* set the colour given a particular String specifying either a
-
* colour name or #RGB or #RRGGBB
-
*/
-
public ColorType (String value) {
-
if (value.startsWith("#")) {
-
try {
-
if (value.length()==4) {
-
// note: divide by 15 so F = FF = 1 and so on
-
this.red = Integer.parseInt(value.substring(1,2),16)/15f;
-
this.green = Integer.parseInt(value.substring(2,3),16)/15f;
-
this.blue = Integer.parseInt(value.substring(3),16)/15f;
-
} else if (value.length()==7) {
-
// note: divide by 255 so FF = 1
-
this.red = Integer.parseInt(value.substring(1,3),16)/255f;
-
this.green = Integer.parseInt(value.substring(3,5),16)/255f;
-
this.blue = Integer.parseInt(value.substring(5),16)/255f;
-
} else {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 0;
-
System.err.println("ERROR: unknown colour format. Must be #RGB or #RRGGBB");
-
}
-
} catch (Exception e) {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 0;
-
System.err.println("ERROR: unknown colour format. Must be #RGB or #RRGGBB");
-
}
-
} else {
-
if (value.toLowerCase().equals("black")) {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("green")) {
-
this.red = 0;
-
this.green = 0.5f;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("silver")) {
-
this.red = 0.75f;
-
this.green = 0.75f;
-
this.blue = 0.75f;
-
} else if (value.toLowerCase().equals("lime")) {
-
this.red = 0;
-
this.green = 1;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("gray")) {
-
this.red = 0.5f;
-
this.green = 0.5f;
-
this.blue = 0.5f;
-
} else if (value.toLowerCase().equals("olive")) {
-
this.red = 0.5f;
-
this.green = 0.5f;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("white")) {
-
this.red = 1;
-
this.green = 1;
-
this.blue = 1;
-
} else if (value.toLowerCase().equals("yellow")) {
-
this.red = 1;
-
this.green = 1;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("maroon")) {
-
this.red = 0.5f;
-
this.green = 0;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("navy")) {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 0.5f;
-
} else if (value.toLowerCase().equals("red")) {
-
this.red = 1;
-
this.green = 0;
-
this.blue = 0;
-
} else if (value.toLowerCase().equals("blue")) {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 1;
-
} else if (value.toLowerCase().equals("purple")) {
-
this.red = 0.5f;
-
this.green = 0;
-
this.blue = 0.5f;
-
} else if (value.toLowerCase().equals("teal")) {
-
this.red = 0;
-
this.green = 0.5f;
-
this.blue = 0.5f;
-
} else if (value.toLowerCase().equals("fuchsia")) {
-
this.red = 1;
-
this.green = 0;
-
this.blue = 1;
-
} else if (value.toLowerCase().equals("aqua")) {
-
this.red = 0;
-
this.green = 1;
-
this.blue = 1;
-
} else if (value.toLowerCase().equals("orange")) {
-
// for compatibility with passiveTex
-
this.red = 0.7f;
-
this.green = 0.5f;
-
this.blue = 0;
-
} else {
-
this.red = 0;
-
this.green = 0;
-
this.blue = 0;
-
System.err.println("ERROR: unknown colour name: " + value);
-
}
-
}
-
}
-
-
public float blue() {
-
return this.blue;
-
}
-
-
public float green() {
-
return this.green;
-
}
-
-
public float red() {
-
return this.red;
-
}
-
}
-
diff --git a/src/org/apache/fop/datatypes/Length.java b/src/org/apache/fop/datatypes/Length.java
index cfb3db774..15b95edf2 100644
--- a/src/org/apache/fop/datatypes/Length.java
+++ b/src/org/apache/fop/datatypes/Length.java
@@ -50,177 +50,89 @@
*/
package org.apache.fop.datatypes;
-
-
import org.apache.fop.fo.Property;
-
-
/**
-
* a length quantity in XSL
-
*/
-
public class Length {
-
-
protected int millipoints = 0;
-
-
protected double fontsize = 12;
-
-
/**
-
* set the length given a particular String specifying length and units
-
*/
-
public Length (String len) {
-
convert(len);
-
}
-
-
/**
-
* set the length given a particular String specifying length and units,
-
* and the font-size (necessary for an em)
-
*/
-
public Length (String len, int fontsize) {
-
this.fontsize = fontsize;
-
convert(len);
-
}
-
-
/**
-
* set the length given a particular multiplier and a length property
-
*/
-
public Length (double multiplier, Property property) {
-
this.millipoints = (int)(multiplier * property.getLength().mvalue());
-
}
-
-
protected void convert(String len) {
-
/* convert the given length to a dimensionless integer representing
-
points. */
-
-
int assumed_resolution = 1; // points/pixel
-
-
int l = len.length();
-
-
if (l == 0) {
-
System.err.println("WARNING: empty length");
-
this.millipoints = 0;
-
} else {
-
String unit = len.substring(l-2);
-
double dvalue =
-
Double.valueOf(len.substring(0,(l-2))).doubleValue();
-
-
if (unit.equals("in"))
-
dvalue = dvalue * 72;
-
else if (unit.equals("cm"))
-
dvalue = dvalue * 28.35;
-
else if (unit.equals("mm"))
-
dvalue = dvalue * 2.84;
-
else if (unit.equals("pt"))
-
dvalue = dvalue;
-
else if (unit.equals("pc"))
-
dvalue = dvalue * 12;
-
else if (unit.equals("em"))
-
dvalue = dvalue * fontsize;
-
else if (unit.equals("px"))
-
dvalue = dvalue * assumed_resolution;
-
else {
-
dvalue = 0;
-
System.err.println("ERROR: unknown length units in "
-
+ len);
-
}
-
-
this.millipoints = (int) (dvalue * 1000);
-
}
-
}
-
-
/**
-
* return the length in 1/1000ths of a point
-
*/
-
public int mvalue() {
-
return millipoints;
-
}
-
-
public String toString() {
-
String s = millipoints + "mpt";
-
return s;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/ElementMapping.java b/src/org/apache/fop/fo/ElementMapping.java
index e59cc61fe..d7289536e 100644
--- a/src/org/apache/fop/fo/ElementMapping.java
+++ b/src/org/apache/fop/fo/ElementMapping.java
@@ -50,13 +50,7 @@
*/
package org.apache.fop.fo;
-
-
public interface ElementMapping {
-
-
public void addToBuilder(FOTreeBuilder builder);
-
}
-
diff --git a/src/org/apache/fop/fo/FONode.java b/src/org/apache/fop/fo/FONode.java
index 04b60601e..bad4bfbf2 100644
--- a/src/org/apache/fop/fo/FONode.java
+++ b/src/org/apache/fop/fo/FONode.java
@@ -50,221 +50,111 @@
*/
package org.apache.fop.fo;
-
-
// FOP
-
import org.apache.fop.apps.FOPException;
-
import org.apache.fop.layout.Area;
-
-
// Java
-
import java.util.Vector;
-
-
/**
-
* base class for nodes in the formatting object tree
-
*/
-
abstract public class FONode {
-
-
protected FObj parent;
-
protected Vector children = new Vector();
-
-
/** value of marker before layout begins */
-
public final static int START = -1000;
-
-
/** value of marker after break-after */
-
public final static int BREAK_AFTER = -1001;
-
-
/**
-
* where the layout was up to.
-
* for FObjs it is the child number
-
* for FOText it is the character number
-
*/
-
protected int marker = START;
-
-
protected boolean isInLabel = false;
-
protected boolean isInListBody = false;
-
protected boolean isInTableCell = false;
-
-
protected int bodyIndent;
-
protected int distanceBetweenStarts;
-
protected int labelSeparation;
-
-
protected int forcedStartOffset = 0;
-
protected int forcedWidth = 0;
-
-
protected FONode(FObj parent) {
-
this.parent = parent;
-
}
-
-
public void setIsInLabel() {
-
this.isInLabel = true;
-
}
-
-
public void setIsInListBody() {
-
this.isInListBody = true;
-
}
-
-
public void setIsInTableCell() {
-
this.isInTableCell = true;
-
}
-
-
public void setDistanceBetweenStarts(int distance) {
-
this.distanceBetweenStarts = distance;
-
}
-
-
public void setLabelSeparation(int separation) {
-
this.labelSeparation = separation;
-
}
-
-
public void setBodyIndent(int indent) {
-
this.bodyIndent = indent;
-
}
-
-
public void forceStartOffset(int offset) {
-
this.forcedStartOffset = offset;
-
}
-
-
public void forceWidth(int width) {
-
this.forcedWidth = width;
-
}
-
-
public void resetMarker() {
-
this.marker = START;
-
int numChildren = this.children.size();
-
for (int i = 0; i < numChildren; i++) {
-
((FONode) children.elementAt(i)).resetMarker();
-
}
-
}
-
-
protected void addChild(FONode child) {
-
children.addElement(child);
-
}
-
-
public FObj getParent() {
-
return this.parent;
-
}
-
-
/* status */
-
/* layout was fully completed */
-
public final static int OK = 1;
-
/* none of the formatting object could be laid out because the
-
containing area was full (end of page) */
-
public final static int AREA_FULL_NONE = 2;
-
/* some of the formatting object could not be laid out because the
-
containing area was full (end of page) */
-
public final static int AREA_FULL_SOME = 3;
-
/* force page break */
-
public final static int FORCE_PAGE_BREAK = 4;
-
public final static int FORCE_PAGE_BREAK_EVEN = 5;
-
public final static int FORCE_PAGE_BREAK_ODD = 6;
-
-
abstract public int layout(Area area)
-
throws FOPException;
-
}
-
diff --git a/src/org/apache/fop/fo/FOText.java b/src/org/apache/fop/fo/FOText.java
index 1fe2fb1a0..6da9163a7 100644
--- a/src/org/apache/fop/fo/FOText.java
+++ b/src/org/apache/fop/fo/FOText.java
@@ -50,161 +50,81 @@
*/
package org.apache.fop.fo;
-
-
// FOP
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.datatypes.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* a text node in the formatting object tree
-
*/
-
public class FOText extends FONode {
-
-
protected char[] ca;
-
protected int start;
-
protected int length;
-
-
FontState fs;
-
float red;
-
float green;
-
float blue;
-
int wrapOption;
-
int whiteSpaceTreatment;
-
-
protected FOText(char[] chars, int s, int e, FObj parent) {
-
super(parent);
-
this.start = 0;
-
this.ca = new char[e - s];
-
for (int i = s; i < e; i++)
-
this.ca[i - s] = chars[i];
-
this.length = e - s;
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (!(area instanceof BlockArea)) {
-
System.err.println("WARNING: text outside block area" + new String(ca, start, length));
-
return OK;
-
}
-
if (this.marker == START) {
-
String fontFamily =
-
this.parent.properties.get("font-family").getString();
-
String fontStyle =
-
this.parent.properties.get("font-style").getString();
-
String fontWeight =
-
this.parent.properties.get("font-weight").getString();
-
int fontSize =
-
this.parent.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily, fontStyle,
-
fontWeight, fontSize);
-
-
ColorType c =
-
this.parent.properties.get("color").getColorType();
-
this.red = c.red();
-
this.green = c.green();
-
this.blue = c.blue();
-
-
this.wrapOption =
-
this.parent.properties.get("wrap-option").getEnum();
-
this.whiteSpaceTreatment =
-
this.parent.properties.get("white-space-treatment").getEnum();
-
-
this.marker = this.start;
-
}
-
int orig_start = this.marker;
-
this.marker = ((BlockArea) area).addText(fs, red, green, blue,
-
wrapOption,
-
whiteSpaceTreatment,
-
ca, this.marker, length);
-
if (this.marker == -1) {
-
return OK;
-
} else if (this.marker != orig_start) {
-
return AREA_FULL_SOME;
-
} else {
-
return AREA_FULL_NONE;
-
}
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/FOTreeBuilder.java b/src/org/apache/fop/fo/FOTreeBuilder.java
index bd8c87d77..0d3bc52ea 100644
--- a/src/org/apache/fop/fo/FOTreeBuilder.java
+++ b/src/org/apache/fop/fo/FOTreeBuilder.java
@@ -50,409 +50,205 @@
*/
package org.apache.fop.fo;
-
-
// FOP
-
import org.apache.fop.layout.AreaTree;
-
import org.apache.fop.apps.FOPException;
-
import org.apache.fop.fo.pagination.Root;
-
-
// SAX
-
import org.xml.sax.HandlerBase;
-
import org.xml.sax.SAXException;
-
import org.xml.sax.InputSource;
-
import org.xml.sax.AttributeList;
-
-
// Java
-
import java.util.Hashtable;
-
import java.util.Stack;
-
import java.io.IOException;
-
-
/**
-
* SAX Handler that builds the formatting object tree.
-
*/
-
public class FOTreeBuilder extends HandlerBase {
-
-
/**
-
* table mapping element names to the makers of objects
-
* representing formatting objects
-
*/
-
protected Hashtable fobjTable = new Hashtable();
-
-
/**
-
* class that builds a property list for each formatting object
-
*/
-
protected PropertyListBuilder propertyListBuilder = new
-
PropertyListBuilder();
-
-
/**
-
* current formatting object being handled
-
*/
-
protected FObj currentFObj = null;
-
-
/**
-
* the root of the formatting object tree
-
*/
-
protected FObj rootFObj = null;
-
-
/**
-
* set of names of formatting objects encountered but unknown
-
*/
-
protected Hashtable unknownFOs = new Hashtable();
-
-
// namespace implementation ideas pinched from John Cowan
-
protected static class NSMap {
-
String prefix;
-
String uri;
-
int level;
-
-
NSMap(String prefix, String uri, int level) {
-
this.prefix = prefix;
-
this.uri = uri;
-
this.level = level;
-
}
-
}
-
-
protected int level = 0;
-
protected Stack namespaceStack = new Stack();
-
-
{
-
namespaceStack.push(new NSMap("xml",
-
"http://www.w3.org/XML/1998/namespace",
-
-1));
-
namespaceStack.push(new NSMap("", "", -1));
-
}
-
-
protected String findURI(String prefix) {
-
for (int i = namespaceStack.size() - 1; i >= 0; i--) {
-
NSMap nsMap = (NSMap) (namespaceStack.elementAt(i));
-
if (prefix.equals(nsMap.prefix)) return nsMap.uri;
-
}
-
return null;
-
}
-
-
protected String mapName(String name)
-
throws SAXException {
-
int colon = name.indexOf(':');
-
String prefix = "";
-
String localPart = name;
-
if (colon != -1) {
-
prefix = name.substring(0, colon);
-
localPart = name.substring(colon + 1);
-
}
-
String uri = findURI(prefix);
-
if (uri == null) {
-
if (prefix.equals("")) {
-
return name;
-
} else {
-
throw new SAXException(new FOPException("Unknown namespace prefix " + prefix));
-
}
-
}
-
return uri + "^" + localPart;
-
}
-
-
/**
-
* add a mapping from element name to maker.
-
*
-
* @param namespaceURI namespace URI of formatting object element
-
* @param localName local name of formatting object element
-
* @param maker Maker for class representing formatting object
-
*/
-
public void addMapping(String namespaceURI, String localName,
-
FObj.Maker maker) {
-
this.fobjTable.put(namespaceURI + "^" + localName, maker);
-
}
-
-
/** SAX Handler for characters */
-
public void characters(char data[], int start, int length) {
-
currentFObj.addCharacters(data, start, start + length);
-
}
-
-
/** SAX Handler for the end of an element */
-
public void endElement(String name) {
-
currentFObj.end();
-
currentFObj = (FObj) currentFObj.getParent();
-
level--;
-
while (((NSMap) namespaceStack.peek()).level > level) {
-
namespaceStack.pop();
-
}
-
}
-
-
/** SAX Handler for the start of the document */
-
public void startDocument() {
-
System.err.println("building formatting object tree");
-
}
-
-
/** SAX Handler for the start of an element */
-
public void startElement(String name, AttributeList attlist)
-
throws SAXException {
-
-
/* the formatting object started */
-
FObj fobj;
-
-
/* the maker for the formatting object started */
-
FObj.Maker fobjMaker;
-
-
level++;
-
int length = attlist.getLength();
-
for (int i = 0; i < length; i++) {
-
String att = attlist.getName(i);
-
if (att.equals("xmlns")) {
-
namespaceStack.push( new NSMap("",
-
attlist.getValue(i),
-
level));
-
} else if (att.startsWith("xmlns:")) {
-
String value = attlist.getValue(i);
-
namespaceStack.push(new NSMap(att.substring(6), value,
-
level));
-
}
-
}
-
String fullName = mapName(name);
-
-
fobjMaker = (FObj.Maker) fobjTable.get(fullName);
-
-
if (fobjMaker == null) {
-
if (!this.unknownFOs.containsKey(fullName)) {
-
this.unknownFOs.put(fullName, "");
-
System.err.println("WARNING: Unknown formatting object "
-
+ fullName);
-
}
-
fobjMaker = new FObjMixed.Maker(); // fall back
-
}
-
-
try {
-
fobj =
-
fobjMaker.make(currentFObj,
-
this.propertyListBuilder.makeList(attlist,
-
(currentFObj == null) ? null : currentFObj.properties));
-
} catch (FOPException e) {
-
throw new SAXException(e);
-
}
-
-
if (rootFObj == null) {
-
rootFObj = fobj;
-
if (!fobj.getName().equals("fo:root")) {
-
throw new SAXException(new FOPException("Root element must"
-
+ " be root, not "
-
+ fobj.getName()));
-
}
-
} else {
-
currentFObj.addChild(fobj);
-
}
-
-
currentFObj = fobj;
-
}
-
-
/**
-
* format this formatting object tree
-
*
-
* @param areaTree the area tree to format into
-
*/
-
public void format(AreaTree areaTree)
-
throws FOPException {
-
System.err.println("formatting FOs into areas");
-
((Root) this.rootFObj).format(areaTree);
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/FObj.java b/src/org/apache/fop/fo/FObj.java
index 73aaddaae..9e48e969d 100644
--- a/src/org/apache/fop/fo/FObj.java
+++ b/src/org/apache/fop/fo/FObj.java
@@ -50,115 +50,58 @@
*/
package org.apache.fop.fo;
-
-
// FOP
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Hashtable;
-
import java.util.Enumeration;
-
-
/**
-
* base class for representation of formatting objects and their processing
-
*/
-
public class FObj extends FONode {
-
-
public static class Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new FObj(parent, propertyList);
-
}
-
}
-
-
public static Maker maker() {
-
return new Maker();
-
}
-
-
protected PropertyList properties;
-
protected String name;
-
-
protected FObj(FObj parent, PropertyList propertyList) {
-
super(parent);
-
this.properties = propertyList;
-
this.name = "default FO";
-
}
-
-
protected void addCharacters(char data[], int start, int length) {
-
// ignore
-
}
-
-
public int layout(Area area) throws FOPException {
-
// should always be overridden
-
return OK;
-
}
-
-
public String getName() {
-
return this.name;
-
}
-
-
protected void start() {
-
// do nothing by default
-
}
-
-
protected void end() {
-
// do nothing by default
-
}
-
}
-
-
diff --git a/src/org/apache/fop/fo/FObjMixed.java b/src/org/apache/fop/fo/FObjMixed.java
index 53d74a6e2..a005991ec 100644
--- a/src/org/apache/fop/fo/FObjMixed.java
+++ b/src/org/apache/fop/fo/FObjMixed.java
@@ -50,99 +50,50 @@
*/
package org.apache.fop.fo;
-
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* base class for representation of mixed content formatting objects
-
* and their processing
-
*/
-
public class FObjMixed extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new FObjMixed(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new FObjMixed.Maker();
-
}
-
-
protected FObjMixed(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
}
-
-
protected void addCharacters(char data[], int start, int length) {
-
children.addElement(new FOText(data,start,length,this));
-
}
-
-
public int layout(Area area) throws FOPException {
-
-
if (this.marker == START) {
-
this.marker = 0;
-
}
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FONode fo = (FONode) children.elementAt(i);
-
int status;
-
if ((status = fo.layout(area)) != OK) {
-
this.marker = i;
-
return status;
-
}
-
}
-
return OK;
-
}
-
}
-
-
diff --git a/src/org/apache/fop/fo/Property.java b/src/org/apache/fop/fo/Property.java
index 65851aa2d..5645b2df4 100644
--- a/src/org/apache/fop/fo/Property.java
+++ b/src/org/apache/fop/fo/Property.java
@@ -50,83 +50,42 @@
*/
package org.apache.fop.fo;
-
-
import org.apache.fop.datatypes.*;
-
import org.apache.fop.apps.FOPException;
-
-
public class Property {
-
-
public static class Maker {
-
-
public boolean isInherited() { return false; }
-
-
public Property make(PropertyList propertyList, String value) throws FOPException {
-
return null;
-
}
-
-
public Property make(PropertyList propertyList) throws FOPException { // default
-
return null;
-
}
-
-
public Property compute(PropertyList propertyList) { // compute
-
return null;
-
}
-
}
-
protected PropertyList propertyList;
-
-
public Length getLength() { return null; }
-
public String getString() { return null; }
-
public ColorType getColorType() { return null; }
-
public int getEnum() { return 0; }
-
-
public static double toDouble(String s) {
-
double d;
-
try {
-
d = Double.valueOf(s).doubleValue();
-
} catch (NumberFormatException e) {
-
d = Double.NaN;
-
}
-
return d;
-
}
-
-
}
-
diff --git a/src/org/apache/fop/fo/PropertyList.java b/src/org/apache/fop/fo/PropertyList.java
index d34ed50cc..ca53e2b0b 100644
--- a/src/org/apache/fop/fo/PropertyList.java
+++ b/src/org/apache/fop/fo/PropertyList.java
@@ -50,83 +50,42 @@
*/
package org.apache.fop.fo;
-
-
import java.util.Hashtable;
-
-
import org.apache.fop.apps.FOPException;
-
-
public class PropertyList extends Hashtable {
-
private PropertyListBuilder builder;
-
private PropertyList parentPropertyList = null;
-
-
public PropertyList(PropertyList parentPropertyList) {
-
this.parentPropertyList = parentPropertyList;
-
}
-
-
public Property get(String propertyName) {
-
-
if (builder == null)
-
System.err.println("OH OH, builder has not been set");
-
Property p = (Property)super.get(propertyName);
-
-
if (p == null) { // if not explicit
-
p = this.builder.computeProperty(this,propertyName);
-
if (p == null) { // else inherit
-
if ((this.parentPropertyList != null)&&(this.builder.isInherited(propertyName))) { // check for parent
-
p = this.parentPropertyList.get(propertyName); // retrieve parent's value
-
} else { // default
-
try {
-
p = this.builder.makeProperty(this,propertyName);
-
} catch (FOPException e) {
-
// don't know what to do here
-
}
-
}
-
}
-
}
-
return p;
-
}
-
-
public void setBuilder(PropertyListBuilder builder) {
-
this.builder = builder;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/PropertyListBuilder.java b/src/org/apache/fop/fo/PropertyListBuilder.java
index c9c898f7d..9465cdc53 100644
--- a/src/org/apache/fop/fo/PropertyListBuilder.java
+++ b/src/org/apache/fop/fo/PropertyListBuilder.java
@@ -50,241 +50,121 @@
*/
package org.apache.fop.fo;
-
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.svg.*;
-
-
import org.apache.fop.apps.FOPException;
-
-
import org.xml.sax.AttributeList;
-
-
import java.util.Hashtable;
-
-
public class PropertyListBuilder {
-
private Hashtable propertyTable;
-
-
public PropertyListBuilder() {
-
this.propertyTable = new Hashtable();
-
-
propertyTable.put("end-indent",EndIndent.maker());
-
propertyTable.put("page-master-name",PageMasterName.maker());
-
propertyTable.put("page-master-first",PageMasterFirst.maker());
-
propertyTable.put("page-master-repeating",PageMasterRepeating.maker());
-
propertyTable.put("page-master-odd",PageMasterOdd.maker());
-
propertyTable.put("page-master-even",PageMasterEven.maker());
-
propertyTable.put("margin-top",MarginTop.maker());
-
propertyTable.put("margin-bottom",MarginBottom.maker());
-
propertyTable.put("margin-left",MarginLeft.maker());
-
propertyTable.put("margin-right",MarginRight.maker());
-
propertyTable.put("extent",Extent.maker());
-
propertyTable.put("page-width",PageWidth.maker());
-
propertyTable.put("page-height",PageHeight.maker());
-
propertyTable.put("flow-name",FlowName.maker());
-
propertyTable.put("font-family",FontFamily.maker());
-
propertyTable.put("font-style",FontStyle.maker());
-
propertyTable.put("font-weight",FontWeight.maker());
-
propertyTable.put("font-size",FontSize.maker());
-
propertyTable.put("line-height",LineHeight.maker());
-
propertyTable.put("text-align",TextAlign.maker());
-
propertyTable.put("text-align-last",TextAlignLast.maker());
-
propertyTable.put("space-before.optimum",SpaceBeforeOptimum.maker());
-
propertyTable.put("space-after.optimum",SpaceAfterOptimum.maker());
-
propertyTable.put("start-indent",StartIndent.maker());
-
propertyTable.put("end-indent",EndIndent.maker());
-
propertyTable.put("provisional-distance-between-starts",ProvisionalDistanceBetweenStarts.maker());
-
propertyTable.put("provisional-label-separation",ProvisionalLabelSeparation.maker());
-
propertyTable.put("rule-thickness",RuleThickness.maker());
-
propertyTable.put("color",Color.maker());
-
propertyTable.put("wrap-option",WrapOption.maker());
-
propertyTable.put("white-space-treatment",WhiteSpaceTreatment.maker());
-
propertyTable.put("break-before",BreakBefore.maker());
-
propertyTable.put("break-after",BreakAfter.maker());
-
propertyTable.put("text-indent",TextIndent.maker());
-
propertyTable.put("href",HRef.maker());
-
propertyTable.put("column-width",ColumnWidth.maker());
-
propertyTable.put("height",SVGLength.maker());
-
propertyTable.put("width",SVGLength.maker());
-
propertyTable.put("x",SVGLength.maker());
-
propertyTable.put("y",SVGLength.maker());
-
propertyTable.put("x1",SVGLength.maker());
-
propertyTable.put("x2",SVGLength.maker());
-
propertyTable.put("y1",SVGLength.maker());
-
propertyTable.put("y2",SVGLength.maker());
-
}
-
-
public Property computeProperty(PropertyList propertyList, String propertyName) {
-
-
Property p = null;
-
-
Property.Maker propertyMaker = (Property.Maker)propertyTable.get(propertyName);
-
if (propertyMaker != null) {
-
p = propertyMaker.compute(propertyList);
-
} else {
-
//System.err.println("WARNING: property " + propertyName + " ignored");
-
}
-
return p;
-
}
-
-
public boolean isInherited(String propertyName) {
-
boolean b;
-
-
Property.Maker propertyMaker = (Property.Maker)propertyTable.get(propertyName);
-
if (propertyMaker != null) {
-
b = propertyMaker.isInherited();
-
} else {
-
//System.err.println("WARNING: Unknown property " + propertyName);
-
b = true;
-
}
-
return b;
-
}
-
-
public PropertyList makeList(AttributeList attributes, PropertyList parentPropertyList) throws FOPException {
-
-
PropertyList p = new PropertyList(parentPropertyList);
-
p.setBuilder(this);
-
-
for (int i = 0; i < attributes.getLength(); i++) {
-
String attributeName = attributes.getName(i);
-
Property.Maker propertyMaker = (Property.Maker)propertyTable.get(attributeName);
-
if (propertyMaker != null) {
-
p.put(attributeName,propertyMaker.make(p,attributes.getValue(i)));
-
} else {
-
//System.err.println("WARNING: property " + attributeName + " ignored");
-
}
-
}
-
-
return p;
-
}
-
-
public Property makeProperty(PropertyList propertyList, String propertyName) throws FOPException {
-
-
Property p = null;
-
-
Property.Maker propertyMaker = (Property.Maker)propertyTable.get(propertyName);
-
if (propertyMaker != null) {
-
p = propertyMaker.make(propertyList);
-
} else {
-
//System.err.println("WARNING: property " + propertyName + " ignored");
-
}
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/StandardElementMapping.java b/src/org/apache/fop/fo/StandardElementMapping.java
index 16e7f47d4..006c3bd4e 100644
--- a/src/org/apache/fop/fo/StandardElementMapping.java
+++ b/src/org/apache/fop/fo/StandardElementMapping.java
@@ -50,105 +50,53 @@
*/
package org.apache.fop.fo;
-
-
import org.apache.fop.fo.flow.*;
-
import org.apache.fop.fo.pagination.*;
-
-
public class StandardElementMapping implements ElementMapping {
-
-
public void addToBuilder(FOTreeBuilder builder) {
-
-
String uri = "http://www.w3.org/1999/XSL/Format";
-
-
builder.addMapping(uri, "root", Root.maker());
-
builder.addMapping(uri, "layout-master-set",
-
LayoutMasterSet.maker());
-
builder.addMapping(uri, "simple-page-master",
-
SimplePageMaster.maker());
-
builder.addMapping(uri, "region-body", RegionBody.maker());
-
builder.addMapping(uri, "region-before", RegionBefore.maker());
-
builder.addMapping(uri, "region-after", RegionAfter.maker());
-
builder.addMapping(uri, "page-sequence", PageSequence.maker());
-
builder.addMapping(uri, "sequence-specification",
-
SequenceSpecification.maker());
-
builder.addMapping(uri, "sequence-specifier-single",
-
SequenceSpecifierSingle.maker());
-
builder.addMapping(uri, "sequence-specifier-repeating",
-
SequenceSpecifierRepeating.maker());
-
builder.addMapping(uri, "sequence-specifier-alternating",
-
SequenceSpecifierAlternating.maker());
-
builder.addMapping(uri, "flow", Flow.maker());
-
builder.addMapping(uri, "static-content",
-
StaticContent.maker());
-
builder.addMapping(uri, "block", Block.maker());
-
builder.addMapping(uri, "list-block", ListBlock.maker());
-
builder.addMapping(uri, "list-item", ListItem.maker());
-
builder.addMapping(uri, "list-item-label",
-
ListItemLabel.maker());
-
builder.addMapping(uri, "list-item-body", ListItemBody.maker());
-
builder.addMapping(uri, "page-number", PageNumber.maker());
-
builder.addMapping(uri, "display-sequence",
-
DisplaySequence.maker());
-
builder.addMapping(uri, "inline-sequence",
-
InlineSequence.maker());
-
builder.addMapping(uri, "display-rule", DisplayRule.maker());
-
builder.addMapping(uri, "display-graphic",
-
DisplayGraphic.maker());
-
builder.addMapping(uri, "table", Table.maker());
-
builder.addMapping(uri, "table-column", TableColumn.maker());
-
builder.addMapping(uri, "table-body", TableBody.maker());
-
builder.addMapping(uri, "table-row", TableRow.maker());
-
builder.addMapping(uri, "table-cell", TableCell.maker());
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/Block.java b/src/org/apache/fop/fo/flow/Block.java
index 55e115c35..113b9eeb3 100644
--- a/src/org/apache/fop/fo/flow/Block.java
+++ b/src/org/apache/fop/fo/flow/Block.java
@@ -50,385 +50,193 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
public class Block extends FObjMixed {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Block(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new Block.Maker();
-
}
-
-
FontState fs;
-
int align;
-
int alignLast;
-
int breakBefore;
-
int breakAfter;
-
int lineHeight;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
int textIndent;
-
-
BlockArea blockArea;
-
-
// this may be helpful on other FOs too
-
boolean anythingLaidOut = false;
-
-
public Block(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:block";
-
}
-
-
public int layout(Area area) throws FOPException {
-
// System.err.print(" b:LAY[" + marker + "] ");
-
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
this.align = this.properties.get("text-align").getEnum();
-
this.alignLast =
-
this.properties.get("text-align-last").getEnum();
-
this.breakBefore =
-
this.properties.get("break-before").getEnum();
-
this.breakAfter =
-
this.properties.get("break-after").getEnum();
-
this.lineHeight =
-
this.properties.get("line-height").getLength().mvalue();
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
this.textIndent =
-
this.properties.get("text-indent").getLength().mvalue();
-
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
if (this.isInLabel) {
-
startIndent += bodyIndent;
-
endIndent += (area.getAllocationWidth()
-
- distanceBetweenStarts - startIndent)
-
+ labelSeparation;
-
}
-
-
if (this.isInListBody) {
-
startIndent += bodyIndent + distanceBetweenStarts;
-
}
-
-
if (this.isInTableCell) {
-
startIndent += forcedStartOffset;
-
endIndent = area.getAllocationWidth() - startIndent -
-
forcedWidth;
-
}
-
-
this.marker = 0;
-
-
if (breakBefore == BreakBefore.PAGE) {
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakBefore == BreakBefore.ODD_PAGE) {
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakBefore == BreakBefore.EVEN_PAGE) {
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
}
-
-
if ((spaceBefore != 0) && (this.marker ==0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
if (anythingLaidOut) {
-
this.textIndent = 0;
-
}
-
-
this.blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent,
-
textIndent, align, alignLast, lineHeight);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FONode fo = (FONode) children.elementAt(i);
-
if (this.isInListBody) {
-
fo.setIsInListBody();
-
fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
fo.setBodyIndent(this.bodyIndent);
-
}
-
int status;
-
if ((status = fo.layout(blockArea)) != OK) {
-
this.marker = i;
-
if ((i != 0) && (status == AREA_FULL_NONE)) {
-
status = AREA_FULL_SOME;
-
}
-
//blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
anythingLaidOut = true;
-
return status;
-
}
-
anythingLaidOut = true;
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
-
/* should this be combined into above? */
-
area.increaseHeight(blockArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
if (breakAfter == BreakAfter.PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakAfter == BreakAfter.ODD_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakAfter == BreakAfter.EVEN_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
-
//System.err.print(" b:OK" + marker + " ");
-
return OK;
-
}
-
-
public int getAreaHeight() {
-
return blockArea.getHeight();
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/DisplayGraphic.java b/src/org/apache/fop/fo/flow/DisplayGraphic.java
index a424a9b71..47e360fae 100644
--- a/src/org/apache/fop/fo/flow/DisplayGraphic.java
+++ b/src/org/apache/fop/fo/flow/DisplayGraphic.java
@@ -50,265 +50,133 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
import org.apache.fop.image.*;
-
-
// Java
-
import java.util.Enumeration;
-
import java.util.Hashtable;
-
-
public class DisplayGraphic extends FObj {
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new DisplayGraphic(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new DisplayGraphic.Maker();
-
}
-
-
FontState fs;
-
int align;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
String href;
-
int height;
-
int width;
-
-
ImageArea imageArea;
-
-
public DisplayGraphic(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:display-graphic";
-
}
-
-
public int layout(Area area) throws FOPException {
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
// FIXME
-
this.align = this.properties.get("text-align").getEnum();
-
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
-
this.href = this.properties.get("href").getString();
-
this.width =
-
this.properties.get("width").getLength().mvalue();
-
this.height =
-
this.properties.get("height").getLength().mvalue();
-
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
if (this.isInLabel) {
-
startIndent += bodyIndent;
-
endIndent += (area.getAllocationWidth()
-
- distanceBetweenStarts - startIndent)
-
+ labelSeparation;
-
}
-
-
if (this.isInListBody) {
-
startIndent += bodyIndent + distanceBetweenStarts;
-
}
-
-
if (this.isInTableCell) {
-
startIndent += forcedStartOffset;
-
endIndent = area.getAllocationWidth() - startIndent -
-
forcedWidth;
-
}
-
-
this.marker = 0;
-
}
-
-
if ((spaceBefore != 0) && (this.marker == 0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
FopImage img = FopImageFactory.Make(href, 0, 0, width, height);
-
-
this.imageArea = new ImageArea(fs,
-
img,
-
area.getAllocationWidth(),
-
img.getWidth(),
-
img.getHeight(),
-
startIndent, endIndent,
-
align);
-
-
imageArea.start();
-
imageArea.end();
-
area.addChild(imageArea);
-
area.increaseHeight(imageArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/DisplayRule.java b/src/org/apache/fop/fo/flow/DisplayRule.java
index 4e988fb03..855ec6d8d 100644
--- a/src/org/apache/fop/fo/flow/DisplayRule.java
+++ b/src/org/apache/fop/fo/flow/DisplayRule.java
@@ -50,177 +50,89 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.datatypes.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.RuleArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
public class DisplayRule extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new DisplayRule(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new DisplayRule.Maker();
-
}
-
-
public DisplayRule(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:display-rule";
-
}
-
-
public int layout(Area area) throws FOPException {
-
// FIXME: doesn't check to see if it will fit
-
-
String fontFamily = this.properties.get("font-family").getString();
-
String fontStyle = this.properties.get("font-style").getString();
-
String fontWeight = this.properties.get("font-weight").getString();
-
int fontSize = this.properties.get("font-size").getLength().mvalue();
-
-
FontState fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
int align = this.properties.get("text-align").getEnum();
-
int startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
int endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
int spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
int spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
int ruleThickness =
-
this.properties.get("rule-thickness").getLength().mvalue();
-
int ruleLength = 0; // not used;
-
-
ColorType c = this.properties.get("color").getColorType();
-
float red = c.red();
-
float green = c.green();
-
float blue = c.blue();
-
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
if (spaceBefore != 0) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
RuleArea ruleArea = new RuleArea(fs,
-
area.getAllocationWidth(),
-
area.spaceLeft(),
-
startIndent, endIndent,
-
align, ruleThickness,
-
ruleLength, red, green,
-
blue);
-
area.addChild(ruleArea);
-
area.increaseHeight(ruleArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/DisplaySequence.java b/src/org/apache/fop/fo/flow/DisplaySequence.java
index c83807140..35189ebff 100644
--- a/src/org/apache/fop/fo/flow/DisplaySequence.java
+++ b/src/org/apache/fop/fo/flow/DisplaySequence.java
@@ -50,105 +50,53 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class DisplaySequence extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new DisplaySequence(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new DisplaySequence.Maker();
-
}
-
-
public DisplaySequence(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:display-sequence";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == START) {
-
this.marker = 0;
-
}
-
// this is such common code, perhaps it should be in the super class
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FObj fo = (FObj) children.elementAt(i);
-
int status;
-
if ((status = fo.layout(area)) != OK) {
-
/* message from child */
-
if (status > OK) {
-
/* child still successful */
-
this.marker = i+1;
-
} else {
-
/* child unsucessful */
-
this.marker = i;
-
}
-
return status;
-
}
-
}
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/Flow.java b/src/org/apache/fop/fo/flow/Flow.java
index 66d7e4781..380af416c 100644
--- a/src/org/apache/fop/fo/flow/Flow.java
+++ b/src/org/apache/fop/fo/flow/Flow.java
@@ -50,119 +50,60 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.fo.pagination.PageSequence;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Hashtable;
-
import java.util.Enumeration;
-
-
public class Flow extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Flow(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new Flow.Maker();
-
}
-
-
PageSequence pageSequence;
-
-
protected Flow(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:flow";
-
-
if (parent.getName().equals("fo:page-sequence")) {
-
this.pageSequence = (PageSequence) parent;
-
} else {
-
throw new FOPException("flow must be child of "
-
+ "page-sequence, not "
-
+ parent.getName());
-
}
-
pageSequence.setFlow(this);
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == START) {
-
this.marker = 0;
-
}
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FObj fo = (FObj) children.elementAt(i);
-
int status;
-
if ((status = fo.layout(area)) != OK) {
-
this.marker = i;
-
return status;
-
}
-
}
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/InlineSequence.java b/src/org/apache/fop/fo/flow/InlineSequence.java
index 04aeb2be5..c7965636a 100644
--- a/src/org/apache/fop/fo/flow/InlineSequence.java
+++ b/src/org/apache/fop/fo/flow/InlineSequence.java
@@ -50,71 +50,36 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class InlineSequence extends FObjMixed {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new InlineSequence(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new InlineSequence.Maker();
-
}
-
-
public InlineSequence(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:inline-sequence";
-
-
if (parent.getName().equals("fo:flow")) {
-
throw new FOPException("inline-sequence can't be directly"
-
+ " under flow");
-
}
-
}
-
-
}
-
diff --git a/src/org/apache/fop/fo/flow/ListBlock.java b/src/org/apache/fop/fo/flow/ListBlock.java
index 99f351c5a..a3a649719 100644
--- a/src/org/apache/fop/fo/flow/ListBlock.java
+++ b/src/org/apache/fop/fo/flow/ListBlock.java
@@ -50,287 +50,144 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class ListBlock extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new ListBlock(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new ListBlock.Maker();
-
}
-
-
FontState fs;
-
int align;
-
int alignLast;
-
int breakBefore;
-
int breakAfter;
-
int lineHeight;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
int provisionalDistanceBetweenStarts;
-
int provisionalLabelSeparation;
-
int spaceBetweenListRows = 0;
-
-
public ListBlock(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:list-block";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
this.align = this.properties.get("text-align").getEnum();
-
this.alignLast =
-
this.properties.get("text-align-last").getEnum();
-
this.lineHeight =
-
this.properties.get("line-height").getLength().mvalue();
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
this.provisionalDistanceBetweenStarts =
-
this.properties.get("provisional-distance-between-starts").getLength().mvalue();
-
this.provisionalLabelSeparation =
-
this.properties.get("provisional-label-separation").getLength().mvalue();
-
this.spaceBetweenListRows = 0; // not used at present
-
-
this.marker = 0;
-
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
if (spaceBefore != 0) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
if (this.isInListBody) {
-
startIndent += bodyIndent + distanceBetweenStarts;
-
bodyIndent = startIndent;
-
}
-
}
-
-
BlockArea blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent, 0,
-
align, alignLast, lineHeight);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
if (!(children.elementAt(i) instanceof ListItem)) {
-
System.err.println("WARNING: This version of FOP requires list-items inside list-blocks");
-
return OK;
-
}
-
ListItem listItem = (ListItem) children.elementAt(i);
-
listItem.setDistanceBetweenStarts(this.provisionalDistanceBetweenStarts);
-
listItem.setLabelSeparation(this.provisionalLabelSeparation);
-
listItem.setBodyIndent(this.bodyIndent);
-
int status;
-
if ((status = listItem.layout(blockArea)) != OK) {
-
/* message from child */
-
if (status > OK) {
-
/* child still successful */
-
this.marker = i+1;
-
} else {
-
/* child unsucessful */
-
this.marker = i;
-
}
-
blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
return status;
-
}
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/ListItem.java b/src/org/apache/fop/fo/flow/ListItem.java
index cf43f72a3..4ab9a8290 100644
--- a/src/org/apache/fop/fo/flow/ListItem.java
+++ b/src/org/apache/fop/fo/flow/ListItem.java
@@ -50,289 +50,145 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class ListItem extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new ListItem(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new ListItem.Maker();
-
}
-
-
FontState fs;
-
int align;
-
int alignLast;
-
int breakBefore;
-
int breakAfter;
-
int lineHeight;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
-
public ListItem(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:list-item";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
this.align = this.properties.get("text-align").getEnum();
-
this.alignLast =
-
this.properties.get("text-align-last").getEnum();
-
this.lineHeight =
-
this.properties.get("line-height").getLength().mvalue();
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
-
this.marker = 0;
-
}
-
-
/* not sure this is needed given we know area is from list block */
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
if (spaceBefore != 0) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
startIndent += this.bodyIndent;
-
-
BlockArea blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent,
-
0, align, alignLast, lineHeight);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
if (numChildren != 2) {
-
throw new FOPException("list-item must have exactly two children");
-
}
-
ListItemLabel label = (ListItemLabel) children.elementAt(0);
-
ListItemBody body = (ListItemBody) children.elementAt(1);
-
-
label.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
label.setLabelSeparation(this.labelSeparation);
-
label.setBodyIndent(this.bodyIndent);
-
-
body.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
body.setBodyIndent(this.bodyIndent);
-
-
/* this doesn't actually do anything */
-
body.setLabelSeparation(this.labelSeparation);
-
-
int status;
-
-
// what follows doesn't yet take into account whether the
-
// body failed completely or only got some text in
-
-
if (this.marker == 0) {
-
status = label.layout(blockArea);
-
if (status != OK) {
-
return status;
-
}
-
}
-
-
status = body.layout(blockArea);
-
if (status != OK) {
-
blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
this.marker = 1;
-
return status;
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
/* not sure this is needed given we know area is from list block */
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/ListItemBody.java b/src/org/apache/fop/fo/flow/ListItemBody.java
index f62962889..c3799860e 100644
--- a/src/org/apache/fop/fo/flow/ListItemBody.java
+++ b/src/org/apache/fop/fo/flow/ListItemBody.java
@@ -50,109 +50,55 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class ListItemBody extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new ListItemBody(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new ListItemBody.Maker();
-
}
-
-
public ListItemBody(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:list-item-body";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == START) {
-
this.marker = 0;
-
}
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FObj fo = (FObj) children.elementAt(i);
-
fo.setIsInListBody();
-
fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
fo.setLabelSeparation(this.labelSeparation);
-
fo.setBodyIndent(this.bodyIndent);
-
int status;
-
if ((status = fo.layout(area)) != OK) {
-
this.marker = i;
-
if ((i == 0) && (status == AREA_FULL_NONE)) {
-
return AREA_FULL_NONE;
-
} else {
-
return AREA_FULL_SOME;
-
}
-
}
-
}
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/ListItemLabel.java b/src/org/apache/fop/fo/flow/ListItemLabel.java
index b2ecb6eb7..07278de8b 100644
--- a/src/org/apache/fop/fo/flow/ListItemLabel.java
+++ b/src/org/apache/fop/fo/flow/ListItemLabel.java
@@ -50,99 +50,50 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class ListItemLabel extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new ListItemLabel(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new ListItemLabel.Maker();
-
}
-
-
public ListItemLabel(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:list-item-label";
-
}
-
-
public int layout(Area area) throws FOPException {
-
int numChildren = this.children.size();
-
-
if (numChildren != 1) {
-
throw new FOPException("list-item-label must have exactly one block in this version of FOP");
-
}
-
Block block = (Block) children.elementAt(0);
-
-
block.setIsInLabel();
-
block.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
block.setLabelSeparation(this.labelSeparation);
-
block.setBodyIndent(this.bodyIndent);
-
-
int status;
-
status = block.layout(area);
-
area.addDisplaySpace(-block.getAreaHeight());
-
return status;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/PageNumber.java b/src/org/apache/fop/fo/flow/PageNumber.java
index 338929aff..e31d7ab62 100644
--- a/src/org/apache/fop/fo/flow/PageNumber.java
+++ b/src/org/apache/fop/fo/flow/PageNumber.java
@@ -50,133 +50,67 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.datatypes.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class PageNumber extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new PageNumber(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new PageNumber.Maker();
-
}
-
-
FontState fs;
-
float red;
-
float green;
-
float blue;
-
int wrapOption;
-
int whiteSpaceTreatment;
-
-
public PageNumber(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:page-number";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (!(area instanceof BlockArea)) {
-
System.err.println("WARNING: page-number outside block area");
-
return OK;
-
}
-
if (this.marker == START) {
-
String fontFamily = this.properties.get("font-family").getString();
-
String fontStyle = this.properties.get("font-style").getString();
-
String fontWeight = this.properties.get("font-weight").getString();
-
int fontSize = this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
ColorType c = this.properties.get("color").getColorType();
-
this.red = c.red();
-
this.green = c.green();
-
this.blue = c.blue();
-
-
this.wrapOption = this.properties.get("wrap-option").getEnum();
-
this.whiteSpaceTreatment = this.properties.get("white-space-treatment").getEnum();
-
-
this.marker = 0;
-
}
-
String p = Integer.toString(area.getPage().getNumber());
-
this.marker = ((BlockArea) area).addText(fs, red, green, blue, wrapOption, whiteSpaceTreatment, p.toCharArray(), 0, p.length());
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/StaticContent.java b/src/org/apache/fop/fo/flow/StaticContent.java
index 22a983ce9..e62185a4b 100644
--- a/src/org/apache/fop/fo/flow/StaticContent.java
+++ b/src/org/apache/fop/fo/flow/StaticContent.java
@@ -50,109 +50,55 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.fo.pagination.PageSequence;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Enumeration;
-
-
public class StaticContent extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new StaticContent(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new StaticContent.Maker();
-
}
-
-
PageSequence pageSequence;
-
-
protected StaticContent(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:static-content";
-
-
if (parent.getName().equals("fo:page-sequence")) {
-
this.pageSequence = (PageSequence) parent;
-
} else {
-
throw new FOPException("static-content must be child of "
-
+ "fo:page-sequence, not "
-
+ parent.getName());
-
}
-
String flowName = this.properties.get("flow-name").getString();
-
-
pageSequence.setStaticContent(flowName, this);
-
}
-
-
public int layout(Area area) throws FOPException {
-
int numChildren = this.children.size();
-
for (int i = 0; i < numChildren; i++) {
-
FObj fo = (FObj) children.elementAt(i);
-
fo.layout(area);
-
}
-
resetMarker();
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/Table.java b/src/org/apache/fop/fo/flow/Table.java
index 61e6fd530..eff120aa5 100644
--- a/src/org/apache/fop/fo/flow/Table.java
+++ b/src/org/apache/fop/fo/flow/Table.java
@@ -50,367 +50,184 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Vector;
-
-
public class Table extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Table(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new Table.Maker();
-
}
-
-
FontState fs;
-
int breakBefore;
-
int breakAfter;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
-
Vector columns = new Vector();
-
int currentColumnNumber = 0;
-
-
BlockArea blockArea;
-
-
public Table(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:table";
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
this.breakBefore =
-
this.properties.get("break-before").getEnum();
-
this.breakAfter =
-
this.properties.get("break-after").getEnum();
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
if (this.isInListBody) {
-
startIndent += bodyIndent + distanceBetweenStarts;
-
}
-
-
this.marker = 0;
-
-
if (breakBefore == BreakBefore.PAGE) {
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakBefore == BreakBefore.ODD_PAGE) {
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakBefore == BreakBefore.EVEN_PAGE) {
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
}
-
-
if ((spaceBefore != 0) && (this.marker ==0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
this.blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent, 0,
-
0, 0, 0);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FONode fo = (FONode) children.elementAt(i);
-
if (fo instanceof TableColumn) {
-
TableColumn c = (TableColumn) fo;
-
int num = c.getColumnNumber();
-
if (num == 0) {
-
num = currentColumnNumber + 1;
-
}
-
currentColumnNumber = num;
-
if (num > columns.size()) {
-
columns.setSize(num);
-
}
-
columns.setElementAt(c, num-1);
-
} else if (fo instanceof TableBody) {
-
if (columns.size() == 0) {
-
System.err.println("WARNING: current implementation of tables requires a table-column for each column, indicating column-width");
-
return OK;
-
}
-
-
//if (this.isInListBody) {
-
//fo.setIsInListBody();
-
//fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
//fo.setBodyIndent(this.bodyIndent);
-
//}
-
-
((TableBody) fo).setColumns(columns);
-
-
int status;
-
if ((status = fo.layout(blockArea)) != OK) {
-
this.marker = i;
-
if ((i != 0) && (status == AREA_FULL_NONE)) {
-
status = AREA_FULL_SOME;
-
}
-
//blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
return status;
-
}
-
}
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
-
/* should this be combined into above? */
-
area.increaseHeight(blockArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
if (breakAfter == BreakAfter.PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakAfter == BreakAfter.ODD_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakAfter == BreakAfter.EVEN_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
-
return OK;
-
}
-
-
public int getAreaHeight() {
-
return blockArea.getHeight();
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/TableBody.java b/src/org/apache/fop/fo/flow/TableBody.java
index c87546ed2..c3d5a8c5d 100644
--- a/src/org/apache/fop/fo/flow/TableBody.java
+++ b/src/org/apache/fop/fo/flow/TableBody.java
@@ -50,275 +50,138 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Vector;
-
-
public class TableBody extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new TableBody(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new TableBody.Maker();
-
}
-
-
FontState fs;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
-
Vector columns;
-
-
BlockArea blockArea;
-
-
public TableBody(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:table-body";
-
}
-
-
public void setColumns(Vector columns) {
-
this.columns = columns;
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
//if (this.isInListBody) {
-
//startIndent += bodyIndent + distanceBetweenStarts;
-
//}
-
-
this.marker = 0;
-
-
}
-
-
if ((spaceBefore != 0) && (this.marker ==0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
this.blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent, 0,
-
0, 0, 0);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
TableRow row = (TableRow) children.elementAt(i);
-
-
//if (this.isInListBody) {
-
//fo.setIsInListBody();
-
//fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
//fo.setBodyIndent(this.bodyIndent);
-
//}
-
-
row.setColumns(columns);
-
-
int status;
-
if ((status = row.layout(blockArea)) != OK) {
-
this.marker = i;
-
if ((i != 0) && (status == AREA_FULL_NONE)) {
-
status = AREA_FULL_SOME;
-
}
-
//blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
return status;
-
}
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
-
/* should this be combined into above? */
-
area.increaseHeight(blockArea.getHeight());
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
return OK;
-
}
-
-
public int getAreaHeight() {
-
return blockArea.getHeight();
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/TableCell.java b/src/org/apache/fop/fo/flow/TableCell.java
index 694364a7d..5abe8c578 100644
--- a/src/org/apache/fop/fo/flow/TableCell.java
+++ b/src/org/apache/fop/fo/flow/TableCell.java
@@ -50,245 +50,123 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
public class TableCell extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new TableCell(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new TableCell.Maker();
-
}
-
-
FontState fs;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
-
protected int startOffset;
-
protected int width;
-
protected int height = 0;
-
-
BlockArea blockArea;
-
-
public TableCell(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:table-cell";
-
}
-
-
public void setStartOffset(int offset) {
-
startOffset = offset;
-
}
-
-
public void setWidth(int width) {
-
this.width = width;
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
//if (this.isInListBody) {
-
//startIndent += bodyIndent + distanceBetweenStarts;
-
//}
-
-
this.marker = 0;
-
-
}
-
-
if ((spaceBefore != 0) && (this.marker ==0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
this.blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent, 0,
-
0, 0, 0);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
for (int i = this.marker; i < numChildren; i++) {
-
FObj fo = (FObj) children.elementAt(i);
-
fo.setIsInTableCell();
-
fo.forceStartOffset(startOffset);
-
fo.forceWidth(width);
-
int status;
-
if ((status = fo.layout(blockArea)) != OK) {
-
this.marker = i;
-
if ((i == 0) && (status == AREA_FULL_NONE)) {
-
return AREA_FULL_NONE;
-
} else {
-
return AREA_FULL_SOME;
-
}
-
}
-
height += blockArea.getHeight();
-
-
}
-
blockArea.end();
-
area.addChild(blockArea);
-
-
return OK;
-
}
-
-
public int getHeight() {
-
return height;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/TableColumn.java b/src/org/apache/fop/fo/flow/TableColumn.java
index 1fa05aab6..4a1b23bcc 100644
--- a/src/org/apache/fop/fo/flow/TableColumn.java
+++ b/src/org/apache/fop/fo/flow/TableColumn.java
@@ -50,69 +50,35 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
public class TableColumn extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new TableColumn(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new TableColumn.Maker();
-
}
-
-
public TableColumn(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:table-column";
-
}
-
-
public int getColumnWidth() {
-
return this.properties.get("column-width").getLength().mvalue();
-
}
-
-
public int getColumnNumber() {
-
return 0; // not implemented yet
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/flow/TableRow.java b/src/org/apache/fop/fo/flow/TableRow.java
index 3f80f0c00..9578f0ea3 100644
--- a/src/org/apache/fop/fo/flow/TableRow.java
+++ b/src/org/apache/fop/fo/flow/TableRow.java
@@ -50,311 +50,156 @@
*/
package org.apache.fop.fo.flow;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Vector;
-
-
public class TableRow extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new TableRow(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new TableRow.Maker();
-
}
-
-
FontState fs;
-
int startIndent;
-
int endIndent;
-
int spaceBefore;
-
int spaceAfter;
-
-
int widthOfCellsSoFar = 0;
-
int largestCellHeight = 0;
-
-
Vector columns;
-
-
BlockArea blockArea;
-
-
public TableRow(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "fo:table-row";
-
}
-
-
public void setColumns(Vector columns) {
-
this.columns = columns;
-
}
-
-
public int layout(Area area) throws FOPException {
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
String fontFamily =
-
this.properties.get("font-family").getString();
-
String fontStyle =
-
this.properties.get("font-style").getString();
-
String fontWeight =
-
this.properties.get("font-weight").getString();
-
int fontSize =
-
this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
this.startIndent =
-
this.properties.get("start-indent").getLength().mvalue();
-
this.endIndent =
-
this.properties.get("end-indent").getLength().mvalue();
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
if (area instanceof BlockArea) {
-
area.end();
-
}
-
-
//if (this.isInListBody) {
-
//startIndent += bodyIndent + distanceBetweenStarts;
-
//}
-
-
this.marker = 0;
-
-
}
-
-
if ((spaceBefore != 0) && (this.marker ==0)) {
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
this.blockArea =
-
new BlockArea(fs, area.getAllocationWidth(),
-
area.spaceLeft(), startIndent, endIndent, 0,
-
0, 0, 0);
-
blockArea.setPage(area.getPage());
-
blockArea.start();
-
-
int numChildren = this.children.size();
-
if (numChildren != columns.size()) {
-
System.err.println("WARNING: Number of children under table-row not equal to number of table-columns");
-
return OK;
-
}
-
-
for (int i = this.marker; i < numChildren; i++) {
-
TableCell cell = (TableCell) children.elementAt(i);
-
-
//if (this.isInListBody) {
-
//fo.setIsInListBody();
-
//fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
-
//fo.setBodyIndent(this.bodyIndent);
-
//}
-
-
cell.setStartOffset(widthOfCellsSoFar);
-
int width = ((TableColumn) columns.elementAt(i)).getColumnWidth();
-
-
cell.setWidth(width);
-
widthOfCellsSoFar += width;
-
-
int status;
-
if ((status = cell.layout(blockArea)) != OK) {
-
this.marker = i;
-
if ((i != 0) && (status == AREA_FULL_NONE)) {
-
status = AREA_FULL_SOME;
-
}
-
//blockArea.end();
-
area.addChild(blockArea);
-
area.increaseHeight(blockArea.getHeight());
-
return status;
-
}
-
-
int h = cell.getHeight();
-
blockArea.addDisplaySpace(-h);
-
if (h > largestCellHeight) {
-
largestCellHeight = h;
-
}
-
-
}
-
-
blockArea.end();
-
area.addChild(blockArea);
-
area.addDisplaySpace(largestCellHeight);
-
area.increaseHeight(largestCellHeight);
-
-
if (spaceAfter != 0) {
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
if (area instanceof BlockArea) {
-
area.start();
-
}
-
-
return OK;
-
}
-
-
public int getAreaHeight() {
-
return blockArea.getHeight();
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/LayoutMasterSet.java b/src/org/apache/fop/fo/pagination/LayoutMasterSet.java
index 05d5836db..ba38263a4 100644
--- a/src/org/apache/fop/fo/pagination/LayoutMasterSet.java
+++ b/src/org/apache/fop/fo/pagination/LayoutMasterSet.java
@@ -50,101 +50,51 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Hashtable;
-
-
public class LayoutMasterSet extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new LayoutMasterSet(parent,propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new LayoutMasterSet.Maker();
-
}
-
-
private Hashtable layoutMasters;
-
private Root root;
-
-
protected LayoutMasterSet(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:layout-master-set";
-
-
this.layoutMasters = new Hashtable();
-
if (parent.getName().equals("fo:root")) {
-
this.root = (Root)parent;
-
root.setLayoutMasterSet(this);
-
} else {
-
throw
-
new FOPException("fo:layout-master-set must be child of fo:root, not "
-
+ parent.getName());
-
}
-
}
-
-
protected void addLayoutMaster(String masterName, SimplePageMaster layoutMaster) {
-
this.layoutMasters.put(masterName, layoutMaster);
-
}
-
-
protected SimplePageMaster getLayoutMaster(String masterName) {
-
return (SimplePageMaster)this.layoutMasters.get(masterName);
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/PageSequence.java b/src/org/apache/fop/fo/pagination/PageSequence.java
index 0e6f454d8..47260026d 100644
--- a/src/org/apache/fop/fo/pagination/PageSequence.java
+++ b/src/org/apache/fop/fo/pagination/PageSequence.java
@@ -50,277 +50,139 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.fo.flow.Flow;
-
import org.apache.fop.fo.flow.StaticContent;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.AreaContainer;
-
import org.apache.fop.layout.AreaTree;
-
import org.apache.fop.layout.Page;
-
import org.apache.fop.layout.PageMaster;
-
import org.apache.fop.layout.PageMasterFactory;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Hashtable;
-
import java.util.Vector;
-
-
public class PageSequence extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new PageSequence(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new PageSequence.Maker();
-
}
-
-
protected Root root;
-
protected SequenceSpecification sequenceSpecification;
-
protected Flow flow;
-
protected StaticContent staticBefore;
-
protected StaticContent staticAfter;
-
protected LayoutMasterSet layoutMasterSet;
-
-
protected Page currentPage;
-
protected int currentPageNumber = 0;
-
-
protected PageSequence(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:page-sequence";
-
-
if (parent.getName().equals("fo:root")) {
-
this.root = (Root) parent;
-
this.root.addPageSequence(this);
-
} else {
-
throw
-
new FOPException("page-sequence must be child of root, not "
-
+ parent.getName());
-
}
-
layoutMasterSet = root.getLayoutMasterSet();
-
}
-
-
protected Page makePage(AreaTree areaTree) throws FOPException {
-
PageMaster pageMaster;
-
// layout this page sequence
-
-
// while there is still stuff in the flow, ask the
-
// sequence-specification for a new page
-
-
if (this.sequenceSpecification == null) {
-
throw new FOPException("page-sequence is missing an"
-
+ " sequence-specification");
-
}
-
-
PageMasterFactory pmf =
-
this.sequenceSpecification.getFirstPageMasterFactory();
-
-
pageMaster = pmf.getNextPageMaster();
-
-
while (pageMaster == null) {
-
/* move on to next sequence specifier */
-
pmf = pmf.getNext();
-
if (pmf == null) {
-
throw new FOPException("out of sequence specifiers"
-
+ " (FOP will eventually allow this)");
-
}
-
pageMaster = pmf.getNextPageMaster();
-
}
-
return pageMaster.makePage(areaTree);
-
}
-
-
public void format(AreaTree areaTree) throws FOPException {
-
int status = OK;
-
-
do {
-
currentPage = makePage(areaTree);
-
currentPage.setNumber(++this.currentPageNumber);
-
System.err.print(" [" + currentPageNumber);
-
if ((this.staticBefore != null) &&
-
(currentPage.getBefore() != null)) {
-
AreaContainer beforeArea = currentPage.getBefore();
-
this.staticBefore.layout(beforeArea);
-
}
-
if ((this.staticAfter != null) &&
-
(currentPage.getAfter() != null)) {
-
AreaContainer afterArea = currentPage.getAfter();
-
this.staticAfter.layout(afterArea);
-
}
-
if ((status == FORCE_PAGE_BREAK_EVEN) &&
-
((currentPageNumber % 2) == 1)) {
-
} else if ((status == FORCE_PAGE_BREAK_ODD) &&
-
((currentPageNumber % 2) == 0)) {
-
} else {
-
AreaContainer bodyArea = currentPage.getBody();
-
status = this.flow.layout(bodyArea);
-
}
-
System.err.print("]");
-
areaTree.addPage(currentPage);
-
} while (status != OK);
-
System.err.println();
-
}
-
-
public void setFlow(Flow flow) {
-
this.flow = flow;
-
}
-
-
protected void setSequenceSpecification(SequenceSpecification sequenceSpecification) {
-
this.sequenceSpecification = sequenceSpecification;
-
sequenceSpecification.setLayoutMasterSet(this.layoutMasterSet);
-
}
-
-
public void setStaticContent(String name, StaticContent staticContent) {
-
if (name.equals("xsl-before")) {
-
this.staticBefore = staticContent;
-
} else if (name.equals("xsl-after")) {
-
this.staticAfter = staticContent;
-
} else {
-
System.err.println("WARNING: this version of FOP only supports "
-
+ "static-content in region-before and region-after");
-
}
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/RegionAfter.java b/src/org/apache/fop/fo/pagination/RegionAfter.java
index 78dcecc93..9b8872e1f 100644
--- a/src/org/apache/fop/fo/pagination/RegionAfter.java
+++ b/src/org/apache/fop/fo/pagination/RegionAfter.java
@@ -50,109 +50,55 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Region;
-
import org.apache.fop.apps.FOPException;
-
-
public class RegionAfter extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList) throws FOPException {
-
return new RegionAfter(parent,propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new RegionAfter.Maker();
-
}
-
-
SimplePageMaster layoutMaster;
-
-
protected RegionAfter(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:region-after";
-
-
if (parent.getName().equals("fo:simple-page-master")) {
-
this.layoutMaster = (SimplePageMaster) parent;
-
this.layoutMaster.setRegionAfter(this);
-
} else {
-
throw new FOPException("region-after must be child "
-
+ "of simple-page-master, not "
-
+ parent.getName());
-
}
-
}
-
-
Region makeRegion(int allocationRectangleXPosition,
-
int allocationRectangleYPosition,
-
int allocationRectangleWidth,
-
int allocationRectangleHeight) {
-
int marginTop = this.properties.get("margin-top").getLength().mvalue();
-
int marginBottom = this.properties.get("margin-bottom").getLength().mvalue();
-
int marginLeft = this.properties.get("margin-left").getLength().mvalue();
-
int marginRight = this.properties.get("margin-right").getLength().mvalue();
-
int extent = this.properties.get("extent").getLength().mvalue();
-
-
return new Region(allocationRectangleXPosition + marginLeft,
-
allocationRectangleYPosition -
-
allocationRectangleHeight + extent,
-
allocationRectangleWidth - marginLeft -
-
marginRight,extent);
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/RegionBefore.java b/src/org/apache/fop/fo/pagination/RegionBefore.java
index 258ec88dc..55747c196 100644
--- a/src/org/apache/fop/fo/pagination/RegionBefore.java
+++ b/src/org/apache/fop/fo/pagination/RegionBefore.java
@@ -50,107 +50,54 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Region;
-
import org.apache.fop.apps.FOPException;
-
-
public class RegionBefore extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList) throws FOPException {
-
return new RegionBefore(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new RegionBefore.Maker();
-
}
-
-
SimplePageMaster layoutMaster;
-
-
protected RegionBefore(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:region-before";
-
-
if (parent.getName().equals("fo:simple-page-master")) {
-
this.layoutMaster = (SimplePageMaster) parent;
-
this.layoutMaster.setRegionBefore(this);
-
} else {
-
throw new FOPException("region-before must be child of "
-
+ "simple-page-master, not "
-
+ parent.getName());
-
}
-
}
-
-
Region makeRegion(int allocationRectangleXPosition,
-
int allocationRectangleYPosition,
-
int allocationRectangleWidth,
-
int allocationRectangleHeight) {
-
int marginTop = this.properties.get("margin-top").getLength().mvalue();
-
int marginBottom = this.properties.get("margin-bottom").getLength().mvalue();
-
int marginLeft = this.properties.get("margin-left").getLength().mvalue();
-
int marginRight = this.properties.get("margin-right").getLength().mvalue();
-
int extent = this.properties.get("extent").getLength().mvalue();
-
-
return new Region(allocationRectangleXPosition + marginLeft,
-
allocationRectangleYPosition - marginTop,
-
allocationRectangleWidth - marginLeft -
-
marginRight, extent);
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/RegionBody.java b/src/org/apache/fop/fo/pagination/RegionBody.java
index 314be56c7..72a86819b 100644
--- a/src/org/apache/fop/fo/pagination/RegionBody.java
+++ b/src/org/apache/fop/fo/pagination/RegionBody.java
@@ -50,101 +50,51 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Region;
-
import org.apache.fop.apps.FOPException;
-
-
public class RegionBody extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList) throws FOPException {
-
return new RegionBody(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new RegionBody.Maker();
-
}
-
-
protected RegionBody(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:region-body";
-
-
if (parent.getName().equals("fo:simple-page-master")) {
-
((SimplePageMaster) parent).setRegionBody(this);
-
} else {
-
throw new FOPException("region-body must be child of "
-
+ "simple-page-master, not "
-
+ parent.getName());
-
}
-
}
-
-
Region makeRegion(int allocationRectangleXPosition,
-
int allocationRectangleYPosition,
-
int allocationRectangleWidth,
-
int allocationRectangleHeight) {
-
int marginTop = this.properties.get("margin-top").getLength().mvalue();
-
int marginBottom = this.properties.get("margin-bottom").getLength().mvalue();
-
int marginLeft = this.properties.get("margin-left").getLength().mvalue();
-
int marginRight = this.properties.get("margin-right").getLength().mvalue();
-
-
return new Region(allocationRectangleXPosition + marginLeft,
-
allocationRectangleYPosition - marginTop,
-
allocationRectangleWidth - marginLeft -
-
marginRight, allocationRectangleHeight -
-
marginTop - marginBottom);
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/Root.java b/src/org/apache/fop/fo/pagination/Root.java
index 91cb00994..f7f8bbbd6 100644
--- a/src/org/apache/fop/fo/pagination/Root.java
+++ b/src/org/apache/fop/fo/pagination/Root.java
@@ -50,123 +50,62 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.AreaTree;
-
import org.apache.fop.apps.FOPException;
-
-
// Java
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class Root extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Root(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new Root.Maker();
-
}
-
-
LayoutMasterSet layoutMasterSet;
-
Vector pageSequences;
-
-
protected Root(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:root";
-
-
pageSequences = new Vector();
-
if (parent != null) {
-
throw new FOPException("root must be root element");
-
}
-
}
-
-
public void addPageSequence(PageSequence pageSequence) {
-
this.pageSequences.addElement(pageSequence);
-
}
-
-
public LayoutMasterSet getLayoutMasterSet() {
-
return this.layoutMasterSet;
-
}
-
-
public void format(AreaTree areaTree) throws FOPException {
-
if (layoutMasterSet == null) {
-
throw new FOPException("No layout master set.");
-
}
-
Enumeration e = pageSequences.elements();
-
while (e.hasMoreElements()) {
-
((PageSequence) e.nextElement()).format(areaTree);
-
}
-
}
-
-
public void setLayoutMasterSet(LayoutMasterSet layoutMasterSet) {
-
this.layoutMasterSet = layoutMasterSet;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SequenceSpecification.java b/src/org/apache/fop/fo/pagination/SequenceSpecification.java
index a620ff5f4..6113624c1 100644
--- a/src/org/apache/fop/fo/pagination/SequenceSpecification.java
+++ b/src/org/apache/fop/fo/pagination/SequenceSpecification.java
@@ -50,133 +50,67 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.PageMasterFactory;
-
import org.apache.fop.apps.FOPException;
-
-
public class SequenceSpecification extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SequenceSpecification(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new SequenceSpecification.Maker();
-
}
-
-
private PageSequence pageSequence;
-
private LayoutMasterSet layoutMasterSet;
-
private PageMasterFactory firstPMF;
-
private PageMasterFactory currentPMF;
-
-
protected SequenceSpecification(FObj parent,
-
PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:sequence-specification";
-
-
if (parent.getName().equals("fo:page-sequence")) {
-
this.pageSequence = (PageSequence) parent;
-
this.pageSequence.setSequenceSpecification(this);
-
} else {
-
throw new FOPException("sequence-specification must be child"
-
+ " of page-sequence, not "
-
+ parent.getName());
-
}
-
this.firstPMF = null;
-
this.currentPMF = null;
-
-
}
-
-
protected void addSequenceSpecifier(SequenceSpecifier sequenceSpecifier) {
-
if (this.firstPMF == null) {
-
this.firstPMF = sequenceSpecifier.getPageMasterFactory();
-
} else {
-
this.currentPMF.setNext(sequenceSpecifier.getPageMasterFactory());
-
}
-
this.currentPMF = sequenceSpecifier.getPageMasterFactory();
-
}
-
-
protected PageMasterFactory getFirstPageMasterFactory() {
-
return this.firstPMF;
-
}
-
-
LayoutMasterSet getLayoutMasterSet() {
-
return this.layoutMasterSet;
-
}
-
-
protected void setLayoutMasterSet(LayoutMasterSet layoutMasterSet) {
-
this.layoutMasterSet = layoutMasterSet;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SequenceSpecifier.java b/src/org/apache/fop/fo/pagination/SequenceSpecifier.java
index 9e977efc9..b2f2bec0a 100644
--- a/src/org/apache/fop/fo/pagination/SequenceSpecifier.java
+++ b/src/org/apache/fop/fo/pagination/SequenceSpecifier.java
@@ -50,27 +50,14 @@
*/
package org.apache.fop.fo.pagination;
-
-
import org.apache.fop.fo.*;
-
import org.apache.fop.layout.PageMasterFactory;
-
-
abstract public class SequenceSpecifier extends FObj {
-
-
protected SequenceSpecifier(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
}
-
-
public abstract PageMasterFactory getPageMasterFactory();
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SequenceSpecifierAlternating.java b/src/org/apache/fop/fo/pagination/SequenceSpecifierAlternating.java
index 51b8a88c7..39db4482c 100644
--- a/src/org/apache/fop/fo/pagination/SequenceSpecifierAlternating.java
+++ b/src/org/apache/fop/fo/pagination/SequenceSpecifierAlternating.java
@@ -50,131 +50,66 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.PageMasterFactory;
-
import org.apache.fop.layout.AlternatingPageMasterFactory;
-
import org.apache.fop.layout.PageMaster;
-
import org.apache.fop.apps.FOPException;
-
-
public class SequenceSpecifierAlternating extends SequenceSpecifier {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SequenceSpecifierAlternating(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new SequenceSpecifierAlternating.Maker();
-
}
-
-
private SequenceSpecification sequenceSpecification;
-
private LayoutMasterSet layoutMasterSet;
-
private AlternatingPageMasterFactory pageMasterFactory;
-
-
protected SequenceSpecifierAlternating(FObj parent,
-
PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
PageMaster pf, pe, po;
-
-
this.name = "fo:sequence-specifer-alternating";
-
-
if (parent.getName().equals("fo:sequence-specification")) {
-
this.sequenceSpecification = (SequenceSpecification) parent;
-
this.layoutMasterSet = this.sequenceSpecification.getLayoutMasterSet();
-
} else {
-
throw new FOPException("fo:sequence-specifier-alternating must be "
-
+ " child of fo:sequence-specification, not "
-
+ parent.getName());
-
}
-
-
String pageMasterFirst = this.properties.get("page-master-first").getString();
-
String pageMasterOdd = this.properties.get("page-master-odd").getString();
-
String pageMasterEven = this.properties.get("page-master-even").getString();
-
-
try {
-
pf = this.layoutMasterSet.getLayoutMaster(pageMasterFirst).getPageMaster();
-
pe = this.layoutMasterSet.getLayoutMaster(pageMasterEven).getPageMaster();
-
po = this.layoutMasterSet.getLayoutMaster(pageMasterOdd).getPageMaster();
-
this.pageMasterFactory = new AlternatingPageMasterFactory(pf,pe,po);
-
} catch (java.lang.NullPointerException e) {
-
throw new FOPException("at least one of the page-master names in"
-
+ " sequence-specifier-alternating is not in"
-
+ " layout-master-set");
-
}
-
this.sequenceSpecification.addSequenceSpecifier(this);
-
}
-
-
public PageMasterFactory getPageMasterFactory() {
-
return this.pageMasterFactory;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SequenceSpecifierRepeating.java b/src/org/apache/fop/fo/pagination/SequenceSpecifierRepeating.java
index bddbac7c3..683c05670 100644
--- a/src/org/apache/fop/fo/pagination/SequenceSpecifierRepeating.java
+++ b/src/org/apache/fop/fo/pagination/SequenceSpecifierRepeating.java
@@ -50,123 +50,62 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.PageMasterFactory;
-
import org.apache.fop.layout.RepeatingPageMasterFactory;
-
import org.apache.fop.layout.PageMaster;
-
import org.apache.fop.apps.FOPException;
-
-
public class SequenceSpecifierRepeating extends SequenceSpecifier {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SequenceSpecifierRepeating(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new SequenceSpecifierRepeating.Maker();
-
}
-
-
private SequenceSpecification sequenceSpecification;
-
private LayoutMasterSet layoutMasterSet;
-
private RepeatingPageMasterFactory pageMasterFactory;
-
-
protected SequenceSpecifierRepeating(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
PageMaster pf, pr;
-
-
this.name = "fo:sequence-specifer-repeating";
-
-
if (parent.getName().equals("fo:sequence-specification")) {
-
this.sequenceSpecification = (SequenceSpecification) parent;
-
this.layoutMasterSet = this.sequenceSpecification.getLayoutMasterSet();
-
} else {
-
throw new FOPException("sequence-specifier-repeating must be "
-
+ "child of fo:sequence-specification, "
-
+ "not " + parent.getName());
-
}
-
-
String pageMasterFirst = this.properties.get("page-master-first").getString();
-
String pageMasterRepeating = this.properties.get("page-master-repeating").getString();
-
try {
-
pf = this.layoutMasterSet.getLayoutMaster(pageMasterFirst).getPageMaster();
-
pr = this.layoutMasterSet.getLayoutMaster(pageMasterRepeating).getPageMaster();
-
this.pageMasterFactory = new RepeatingPageMasterFactory(pf, pr);
-
} catch (java.lang.NullPointerException e) {
-
throw new FOPException("at least one of the page-master names in "
-
+ "sequence-specifier-repeating is not in "
-
+ "layout-master-set");
-
}
-
this.sequenceSpecification.addSequenceSpecifier(this);
-
}
-
-
public PageMasterFactory getPageMasterFactory() {
-
return this.pageMasterFactory;
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SequenceSpecifierSingle.java b/src/org/apache/fop/fo/pagination/SequenceSpecifierSingle.java
index a062f0315..d6f0129c9 100644
--- a/src/org/apache/fop/fo/pagination/SequenceSpecifierSingle.java
+++ b/src/org/apache/fop/fo/pagination/SequenceSpecifierSingle.java
@@ -50,119 +50,60 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.PageMasterFactory;
-
import org.apache.fop.layout.SinglePageMasterFactory;
-
import org.apache.fop.layout.PageMaster;
-
import org.apache.fop.apps.FOPException;
-
-
public class SequenceSpecifierSingle extends SequenceSpecifier {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SequenceSpecifierSingle(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new SequenceSpecifierSingle.Maker();
-
}
-
-
private SequenceSpecification sequenceSpecification;
-
private LayoutMasterSet layoutMasterSet;
-
private SinglePageMasterFactory pageMasterFactory;
-
-
protected SequenceSpecifierSingle(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:sequence-specifer-single";
-
-
if (parent.getName().equals("fo:sequence-specification")) {
-
this.sequenceSpecification = (SequenceSpecification) parent;
-
this.layoutMasterSet = this.sequenceSpecification.getLayoutMasterSet();
-
} else {
-
throw new FOPException("sequence-specifier-single must be "
-
+ "child of fo:sequence-specification, "
-
+ "not " + parent.getName());
-
}
-
-
String pageMasterName = this.properties.get("page-master-name").getString();
-
try {
-
this.pageMasterFactory = new SinglePageMasterFactory(this.layoutMasterSet.getLayoutMaster(pageMasterName).getPageMaster());
-
} catch (java.lang.NullPointerException e) {
-
throw new FOPException("page-master-name " +
-
pageMasterName + " must be in layout-master-set");
-
}
-
this.sequenceSpecification.addSequenceSpecifier(this);
-
}
-
-
public PageMasterFactory getPageMasterFactory() {
-
return this.pageMasterFactory;
-
}
-
-
public String getPageMasterName() {
-
return this.properties.get("page-master-name").getString();
-
}
-
}
-
diff --git a/src/org/apache/fop/fo/pagination/SimplePageMaster.java b/src/org/apache/fop/fo/pagination/SimplePageMaster.java
index 11fcffd2c..8ccfc38d0 100644
--- a/src/org/apache/fop/fo/pagination/SimplePageMaster.java
+++ b/src/org/apache/fop/fo/pagination/SimplePageMaster.java
@@ -50,179 +50,90 @@
*/
package org.apache.fop.fo.pagination;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.PageMaster;
-
import org.apache.fop.layout.Region;
-
import org.apache.fop.apps.FOPException;
-
-
public class SimplePageMaster extends FObj {
-
-
public static class Maker extends FObj.Maker {
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SimplePageMaster(parent, propertyList);
-
}
-
}
-
-
public static FObj.Maker maker() {
-
return new SimplePageMaster.Maker();
-
}
-
-
RegionBody regionBody;
-
RegionBefore regionBefore;
-
RegionAfter regionAfter;
-
-
LayoutMasterSet layoutMasterSet;
-
PageMaster pageMaster;
-
-
protected SimplePageMaster(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
super(parent, propertyList);
-
this.name = "fo:simple-page-master";
-
-
if (parent.getName().equals("fo:layout-master-set")) {
-
this.layoutMasterSet = (LayoutMasterSet) parent;
-
String pm = this.properties.get("page-master-name").getString();
-
if (pm == null) {
-
System.err.println("WARNING: simple-page-master does not have "
-
+ "a page-master-name and so is being ignored");
-
} else {
-
this.layoutMasterSet.addLayoutMaster(pm, this);
-
}
-
} else {
-
throw new FOPException("fo:simple-page-master must be child "
-
+ "of fo:layout-master-set, not "
-
+ parent.getName());
-
}
-
}
-
-
protected void end() {
-
int pageWidth = this.properties.get("page-width").getLength().mvalue();
-
int pageHeight = this.properties.get("page-height").getLength().mvalue();
-
-
int marginTop = this.properties.get("margin-top").getLength().mvalue();
-
int marginBottom = this.properties.get("margin-bottom").getLength().mvalue();
-
int marginLeft = this.properties.get("margin-left").getLength().mvalue();
-
int marginRight = this.properties.get("margin-right").getLength().mvalue();
-
-
int contentRectangleXPosition = marginLeft;
-
int contentRectangleYPosition = pageHeight - marginTop;
-
int contentRectangleWidth = pageWidth - marginLeft - marginRight;
-
int contentRectangleHeight = pageHeight - marginTop - marginBottom;
-
-
this.pageMaster = new PageMaster(pageWidth, pageHeight);
-
this.pageMaster.addBody(this.regionBody.makeRegion(contentRectangleXPosition,contentRectangleYPosition,contentRectangleWidth,contentRectangleHeight));
-
-
if (this.regionBefore != null)
-
this.pageMaster.addBefore(this.regionBefore.makeRegion(contentRectangleXPosition,contentRectangleYPosition,contentRectangleWidth,contentRectangleHeight));
-
if (this.regionAfter != null)
-
this.pageMaster.addAfter(this.regionAfter.makeRegion(contentRectangleXPosition,contentRectangleYPosition,contentRectangleWidth,contentRectangleHeight));
-
}
-
-
PageMaster getPageMaster() {
-
return this.pageMaster;
-
}
-
-
protected void setRegionAfter(RegionAfter region) {
-
this.regionAfter = region;
-
}
-
-
protected void setRegionBefore(RegionBefore region) {
-
this.regionBefore = region;
-
}
-
-
protected void setRegionBody(RegionBody region) {
-
this.regionBody = region;
-
}
-
}
-
diff --git a/src/org/apache/fop/image/BmpBwImage.java b/src/org/apache/fop/image/BmpBwImage.java
index 3885ad2a7..18830bfdd 100644
--- a/src/org/apache/fop/image/BmpBwImage.java
+++ b/src/org/apache/fop/image/BmpBwImage.java
@@ -50,217 +50,109 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
//Title: BoBoGi FOP
-
//Version:
-
//Copyright: Copyright (c) 1999
-
//Author: Sergio Botti
-
//Company: Dibe Elsag
-
//Description: xml to pdf converter
-
-
package org.apache.fop.image;
-
import java.io.FileInputStream;
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
public class BmpBwImage implements FopImage {
-
int X;
-
int Y;
-
int width;
-
int height;
-
int pixelwidth;
-
int pixelheight;
-
String ref;
-
boolean color;
-
int bitperpixel;
-
int[] imagemap;
-
int imagestart;
-
/*
-
Costructor read the header of the bmp file to get the size
-
and the other data
-
SB
-
*/
-
public BmpBwImage(String href,int x,int y,int w,int h)
-
{
-
this.ref=href;
-
this.X=x;
-
this.Y=y;
-
-
int wpos=18;
-
int hpos=22; //offset positioning for w and height in bmp files
-
int [] headermap = new int[54];
-
try{
-
FileInputStream file=new FileInputStream(ref);
-
boolean eof=false;
-
int count=0;
-
while ((!eof) && (count<54) ) {
-
int input =file.read();
-
if (input==-1)
-
eof=true;
-
else
-
headermap[count++]=input;
-
}
-
file.close();
-
}catch (IOException e) {System.err.println("Image not found");}
-
// gets h & w from headermap
-
this.pixelwidth = headermap[wpos]+headermap[wpos+1]*256+headermap[wpos+2]*256*256+headermap[wpos+3]*256*256*256;
-
this.pixelheight = headermap[hpos]+headermap[hpos+1]*256+headermap[hpos+2]*256*256+headermap[hpos+3]*256*256*256;
-
if (w==0)
-
this.width=this.pixelwidth*1000;
-
else
-
this.width=w;
-
if (h==0)
-
this.height=this.pixelheight*1000;
-
else
-
this.height=h;
-
-
this.imagestart =headermap[10]+headermap[11]*256+headermap[12]*256*256+headermap[13]*256*256*256;
-
this.bitperpixel=headermap[28];
-
}
-
-
public String gethref() { return this.ref; }
-
public int getWidth() { return this.width; }
-
public int getHeight() { return this.height; }
-
public int getpixelwidth() { return this.pixelwidth; }
-
public int getpixelheight() { return this.pixelheight; }
-
public int getX(){ return this.X; }
-
public int getY(){ return this.Y; }
-
-
public int[] getimagemap(){
-
int input;
-
int[] temp = new int[nextfourdiv(this.pixelwidth)*(this.pixelheight)];
-
try {
-
FileInputStream file = new FileInputStream(this.ref);
-
int count = 0;
-
file.skip((long) this.imagestart);
-
while ((input = file.read()) != -1) {
-
temp[count++] = input;
-
}
-
file.close();
-
} catch (IOException e) {
-
System.err.println("Image not found");
-
}
-
int[] map = new int[this.pixelheight * this.pixelwidth];
-
int k = 0;
-
for (int y = 0; y < this.pixelheight; y++) {
-
for (int x = 0; x < this.pixelwidth; x++)
-
map[k++] = temp[y * nextfourdiv(this.pixelwidth) + x];
-
}
-
return map;
-
}
-
-
public boolean getcolor(){return false;}
-
public int getbitperpixel() {return this.bitperpixel;}
-
-
private int nextfourdiv(int number) {
-
return ((number/4)+1)*4;
-
}
-
-
}
-
diff --git a/src/org/apache/fop/image/BmpColImage.java b/src/org/apache/fop/image/BmpColImage.java
index b8c21d9f0..88688cad5 100644
--- a/src/org/apache/fop/image/BmpColImage.java
+++ b/src/org/apache/fop/image/BmpColImage.java
@@ -50,253 +50,127 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
//Title: BoBoGi FOP
-
//Version:
-
//Copyright: Copyright (c) 1999
-
//Author: Sergio Botti
-
//Company: Dibe Elsag
-
//Description: xml to pdf converter
-
-
package org.apache.fop.image;
-
import java.io.FileInputStream;
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
public class BmpColImage implements FopImage {
-
int X;
-
int Y;
-
int width;
-
int height;
-
int pixelwidth;
-
int pixelheight;
-
String ref;
-
boolean color=true;
-
int bitperpixel;
-
int[] imagemap;
-
int imagestart;
-
/*
-
Costructor read the header of the bmp file to get the size
-
and the other data
-
SB
-
*/
-
public BmpColImage(String href,int x,int y,int w,int h)
-
{
-
this.ref=href;
-
this.X=x;
-
this.Y=y;
-
-
int wpos=18;
-
int hpos=22; //offset positioning for w and height in bmp files
-
int [] headermap = new int[54];
-
try{
-
FileInputStream file=new FileInputStream(ref);
-
boolean eof=false;
-
int count=0;
-
while ((!eof) && (count<54) ) {
-
int input =file.read();
-
if (input==-1)
-
eof=true;
-
else
-
headermap[count++]=input;
-
}
-
file.close();
-
}catch (IOException e) {System.err.println("Image not found");}
-
// gets h & w from headermap
-
this.pixelwidth = headermap[wpos]+headermap[wpos+1]*256+headermap[wpos+2]*256*256+headermap[wpos+3]*256*256*256;
-
this.pixelheight = headermap[hpos]+headermap[hpos+1]*256+headermap[hpos+2]*256*256+headermap[hpos+3]*256*256*256;
-
if (w==0)
-
this.width=this.pixelwidth*1000;
-
else
-
this.width=w;
-
if (h==0)
-
this.height=this.pixelheight*1000;
-
else
-
this.height=h;
-
-
this.imagestart =headermap[10]+headermap[11]*256+headermap[12]*256*256+headermap[13]*256*256*256;
-
this.bitperpixel=headermap[28];
-
}
-
-
public String gethref() { return this.ref; }
-
public int getWidth() { return this.width; }
-
public int getHeight() { return this.height; }
-
public int getpixelwidth() { return this.pixelwidth; }
-
public int getpixelheight() { return this.pixelheight; }
-
public int getX(){ return this.X; }
-
public int getY(){ return this.Y; }
-
-
public int[] getimagemap(){
-
int[] temp = new int[nextfourdiv(this.pixelwidth*3)*(this.pixelheight)];
-
try{
-
FileInputStream file=new FileInputStream(this.ref);
-
boolean eof=false;
-
int count=0;
-
file.skip((long)this.imagestart);
-
while (!eof) {
-
int input = file.read();
-
if (input==-1) {
-
eof=true;
-
} else {
-
temp[count++]=input;
-
}
-
}
-
file.close();
-
} catch (IOException e) {
-
System.err.println("Image not found");
-
}
-
-
int[] map =new int[this.pixelheight*this.pixelwidth*3];
-
int k=0;
-
-
for (int y=0;y<this.pixelheight;y++) {
-
for (int x=0;x<(this.pixelwidth);x++) {
-
map[k++]=temp[y*nextfourdiv(this.pixelwidth*3)+x*3+2];
-
map[k++]=temp[y*nextfourdiv(this.pixelwidth*3)+x*3+1];
-
map[k++]=temp[y*nextfourdiv(this.pixelwidth*3)+x*3];
-
-
//map[k++]=temp[y*nextfourdiv(this.pixelwidth*3)+x];
-
}
-
}
-
return map;
-
}
-
-
-
public boolean getcolor(){return true;}
-
public int getbitperpixel() {return this.bitperpixel;}
-
-
//
-
private int nextfourdiv(int number) {
-
int n = number;
-
while((n%4)!=0) {
-
n++;
-
}
-
return n;
-
}
-
-
}
-
diff --git a/src/org/apache/fop/image/FopImage.java b/src/org/apache/fop/image/FopImage.java
index e46286aad..c4c2f88b5 100644
--- a/src/org/apache/fop/image/FopImage.java
+++ b/src/org/apache/fop/image/FopImage.java
@@ -50,49 +50,25 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
//Title: BoBoGi FOP
-
//Version:
-
//Copyright: Copyright (c) 1999
-
//Author: Sergio Botti
-
//Company: Dibe Elsag
-
//Description: Part in xml to pdf converter
-
-
-
package org.apache.fop.image;
-
-
public interface FopImage {
-
public int getpixelwidth();
-
public int getpixelheight();
-
public int getWidth();
-
public int getHeight();
-
public int getX();
-
public int getY();
-
public String gethref();
-
public int[] getimagemap();
-
public boolean getcolor();
-
public int getbitperpixel();
-
}
-
diff --git a/src/org/apache/fop/image/FopImageFactory.java b/src/org/apache/fop/image/FopImageFactory.java
index 06b9c95ef..fe77d2277 100644
--- a/src/org/apache/fop/image/FopImageFactory.java
+++ b/src/org/apache/fop/image/FopImageFactory.java
@@ -50,95 +50,48 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
//Title: BoBoGi FOP
-
//Version: x
-
//Copyright: Copyright (c) 1999
-
//Author: Sergio Botti
-
//Company: Dibe Elsag
-
//Description: xml to pdf converter
-
-
-
package org.apache.fop.image;
-
-
import java.io.FileInputStream;
-
import java.io.IOException;
-
-
public class FopImageFactory {
-
-
public static FopImage Make(String ref,int x,int y, int width, int height) {
-
-
-
int colorpos=28; //offset positioning for w and height in bmp files
-
int [] headermap = new int[54];
-
try{
-
FileInputStream file=new FileInputStream(ref);
-
boolean eof=false;
-
int count=0;
-
while ((!eof) && (count<54) ) {
-
int input =file.read();
-
if (input==-1)
-
eof=true;
-
else
-
headermap[count++]=input;
-
}
-
file.close();
-
} catch (IOException e) {System.err.println("Image not found");}
-
int bpp=headermap[28];
-
if (bpp==8) {
-
return (new BmpBwImage(ref,x,y,width,height));
-
} else if (bpp==24) {
-
return (new BmpColImage(ref,x,y,width,height));
-
}
-
System.err.println("Unsupported bmp format");
-
-
return null;
-
-
}
-
}
-
diff --git a/src/org/apache/fop/image/GifJpegImage.java b/src/org/apache/fop/image/GifJpegImage.java
index 4d5d66e65..4928ee304 100644
--- a/src/org/apache/fop/image/GifJpegImage.java
+++ b/src/org/apache/fop/image/GifJpegImage.java
@@ -50,241 +50,121 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
//Title: BoBoGi FOP
-
//Version:
-
//Copyright: Copyright (c) 1999
-
//Author: Sergio Botti
-
//Company: Dibe Elsag
-
//Description: xml to pdf converter
-
-
-
package org.apache.fop.image;
-
-
import java.util.Hashtable;
-
import java.net.URL;
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
import java.awt.image.*;
-
import java.awt.Image;
-
import java.awt.Toolkit;
-
-
public class GifJpegImage implements FopImage {
-
int X;
-
int Y;
-
int width;
-
int height;
-
int pixelwidth;
-
int pixelheight;
-
String ref;
-
boolean color=true;
-
int bitperpixel=8;
-
int[] imagemap;
-
int[] tempmap;
-
/*
-
Costructor read the header of the bmp file to get the size
-
and the other data
-
SB
-
*/
-
-
public GifJpegImage(String href,int x,int y,int w,int h)
-
{
-
this.ref=href;
-
this.X=x;
-
this.Y=y;
-
this.pixelheight=-1;
-
this.pixelwidth=-1;
-
try {
-
URL url = new URL(href);
-
ImageProducer ip = (ImageProducer)url.getContent();
-
FopImageConsumer consumer = new FopImageConsumer();
-
ip.startProduction(consumer);
-
while ((this.pixelheight = consumer.getHeight())==-1) {}
-
while ((this.pixelwidth = consumer.getWidth())==-1) {}
-
this.tempmap = new int[this.pixelwidth*this.pixelheight];
-
//Image img=Toolkit.getDefaultToolkit().getImage("prova.gif");
-
// Image img=Toolkit.getDefaultToolkit().getImage(url);
-
PixelGrabber pg = new PixelGrabber(ip,0,0,this.pixelwidth,this.pixelheight,this.tempmap,0,w);
-
try {
-
pg.grabPixels();
-
}catch (InterruptedException e) {System.err.println("Image grabbing interrupted");}
-
} catch (ClassCastException e) {System.err.println("Image format not supported: " + href);
-
} catch (Exception e) {System.err.println("Error loading image " + href + " : " +e);
-
}
-
if (w==0)
-
this.width=this.pixelwidth*1000;
-
else
-
this.width=w;
-
if (h==0)
-
this.height=this.pixelheight*1000;
-
else
-
this.height=h;
-
}
-
//
-
public static class FopImageConsumer implements ImageConsumer {
-
int width = -1;
-
int height = -1;
-
public void imageComplete(int status) {}
-
public void setColorModel(ColorModel model) {}
-
public void setDimensions(int width, int height) {
-
this.width = width;
-
this.height = height;
-
}
-
public void setHints(int hintflags) {}
-
public void setPixels(int x, int y, int w, int h,ColorModel model, byte[] pixels,int off, int scansize) {}
-
public void setPixels(int x, int y, int w, int h,ColorModel model, int[] pixels,int off, int scansize) {}
-
public void setProperties(Hashtable props) {}
-
public int getWidth() { return this.width; }
-
public int getHeight() { return this.height; }
-
}
-
-
//
-
public String gethref() { return this.ref; }
-
public int getWidth() { return this.width; }
-
public int getHeight() { return this.height; }
-
public int getpixelwidth() { return this.pixelwidth; }
-
public int getpixelheight() { return this.pixelheight; }
-
public int getX(){ return this.X; }
-
public int getY(){ return this.Y; }
-
-
public int[] getimagemap(){
-
this.imagemap=new int[this.pixelheight*this.pixelwidth*3];
-
int count=0;
-
int i;
-
for(i=0;i<(this.pixelheight*this.pixelwidth);i++)
-
{
-
int red = ((this.tempmap[i]>>16) & 0xff);
-
int green = ((this.tempmap[i]>> 8) & 0xff);
-
int blue = ((this.tempmap[i] ) & 0xff);
-
this.imagemap[count++]=red;
-
this.imagemap[count++]=green;
-
this.imagemap[count++]=blue;
-
}
-
return imagemap;
-
}
-
-
-
public boolean getcolor(){return true;}
-
public int getbitperpixel() {return this.bitperpixel;}
-
}
-
-
-
diff --git a/src/org/apache/fop/image/ImageArea.java b/src/org/apache/fop/image/ImageArea.java
index b8edcdf0b..9ff0698e2 100644
--- a/src/org/apache/fop/image/ImageArea.java
+++ b/src/org/apache/fop/image/ImageArea.java
@@ -50,115 +50,58 @@
*/
/* modified by JKT to integrate into 0.12.0 */
-
-
package org.apache.fop.image;
-
-
import org.apache.fop.layout.*;
-
import org.apache.fop.render.Renderer;
-
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class ImageArea extends Area {
-
-
protected int xOffset = 0;
-
protected FopImage image;
-
-
public ImageArea(FontState fontState, FopImage img,
-
int AllocationWidth, int width, int height,
-
int startIndent, int endIndent, int align) {
-
super(fontState,width,height);
-
this.currentHeight = height;
-
this.contentRectangleWidth = width;
-
this.image = img;
-
-
switch (align) {
-
case 1:
-
xOffset = startIndent;
-
break;
-
case 2:
-
if (endIndent == 0)
-
endIndent = AllocationWidth;
-
xOffset = (endIndent - width);
-
break;
-
case 3:
-
case 4:
-
if (endIndent == 0)
-
endIndent = AllocationWidth;
-
xOffset = startIndent + ((endIndent - startIndent) - width)/2;
-
break;
-
}
-
}
-
-
public int getXOffset() {
-
return this.xOffset;
-
}
-
-
public FopImage getImage() {
-
return this.image;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderImageArea(this);
-
}
-
-
public int getImageHeight() {
-
return currentHeight;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/AlternatingPageMasterFactory.java b/src/org/apache/fop/layout/AlternatingPageMasterFactory.java
index 23e1739b4..d08bbdf20 100644
--- a/src/org/apache/fop/layout/AlternatingPageMasterFactory.java
+++ b/src/org/apache/fop/layout/AlternatingPageMasterFactory.java
@@ -50,83 +50,42 @@
*/
package org.apache.fop.layout;
-
-
public class AlternatingPageMasterFactory extends PageMasterFactory {
-
-
private PageMaster pageMasterFirst;
-
private PageMaster pageMasterEven;
-
private PageMaster pageMasterOdd;
-
-
private static final int FIRST = 0;
-
private static final int EVEN = 1;
-
private static final int ODD = 2;
-
-
private int state;
-
-
public AlternatingPageMasterFactory(PageMaster first, PageMaster even, PageMaster odd) {
-
this.pageMasterFirst = first;
-
this.pageMasterEven = even;
-
this.pageMasterOdd = odd;
-
this.state = FIRST;
-
}
-
-
public int getHeight() {
-
return this.pageMasterFirst.getHeight();
-
}
-
-
public PageMaster getNextPageMaster() {
-
PageMaster pm;
-
-
switch (this.state) {
-
case EVEN: pm = this.pageMasterEven; this.state = ODD; break;
-
case ODD: pm = this.pageMasterOdd; this.state = EVEN; break;
-
default: pm = this.pageMasterFirst; this.state = EVEN;
-
}
-
-
return pm;
-
}
-
-
public int getWidth() {
-
return this.pageMasterFirst.getWidth();
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/Area.java b/src/org/apache/fop/layout/Area.java
index a0b4281a6..0849b2ba4 100644
--- a/src/org/apache/fop/layout/Area.java
+++ b/src/org/apache/fop/layout/Area.java
@@ -50,207 +50,104 @@
*/
package org.apache.fop.layout;
-
-
// Java
-
import java.util.Vector;
-
-
abstract public class Area extends Box {
-
-
/* nominal font size and nominal font family incorporated in
-
fontState */
-
protected FontState fontState;
-
-
protected Vector children = new Vector();
-
-
/* max size in line-progression-direction */
-
protected int maxHeight;
-
-
protected int currentHeight = 0;
-
-
protected int contentRectangleWidth;
-
-
protected int allocationWidth;
-
-
/* the inner-most area container the area is in */
-
protected AreaContainer areaContainer;
-
-
/* the page this area is on */
-
protected Page page;
-
-
public Area (FontState fontState) {
-
this.fontState = fontState;
-
}
-
-
public Area (FontState fontState, int allocationWidth, int maxHeight) {
-
this.fontState = fontState;
-
this.allocationWidth = allocationWidth;
-
this.maxHeight = maxHeight;
-
}
-
-
public void addChild(Box child) {
-
this.children.addElement(child);
-
child.parent = this;
-
}
-
-
public void addChildAtStart(Box child) {
-
this.children.insertElementAt(child,0);
-
child.parent = this;
-
}
-
-
public void addDisplaySpace(int size) {
-
this.addChild(new DisplaySpace(size));
-
this.currentHeight += size;
-
}
-
-
public FontInfo getFontInfo() {
-
return this.page.getFontInfo();
-
}
-
-
public void end() {
-
}
-
-
public int getAllocationWidth() {
-
return this.allocationWidth;
-
}
-
-
public Vector getChildren() {
-
return this.children;
-
}
-
-
public int getContentWidth() {
-
return this.contentRectangleWidth;
-
}
-
-
public FontState getFontState() {
-
return this.fontState;
-
}
-
-
public int getHeight() {
-
return this.currentHeight;
-
}
-
-
public int getMaxHeight() {
-
return this.maxHeight;
-
}
-
-
public Page getPage() {
-
return this.page;
-
}
-
-
public void increaseHeight(int amount) {
-
this.currentHeight += amount;
-
}
-
-
public void setPage(Page page) {
-
this.page = page;
-
}
-
-
public int spaceLeft() {
-
return maxHeight - currentHeight;
-
}
-
-
public void start() {
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/AreaContainer.java b/src/org/apache/fop/layout/AreaContainer.java
index 30182f4d6..af39677cf 100644
--- a/src/org/apache/fop/layout/AreaContainer.java
+++ b/src/org/apache/fop/layout/AreaContainer.java
@@ -50,65 +50,33 @@
*/
package org.apache.fop.layout;
-
-
// FOP
-
import org.apache.fop.render.Renderer;
-
-
// Java
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class AreaContainer extends Area {
-
-
private int xPosition; // should be able to take value 'left' and 'right' too
-
private int yPosition; // should be able to take value 'top' and 'bottom' too
-
-
AreaContainer(int xPosition, int yPosition, int allocationWidth, int maxHeight) {
-
super(null, allocationWidth, maxHeight);
-
this.xPosition = xPosition;
-
this.yPosition = yPosition;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderAreaContainer(this);
-
}
-
-
public int getXPosition() {
-
return xPosition;
-
}
-
-
public int getYPosition() {
-
return yPosition;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/AreaTree.java b/src/org/apache/fop/layout/AreaTree.java
index 6f0ba0bdd..b0bc7159e 100644
--- a/src/org/apache/fop/layout/AreaTree.java
+++ b/src/org/apache/fop/layout/AreaTree.java
@@ -50,81 +50,41 @@
*/
package org.apache.fop.layout;
-
-
// FOP
-
import org.apache.fop.apps.FOPException;
-
import org.apache.fop.fo.flow.StaticContent;
-
import org.apache.fop.svg.*;
-
import org.apache.fop.render.Renderer;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
import java.util.Enumeration;
-
import java.util.Stack;
-
import java.util.Vector;
-
-
public class AreaTree {
-
-
/** object containing information on available fonts, including
-
metrics */
-
FontInfo fontInfo;
-
-
/* list of all the pages */
-
Vector pageList = new Vector();
-
-
public void setFontInfo(FontInfo fontInfo) {
-
this.fontInfo = fontInfo;
-
}
-
-
public FontInfo getFontInfo() {
-
return this.fontInfo;
-
}
-
-
public void addPage(Page page) {
-
this.pageList.addElement(page);
-
}
-
-
public Vector getPages() {
-
return this.pageList;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/BlockArea.java b/src/org/apache/fop/layout/BlockArea.java
index ded113146..a9242bbbb 100644
--- a/src/org/apache/fop/layout/BlockArea.java
+++ b/src/org/apache/fop/layout/BlockArea.java
@@ -50,265 +50,133 @@
*/
package org.apache.fop.layout;
-
-
// FOP
-
import org.apache.fop.render.Renderer;
-
-
// Java
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class BlockArea extends Area {
-
-
/* relative to area container */
-
protected int startIndent;
-
protected int endIndent;
-
-
/* first line startIndent modifier */
-
protected int textIndent;
-
-
protected int lineHeight;
-
-
protected int halfLeading;
-
-
/* text-align of all but the last line */
-
protected int align;
-
-
/* text-align of the last line */
-
protected int alignLastLine;
-
-
protected LineArea currentLineArea;
-
-
/* have any line areas been used? */
-
protected boolean hasLines = false;
-
-
public BlockArea(FontState fontState, int allocationWidth,
-
int maxHeight, int startIndent, int endIndent,
-
int textIndent, int align, int alignLastLine,
-
int lineHeight) {
-
super(fontState, allocationWidth, maxHeight);
-
-
this.startIndent = startIndent;
-
this.endIndent = endIndent;
-
this.textIndent = textIndent;
-
this.contentRectangleWidth = allocationWidth - startIndent - endIndent;
-
this.align = align;
-
this.alignLastLine = alignLastLine;
-
this.lineHeight = lineHeight;
-
-
this.halfLeading = (lineHeight - fontState.getFontSize())/2;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderBlockArea(this);
-
}
-
-
public void addLineArea(LineArea la) {
-
if (!la.isEmpty()) {
-
this.addDisplaySpace(this.halfLeading);
-
int size = la.getHeight();
-
this.addChild(la);
-
this.increaseHeight(size);
-
this.addDisplaySpace(this.halfLeading);
-
}
-
}
-
-
public int addText(FontState fontState, float red, float green,
-
float blue, int wrapOption,
-
int whiteSpaceTreatment, char data[],
-
int start, int end) {
-
int ts, te;
-
char[] ca;
-
-
ts = start;
-
te = end;
-
ca = data;
-
-
if (currentHeight + currentLineArea.getHeight() > maxHeight) {
-
return start;
-
}
-
-
this.currentLineArea.changeFont(fontState);
-
this.currentLineArea.changeColor(red, green, blue);
-
this.currentLineArea.changeWrapOption(wrapOption);
-
this.currentLineArea.changeWhiteSpaceTreatment(whiteSpaceTreatment);
-
ts = this.currentLineArea.addText(ca, ts, te);
-
this.hasLines = true;
-
-
while (ts != -1) {
-
this.currentLineArea.align(this.align);
-
this.addLineArea(this.currentLineArea);
-
this.currentLineArea = new
-
LineArea(fontState, lineHeight, halfLeading,
-
allocationWidth, startIndent, endIndent);
-
if (currentHeight + currentLineArea.getHeight() >
-
this.maxHeight) {
-
return ts;
-
}
-
this.currentLineArea.changeFont(fontState);
-
this.currentLineArea.changeColor(red, green, blue);
-
this.currentLineArea.changeWrapOption(wrapOption);
-
this.currentLineArea.changeWhiteSpaceTreatment(whiteSpaceTreatment);
-
ts = this.currentLineArea.addText(ca, ts, te);
-
}
-
return -1;
-
}
-
-
public void end() {
-
if (this.hasLines) {
-
this.currentLineArea.addPending();
-
this.currentLineArea.align(this.alignLastLine);
-
this.addLineArea(this.currentLineArea);
-
}
-
}
-
-
public void start() {
-
currentLineArea = new LineArea(fontState, lineHeight,
-
halfLeading, allocationWidth,
-
startIndent + textIndent,
-
endIndent);
-
}
-
-
public int getEndIndent() {
-
return endIndent;
-
}
-
-
public int getStartIndent() {
-
return startIndent;
-
}
-
-
public int spaceLeft() {
-
return maxHeight - currentHeight;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/Box.java b/src/org/apache/fop/layout/Box.java
index e02193bef..c71724247 100644
--- a/src/org/apache/fop/layout/Box.java
+++ b/src/org/apache/fop/layout/Box.java
@@ -50,19 +50,10 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
abstract public class Box {
-
protected Area parent;
-
protected AreaTree areaTree;
-
abstract public void render(Renderer renderer);
-
}
-
diff --git a/src/org/apache/fop/layout/DisplaySpace.java b/src/org/apache/fop/layout/DisplaySpace.java
index 5cc50fbf4..abb439573 100644
--- a/src/org/apache/fop/layout/DisplaySpace.java
+++ b/src/org/apache/fop/layout/DisplaySpace.java
@@ -50,37 +50,19 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
public class DisplaySpace extends Space {
-
private int size;
-
-
public DisplaySpace(int size) {
-
this.size = size;
-
}
-
public int getSize() {
-
return size;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderDisplaySpace(this);
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/FontInfo.java b/src/org/apache/fop/layout/FontInfo.java
index dc6d778fb..e651baa2a 100644
--- a/src/org/apache/fop/layout/FontInfo.java
+++ b/src/org/apache/fop/layout/FontInfo.java
@@ -50,155 +50,78 @@
*/
package org.apache.fop.layout;
-
-
import java.util.Hashtable;
-
import java.util.Enumeration;
-
-
import org.apache.fop.apps.FOPException;
-
-
public class FontInfo {
-
-
Hashtable triplets; // look up a font-triplet to find a font-name
-
Hashtable fonts; // look up a font-name to get a font (that implements FontMetric at least)
-
-
public FontInfo() {
-
this.triplets = new Hashtable();
-
this.fonts = new Hashtable();
-
}
-
-
public void addFontProperties(String name, String family, String style, String weight) {
-
/* add the given family, style and weight as a lookup for the font
-
with the given name */
-
-
String key = family + "," + style + "," + weight;
-
this.triplets.put(key,name);
-
}
-
-
public void addMetrics(String name, FontMetric metrics) {
-
// add the given metrics as a font with the given name
-
-
this.fonts.put(name,metrics);
-
}
-
-
public String fontLookup(String family, String style, String weight) throws FOPException {
-
// given a family, style and weight, return the font name
-
int i;
-
-
try {
-
i = Integer.parseInt(weight);
-
} catch (NumberFormatException e) {
-
i = 0;
-
}
-
-
if (i > 600)
-
weight = "bold";
-
else if (i > 0)
-
weight = "normal";
-
-
String key = family + "," + style + "," + weight;
-
-
String f = (String)this.triplets.get(key);
-
if (f == null) {
-
f = (String)this.triplets.get("any," + style + "," + weight);
-
if (f == null) {
-
f = (String)this.triplets.get("any,normal,normal");
-
if (f == null) {
-
throw new FOPException("no default font defined by OutputConverter");
-
}
-
System.err.println("WARNING: defaulted font to any,normal,normal");
-
}
-
System.err.println("WARNING: unknown font "+family+" so defaulted font to any");
-
}
-
return f;
-
}
-
-
public Hashtable getFonts() {
-
return this.fonts;
-
}
-
-
public FontMetric getMetricsFor(String fontName) throws FOPException {
-
return (FontMetric)fonts.get(fontName);
-
}
-
-
public FontMetric getMetricsFor(String family, String style, String weight) throws FOPException {
-
// given a family, style and weight, return the metric
-
-
return (FontMetric)fonts.get(fontLookup(family,style,weight));
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/FontMetric.java b/src/org/apache/fop/layout/FontMetric.java
index 3ef8f6436..68398b0a9 100644
--- a/src/org/apache/fop/layout/FontMetric.java
+++ b/src/org/apache/fop/layout/FontMetric.java
@@ -50,35 +50,18 @@
*/
package org.apache.fop.layout;
-
-
/**
-
* interface for font metric classes
-
*/
-
public interface FontMetric {
-
int getAscender();
-
int getCapHeight();
-
int getDescender();
-
int getXHeight();
-
-
/**
-
* return width (in 1/1000ths of point size) of character at
-
* code point i
-
*/
-
public int width(int i);
-
}
-
diff --git a/src/org/apache/fop/layout/FontState.java b/src/org/apache/fop/layout/FontState.java
index 4dbdaa7b1..12abcea13 100644
--- a/src/org/apache/fop/layout/FontState.java
+++ b/src/org/apache/fop/layout/FontState.java
@@ -50,123 +50,62 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.apps.FOPException;
-
-
public class FontState {
-
-
protected FontInfo fontInfo;
-
private String fontName;
-
private int fontSize;
-
private String fontFamily;
-
private String fontStyle;
-
private String fontWeight;
-
private FontMetric metric;
-
-
public FontState(FontInfo fontInfo, String fontFamily, String fontStyle, String fontWeight, int fontSize) throws FOPException {
-
this.fontInfo = fontInfo;
-
this.fontFamily = fontFamily;
-
this.fontStyle = fontStyle;
-
this.fontWeight = fontWeight;
-
this.fontSize = fontSize;
-
this.fontName = fontInfo.fontLookup(fontFamily,fontStyle,fontWeight);
-
this.metric = fontInfo.getMetricsFor(fontName);
-
}
-
-
public int getAscender() {
-
return fontSize * metric.getAscender() / 1000;
-
}
-
-
public int getCapHeight() {
-
return fontSize * metric.getCapHeight() / 1000;
-
}
-
-
public int getDescender() {
-
return fontSize * metric.getDescender() / 1000;
-
}
-
-
public String getFontName() {
-
return this.fontName;
-
}
-
-
public int getFontSize() {
-
return this.fontSize;
-
}
-
-
public String getFontWeight() {
-
return this.fontWeight;
-
}
-
-
public FontInfo getFontInfo() {
-
return this.fontInfo;
-
}
-
-
public int getXHeight() {
-
return fontSize * metric.getXHeight() / 1000;
-
}
-
-
public int width(int charnum) {
-
// returns width of given character number in millipoints
-
return (fontSize * metric.width(charnum) / 1000);
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/InlineArea.java b/src/org/apache/fop/layout/InlineArea.java
index 37bff3339..239270a7a 100644
--- a/src/org/apache/fop/layout/InlineArea.java
+++ b/src/org/apache/fop/layout/InlineArea.java
@@ -50,77 +50,39 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
public class InlineArea extends Area {
-
-
private String text;
-
private float red, green, blue;
-
-
public InlineArea(FontState fontState, float red, float green, float blue, String text, int width) {
-
super(fontState);
-
this.red = red;
-
this.green = green;
-
this.blue = blue;
-
this.text = text;
-
this.contentRectangleWidth = width;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderInlineArea(this);
-
}
-
-
public float getBlue() {
-
return this.blue;
-
}
-
-
public float getGreen() {
-
return this.green;
-
}
-
-
public float getRed() {
-
return this.red;
-
}
-
-
public String getText() {
-
return this.text;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/InlineSpace.java b/src/org/apache/fop/layout/InlineSpace.java
index 2fc059832..4ff64cd43 100644
--- a/src/org/apache/fop/layout/InlineSpace.java
+++ b/src/org/apache/fop/layout/InlineSpace.java
@@ -50,47 +50,24 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
public class InlineSpace extends Space {
-
private int size; // in millipoints
-
-
public InlineSpace(int amount) {
-
this.size = amount;
-
}
-
-
public int getSize() {
-
return size;
-
}
-
-
public void setSize(int amount) {
-
this.size = amount;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderInlineSpace(this);
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/LineArea.java b/src/org/apache/fop/layout/LineArea.java
index ff2b4e2f9..c2993f38e 100644
--- a/src/org/apache/fop/layout/LineArea.java
+++ b/src/org/apache/fop/layout/LineArea.java
@@ -50,803 +50,402 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
import org.apache.fop.fo.properties.WrapOption; // for enumerated
-
// values
-
import org.apache.fop.fo.properties.WhiteSpaceTreatment; // for
-
// enumerated values
-
import org.apache.fop.fo.properties.TextAlign; // for enumerated
-
// values
-
import org.apache.fop.fo.properties.TextAlignLast; // for enumerated
-
// values
-
-
public class LineArea extends Area {
-
-
protected int lineHeight;
-
protected int halfLeading;
-
protected int nominalFontSize;
-
protected int nominalGlyphHeight;
-
-
protected int allocationHeight;
-
protected int startIndent;
-
protected int endIndent;
-
-
private int placementOffset;
-
-
private FontState currentFontState; // not the nominal, which is
-
// in this.fontState
-
private float red, green, blue;
-
private int wrapOption;
-
private int whiteSpaceTreatment;
-
-
/* the width of text that has definitely made it into the line
-
area */
-
protected int finalWidth = 0;
-
-
/* the width of the current word so far */
-
protected int wordWidth = 0;
-
-
/* values that prev (below) may take */
-
protected static final int NOTHING = 0;
-
protected static final int WHITESPACE = 1;
-
protected static final int TEXT = 2;
-
-
/* the character type of the previous character */
-
protected int prev = NOTHING;
-
-
/* the position in data[] of the start of the current word */
-
protected int wordStart;
-
-
/* the length (in characters) of the current word */
-
protected int wordLength = 0;
-
-
/* width of spaces before current word */
-
protected int spaceWidth = 0;
-
-
/* the inline areas that have not yet been added to the line
-
because subsequent characters to come (in a different addText)
-
may be part of the same word */
-
protected Vector pendingAreas = new Vector();
-
-
/* the width of the pendingAreas */
-
protected int pendingWidth = 0;
-
-
public LineArea(FontState fontState, int lineHeight, int
-
halfLeading, int allocationWidth, int startIndent,
-
int endIndent) {
-
super(fontState);
-
-
this.currentFontState = fontState;
-
this.lineHeight = lineHeight;
-
this.nominalFontSize = fontState.getFontSize();
-
this.nominalGlyphHeight = fontState.getAscender() -
-
fontState.getDescender();
-
-
this.placementOffset = fontState.getAscender();
-
this.contentRectangleWidth = allocationWidth - startIndent -
-
endIndent;
-
this.fontState = fontState;
-
-
this.allocationHeight = this.nominalGlyphHeight;
-
this.halfLeading = this.lineHeight - this.allocationHeight;
-
-
this.startIndent = startIndent;
-
this.endIndent = endIndent;
-
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderLineArea(this);
-
}
-
-
public int addText(char data[], int start, int end) {
-
boolean overrun = false;
-
-
wordStart = start;
-
wordLength = 0;
-
wordWidth = 0;
-
-
/* iterate over each character */
-
for (int i = start; i < end; i++) {
-
int charWidth;
-
/* get the character */
-
char c = data[i];
-
-
if (c > 127) {
-
/* this class shouldn't be hard coded */
-
char d =
-
org.apache.fop.render.pdf.CodePointMapping.map[c];
-
if (d != 0) {
-
c = data[i] = d;
-
} else {
-
System.err.print("ch"
-
+ (int)c + "?");
-
c = data[i] = '#';
-
}
-
}
-
-
charWidth = currentFontState.width(c);
-
-
if ((c == ' ') ||
-
(c == '\n') ||
-
(c == '\r') ||
-
(c == '\t')) { // whitespace
-
-
if (prev == WHITESPACE) {
-
-
// if current & previous are WHITESPACE
-
-
if (this.whiteSpaceTreatment ==
-
WhiteSpaceTreatment.PRESERVE) {
-
if (c == ' ') {
-
spaceWidth += currentFontState.width(32);
-
} else if (c == '\n') {
-
// force line break
-
return i;
-
} else if (c == '\t') {
-
spaceWidth += 8 * currentFontState.width(32);
-
}
-
} // else ignore it
-
-
} else if (prev == TEXT) {
-
-
// if current is WHITESPACE and previous TEXT
-
-
// the current word made it, so
-
-
// add the space before the current word (if there
-
// was some)
-
-
if (spaceWidth > 0) {
-
addChild(new InlineSpace(spaceWidth));
-
finalWidth += spaceWidth;
-
spaceWidth = 0;
-
}
-
-
// add any pending areas
-
-
Enumeration e = pendingAreas.elements();
-
while (e.hasMoreElements()) {
-
InlineArea inlineArea = (InlineArea) e.nextElement();
-
addChild(inlineArea);
-
}
-
finalWidth += pendingWidth;
-
-
// reset pending areas array
-
pendingWidth = 0;
-
pendingAreas = new Vector();
-
-
// add the current word
-
-
if (wordLength > 0) {
-
addChild(new InlineArea(currentFontState,
-
this.red, this.green,
-
this.blue, new
-
String(data, wordStart,
-
wordLength),
-
wordWidth));
-
finalWidth += wordWidth;
-
-
// reset word width
-
wordWidth = 0;
-
}
-
-
// deal with this new whitespace following the
-
// word we just added
-
-
prev = WHITESPACE;
-
-
if (this.whiteSpaceTreatment ==
-
WhiteSpaceTreatment.IGNORE) {
-
// do nothing
-
} else {
-
spaceWidth = currentFontState.width(32);
-
}
-
if (this.whiteSpaceTreatment ==
-
WhiteSpaceTreatment.PRESERVE) {
-
if (c == '\n') {
-
// force a line break
-
return i;
-
} else if (c == '\t') {
-
spaceWidth = currentFontState.width(32);
-
}
-
}
-
-
} else {
-
-
// if current is WHITESPACE and no previous
-
-
if (this.whiteSpaceTreatment ==
-
WhiteSpaceTreatment.PRESERVE) {
-
prev = WHITESPACE;
-
spaceWidth = currentFontState.width(32);
-
} else {
-
// skip over it
-
start++;
-
}
-
}
-
-
} else { // current is TEXT
-
-
if (prev == WHITESPACE) {
-
-
// if current is TEXT and previous WHITESPACE
-
-
wordWidth = charWidth;
-
if ((finalWidth + spaceWidth + wordWidth) >
-
this.contentRectangleWidth) {
-
if (overrun)
-
System.err.print(">");
-
if (this.wrapOption == WrapOption.WRAP)
-
return i;
-
}
-
prev = TEXT;
-
wordStart = i;
-
wordLength = 1;
-
} else if (prev == TEXT) {
-
wordLength++;
-
wordWidth += charWidth;
-
} else { // nothing previous
-
prev = TEXT;
-
wordStart = i;
-
wordLength = 1;
-
wordWidth = charWidth;
-
}
-
-
if ((finalWidth + spaceWidth + pendingWidth + wordWidth) >
-
this.contentRectangleWidth) {
-
-
// BREAK MID WORD
-
if (wordStart == start) { // if couldn't even fit
-
// first word
-
overrun = true;
-
// if not at start of line, return word start
-
// to try again on a new line
-
if (finalWidth > 0) {
-
return wordStart;
-
}
-
} else if (this.wrapOption == WrapOption.WRAP) {
-
return wordStart;
-
}
-
}
-
-
}
-
} // end of iteration over text
-
-
if (prev == TEXT) {
-
pendingAreas.addElement(new InlineArea(currentFontState, this.red,
-
this.green, this.blue, new
-
String(data, wordStart,
-
wordLength), wordWidth));
-
pendingWidth += wordWidth;
-
wordWidth = 0;
-
}
-
-
if (overrun)
-
System.err.print(">");
-
return -1;
-
}
-
-
public void addPending() {
-
if (spaceWidth > 0) {
-
addChild(new InlineSpace(spaceWidth));
-
finalWidth += spaceWidth;
-
spaceWidth = 0;
-
}
-
-
Enumeration e = pendingAreas.elements();
-
while (e.hasMoreElements()) {
-
InlineArea inlineArea = (InlineArea) e.nextElement();
-
addChild(inlineArea);
-
}
-
finalWidth += pendingWidth;
-
-
// reset pending areas array
-
pendingWidth = 0;
-
pendingAreas = new Vector();
-
}
-
-
public void align(int type) {
-
int padding;
-
-
switch (type) {
-
case TextAlign.START: // left
-
padding = this.contentRectangleWidth - finalWidth;
-
endIndent += padding;
-
break;
-
case TextAlign.END: // right
-
padding = this.contentRectangleWidth - finalWidth;
-
startIndent += padding;
-
break;
-
case TextAlign.CENTERED: // center
-
padding = (this.contentRectangleWidth - finalWidth)/2;
-
startIndent += padding;
-
endIndent += padding;
-
break;
-
case TextAlign.JUSTIFIED: // justify
-
Vector spaceList = new Vector();
-
-
int spaceCount = 0;
-
Enumeration e = children.elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box)e.nextElement();
-
if (b instanceof InlineSpace) {
-
InlineSpace space = (InlineSpace)b;
-
spaceList.addElement(space);
-
spaceCount++;
-
}
-
}
-
if (spaceCount > 0) {
-
padding = (this.contentRectangleWidth - finalWidth) /
-
spaceCount;
-
} else { // no spaces
-
padding = 0;
-
}
-
Enumeration f = spaceList.elements();
-
while (f.hasMoreElements()) {
-
InlineSpace space2 = (InlineSpace)f.nextElement();
-
int i = space2.getSize();
-
space2.setSize(i + padding);
-
}
-
}
-
}
-
-
public void changeColor(float red, float green, float blue) {
-
this.red = red;
-
this.green = green;
-
this.blue = blue;
-
}
-
-
public void changeFont(FontState fontState) {
-
this.currentFontState = fontState;
-
}
-
-
public void changeWhiteSpaceTreatment(int whiteSpaceTreatment) {
-
this.whiteSpaceTreatment = whiteSpaceTreatment;
-
}
-
-
public void changeWrapOption(int wrapOption) {
-
this.wrapOption = wrapOption;
-
}
-
-
public int getEndIndent() {
-
return endIndent;
-
}
-
-
public int getHeight() {
-
return this.allocationHeight;
-
}
-
-
public int getPlacementOffset() {
-
return this.placementOffset;
-
}
-
-
public int getStartIndent() {
-
return startIndent;
-
}
-
-
public boolean isEmpty() {
-
return (prev==0);
-
}
-
-
public Vector getPendingAreas() {
-
return pendingAreas;
-
}
-
-
public int getPendingWidth() {
-
return pendingWidth;
-
}
-
-
public void setPendingAreas(Vector areas) {
-
pendingAreas = areas;
-
}
-
-
public void setPendingWidth(int width) {
-
pendingWidth = width;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/Page.java b/src/org/apache/fop/layout/Page.java
index beedcda4f..c283b0d5c 100644
--- a/src/org/apache/fop/layout/Page.java
+++ b/src/org/apache/fop/layout/Page.java
@@ -50,183 +50,92 @@
*/
package org.apache.fop.layout;
-
-
// FOP
-
import org.apache.fop.render.Renderer;
-
-
// Java
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class Page {
-
-
private int height;
-
private int width;
-
-
private AreaContainer body;
-
private AreaContainer before;
-
private AreaContainer after;
-
private AreaContainer start;
-
private AreaContainer end;
-
-
private AreaTree areaTree;
-
-
protected int pageNumber = 0;
-
-
Page(AreaTree areaTree, int height, int width) {
-
this.areaTree = areaTree;
-
this.height = height;
-
this.width = width;
-
}
-
-
public void setNumber(int number) {
-
this.pageNumber = number;
-
}
-
-
public int getNumber() {
-
return this.pageNumber;
-
}
-
-
void addAfter(AreaContainer area) {
-
this.after = area;
-
area.setPage(this);
-
}
-
-
void addBefore(AreaContainer area) {
-
this.before = area;
-
area.setPage(this);
-
}
-
-
void addBody(AreaContainer area) {
-
this.body = area;
-
area.setPage(this);
-
}
-
-
void addEnd(AreaContainer area) {
-
this.end = area;
-
area.setPage(this);
-
}
-
-
void addStart(AreaContainer area) {
-
this.start = area;
-
area.setPage(this);
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderPage(this);
-
}
-
-
public AreaContainer getAfter() {
-
return this.after;
-
}
-
-
public AreaContainer getBefore() {
-
return this.before;
-
}
-
-
public AreaContainer getBody() {
-
return this.body;
-
}
-
-
public int getHeight() {
-
return this.height;
-
}
-
-
public int getWidth() {
-
return this.width;
-
}
-
-
public FontInfo getFontInfo() {
-
return this.areaTree.getFontInfo();
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/PageMaster.java b/src/org/apache/fop/layout/PageMaster.java
index 3b44785ae..67ca59b5a 100644
--- a/src/org/apache/fop/layout/PageMaster.java
+++ b/src/org/apache/fop/layout/PageMaster.java
@@ -50,133 +50,67 @@
*/
package org.apache.fop.layout;
-
-
public class PageMaster {
-
-
private int width;
-
private int height;
-
-
private Region body;
-
private Region before;
-
private Region after;
-
private Region start;
-
private Region end;
-
-
public PageMaster(int pageWidth, int pageHeight) {
-
this.width = pageWidth;
-
this.height = pageHeight;
-
}
-
-
public void addAfter(Region region) {
-
this.after = region;
-
}
-
-
public void addBefore(Region region) {
-
this.before = region;
-
}
-
-
public void addBody(Region region) {
-
this.body = region;
-
}
-
-
public void addEnd(Region region) {
-
this.end = region;
-
}
-
-
public void addStart(Region region) {
-
this.start = region;
-
}
-
-
public int getHeight() {
-
return this.height;
-
}
-
-
public int getWidth() {
-
return this.width;
-
}
-
-
public Page makePage(AreaTree areaTree) {
-
Page p = new Page(areaTree, this.height, this.width);
-
if (this.body != null) {
-
p.addBody(body.makeAreaContainer());
-
}
-
if (this.before != null) {
-
p.addBefore(before.makeAreaContainer());
-
}
-
if (this.after != null) {
-
p.addAfter(after.makeAreaContainer());
-
}
-
if (this.start != null) {
-
p.addStart(start.makeAreaContainer());
-
}
-
if (this.end != null) {
-
p.addEnd(end.makeAreaContainer());
-
}
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/PageMasterFactory.java b/src/org/apache/fop/layout/PageMasterFactory.java
index e7499f78a..1339d9645 100644
--- a/src/org/apache/fop/layout/PageMasterFactory.java
+++ b/src/org/apache/fop/layout/PageMasterFactory.java
@@ -50,41 +50,21 @@
*/
package org.apache.fop.layout;
-
-
abstract public class PageMasterFactory {
-
-
private PageMasterFactory next;
-
-
abstract public int getHeight();
-
-
abstract public int getWidth();
-
-
public PageMasterFactory getNext() {
-
return this.next;
-
}
-
-
abstract public PageMaster getNextPageMaster();
-
-
public void setNext(PageMasterFactory pmf) {
-
this.next = pmf;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/Region.java b/src/org/apache/fop/layout/Region.java
index e40891e06..0e4ed529a 100644
--- a/src/org/apache/fop/layout/Region.java
+++ b/src/org/apache/fop/layout/Region.java
@@ -50,41 +50,21 @@
*/
package org.apache.fop.layout;
-
-
public class Region {
-
-
private int xPosition;
-
private int yPosition;
-
private int width;
-
private int height;
-
-
public Region(int xPosition, int yPosition, int width, int height) {
-
this.xPosition = xPosition;
-
this.yPosition = yPosition;
-
this.width = width;
-
this.height = height;
-
}
-
-
public AreaContainer makeAreaContainer() {
-
return new AreaContainer(xPosition, yPosition, width, height);
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/RepeatingPageMasterFactory.java b/src/org/apache/fop/layout/RepeatingPageMasterFactory.java
index 51a38ec6e..a0f84ccf6 100644
--- a/src/org/apache/fop/layout/RepeatingPageMasterFactory.java
+++ b/src/org/apache/fop/layout/RepeatingPageMasterFactory.java
@@ -50,75 +50,38 @@
*/
package org.apache.fop.layout;
-
-
public class RepeatingPageMasterFactory extends PageMasterFactory {
-
-
private PageMaster pageMasterFirst;
-
private PageMaster pageMasterRepeating;
-
-
private static final int FIRST = 0;
-
private static final int REST = 1;
-
-
private int state;
-
-
public RepeatingPageMasterFactory(PageMaster first, PageMaster repeating) {
-
this.pageMasterFirst = first;
-
this.pageMasterRepeating = repeating;
-
this.state = FIRST;
-
}
-
-
public int getHeight() {
-
return this.pageMasterFirst.getHeight();
-
}
-
-
public PageMaster getNextPageMaster() {
-
PageMaster pm;
-
-
switch (this.state) {
-
case REST: pm = this.pageMasterRepeating; this.state = REST; break;
-
default: pm = this.pageMasterFirst; this.state = REST;
-
}
-
-
return pm;
-
}
-
-
public int getWidth() {
-
return this.pageMasterFirst.getWidth();
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/RuleArea.java b/src/org/apache/fop/layout/RuleArea.java
index 26c8fee0b..5c8c19d26 100644
--- a/src/org/apache/fop/layout/RuleArea.java
+++ b/src/org/apache/fop/layout/RuleArea.java
@@ -50,119 +50,60 @@
*/
package org.apache.fop.layout;
-
-
import org.apache.fop.render.Renderer;
-
-
import java.util.Vector;
-
import java.util.Enumeration;
-
-
public class RuleArea extends Area {
-
-
int align; // text-align
-
int length; // length in millipoints
-
int ruleThickness;
-
-
int startIndent;
-
int endIndent;
-
-
float red, green, blue;
-
public RuleArea(FontState fontState, int allocationWidth, int maxHeight, int startIndent, int endIndent, int align, int ruleThickness, int length, float red, float green, float blue) {
-
super(fontState,allocationWidth,maxHeight);
-
-
this.contentRectangleWidth = allocationWidth - startIndent - endIndent;
-
this.align = align;
-
-
this.startIndent = startIndent;
-
this.endIndent = endIndent;
-
this.ruleThickness = ruleThickness;
-
this.length = length;
-
this.currentHeight = maxHeight;
-
-
this.red = red;
-
this.green = green;
-
this.blue = blue;
-
}
-
-
public void render(Renderer renderer) {
-
renderer.renderRuleArea(this);
-
}
-
public float getBlue() {
-
return this.blue;
-
}
-
public int getEndIndent() {
-
return endIndent;
-
}
-
public float getGreen() {
-
return this.green;
-
}
-
public int getHeight() {
-
return this.ruleThickness;
-
}
-
public float getRed() {
-
return this.red;
-
}
-
public int getRuleThickness() {
-
return this.ruleThickness;
-
}
-
public int getStartIndent() {
-
return startIndent;
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/SinglePageMasterFactory.java b/src/org/apache/fop/layout/SinglePageMasterFactory.java
index a26bfae02..3b5e19bf3 100644
--- a/src/org/apache/fop/layout/SinglePageMasterFactory.java
+++ b/src/org/apache/fop/layout/SinglePageMasterFactory.java
@@ -50,69 +50,35 @@
*/
package org.apache.fop.layout;
-
-
public class SinglePageMasterFactory extends PageMasterFactory {
-
-
private PageMaster pageMaster;
-
-
private static final int FIRST = 0;
-
private static final int DONE = 1;
-
-
private int state;
-
-
public SinglePageMasterFactory(PageMaster pageMaster) {
-
this.pageMaster = pageMaster;
-
this.state = FIRST;
-
}
-
-
public int getHeight() {
-
return this.pageMaster.getHeight();
-
}
-
-
public PageMaster getNextPageMaster() {
-
PageMaster pm;
-
-
switch (this.state) {
-
case FIRST: pm = this.pageMaster; this.state = DONE; break;
-
default: pm = null;
-
}
-
-
return pm;
-
}
-
public int getWidth() {
-
return this.pageMaster.getWidth();
-
}
-
}
-
diff --git a/src/org/apache/fop/layout/Space.java b/src/org/apache/fop/layout/Space.java
index bbc2f138a..5a6e16228 100644
--- a/src/org/apache/fop/layout/Space.java
+++ b/src/org/apache/fop/layout/Space.java
@@ -50,9 +50,5 @@
*/
package org.apache.fop.layout;
-
-
abstract public class Space extends Box {
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFDocument.java b/src/org/apache/fop/pdf/PDFDocument.java
index 7cbf8bd3f..042f8b1a8 100644
--- a/src/org/apache/fop/pdf/PDFDocument.java
+++ b/src/org/apache/fop/pdf/PDFDocument.java
@@ -50,611 +50,306 @@
*/
/* image support modified from work of BoBoGi */
-
-
package org.apache.fop.pdf;
-
-
// images are the one place that FOP classes outside this package get
-
// referenced and I'd rather not do it
-
import org.apache.fop.image.FopImage;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
import java.util.Vector;
-
-
/**
-
* class representing a PDF document.
-
*
-
* The document is built up by calling various methods and then finally
-
* output to given filehandle using output method.
-
*
-
* A PDF document consists of a series of numbered objects preceded by a
-
* header and followed by an xref table and trailer. The xref table
-
* allows for quick access to objects by listing their character
-
* positions within the document. For this reason the PDF document must
-
* keep track of the character position of each object. The document
-
* also keeps direct track of the /Root, /Info and /Resources objects.
-
*/
-
public class PDFDocument {
-
-
/** the version of PDF supported */
-
protected static final String pdfVersion = "1.2";
-
-
/** the current character position */
-
protected int position = 0;
-
-
/** the character position of each object */
-
protected Vector location = new Vector();
-
-
/** the counter for object numbering */
-
protected int objectcount = 0;
-
-
/** the objects themselves */
-
protected Vector objects = new Vector();
-
-
/** character position of xref table */
-
protected int xref;
-
-
/** the /Root object */
-
protected PDFRoot root;
-
-
/** the /Info object */
-
protected PDFInfo info;
-
-
/** the /Resources object */
-
protected PDFResources resources;
-
-
protected int xObjectCount = 0;
-
protected Vector xObjects = new Vector();
-
-
/**
-
* creates an empty PDF document
-
*/
-
public PDFDocument() {
-
-
/* create the /Root, /Info and /Resources objects */
-
this.root = makeRoot();
-
this.info = makeInfo();
-
this.resources = makeResources();
-
}
-
-
/**
-
* set the producer of the document
-
*
-
* @param producer string indicating application producing the PDF
-
*/
-
public void setProducer(String producer) {
-
this.info.setProducer(producer);
-
}
-
-
/**
-
* make /Root object as next object
-
*
-
* @return the created /Root object
-
*/
-
protected PDFRoot makeRoot() {
-
-
/* create a PDFRoot with the next object number and add to
-
list of objects */
-
PDFRoot pdfRoot = new PDFRoot(++this.objectcount);
-
this.objects.addElement(pdfRoot);
-
-
/* create a new /Pages object to be root of Pages hierarchy
-
and add to list of objects */
-
PDFPages rootPages = new PDFPages(++this.objectcount);
-
this.objects.addElement(rootPages);
-
-
/* inform the /Root object of the /Pages root */
-
pdfRoot.setRootPages(rootPages);
-
return pdfRoot;
-
}
-
-
/**
-
* make an /Info object
-
*
-
* @param producer string indicating application producing the PDF
-
* @return the created /Info object
-
*/
-
protected PDFInfo makeInfo() {
-
-
/* create a PDFInfo with the next object number and add to
-
list of objects */
-
PDFInfo pdfInfo = new PDFInfo(++this.objectcount);
-
this.objects.addElement(pdfInfo);
-
return pdfInfo;
-
}
-
-
/**
-
* make a /Resources object
-
*
-
* @return the created /Resources object
-
*/
-
private PDFResources makeResources() {
-
-
/* create a PDFResources with the next object number and add
-
to list of objects */
-
PDFResources pdfResources = new PDFResources(++this.objectcount);
-
this.objects.addElement(pdfResources);
-
return pdfResources;
-
}
-
-
/**
-
* make a Type1 /Font object
-
*
-
* @param fontname internal name to use for this font (eg "F1")
-
* @param basefont name of the base font (eg "Helvetica")
-
* @param encoding character encoding scheme used by the font
-
* @return the created /Font object
-
*/
-
public PDFFont makeFont(String fontname, String basefont,
-
String encoding) {
-
-
/* create a PDFFont with the next object number and add to the
-
list of objects */
-
PDFFont font = new PDFFont(++this.objectcount, fontname,
-
basefont, encoding);
-
this.objects.addElement(font);
-
return font;
-
}
-
-
public int addImage(FopImage img) {
-
PDFXObject xObject = new PDFXObject(++this.objectcount,
-
++this.xObjectCount, img);
-
this.objects.addElement(xObject);
-
this.xObjects.addElement(xObject);
-
return xObjectCount;
-
}
-
-
/**
-
* make a /Page object
-
*
-
* @param resources resources object to use
-
* @param contents stream object with content
-
* @param pagewidth width of the page in points
-
* @param pageheight height of the page in points
-
* @return the created /Page object
-
*/
-
public PDFPage makePage(PDFResources resources,
-
PDFStream contents, int pagewidth,
-
int pageheight) {
-
-
/* create a PDFPage with the next object number, the given
-
resources, contents and dimensions */
-
PDFPage page = new PDFPage(++this.objectcount, resources,
-
contents, pagewidth, pageheight);
-
-
/* add it to the list of objects */
-
this.objects.addElement(page);
-
-
/* add the page to the Root */
-
this.root.addPage(page);
-
-
return page;
-
}
-
-
/**
-
* make a stream object
-
*
-
* @return the stream object created
-
*/
-
public PDFStream makeStream() {
-
-
/* create a PDFStream with the next object number and add it
-
to the list of objects */
-
PDFStream obj = new PDFStream(++this.objectcount);
-
this.objects.addElement(obj);
-
return obj;
-
}
-
-
/**
-
* get the /Resources object for the document
-
*
-
* @return the /Resources object
-
*/
-
public PDFResources getResources() {
-
return this.resources;
-
}
-
-
/**
-
* write the entire document out
-
*
-
* @param writer the PrinterWriter to output the document to
-
*/
-
public void output(PrintWriter writer) throws IOException {
-
-
/* output the header and increment the character position by
-
the header's length */
-
this.position += outputHeader(writer);
-
-
this.resources.setXObjects(xObjects);
-
-
/* loop through the object numbers */
-
for (int i=1; i <= this.objectcount; i++) {
-
-
/* add the position of this object to the list of object
-
locations */
-
this.location.addElement(new Integer(this.position));
-
-
/* retrieve the object with the current number */
-
PDFObject object = (PDFObject)this.objects.elementAt(i-1);
-
-
/* output the object and increment the character position
-
by the object's length */
-
this.position += object.output(writer);
-
}
-
-
/* output the xref table and increment the character position
-
by the table's length */
-
this.position += outputXref(writer);
-
-
/* output the trailer and flush the Writer */
-
outputTrailer(writer);
-
writer.flush();
-
}
-
-
/**
-
* write the PDF header
-
*
-
* @param writer the PrintWriter to write the header to
-
* @return the number of characters written
-
*/
-
protected int outputHeader(PrintWriter writer) throws IOException {
-
String pdf = "%PDF-" + this.pdfVersion + "\n";
-
writer.write(pdf);
-
return pdf.length();
-
}
-
-
/**
-
* write the trailer
-
*
-
* @param writer the PrintWriter to write the trailer to
-
*/
-
protected void outputTrailer(PrintWriter writer) throws IOException {
-
-
/* construct the trailer */
-
String pdf = "trailer\n<<\n/Size " + (this.objectcount+1)
-
+ "\n/Root " + this.root.number + " " + this.root.generation
-
+ " R\n/Info " + this.info.number + " "
-
+ this.info.generation + " R\n>>\nstartxref\n" + this.xref
-
+ "\n%%EOF\n";
-
-
/* write the trailer */
-
writer.write(pdf);
-
}
-
-
/**
-
* write the xref table
-
*
-
* @param writer the PrintWriter to write the xref table to
-
* @return the number of characters written
-
*/
-
private int outputXref(PrintWriter writer) throws IOException {
-
-
/* remember position of xref table */
-
this.xref = this.position;
-
-
/* construct initial part of xref */
-
StringBuffer pdf = new StringBuffer("xref\n0 " + (this.objectcount+1)
-
+ "\n0000000000 65535 f \n");
-
-
/* loop through object numbers */
-
for (int i=1; i < this.objectcount+1; i++) {
-
-
/* contruct xref entry for object */
-
String padding = "0000000000";
-
String x = this.location.elementAt(i-1).toString();
-
String loc = padding.substring(x.length()) + x;
-
-
/* append to xref table */
-
pdf = pdf.append(loc + " 00000 n \n");
-
}
-
-
/* write the xref table and return the character length */
-
writer.write(pdf.toString());
-
return pdf.length();
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFFont.java b/src/org/apache/fop/pdf/PDFFont.java
index 562bddf2e..49a6c4791 100644
--- a/src/org/apache/fop/pdf/PDFFont.java
+++ b/src/org/apache/fop/pdf/PDFFont.java
@@ -50,135 +50,68 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
/**
-
* class representing a /Font object.
-
*
-
* A small object expressing the base font name and encoding of a
-
* Type 1 font along with an internal name for the font used within
-
* streams of content
-
*/
-
public class PDFFont extends PDFObject {
-
-
/** the internal name for the font (eg "F1") */
-
protected String fontname;
-
-
/** the base font name (eg "Helvetica") */
-
protected String basefont;
-
-
/** the character encoding scheme used by the font (eg
-
"WinAnsiEncoding") */
-
protected String encoding;
-
-
/**
-
* create the /Font object
-
*
-
* @param the object's number
-
* @param fontname the internal name for the font
-
* @param basefont the base font name
-
* @param encoding the character encoding schema used by the font
-
*/
-
public PDFFont(int number, String fontname, String basefont,
-
String encoding) {
-
-
/* generic creation of PDF object */
-
super(number);
-
-
/* set fields using paramaters */
-
this.fontname = fontname;
-
this.basefont = basefont;
-
this.encoding = encoding;
-
}
-
-
/**
-
* get the internal name used for this font
-
*
-
* @return the internal name
-
*/
-
public String getName() {
-
return this.fontname;
-
}
-
-
/**
-
* produce the PDF representation for the object
-
*
-
* @return the PDF
-
*/
-
public String toPDF() {
-
String p = this.number + " " + this.generation
-
+ " obj\n<< /Type /Font\n/Subtype /Type1\n/Name /"
-
+ this.fontname + "\n/BaseFont /" + this.basefont
-
+ "\n/Encoding /"+ this.encoding + " >>\nendobj\n";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFInfo.java b/src/org/apache/fop/pdf/PDFInfo.java
index e469546e1..89f8b3ec7 100644
--- a/src/org/apache/fop/pdf/PDFInfo.java
+++ b/src/org/apache/fop/pdf/PDFInfo.java
@@ -50,89 +50,45 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
/**
-
* class representing an /Info object
-
*/
-
public class PDFInfo extends PDFObject {
-
-
/** the application producing the PDF */
-
protected String producer;
-
-
/**
-
* create an Info object
-
*
-
* @param number the object's number
-
*/
-
public PDFInfo(int number) {
-
super(number);
-
}
-
-
/**
-
* set the producer string
-
*
-
* @param producer the producer string
-
*/
-
public void setProducer(String producer) {
-
this.producer = producer;
-
}
-
-
/**
-
* produce the PDF representation of the object
-
*
-
* @return the PDF
-
*/
-
public String toPDF() {
-
String p = this.number + " " + this.generation
-
+ " obj\n<< /Type /Info\n/Producer (" + this.producer
-
+ ") >>\nendobj\n";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFObject.java b/src/org/apache/fop/pdf/PDFObject.java
index 9c283ec74..656377519 100644
--- a/src/org/apache/fop/pdf/PDFObject.java
+++ b/src/org/apache/fop/pdf/PDFObject.java
@@ -50,119 +50,60 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
/**
-
* generic PDF object.
-
*
-
* A PDF Document is essentially a collection of these objects. A PDF
-
* Object has a number and a generation (although the generation will always
-
* be 0 in new documents).
-
*/
-
public abstract class PDFObject {
-
-
/** the object's number */
-
protected int number;
-
-
/** the object's generation (0 in new documents) */
-
protected int generation = 0;
-
-
/**
-
* create an empty object
-
*
-
* @param number the object's number
-
*/
-
public PDFObject(int number) {
-
this.number = number;
-
}
-
-
/**
-
* write the PDF represention of this object
-
*
-
* @param writer the PrintWriter to write the PDF to
-
* @return the number of characters written
-
*/
-
protected int output(PrintWriter writer) throws IOException {
-
String pdf = this.toPDF();
-
writer.write(pdf);
-
return pdf.length();
-
}
-
-
/**
-
* the PDF representation of a reference to this object
-
*
-
* @return the reference string
-
*/
-
protected String referencePDF() {
-
String p = this.number + " " + this.generation + " R";
-
return p;
-
}
-
-
/**
-
* represent object as PDF
-
*
-
* @return PDF string
-
*/
-
abstract String toPDF();
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFPage.java b/src/org/apache/fop/pdf/PDFPage.java
index e96a2211c..9242da03e 100644
--- a/src/org/apache/fop/pdf/PDFPage.java
+++ b/src/org/apache/fop/pdf/PDFPage.java
@@ -50,157 +50,79 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.PrintWriter;
-
import java.util.Vector;
-
-
/**
-
* class representing a /Page object.
-
*
-
* There is one of these for every page in a PDF document. The object
-
* specifies the dimensions of the page and references a /Resources
-
* object, a contents stream and the page's parent in the page
-
* hierarchy.
-
*/
-
public class PDFPage extends PDFObject {
-
-
/** the page's parent, a /Pages object */
-
protected PDFPages parent;
-
-
/** the page's /Resource object */
-
protected PDFResources resources;
-
-
/** the contents stream */
-
protected PDFStream contents;
-
-
/** the width of the page in points */
-
protected int pagewidth;
-
-
/** the height of the page in points */
-
protected int pageheight;
-
-
/**
-
* create a /Page object
-
*
-
* @param number the object's number
-
* @param resources the /Resources object
-
* @param contents the content stream
-
* @param pagewidth the page's width in points
-
* @param pageheight the page's height in points
-
*/
-
public PDFPage(int number, PDFResources resources,
-
PDFStream contents, int pagewidth,
-
int pageheight) {
-
-
/* generic creation of object */
-
super(number);
-
-
/* set fields using parameters */
-
this.resources = resources;
-
this.contents = contents;
-
this.pagewidth = pagewidth;
-
this.pageheight = pageheight;
-
}
-
-
/**
-
* set this page's parent
-
*
-
* @param parent the /Pages object that is this page's parent
-
*/
-
public void setParent(PDFPages parent) {
-
this.parent = parent;
-
}
-
-
/**
-
* represent this object as PDF
-
*
-
* @return the PDF string
-
*/
-
public String toPDF() {
-
String p = this.number + " " + this.generation
-
+ " obj\n<< /Type /Page\n/Parent "
-
+ this.parent.referencePDF() + "\n/MediaBox [ 0 0 "
-
+ this.pagewidth + " " + this.pageheight + " ]\n/Resources "
-
+ this.resources.referencePDF() + "\n/Contents "
-
+ this.contents.referencePDF() + " >>\nendobj\n";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFPages.java b/src/org/apache/fop/pdf/PDFPages.java
index c4dcf1f4d..4e4b29c67 100644
--- a/src/org/apache/fop/pdf/PDFPages.java
+++ b/src/org/apache/fop/pdf/PDFPages.java
@@ -50,141 +50,71 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.PrintWriter;
-
import java.util.Vector;
-
-
/**
-
* class representing a /Pages object.
-
*
-
* A /Pages object is an ordered collection of pages (/Page objects)
-
* (Actually, /Pages can contain further /Pages as well but this
-
* implementation doesn't allow this)
-
*/
-
public class PDFPages extends PDFObject {
-
-
/** the /Page objects */
-
protected Vector kids = new Vector();
-
-
/** the number of /Page objects */
-
protected int count = 0;
-
-
// private PDFPages parent;
-
-
/**
-
* create a /Pages object.
-
*
-
* @param number the object's number
-
*/
-
public PDFPages(int number) {
-
-
/* generic creation of object */
-
super(number);
-
}
-
-
/**
-
* add a /Page object.
-
*
-
* @param page the PDFPage to add.
-
*/
-
public void addPage(PDFPage page) {
-
this.kids.addElement(page);
-
page.setParent(this);
-
}
-
-
/**
-
* get the count of /Page objects
-
*
-
* @return the number of pages
-
*/
-
public int getCount() {
-
return this.count;
-
}
-
-
/**
-
* represent the object in PDF
-
*
-
* @return the PDF string
-
*/
-
public String toPDF() {
-
StringBuffer p = new StringBuffer(this.number + " "
-
+ this.generation
-
+ " obj\n<< /Type /Pages\n/Count "
-
+ this.getCount() + "\n/Kids [");
-
for (int i = 0; i < kids.size(); i++) {
-
p = p.append(((PDFObject)kids.elementAt(i)).referencePDF() + " ");
-
}
-
p = p.append("] >>\nendobj\n");
-
return p.toString();
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFResources.java b/src/org/apache/fop/pdf/PDFResources.java
index 64b54dea7..32e39b068 100644
--- a/src/org/apache/fop/pdf/PDFResources.java
+++ b/src/org/apache/fop/pdf/PDFResources.java
@@ -50,167 +50,84 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.PrintWriter;
-
import java.util.Enumeration;
-
import java.util.Vector;
-
import java.util.Hashtable;
-
-
/**
-
* class representing a /Resources object.
-
*
-
* /Resources object contain a list of references to the fonts for the
-
* document
-
*/
-
public class PDFResources extends PDFObject {
-
-
/** /Font objects keyed by their internal name */
-
protected Hashtable fonts = new Hashtable();
-
-
protected Vector xObjects;
-
-
/**
-
* create a /Resources object.
-
*
-
* @param number the object's number
-
*/
-
public PDFResources(int number) {
-
-
/* generic creation of object */
-
super(number);
-
}
-
-
/**
-
* add font object to resources list.
-
*
-
* @param font the PDFFont to add
-
*/
-
public void addFont(PDFFont font) {
-
this.fonts.put(font.getName(),font);
-
}
-
-
public void setXObjects(Vector xObjects) {
-
this.xObjects = xObjects;
-
}
-
-
/**
-
* represent the object in PDF
-
*
-
* @return the PDF
-
*/
-
public String toPDF() {
-
StringBuffer p = new StringBuffer(this.number + " "
-
+ this.generation
-
+ " obj\n<< /Font << ");
-
-
/* construct PDF dictionary of font object references */
-
Enumeration fontEnumeration = fonts.keys();
-
while (fontEnumeration.hasMoreElements()) {
-
String fontName = (String) fontEnumeration.nextElement();
-
p = p.append("/" + fontName + " "
-
+ ((PDFFont) fonts.get(fontName)).referencePDF()
-
+ "\n");
-
}
-
-
p = p.append(">>\n/ProcSet [ /PDF /ImageC /Text ] ");
-
-
if (!this.xObjects.isEmpty()) {
-
p = p.append("/XObject <<");
-
for (int i = 1; i < this.xObjects.size(); i++) {
-
p = p.append("/Im" + i + " " +
-
((PDFXObject)
-
this.xObjects.elementAt(i -
-
1)).referencePDF()
-
+
-
" \n");
-
}
-
}
-
-
p = p.append(">>\nendobj\n");
-
-
return p.toString();
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFRoot.java b/src/org/apache/fop/pdf/PDFRoot.java
index 67f5e45fb..a1f309a31 100644
--- a/src/org/apache/fop/pdf/PDFRoot.java
+++ b/src/org/apache/fop/pdf/PDFRoot.java
@@ -50,107 +50,54 @@
*/
package org.apache.fop.pdf;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
/**
-
* class representing a Root (/Catalog) object
-
*/
-
public class PDFRoot extends PDFObject {
-
-
/** the /Pages object that is root of the Pages hierarchy */
-
protected PDFPages rootPages;
-
-
/**
-
* create a Root (/Catalog) object
-
*
-
* @param number the object's number
-
*/
-
public PDFRoot(int number) {
-
super(number);
-
}
-
-
/**
-
* add a /Page object to the root /Pages object
-
*
-
* @param page the /Page object to add
-
*/
-
public void addPage(PDFPage page) {
-
this.rootPages.addPage(page);
-
}
-
-
/**
-
* set the root /Pages object
-
*
-
* @param pages the /Pages object to set as root
-
*/
-
public void setRootPages(PDFPages pages) {
-
this.rootPages = pages;
-
}
-
-
/**
-
* represent the object as PDF
-
*
-
* @return the PDF string
-
*/
-
public String toPDF() {
-
String p = this.number + " " + this.generation
-
+ " obj\n<< /Type /Catalog\n/Pages "
-
+ this.rootPages.referencePDF() + " >>\nendobj\n";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFStream.java b/src/org/apache/fop/pdf/PDFStream.java
index a8d163a40..f1e1ca76f 100644
--- a/src/org/apache/fop/pdf/PDFStream.java
+++ b/src/org/apache/fop/pdf/PDFStream.java
@@ -50,155 +50,78 @@
*/
package org.apache.fop.pdf;
-
-
/**
-
* class representing a PDF stream.
-
*
-
* A derivative of the PDF Object, a PDF Stream has not only a dictionary
-
* but a stream of PDF commands. The stream of commands is where the real
-
* work is done, the dictionary just provides information like the stream
-
* length.
-
*/
-
public class PDFStream extends PDFObject {
-
-
/** the stream of PDF commands */
-
protected StringBuffer data = new StringBuffer();
-
-
/**
-
* create an empty stream object
-
*
-
* @param number the object's number
-
*/
-
public PDFStream(int number) {
-
super(number);
-
}
-
-
/**
-
* append data to the stream
-
*
-
* @param s the string of PDF to add
-
*/
-
public void add(String s) {
-
this.data = this.data.append(s);
-
}
-
-
/**
-
* append an array of xRGB pixels, ASCII Hex Encoding it first
-
*
-
* @param pixels the area of pixels
-
* @param width the width of the image in pixels
-
* @param height the height of the image in pixels
-
*/
-
public void addImageArray(int[] pixels, int width, int height) {
-
for (int i = 0; i < height; i++) {
-
for (int j = 0; j < width; j++) {
-
int p = pixels[i * width + j];
-
int r = (p >> 16) & 0xFF;
-
int g = (p >> 8) & 0xFF;
-
int b = (p ) & 0xFF;
-
if (r < 16) {
-
this.data = this.data.append(0);
-
}
-
this.data = this.data.append(Integer.toHexString(r));
-
if (g < 16) {
-
this.data = this.data.append(0);
-
}
-
this.data = this.data.append(Integer.toHexString(g));
-
if (b < 16) {
-
this.data = this.data.append(0);
-
}
-
this.data = this.data.append(Integer.toHexString(b));
-
this.data = this.data.append(" ");
-
}
-
}
-
this.data = this.data.append(">\n");
-
}
-
-
/**
-
* represent as PDF.
-
*
-
* @return the PDF string.
-
*/
-
public String toPDF() {
-
String p = this.number + " " + this.generation
-
+ " obj\n<< /Length " + (this.data.length()+1)
-
+ " >>\nstream\n" + this.data + "\nendstream\nendobj\n";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/pdf/PDFXObject.java b/src/org/apache/fop/pdf/PDFXObject.java
index 279cb37a5..f915be811 100644
--- a/src/org/apache/fop/pdf/PDFXObject.java
+++ b/src/org/apache/fop/pdf/PDFXObject.java
@@ -50,201 +50,101 @@
*/
/* modified by JKT to integrate with 0.12.0 */
-
-
package org.apache.fop.pdf;
-
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
-
// shouldn't have to do this
-
import org.apache.fop.image.*;
-
-
/**
-
* PDF XObject
-
*
-
* A derivative of the PDF Object, is a PDF Stream that has not only a
-
* dictionary but a stream of image data.
-
* the dictionary just provides information like the stream length
-
*/
-
public class PDFXObject extends PDFObject {
-
-
FopImage fopimage;
-
int[] map;
-
int Xnum;
-
-
-
/**
-
* create an Xobject with the given number and name and load the
-
* image in the object
-
*/
-
public PDFXObject(int number,int Xnumber,FopImage img) {
-
super(number);
-
this.Xnum=Xnumber;
-
if (img == null)
-
System.err.println("FISH");
-
this.map = img.getimagemap();
-
fopimage=img;
-
}
-
-
/**
-
* represent as PDF
-
*/
-
protected int output(PrintWriter writer) throws IOException {
-
int length=0;
-
int i=0;
-
int x,y;
-
int ncc=(fopimage.getcolor()? 3 : 1);//Number of Color Channels
-
int size=(fopimage.getpixelwidth())*(fopimage.getpixelheight()*ncc);
-
String p;
-
String pdf = this.toPDF();
-
// push the pdf dictionary on the writer
-
writer.write(pdf);
-
length +=pdf.length();
-
p = (size*2+1) + " >>\n";
-
p = p + "stream\n";
-
writer.write(p);
-
length +=p.length();
-
// push all the image data on the writer and takes care of length for trailer
-
for (y=fopimage.getpixelheight()-1;y>=0;y--)
-
{
-
for (x=0;x<fopimage.getpixelwidth()*ncc;x++)
-
{
-
i=y*fopimage.getpixelwidth()*ncc+x;
-
if (this.map[i]<16)
-
{
-
writer.write("0");
-
writer.write(Integer.toHexString(this.map[i]));
-
length++;
-
length++;
-
}else
-
{
-
writer.write(Integer.toHexString(this.map[i]));
-
length++;
-
length++;
-
}
-
}
-
}
-
// close the object
-
p = ">";
-
p += "\nendstream\nendobj\n";
-
writer.write(p);
-
length +=p.length();
-
return length;
-
}
-
-
String toPDF() {
-
String p = this.number + " " + this.generation + " obj\n";
-
p = p + "<</Type /XObject\n";
-
p = p + "/Subtype /Image\n";
-
p = p + "/Name /Im"+Xnum+"\n";
-
p = p + "/Width "+fopimage.getpixelwidth()+"\n";
-
p = p + "/Height "+fopimage.getpixelheight()+"\n";
-
p = p + "/BitsPerComponent 8\n";
-
if (fopimage.getcolor())
-
p = p + "/ColorSpace /DeviceRGB\n";
-
else
-
p = p + "/ColorSpace /DeviceGray\n";
-
p = p + "/Filter /ASCIIHexDecode\n";
-
p = p + "/Length ";
-
return p;
-
}
-
}
-
diff --git a/src/org/apache/fop/render/Renderer.java b/src/org/apache/fop/render/Renderer.java
index 30780169a..0f1ab587a 100644
--- a/src/org/apache/fop/render/Renderer.java
+++ b/src/org/apache/fop/render/Renderer.java
@@ -50,117 +50,59 @@
*/
package org.apache.fop.render;
-
-
// FOP
-
import org.apache.fop.svg.SVGArea;
-
import org.apache.fop.image.ImageArea;
-
import org.apache.fop.layout.*;
-
-
// Java
-
import java.io.PrintWriter;
-
import java.io.IOException;
-
-
/**
-
* interface implement by all renderers.
-
*
-
* a Renderer implementation takes areas/spaces and produces output in
-
* some format.
-
*/
-
public interface Renderer {
-
-
/** set up the given FontInfo */
-
public void setupFontInfo(FontInfo fontInfo);
-
-
/** set the producer of the rendering */
-
public void setProducer(String producer);
-
-
/** render the given area tree to the given writer */
-
public void render(AreaTree areaTree, PrintWriter writer) throws IOException;
-
-
/** render the given area container */
-
public void renderAreaContainer(AreaContainer area);
-
-
/** render the given block area */
-
public void renderBlockArea(BlockArea area);
-
-
/** render the given display space */
-
public void renderDisplaySpace(DisplaySpace space);
-
-
/** render the given SVG area */
-
public void renderSVGArea(SVGArea area);
-
-
/** render the given image area */
-
public void renderImageArea(ImageArea area);
-
-
/** render the given inline area */
-
public void renderInlineArea(InlineArea area);
-
-
/** render the given inline space */
-
public void renderInlineSpace(InlineSpace space);
-
-
/** render the given line area */
-
public void renderLineArea(LineArea area);
-
-
/** render the given page */
-
public void renderPage(Page page);
-
-
/** render the given rule area */
-
public void renderRuleArea(RuleArea area);
-
}
-
diff --git a/src/org/apache/fop/render/pdf/Font.java b/src/org/apache/fop/render/pdf/Font.java
index 49a752703..5717a62ad 100644
--- a/src/org/apache/fop/render/pdf/Font.java
+++ b/src/org/apache/fop/render/pdf/Font.java
@@ -50,41 +50,21 @@
*/
package org.apache.fop.render.pdf;
-
-
// FOP
-
import org.apache.fop.layout.FontMetric;
-
-
/**
-
* base class for PDF font classes
-
*/
-
public abstract class Font implements FontMetric {
-
-
/**
-
* get the encoding of the font
-
*/
-
public abstract String encoding();
-
-
/**
-
* get the base font name
-
*/
-
public abstract String fontName();
-
}
-
diff --git a/src/org/apache/fop/render/pdf/FontSetup.java b/src/org/apache/fop/render/pdf/FontSetup.java
index d9750da30..d3228fa60 100644
--- a/src/org/apache/fop/render/pdf/FontSetup.java
+++ b/src/org/apache/fop/render/pdf/FontSetup.java
@@ -50,335 +50,168 @@
*/
package org.apache.fop.render.pdf;
-
-
// FOP
-
import org.apache.fop.render.pdf.fonts.*;
-
import org.apache.fop.layout.FontInfo;
-
import org.apache.fop.pdf.PDFDocument;
-
import org.apache.fop.pdf.PDFResources;
-
-
// Java
-
import java.util.Enumeration;
-
import java.util.Hashtable;
-
-
/**
-
* sets up the PDF fonts.
-
*
-
* Assigns the font (with metrics) to internal names like "F1" and
-
* assigns family-style-weight triplets to the fonts
-
*/
-
public class FontSetup {
-
-
/**
-
* sets up the font info object.
-
*
-
* adds metrics for basic fonts and useful family-style-weight
-
* triplets for lookup
-
*
-
* @param fontInfo the font info object to set up
-
*/
-
public static void setup(FontInfo fontInfo) {
-
System.err.println("setting up fonts");
-
-
fontInfo.addMetrics("F1", new Helvetica());
-
fontInfo.addMetrics("F2", new HelveticaOblique());
-
fontInfo.addMetrics("F3", new HelveticaBold());
-
fontInfo.addMetrics("F4", new HelveticaBoldOblique());
-
fontInfo.addMetrics("F5", new TimesRoman());
-
fontInfo.addMetrics("F6", new TimesItalic());
-
fontInfo.addMetrics("F7", new TimesBold());
-
fontInfo.addMetrics("F8", new TimesBoldItalic());
-
fontInfo.addMetrics("F9", new Courier());
-
fontInfo.addMetrics("F10", new CourierOblique());
-
fontInfo.addMetrics("F11", new CourierBold());
-
fontInfo.addMetrics("F12", new CourierBoldOblique());
-
-
/* any is treated as serif */
-
fontInfo.addFontProperties("F5", "any", "normal", "normal");
-
fontInfo.addFontProperties("F6", "any", "italic", "normal");
-
fontInfo.addFontProperties("F6", "any", "oblique", "normal");
-
fontInfo.addFontProperties("F7", "any", "normal", "bold");
-
fontInfo.addFontProperties("F8", "any", "italic", "bold");
-
fontInfo.addFontProperties("F8", "any", "oblique", "bold");
-
-
fontInfo.addFontProperties("F1", "sans-serif", "normal",
-
"normal");
-
fontInfo.addFontProperties("F2", "sans-serif", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F2", "sans-serif", "italic",
-
"normal");
-
fontInfo.addFontProperties("F3", "sans-serif", "normal",
-
"bold");
-
fontInfo.addFontProperties("F4", "sans-serif", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F4", "sans-serif", "italic",
-
"bold");
-
fontInfo.addFontProperties("F5", "serif", "normal", "normal");
-
fontInfo.addFontProperties("F6", "serif", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F6", "serif", "italic", "normal");
-
fontInfo.addFontProperties("F7", "serif", "normal", "bold");
-
fontInfo.addFontProperties("F8", "serif", "oblique", "bold");
-
fontInfo.addFontProperties("F8", "serif", "italic", "bold");
-
fontInfo.addFontProperties("F9", "monospace", "normal",
-
"normal");
-
fontInfo.addFontProperties("F10", "monospace", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F10", "monospace", "italic",
-
"normal");
-
fontInfo.addFontProperties("F11", "monospace", "normal",
-
"bold");
-
fontInfo.addFontProperties("F12", "monospace", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F12", "monospace", "italic",
-
"bold");
-
-
fontInfo.addFontProperties("F1", "Helvetica", "normal",
-
"normal");
-
fontInfo.addFontProperties("F2", "Helvetica", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F2", "Helvetica", "italic",
-
"normal");
-
fontInfo.addFontProperties("F3", "Helvetica", "normal",
-
"bold");
-
fontInfo.addFontProperties("F4", "Helvetica", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F4", "Helvetica", "italic",
-
"bold");
-
fontInfo.addFontProperties("F5", "Times", "normal", "normal");
-
fontInfo.addFontProperties("F6", "Times", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F6", "Times", "italic", "normal");
-
fontInfo.addFontProperties("F7", "Times", "normal", "bold");
-
fontInfo.addFontProperties("F8", "Times", "oblique", "bold");
-
fontInfo.addFontProperties("F8", "Times", "italic", "bold");
-
fontInfo.addFontProperties("F9", "Courier", "normal",
-
"normal");
-
fontInfo.addFontProperties("F10", "Courier", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F10", "Courier", "italic",
-
"normal");
-
fontInfo.addFontProperties("F11", "Courier", "normal",
-
"bold");
-
fontInfo.addFontProperties("F12", "Courier", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F12", "Courier", "italic",
-
"bold");
-
-
/* for compatibility with PassiveTex */
-
fontInfo.addFontProperties("F5", "Times-Roman", "normal",
-
"normal");
-
fontInfo.addFontProperties("F6", "Times-Roman", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F6", "Times-Roman", "italic",
-
"normal");
-
fontInfo.addFontProperties("F7", "Times-Roman", "normal",
-
"bold");
-
fontInfo.addFontProperties("F8", "Times-Roman", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F8", "Times-Roman", "italic",
-
"bold");
-
fontInfo.addFontProperties("F5", "Times Roman", "normal",
-
"normal");
-
fontInfo.addFontProperties("F6", "Times Roman", "oblique",
-
"normal");
-
fontInfo.addFontProperties("F6", "Times Roman", "italic",
-
"normal");
-
fontInfo.addFontProperties("F7", "Times Roman", "normal",
-
"bold");
-
fontInfo.addFontProperties("F8", "Times Roman", "oblique",
-
"bold");
-
fontInfo.addFontProperties("F8", "Times Roman", "italic",
-
"bold");
-
fontInfo.addFontProperties("F9", "Computer-Modern-Typewriter",
-
"normal", "normal");
-
}
-
-
/**
-
* add the fonts in the font info to the PDF document
-
*
-
* @param doc PDF document to add fonts to
-
* @param fontInfo font info object to get font information from
-
*/
-
public static void addToResources(PDFDocument doc, FontInfo fontInfo) {
-
Hashtable fonts = fontInfo.getFonts();
-
Enumeration e = fonts.keys();
-
PDFResources resources = doc.getResources();
-
while (e.hasMoreElements()) {
-
String f = (String) e.nextElement();
-
resources.addFont(doc.makeFont(f,
-
((Font)
-
fonts.get(f)).fontName(),
-
((Font)
-
fonts.get(f)).encoding()
-
)
-
);
-
}
-
}
-
}
-
diff --git a/src/org/apache/fop/render/pdf/PDFRenderer.java b/src/org/apache/fop/render/pdf/PDFRenderer.java
index 32498cfd8..b6976fba3 100644
--- a/src/org/apache/fop/render/pdf/PDFRenderer.java
+++ b/src/org/apache/fop/render/pdf/PDFRenderer.java
@@ -50,853 +50,427 @@
*/
package org.apache.fop.render.pdf;
-
-
// FOP
-
import org.apache.fop.render.Renderer;
-
import org.apache.fop.image.ImageArea;
-
import org.apache.fop.image.FopImage;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.svg.*;
-
import org.apache.fop.pdf.*;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
import java.util.Enumeration;
-
-
/**
-
* Renderer that renders areas to PDF
-
*/
-
public class PDFRenderer implements Renderer {
-
-
/** the PDF Document being created */
-
protected PDFDocument pdfDoc;
-
-
/** the /Resources object of the PDF document being created */
-
protected PDFResources pdfResources;
-
-
/** the current stream to add PDF commands to */
-
PDFStream currentStream;
-
-
/** the current (internal) font name */
-
protected String currentFontName;
-
-
/** the current font size in millipoints */
-
protected int currentFontSize;
-
-
/** the current colour's red component */
-
protected float currentRed = 0;
-
-
/** the current colour's green component */
-
protected float currentGreen = 0;
-
-
/** the current colour's blue component */
-
protected float currentBlue = 0;
-
-
/** the current vertical position in millipoints from bottom */
-
protected int currentYPosition = 0;
-
-
/** the current horizontal position in millipoints from left */
-
protected int currentXPosition = 0;
-
-
/** the horizontal position of the current area container */
-
private int currentAreaContainerXPosition = 0;
-
-
/**
-
* create the PDF renderer
-
*/
-
public PDFRenderer() {
-
this.pdfDoc = new PDFDocument();
-
}
-
-
/**
-
* set the PDF document's producer
-
*
-
* @param producer string indicating application producing PDF
-
*/
-
public void setProducer(String producer) {
-
this.pdfDoc.setProducer(producer);
-
}
-
-
/**
-
* render the areas into PDF
-
*
-
* @param areaTree the laid-out area tree
-
* @param writer the PrintWriter to write the PDF with
-
*/
-
public void render(AreaTree areaTree, PrintWriter writer) throws IOException {
-
System.err.println("rendering areas to PDF");
-
this.pdfResources = this.pdfDoc.getResources();
-
Enumeration e = areaTree.getPages().elements();
-
while (e.hasMoreElements()) {
-
this.renderPage((Page) e.nextElement());
-
}
-
System.err.println("writing out PDF");
-
this.pdfDoc.output(writer);
-
}
-
-
/**
-
* add a line to the current stream
-
*
-
* @param x1 the start x location in millipoints
-
* @param y1 the start y location in millipoints
-
* @param x2 the end x location in millipoints
-
* @param y2 the end y location in millipoints
-
* @param th the thickness in millipoints
-
* @param r the red component
-
* @param g the green component
-
* @param b the blue component
-
*/
-
protected void addLine(int x1, int y1, int x2, int y2, int th,
-
float r, float g, float b) {
-
currentStream.add(r + " " + g + " " + b + " RG\n"
-
+ (x1/1000f) + " " + (y1/1000f) + " m "
-
+ (x2/1000f) + " " + (y2/1000f) + " l "
-
+ (th/1000f) + " w S\n"
-
+ "0 0 0 RG\n");
-
}
-
-
/**
-
* add a rectangle to the current stream
-
*
-
* @param x the x position of left edge in millipoints
-
* @param y the y position of top edge in millipoints
-
* @param w the width in millipoints
-
* @param h the height in millipoints
-
* @param r the red component
-
* @param g the green component
-
* @param b the blue component
-
*/
-
protected void addRect(int x, int y, int w, int h,
-
float r, float g, float b) {
-
currentStream.add(r + " " + g + " " + b + " RG\n"
-
+ (x/1000f) + " " + (y/1000f) + " "
-
+ (w/1000f) + " " + (h/1000f) + " re S\n"
-
+ "0 0 0 RG\n");
-
}
-
-
/**
-
* add a filled rectangle to the current stream
-
*
-
* @param x the x position of left edge in millipoints
-
* @param y the y position of top edge in millipoints
-
* @param w the width in millipoints
-
* @param h the height in millipoints
-
* @param r the red component of edges
-
* @param g the green component of edges
-
* @param b the blue component of edges
-
* @param fr the red component of the fill
-
* @param fg the green component of the fill
-
* @param fb the blue component of the fill
-
*/
-
protected void addRect(int x, int y, int w, int h,
-
float r, float g, float b,
-
float fr, float fg, float fb) {
-
currentStream.add(fr + " " + fg + " " + fb + " rg\n"
-
+ r + " " + g + " " + b + " RG\n"
-
+ (x/1000f) + " " + (y/1000f) + " "
-
+ (w/1000f) + " " + (h/1000f) + " re S\n"
-
+ (x/1000f) + " " + (y/1000f) + " "
-
+ (w/1000f) + " " + (h/1000f) + " re f\n"
-
+ "0 0 0 RG 0 0 0 rg\n");
-
}
-
-
/**
-
* render area container to PDF
-
*
-
* @param area the area container to render
-
*/
-
public void renderAreaContainer(AreaContainer area) {
-
-
/* move into position */
-
currentStream.add("1 0 0 1 "
-
+ (area.getXPosition()/1000f) + " "
-
+ (area.getYPosition()/1000f) + " Tm\n");
-
-
this.currentYPosition = area.getYPosition();
-
this.currentAreaContainerXPosition = area.getXPosition();
-
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box) e.nextElement();
-
b.render(this);
-
}
-
}
-
-
/**
-
* render block area to PDF
-
*
-
* @param area the block area to render
-
*/
-
public void renderBlockArea(BlockArea area) {
-
int rx = this.currentAreaContainerXPosition
-
+ area.getStartIndent();
-
int ry = this.currentYPosition;
-
int w = area.getContentWidth();
-
int h = area.getHeight();
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box) e.nextElement();
-
b.render(this);
-
}
-
}
-
-
/**
-
* render display space to PDF
-
*
-
* @param space the display space to render
-
*/
-
public void renderDisplaySpace(DisplaySpace space) {
-
int d = space.getSize();
-
this.currentYPosition -= d;
-
}
-
-
/**
-
* render image area to PDF
-
*
-
* @param area the image area to render
-
*/
-
public void renderImageArea(ImageArea area) {
-
// adapted from contribution by BoBoGi
-
int x = this.currentAreaContainerXPosition +
-
area.getXOffset();
-
int y = this.currentYPosition;
-
int w = area.getContentWidth();
-
int h = area.getHeight();
-
-
this.currentYPosition -= h*1000;
-
-
FopImage img = area.getImage();
-
-
int xObjectNum = this.pdfDoc.addImage(img);
-
-
currentStream.add("ET\nq\n" + (img.getWidth()/1000f) + " 0 0 " +
-
(img.getHeight()/1000f) + " " +
-
((x + img.getX())/1000f) + " " +
-
(((y - h) - img.getY())/1000f) + " cm\n" +
-
"/Im" + xObjectNum + " Do\nQ\nBT\n");
-
}
-
-
/**
-
* render SVG area to PDF
-
*
-
* @param area the SVG area to render
-
*/
-
public void renderSVGArea(SVGArea area) {
-
int x = this.currentAreaContainerXPosition;
-
int y = this.currentYPosition;
-
int w = area.getContentWidth();
-
int h = area.getHeight();
-
this.currentYPosition -= h;
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Object o = e.nextElement();
-
if (o instanceof RectGraphic) {
-
int rx = ((RectGraphic)o).x;
-
int ry = ((RectGraphic)o).y;
-
int rw = ((RectGraphic)o).width;
-
int rh = ((RectGraphic)o).height;
-
addRect(x+rx,y-ry,rw,-rh,0,0,0);
-
} else if (o instanceof LineGraphic) {
-
int x1 = ((LineGraphic)o).x1;
-
int y1 = ((LineGraphic)o).y1;
-
int x2 = ((LineGraphic)o).x2;
-
int y2 = ((LineGraphic)o).y2;
-
addLine(x+x1,y-y1,x+x2,y-y2,0,0,0,0);
-
} else if (o instanceof TextGraphic) {
-
int tx = ((TextGraphic)o).x;
-
int ty = ((TextGraphic)o).y;
-
String s = ((TextGraphic)o).s;
-
currentStream.add("1 0 0 1 "
-
+ ((x+tx)/1000f) + " "
-
+ ((y-ty)/1000f) + " Tm "
-
+ "(" + s + ") Tj\n");
-
}
-
}
-
}
-
-
/**
-
* render inline area to PDF
-
*
-
* @param area inline area to render
-
*/
-
public void renderInlineArea(InlineArea area) {
-
char ch;
-
StringBuffer pdf = new StringBuffer();
-
-
String name = area.getFontState().getFontName();
-
int size = area.getFontState().getFontSize();
-
-
float red = area.getRed();
-
float green = area.getGreen();
-
float blue = area.getBlue();
-
-
if ((!name.equals(this.currentFontName))
-
|| (size != this.currentFontSize)) {
-
this.currentFontName = name;
-
this.currentFontSize = size;
-
pdf = pdf.append("/" + name + " " + (size/1000) + " Tf\n");
-
}
-
-
if ((red != this.currentRed)
-
|| (green != this.currentGreen)
-
|| (blue != this.currentBlue)) {
-
this.currentRed = red;
-
this.currentGreen = green;
-
this.currentBlue = blue;
-
pdf = pdf.append(red + " " + green + " " + blue + " rg\n");
-
}
-
-
int rx = this.currentXPosition;
-
int bl = this.currentYPosition;
-
-
pdf = pdf.append("1 0 0 1 "
-
+(rx/1000f) + " " + (bl/1000f)
-
+ " Tm (");
-
-
String s = area.getText();
-
int l = s.length();
-
-
for (int i=0; i < l; i++) {
-
ch = s.charAt(i);
-
if (ch > 127) {
-
pdf = pdf.append("\\");
-
pdf = pdf.append(Integer.toOctalString((int)ch));
-
} else {
-
switch (ch) {
-
case '(' : pdf = pdf.append("\\("); break;
-
case ')' : pdf = pdf.append("\\)"); break;
-
case '\\' : pdf = pdf.append("\\\\"); break;
-
default : pdf = pdf.append(ch); break;
-
}
-
}
-
}
-
pdf = pdf.append(") Tj\n");
-
-
currentStream.add(pdf.toString());
-
-
this.currentXPosition += area.getContentWidth();
-
}
-
-
/**
-
* render inline space to PDF
-
*
-
* @param space space to render
-
*/
-
public void renderInlineSpace(InlineSpace space) {
-
this.currentXPosition += space.getSize();
-
}
-
-
/**
-
* render line area to PDF
-
*
-
* @param area area to render
-
*/
-
public void renderLineArea(LineArea area) {
-
int rx = this.currentAreaContainerXPosition
-
+ area.getStartIndent();
-
int ry = this.currentYPosition;
-
int w = area.getContentWidth();
-
int h = area.getHeight();
-
-
this.currentYPosition -= area.getPlacementOffset();
-
this.currentXPosition = rx;
-
-
int bl = this.currentYPosition;
-
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box) e.nextElement();
-
b.render(this);
-
}
-
-
this.currentYPosition = ry-h;
-
}
-
-
/**
-
* render page into PDF
-
*
-
* @param page page to render
-
*/
-
public void renderPage(Page page) {
-
AreaContainer body, before, after;
-
-
currentStream = this.pdfDoc.makeStream();
-
body = page.getBody();
-
before = page.getBefore();
-
after = page.getAfter();
-
-
this.currentFontName = "";
-
this.currentFontSize = 0;
-
-
currentStream.add("BT\n");
-
renderAreaContainer(body);
-
-
if (before != null) {
-
renderAreaContainer(before);
-
}
-
-
if (after != null) {
-
renderAreaContainer(after);
-
}
-
-
currentStream.add("ET\n");
-
-
this.pdfDoc.makePage(this.pdfResources, currentStream,
-
page.getWidth()/1000, page.getHeight()/1000);
-
}
-
-
/**
-
* render rule area into PDF
-
*
-
* @param area area to render
-
*/
-
public void renderRuleArea(RuleArea area) {
-
int rx = this.currentAreaContainerXPosition
-
+ area.getStartIndent();
-
int ry = this.currentYPosition;
-
int w = area.getContentWidth();
-
int h = area.getHeight();
-
int th = area.getRuleThickness();
-
float r = area.getRed();
-
float g = area.getGreen();
-
float b = area.getBlue();
-
-
addLine(rx, ry, rx+w, ry, th, r, g, b);
-
}
-
-
/**
-
* set up the font info
-
*
-
* @param fontInfo font info to set up
-
*/
-
public void setupFontInfo(FontInfo fontInfo) {
-
FontSetup.setup(fontInfo);
-
FontSetup.addToResources(this.pdfDoc, fontInfo);
-
}
-
}
-
diff --git a/src/org/apache/fop/render/xml/XMLRenderer.java b/src/org/apache/fop/render/xml/XMLRenderer.java
index 2cfcee908..9bc8fa702 100644
--- a/src/org/apache/fop/render/xml/XMLRenderer.java
+++ b/src/org/apache/fop/render/xml/XMLRenderer.java
@@ -50,553 +50,277 @@
*/
package org.apache.fop.render.xml;
-
-
// FOP
-
import org.apache.fop.svg.*;
-
import org.apache.fop.render.Renderer;
-
import org.apache.fop.image.ImageArea;
-
import org.apache.fop.layout.*;
-
import org.apache.fop.pdf.*;
-
-
// Java
-
import java.io.IOException;
-
import java.io.PrintWriter;
-
import java.util.Enumeration;
-
-
/**
-
* Renderer that renders areas to XML for debugging purposes.
-
*/
-
public class XMLRenderer implements Renderer {
-
-
/** indentation to use for pretty-printing the XML */
-
protected int indent = 0;
-
-
/** the application producing the XML */
-
protected String producer;
-
-
/** the writer used to output the XML */
-
protected PrintWriter writer;
-
-
/**
-
* set the document's producer
-
*
-
* @param producer string indicating application producing the XML
-
*/
-
public void setProducer(String producer) {
-
this.producer = producer;
-
}
-
-
/**
-
* render the areas into XML
-
*
-
* @param areaTree the laid-out area tree
-
* @param writer the PrintWriter to give the XML to
-
*/
-
public void render(AreaTree areaTree, PrintWriter writer)
-
throws IOException {
-
System.err.println("rendering areas to XML");
-
this.writer = writer;
-
this.writer.write("<?xml version=\"1.0\"?>\n<!-- produced by "
-
+ this.producer + " -->\n");
-
writeStartTag("<AreaTree>");
-
Enumeration e = areaTree.getPages().elements();
-
while (e.hasMoreElements()) {
-
this.renderPage((Page) e.nextElement());
-
}
-
writeEndTag("</AreaTree>");
-
this.writer.flush();
-
System.err.println("written out XML");
-
}
-
-
/**
-
* write out spaces to make indent
-
*/
-
protected void writeIndent() {
-
StringBuffer s = new StringBuffer();
-
for (int i= 0; i<this.indent; i++) {
-
s = s.append(" ");
-
}
-
this.writer.write(s.toString());
-
}
-
-
/**
-
* write out an element
-
*
-
* @param element the full text of the element including tags
-
*/
-
protected void writeElement(String element) {
-
writeIndent();
-
this.writer.write(element+"\n");
-
}
-
-
/**
-
* write out an empty-element-tag
-
*
-
* @param tag the text of the tag
-
*/
-
protected void writeEmptyElementTag(String tag) {
-
writeIndent();
-
this.writer.write(tag + "\n");
-
}
-
-
/**
-
* write out an end tag
-
*
-
* @param tag the text of the tag
-
*/
-
protected void writeEndTag(String tag) {
-
this.indent--;
-
writeIndent();
-
this.writer.write(tag + "\n");
-
}
-
-
/**
-
* write out a start tag
-
*
-
* @param tag the text of the tag
-
*/
-
protected void writeStartTag(String tag) {
-
writeIndent();
-
this.writer.write(tag + "\n");
-
this.indent++;
-
}
-
-
/**
-
* set up the font info
-
*
-
* @param fontInfo the font info object to set up
-
*/
-
public void setupFontInfo(FontInfo fontInfo) {
-
-
/* use PDF's font setup to get PDF metrics */
-
org.apache.fop.render.pdf.FontSetup.setup(fontInfo);
-
}
-
-
/**
-
* render an area container to XML
-
*
-
* @param area the area container to render
-
*/
-
public void renderAreaContainer(AreaContainer area) {
-
writeStartTag("<AreaContainer>");
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box) e.nextElement();
-
b.render(this);
-
}
-
writeEndTag("</AreaContainer>");
-
}
-
-
/**
-
* render a block area to XML
-
*
-
* @param area the block area to render
-
*/
-
public void renderBlockArea(BlockArea area) {
-
writeStartTag("<BlockArea start-indent=\""
-
+ area.getStartIndent()
-
+ "\" end-indent=\""
-
+ area.getEndIndent() + "\">");
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box) e.nextElement();
-
b.render(this);
-
}
-
writeEndTag("</BlockArea>");
-
}
-
-
/**
-
* render a display space to XML
-
*
-
* @param space the space to render
-
*/
-
public void renderDisplaySpace(DisplaySpace space) {
-
writeEmptyElementTag("<DisplaySpace size=\""
-
+ space.getSize() +"\"/>");
-
}
-
-
/**
-
* render an SVG area to XML
-
*
-
* @param area the area to render
-
*/
-
public void renderSVGArea(SVGArea area) {
-
writeEmptyElementTag("<SVG/>");
-
}
-
-
/**
-
* render an image area to XML
-
*
-
* @param area the area to render
-
*/
-
public void renderImageArea(ImageArea area) {
-
writeEmptyElementTag("<ImageArea/>");
-
}
-
-
/**
-
* render an inline area to XML
-
*
-
* @param area the area to render
-
*/
-
public void renderInlineArea(InlineArea area) {
-
String fontWeight = area.getFontState().getFontWeight();
-
StringBuffer sb = new StringBuffer();
-
String s = area.getText();
-
int l = s.length();
-
for (int i=0; i < l; i++) {
-
char ch = s.charAt(i);
-
if (ch>127)
-
sb = sb.append("&#"+(int)ch+";");
-
else
-
sb = sb.append(ch);
-
}
-
writeElement("<InlineArea font-weight=\""
-
+ fontWeight + "\" red=\""
-
+ area.getRed() + "\" green=\""
-
+ area.getGreen() + "\" blue = \""
-
+ area.getBlue() + " width = \""
-
+ area.getContentWidth() + "\">" + sb.toString()
-
+ "</InlineArea>");
-
}
-
-
/**
-
* render an inline space to XML
-
*
-
* @param space the space to render
-
*/
-
public void renderInlineSpace(InlineSpace space) {
-
writeEmptyElementTag("<InlineSpace size=\""
-
+ space.getSize() +"\"/>");
-
}
-
-
/**
-
* render a line area to XML
-
*
-
* @param area the area to render
-
*/
-
public void renderLineArea(LineArea area) {
-
String fontWeight = area.getFontState().getFontWeight();
-
writeStartTag("<LineArea font-weight=\""
-
+ fontWeight + "\">");
-
Enumeration e = area.getChildren().elements();
-
while (e.hasMoreElements()) {
-
Box b = (Box)e.nextElement();
-
b.render(this);
-
}
-
writeEndTag("</LineArea>");
-
}
-
-
/**
-
* render a page to XML
-
*
-
* @param page the page to render
-
*/
-
public void renderPage(Page page) {
-
AreaContainer body, before, after;
-
writeStartTag("<Page>");
-
body = page.getBody();
-
before = page.getBefore();
-
after = page.getAfter();
-
if (before != null) {
-
renderAreaContainer(before);
-
}
-
renderAreaContainer(body);
-
if (after != null) {
-
renderAreaContainer(after);
-
}
-
writeEndTag("</Page>");
-
}
-
-
/**
-
* render a rule area to XML
-
*
-
* @param area the area to render
-
*/
-
public void renderRuleArea(RuleArea area) {
-
writeEmptyElementTag("<Rule start-indent=\""
-
+ area.getStartIndent()
-
+ "\" end-indent=\""
-
+ area.getEndIndent()
-
+ "\" rule-thickness=\""
-
+ area.getRuleThickness()
-
+ "\" red=\"" + area.getRed()
-
+ "\" green=\"" + area.getGreen()
-
+ "\" blue = \"" + area.getBlue()
-
+ "\"/>");
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/Graphic.java b/src/org/apache/fop/svg/Graphic.java
index 28fa409ff..cd223a417 100644
--- a/src/org/apache/fop/svg/Graphic.java
+++ b/src/org/apache/fop/svg/Graphic.java
@@ -50,17 +50,9 @@
*/
package org.apache.fop.svg;
-
-
/**
-
* base class for SVG graphic objects.
-
*
-
* Graphic objects include rectangles, lines and text
-
*/
-
public abstract class Graphic {}
-
diff --git a/src/org/apache/fop/svg/Line.java b/src/org/apache/fop/svg/Line.java
index d2a6c191f..27d8f76f8 100644
--- a/src/org/apache/fop/svg/Line.java
+++ b/src/org/apache/fop/svg/Line.java
@@ -50,163 +50,82 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* class representing svg:line pseudo flow object.
-
*/
-
public class Line extends FObj {
-
-
/**
-
* inner class for making Line objects.
-
*/
-
public static class Maker extends FObj.Maker {
-
-
/**
-
* make a Line object.
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*
-
* @return the Line object
-
*/
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Line(parent, propertyList);
-
}
-
}
-
-
/**
-
* returns the maker for this object.
-
*
-
* @return the maker for Line objects
-
*/
-
public static FObj.Maker maker() {
-
return new Line.Maker();
-
}
-
-
/**
-
* constructs a Line object (called by Maker).
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*/
-
protected Line(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "svg:line";
-
}
-
-
/**
-
* layout this formatting object.
-
*
-
* @param area the area to layout the object into
-
*
-
* @return the status of the layout
-
*/
-
public int layout(Area area) throws FOPException {
-
-
/* retrieve properties */
-
int x1 = this.properties.get("x1").getLength().mvalue();
-
int x2 = this.properties.get("x2").getLength().mvalue();
-
int y1 = this.properties.get("y1").getLength().mvalue();
-
int y2 = this.properties.get("y2").getLength().mvalue();
-
-
/* if the area this is being put into is an SVGArea */
-
if (area instanceof SVGArea) {
-
/* add a line to the SVGArea */
-
((SVGArea) area).addGraphic(new LineGraphic(x1, y1, x2, y2));
-
} else {
-
/* otherwise generate a warning */
-
System.err.println("WARNING: svg:line outside svg:svg");
-
}
-
-
/* return status */
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/LineGraphic.java b/src/org/apache/fop/svg/LineGraphic.java
index 6e9dd52eb..59ed032d7 100644
--- a/src/org/apache/fop/svg/LineGraphic.java
+++ b/src/org/apache/fop/svg/LineGraphic.java
@@ -50,69 +50,35 @@
*/
package org.apache.fop.svg;
-
-
/**
-
* class representing a line in an SVG Area
-
*/
-
public class LineGraphic extends Graphic {
-
-
/** x-coordinate of start */
-
public int x1;
-
-
/** y-coordinate of start */
-
public int y1;
-
-
/** x-coordinate of end */
-
public int x2;
-
-
/** y-coordinate of end */
-
public int y2;
-
-
/**
-
* construct a line graphic
-
*
-
* @param x1 x-coordinate of start
-
* @param y1 y-coordinate of start
-
* @param x2 x-coordinate of end
-
* @param y2 y-coordinate of end
-
*/
-
public LineGraphic(int x1, int y1, int x2, int y2) {
-
this.x1 = x1;
-
this.y1 = y1;
-
this.x2 = x2;
-
this.y2 = y2;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/Rect.java b/src/org/apache/fop/svg/Rect.java
index ac2e58e41..722b87e28 100644
--- a/src/org/apache/fop/svg/Rect.java
+++ b/src/org/apache/fop/svg/Rect.java
@@ -50,163 +50,82 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* class representing svg:rect pseudo flow object.
-
*/
-
public class Rect extends FObj {
-
-
/**
-
* inner class for making Rect objects.
-
*/
-
public static class Maker extends FObj.Maker {
-
-
/**
-
* make a Rect object.
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*
-
* @return the Rect object
-
*/
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Rect(parent, propertyList);
-
}
-
}
-
-
/**
-
* returns the maker for this object.
-
*
-
* @return the maker for Rect objects
-
*/
-
public static FObj.Maker maker() {
-
return new Rect.Maker();
-
}
-
-
/**
-
* constructs a Rect object (called by Maker).
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*/
-
protected Rect(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "svg:rect";
-
}
-
-
/**
-
* layout this formatting object.
-
*
-
* @param area the area to layout the object into
-
*
-
* @return the status of the layout
-
*/
-
public int layout(Area area) throws FOPException {
-
-
/* retrieve properties */
-
int width = this.properties.get("width").getLength().mvalue();
-
int height = this.properties.get("height").getLength().mvalue();
-
int x = this.properties.get("x").getLength().mvalue();
-
int y = this.properties.get("y").getLength().mvalue();
-
-
/* if the area this is being put into is an SVGArea */
-
if (area instanceof SVGArea) {
-
/* add a rectangle to the SVGArea */
-
((SVGArea) area).addGraphic(new RectGraphic(x, y, width, height));
-
} else {
-
/* otherwise generate a warning */
-
System.err.println("WARNING: svg:rect outside svg:svg");
-
}
-
-
/* return status */
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/RectGraphic.java b/src/org/apache/fop/svg/RectGraphic.java
index 0f6106d85..72b3fc740 100644
--- a/src/org/apache/fop/svg/RectGraphic.java
+++ b/src/org/apache/fop/svg/RectGraphic.java
@@ -50,69 +50,35 @@
*/
package org.apache.fop.svg;
-
-
/**
-
* class representing a rectangle in an SVG Area
-
*/
-
public class RectGraphic extends Graphic {
-
-
/** x-coordinate of corner */
-
public int x;
-
-
/** y-coordinate of corner */
-
public int y;
-
-
/** width of rectangle */
-
public int width;
-
-
/** height of rectangle */
-
public int height;
-
-
/**
-
* construct a rectangle graphic.
-
*
-
* @param x x-coordinate of corner
-
* @param y y-coordinate of corner
-
* @param width width of rectangle
-
* @param height height of rectangle
-
*/
-
public RectGraphic(int x, int y, int width, int height) {
-
this.x = x;
-
this.y = y;
-
this.width = width;
-
this.height = height;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/SVG.java b/src/org/apache/fop/svg/SVG.java
index 61596262d..27042e2b3 100644
--- a/src/org/apache/fop/svg/SVG.java
+++ b/src/org/apache/fop/svg/SVG.java
@@ -50,353 +50,177 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.BlockArea;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* class representing svg:svg pseudo flow object.
-
*/
-
public class SVG extends FObj {
-
-
/**
-
* inner class for making SVG objects.
-
*/
-
public static class Maker extends FObj.Maker {
-
-
/**
-
* make an SVG object.
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*
-
* @return the SVG object
-
*/
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new SVG(parent, propertyList);
-
}
-
}
-
-
/**
-
* returns the maker for this object.
-
*
-
* @return the maker for SVG objects
-
*/
-
public static FObj.Maker maker() {
-
return new SVG.Maker();
-
}
-
-
FontState fs;
-
int breakBefore;
-
int breakAfter;
-
int width;
-
int height;
-
int spaceBefore;
-
int spaceAfter;
-
-
/**
-
* constructs an SVG object (called by Maker).
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*/
-
public SVG(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "svg:svg";
-
}
-
-
/**
-
* layout this formatting object.
-
*
-
* @param area the area to layout the object into
-
*
-
* @return the status of the layout
-
*/
-
public int layout(Area area) throws FOPException {
-
-
if (this.marker == BREAK_AFTER) {
-
return OK;
-
}
-
-
if (this.marker == START) {
-
/* retrieve properties */
-
String fontFamily = this.properties.get("font-family").getString();
-
String fontStyle = this.properties.get("font-style").getString();
-
String fontWeight = this.properties.get("font-weight").getString();
-
int fontSize = this.properties.get("font-size").getLength().mvalue();
-
-
this.fs = new FontState(area.getFontInfo(), fontFamily,
-
fontStyle, fontWeight, fontSize);
-
-
this.breakBefore = this.properties.get("break-before").getEnum();
-
this.breakAfter = this.properties.get("break-after").getEnum();
-
this.width = this.properties.get("width").getLength().mvalue();
-
this.height = this.properties.get("height").getLength().mvalue();
-
-
this.spaceBefore =
-
this.properties.get("space-before.optimum").getLength().mvalue();
-
this.spaceAfter =
-
this.properties.get("space-after.optimum").getLength().mvalue();
-
/* if the SVG is embedded in a block area */
-
if (area instanceof BlockArea) {
-
/* temporarily end the block area */
-
area.end();
-
}
-
-
this.marker = 0;
-
-
if (breakBefore == BreakBefore.PAGE) {
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakBefore == BreakBefore.ODD_PAGE) {
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakBefore == BreakBefore.EVEN_PAGE) {
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
}
-
-
/* if there is a space-before */
-
if (spaceBefore != 0) {
-
/* add a display space */
-
area.addDisplaySpace(spaceBefore);
-
}
-
-
/* create an SVG area */
-
SVGArea svgArea = new SVGArea(fs, width, height);
-
svgArea.start();
-
-
/* add the SVG area to the containing area */
-
area.addChild(svgArea);
-
-
/* iterate over the child formatting objects and lay them out
-
into the SVG area */
-
int numChildren = this.children.size();
-
for (int i = 0; i < numChildren; i++) {
-
FONode fo = (FONode) children.elementAt(i);
-
int status;
-
if ((status = fo.layout(svgArea)) != OK) {
-
return status;
-
}
-
}
-
-
/* finish off the SVG area */
-
svgArea.end();
-
-
/* increase the height of the containing area accordingly */
-
area.increaseHeight(svgArea.getHeight());
-
-
/* if there is a space-after */
-
if (spaceAfter != 0) {
-
/* add a display space */
-
area.addDisplaySpace(spaceAfter);
-
}
-
-
/* if the SVG is embedded in a block area */
-
if (area instanceof BlockArea) {
-
/* re-start the block area */
-
area.start();
-
}
-
-
if (breakAfter == BreakAfter.PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK;
-
}
-
-
if (breakAfter == BreakAfter.ODD_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_ODD;
-
}
-
-
if (breakAfter == BreakAfter.EVEN_PAGE) {
-
this.marker = BREAK_AFTER;
-
return FORCE_PAGE_BREAK_EVEN;
-
}
-
-
/* return status */
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/SVGArea.java b/src/org/apache/fop/svg/SVGArea.java
index 927d13de2..6347d150d 100644
--- a/src/org/apache/fop/svg/SVGArea.java
+++ b/src/org/apache/fop/svg/SVGArea.java
@@ -50,91 +50,46 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.render.Renderer;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.layout.Area;
-
-
/**
-
* class representing an SVG area in which the SVG graphics sit
-
*/
-
public class SVGArea extends Area {
-
-
/**
-
* construct an SVG area
-
*
-
* @param fontState the font state
-
* @param width the width of the area
-
* @param height the height of the area
-
*/
-
public SVGArea(FontState fontState, int width, int height) {
-
super(fontState, width, height);
-
currentHeight = height;
-
contentRectangleWidth = width;
-
}
-
-
/**
-
* add a graphic.
-
*
-
* Graphics include SVG Rectangles, Lines and Text
-
*
-
* @param graphic the Graphic to add
-
*/
-
public void addGraphic(Graphic graphic) {
-
this.children.addElement(graphic);
-
}
-
-
/**
-
* render the SVG.
-
*
-
* @param renderer the Renderer to use
-
*/
-
public void render(Renderer renderer) {
-
renderer.renderSVGArea(this);
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/SVGElementMapping.java b/src/org/apache/fop/svg/SVGElementMapping.java
index 96db2ce06..32a0f78db 100644
--- a/src/org/apache/fop/svg/SVGElementMapping.java
+++ b/src/org/apache/fop/svg/SVGElementMapping.java
@@ -50,31 +50,16 @@
*/
package org.apache.fop.svg;
-
-
import org.apache.fop.fo.FOTreeBuilder;
-
import org.apache.fop.fo.ElementMapping;
-
-
public class SVGElementMapping implements ElementMapping {
-
-
public void addToBuilder(FOTreeBuilder builder) {
-
String uri = "http://www.w3.org/Graphics/SVG/SVG-19990812.dtd";
-
builder.addMapping(uri, "svg", SVG.maker());
-
builder.addMapping(uri, "rect", Rect.maker());
-
builder.addMapping(uri, "line", Line.maker());
-
builder.addMapping(uri, "text", Text.maker());
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/SVGLength.java b/src/org/apache/fop/svg/SVGLength.java
index aade265bc..8ada872a3 100644
--- a/src/org/apache/fop/svg/SVGLength.java
+++ b/src/org/apache/fop/svg/SVGLength.java
@@ -50,155 +50,78 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.datatypes.*;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* a class representing all the length properties in SVG
-
*/
-
public class SVGLength extends Property {
-
-
/**
-
* inner class for making SVG Length objects.
-
*/
-
public static class Maker extends Property.Maker {
-
-
/**
-
* whether this property is inherited or not.
-
*
-
* @return is this inherited?
-
*/
-
public boolean isInherited() { return false; }
-
-
/**
-
* make an SVG Length property with the given value.
-
*
-
* @param propertyList the property list this is a member of
-
* @param value the explicit string value of the property
-
*/
-
public Property make(PropertyList propertyList, String value)
-
throws FOPException {
-
return new SVGLength(propertyList, new Length(value));
-
}
-
-
/**
-
* make an SVG Length property with the default value.
-
*
-
* @param propertyList the property list the property is a member of
-
*/
-
public Property make(PropertyList propertyList) throws FOPException {
-
return make(propertyList, "0pt");
-
}
-
}
-
-
/**
-
* returns the maker for this object.
-
*
-
* @return the maker for SVG Length objects
-
*/
-
public static Property.Maker maker() {
-
return new SVGLength.Maker();
-
}
-
-
/** the length as a Length object */
-
protected Length value;
-
-
/**
-
* construct an SVG length (called by the Maker).
-
*
-
* @param propertyList the property list this is a member of
-
* @param explicitValue the explicit value as a Length object
-
*/
-
protected SVGLength(PropertyList propertyList, Length explicitValue) {
-
this.propertyList = propertyList;
-
this.value = explicitValue;
-
}
-
-
/**
-
* get the length
-
*
-
* @return the length as a Length object
-
*/
-
public Length getLength() {
-
return this.value;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/Text.java b/src/org/apache/fop/svg/Text.java
index 786d65de9..6794ce009 100644
--- a/src/org/apache/fop/svg/Text.java
+++ b/src/org/apache/fop/svg/Text.java
@@ -50,191 +50,96 @@
*/
package org.apache.fop.svg;
-
-
// FOP
-
import org.apache.fop.fo.*;
-
import org.apache.fop.fo.properties.*;
-
import org.apache.fop.layout.Area;
-
import org.apache.fop.layout.FontState;
-
import org.apache.fop.apps.FOPException;
-
-
/**
-
* class representing svg:text pseudo flow object.
-
*/
-
public class Text extends FObjMixed {
-
-
/**
-
* inner class for making SVG Text objects.
-
*/
-
public static class Maker extends FObj.Maker {
-
-
/**
-
* make an SVG Text object.
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*
-
* @return the SVG Text object
-
*/
-
public FObj make(FObj parent, PropertyList propertyList)
-
throws FOPException {
-
return new Text(parent, propertyList);
-
}
-
}
-
-
/**
-
* returns the maker for this object.
-
*
-
* @return the maker for SVG Text objects
-
*/
-
public static FObj.Maker maker() {
-
return new Text.Maker();
-
}
-
-
/**
-
* the string of text to display
-
*/
-
protected String text = "";
-
-
/**
-
* constructs an SVG Text object (called by Maker).
-
*
-
* @param parent the parent formatting object
-
* @param propertyList the explicit properties of this object
-
*/
-
protected Text(FObj parent, PropertyList propertyList) {
-
super(parent, propertyList);
-
this.name = "svg:text";
-
}
-
-
/**
-
* add characters to the string to display.
-
*
-
* @param data array of characters
-
* @param start start offset in character array
-
* @param length number of characters to add
-
*/
-
protected void addCharacters(char data[], int start, int length) {
-
this.text += new String(data, start, length);
-
}
-
-
/**
-
* layout this formatting object.
-
*
-
* @param area the area to layout the object into
-
*
-
* @return the status of the layout
-
*/
-
public int layout(Area area) throws FOPException {
-
-
/* retrieve properties */
-
int x = this.properties.get("x").getLength().mvalue();
-
int y = this.properties.get("y").getLength().mvalue();
-
-
/* if the area this is being put into is an SVGArea */
-
if (area instanceof SVGArea) {
-
/* add the text to the SVGArea */
-
((SVGArea) area).addGraphic(new TextGraphic(x, y, text));
-
} else {
-
/* otherwise generate a warning */
-
System.err.println("WARNING: svg:text outside svg:svg");
-
}
-
-
/* return status */
-
return OK;
-
}
-
}
-
diff --git a/src/org/apache/fop/svg/TextGraphic.java b/src/org/apache/fop/svg/TextGraphic.java
index 736c74897..98be0c70f 100644
--- a/src/org/apache/fop/svg/TextGraphic.java
+++ b/src/org/apache/fop/svg/TextGraphic.java
@@ -50,59 +50,30 @@
*/
package org.apache.fop.svg;
-
-
/**
-
* class representing text in an SVG Area
-
*/
-
public class TextGraphic extends Graphic {
-
-
/** x-coordinate of text */
-
public int x;
-
-
/** y-coordinate of text */
-
public int y;
-
-
/** the text string itself */
-
public String s;
-
-
/**
-
* construct a text graphic
-
*
-
* @param x x-coordinate of text
-
* @param y y-coordinate of text
-
* @param s the text string
-
*/
-
public TextGraphic(int x, int y, String s) {
-
this.x = x;
-
this.y = y;
-
this.s = s;
-
}
-
}
-