123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216 |
- /*
- * Copyright 2006 The Apache Software Foundation.
- *
- * Licensed 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: ExampleDOM2PDF.java 332791 2005-11-12 15:58:07Z jeremias $ */
-
- package embedding.intermediate;
-
- 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.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 org.xml.sax.SAXException;
-
- import embedding.ExampleObj2XML;
- import embedding.model.ProjectMember;
- import embedding.model.ProjectTeam;
-
- /**
- * Example for the intermediate format that demonstrates the concatenation of two documents
- * renderered to the intermediate format. A single PDF file is generated from the two intermediate
- * files.
- */
- public class ExampleConcat {
-
- // configure fopFactory as desired
- private FopFactory fopFactory = FopFactory.newInstance();
-
- /**
- * 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 intermediate file.
- * @param src the source file
- * @param xslt the stylesheet file
- * @param intermediate the target intermediate file (area tree XML)
- * @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 convertToIntermediate(Source src, Source xslt, File intermediate)
- 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 intermediate format (area tree XML)
- XMLRenderer xmlRenderer = new XMLRenderer();
- xmlRenderer.setUserAgent(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(intermediate);
- 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 = new Fop(MimeConstants.MIME_FOP_AREA_TREE, 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 intermediate files to a single PDF file.
- * @param files the array of intermediate files (area tree XML)
- * @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 intermediate 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("Intermediate 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 intermediate files
- app.convertToIntermediate(
- team1.getSourceForProjectTeam(),
- new StreamSource(xsltfile), files[0]);
- app.convertToIntermediate(
- team2.getSourceForProjectTeam(),
- new StreamSource(xsltfile), files[1]);
-
- //Concatenate the individual intermediate files to one document
- app.concatToPDF(files, pdffile);
-
- System.out.println("Success!");
-
- } catch (Exception e) {
- e.printStackTrace(System.err);
- System.exit(-1);
- }
- }
-
- }
|