123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
- /* $Id$ */
-
- package embedding.atxml;
-
- import java.io.File;
- import java.io.IOException;
- import java.io.OutputStream;
-
- import javax.xml.transform.Result;
- import javax.xml.transform.Source;
- import javax.xml.transform.Transformer;
- import javax.xml.transform.TransformerException;
- import javax.xml.transform.TransformerFactory;
- import javax.xml.transform.sax.SAXResult;
- import javax.xml.transform.stream.StreamSource;
-
- import org.xml.sax.SAXException;
-
- import org.apache.fop.apps.FOPException;
- import org.apache.fop.apps.FOUserAgent;
- import org.apache.fop.apps.Fop;
- import org.apache.fop.apps.FopFactory;
- import org.apache.fop.apps.MimeConstants;
- import org.apache.fop.area.AreaTreeModel;
- import org.apache.fop.area.AreaTreeParser;
- import org.apache.fop.area.RenderPagesModel;
- import org.apache.fop.fonts.FontInfo;
- import org.apache.fop.render.Renderer;
- import org.apache.fop.render.xml.XMLRenderer;
-
- import embedding.ExampleObj2XML;
- import embedding.model.ProjectMember;
- import embedding.model.ProjectTeam;
-
- /**
- * Example for the area tree XML format that demonstrates the concatenation of two documents
- * rendered to the area tree XML format. A single PDF file is generated from the two area tree
- * files.
- */
- public class ExampleConcat {
-
- // configure fopFactory as desired
- private final FopFactory fopFactory = FopFactory.newInstance(new File(".").toURI());
-
- /**
- * Creates a sample ProjectTeam instance for this demo.
- * @return ProjectTeam the newly created ProjectTeam instance
- */
- public static ProjectTeam createAnotherProjectTeam() {
- ProjectTeam team = new ProjectTeam();
- team.setProjectName("The Dynamic Duo");
- team.addMember(new ProjectMember(
- "Batman", "lead", "batman@heroes.org"));
- team.addMember(new ProjectMember(
- "Robin", "aid", "robin@heroes.org"));
- return team;
- }
-
- /**
- * Converts an XSL-FO document to an area tree XML file.
- * @param src the source file
- * @param xslt the stylesheet file
- * @param areaTreeFile the target area tree XML file
- * @throws IOException In case of an I/O problem
- * @throws FOPException In case of a FOP problem
- * @throws TransformerException In case of a XSL transformation problem
- */
- public void convertToAreaTreeXML(Source src, Source xslt, File areaTreeFile)
- throws IOException, FOPException, TransformerException {
-
- //Create a user agent
- FOUserAgent userAgent = fopFactory.newFOUserAgent();
-
- //Create an instance of the target renderer so the XMLRenderer can use its font setup
- Renderer targetRenderer = userAgent.getRendererFactory().createRenderer(
- userAgent, MimeConstants.MIME_PDF);
-
- //Create the XMLRenderer to create the area tree XML
- XMLRenderer xmlRenderer = new XMLRenderer(userAgent);
-
- //Tell the XMLRenderer to mimic the target renderer
- xmlRenderer.mimicRenderer(targetRenderer);
-
- //Make sure the prepared XMLRenderer is used
- userAgent.setRendererOverride(xmlRenderer);
-
- // Setup output
- OutputStream out = new java.io.FileOutputStream(areaTreeFile);
- out = new java.io.BufferedOutputStream(out);
- try {
- // Construct fop (the MIME type here is unimportant due to the override
- // on the user agent)
- Fop fop = fopFactory.newFop(null, userAgent, out);
-
- // Setup XSLT
- TransformerFactory factory = TransformerFactory.newInstance();
- Transformer transformer;
- if (xslt != null) {
- transformer = factory.newTransformer(xslt);
- } else {
- transformer = factory.newTransformer();
- }
-
- // Resulting SAX events (the generated FO) must be piped through to FOP
- Result res = new SAXResult(fop.getDefaultHandler());
-
- // Start XSLT transformation and FOP processing
- transformer.transform(src, res);
- } finally {
- out.close();
- }
- }
-
- /**
- * Concatenates an array of area tree XML files to a single PDF file.
- * @param files the array of area tree XML files
- * @param pdffile the target PDF file
- * @throws IOException In case of an I/O problem
- * @throws TransformerException In case of a XSL transformation problem
- * @throws SAXException In case of an XML-related problem
- */
- public void concatToPDF(File[] files, File pdffile)
- throws IOException, TransformerException, SAXException {
- // Setup output
- OutputStream out = new java.io.FileOutputStream(pdffile);
- out = new java.io.BufferedOutputStream(out);
- try {
- //Setup fonts and user agent
- FontInfo fontInfo = new FontInfo();
- FOUserAgent userAgent = fopFactory.newFOUserAgent();
-
- //Construct the AreaTreeModel that will received the individual pages
- AreaTreeModel treeModel = new RenderPagesModel(userAgent,
- MimeConstants.MIME_PDF, fontInfo, out);
-
- //Iterate over all area tree files
- AreaTreeParser parser = new AreaTreeParser();
- for (int i = 0; i < files.length; i++) {
- Source src = new StreamSource(files[i]);
- parser.parse(src, treeModel, userAgent);
- }
-
- //Signal the end of the processing. The renderer can finalize the target document.
- treeModel.endDocument();
- } finally {
- out.close();
- }
- }
-
- /**
- * Main method.
- * @param args command-line arguments
- */
- public static void main(String[] args) {
- try {
- System.out.println("FOP ExampleConcat\n");
-
- //Setup directories
- File baseDir = new File(".");
- File outDir = new File(baseDir, "out");
- outDir.mkdirs();
-
- //Setup output file
- File xsltfile = new File(baseDir, "xml/xslt/projectteam2fo.xsl");
- File[] files = new File[] {
- new File(outDir, "team1.at.xml"),
- new File(outDir, "team2.at.xml")};
- File pdffile = new File(outDir, "ResultConcat.pdf");
- for (int i = 0; i < files.length; i++) {
- System.out.println("Area Tree XML file " + (i + 1) + ": "
- + files[i].getCanonicalPath());
- }
- System.out.println("PDF Output File: " + pdffile.getCanonicalPath());
- System.out.println();
-
-
- ProjectTeam team1 = ExampleObj2XML.createSampleProjectTeam();
- ProjectTeam team2 = createAnotherProjectTeam();
-
- ExampleConcat app = new ExampleConcat();
-
- //Create area tree XML files
- app.convertToAreaTreeXML(
- team1.getSourceForProjectTeam(),
- new StreamSource(xsltfile), files[0]);
- app.convertToAreaTreeXML(
- team2.getSourceForProjectTeam(),
- new StreamSource(xsltfile), files[1]);
-
- //Concatenate the individual area tree files to one document
- app.concatToPDF(files, pdffile);
-
- System.out.println("Success!");
-
- } catch (Exception e) {
- e.printStackTrace(System.err);
- System.exit(-1);
- }
- }
-
- }
|