123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- /*
- * Copyright 2005 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$ */
-
- package embedding;
-
- // Java
- import java.io.BufferedOutputStream;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.OutputStream;
-
- //JAXP
- import javax.xml.transform.Transformer;
- import javax.xml.transform.TransformerFactory;
- import javax.xml.transform.Source;
- import javax.xml.transform.Result;
- import javax.xml.transform.stream.StreamSource;
- import javax.xml.transform.sax.SAXResult;
-
- // FOP
- import org.apache.fop.apps.Fop;
- import org.apache.fop.apps.FOPException;
- import org.apache.fop.apps.MimeConstants;
-
- /**
- * This class demonstrates the conversion of an FO file to RTF using FOP.
- * <p>
- * Please note that this is practically the same as the ExampleFO2PDF example. Only
- * one parameter to the Fop contructor is different!
- */
- public class ExampleFO2RTF {
-
- /**
- * Converts an FO file to a RTF file using FOP
- * @param fo the FO file
- * @param rtf the target RTF file
- * @throws IOException In case of an I/O problem
- * @throws FOPException In case of a FOP problem
- */
- public void convertFO2RTF(File fo, File rtf) throws IOException, FOPException {
-
- OutputStream out = null;
-
- try {
- // Construct fop with desired output format
- Fop fop = new Fop(MimeConstants.MIME_RTF);
-
- // Setup output stream. Note: Using BufferedOutputStream
- // for performance reasons (helpful with FileOutputStreams).
- out = new FileOutputStream(rtf);
- out = new BufferedOutputStream(out);
- fop.setOutputStream(out);
-
- // Setup JAXP using identity transformer
- TransformerFactory factory = TransformerFactory.newInstance();
- Transformer transformer = factory.newTransformer(); // identity transformer
-
- // Setup input stream
- Source src = new StreamSource(fo);
-
- // 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);
-
- // Please note: getResults() won't work for RTF and other flow formats (like MIF)
- // as the layout engine is not involved in the conversion. The page-breaking
- // is done by the application opening the generated file (like MS Word).
- //FormattingResults foResults = fop.getResults();
-
- } catch (Exception e) {
- e.printStackTrace(System.err);
- System.exit(-1);
- } finally {
- out.close();
- }
- }
-
-
- /**
- * Main method.
- * @param args command-line arguments
- */
- public static void main(String[] args) {
- try {
- System.out.println("FOP ExampleFO2RTF\n");
- System.out.println("Preparing...");
-
- //Setup directories
- File baseDir = new File(".");
- File outDir = new File(baseDir, "out");
- outDir.mkdirs();
-
- //Setup input and output files
- File fofile = new File(baseDir, "xml/fo/helloworld.fo");
- File rtffile = new File(outDir, "ResultFO2RTF.rtf");
-
- System.out.println("Input: XSL-FO (" + fofile + ")");
- System.out.println("Output: PDF (" + rtffile + ")");
- System.out.println();
- System.out.println("Transforming...");
-
- ExampleFO2RTF app = new ExampleFO2RTF();
- app.convertFO2RTF(fofile, rtffile);
-
- System.out.println("Success!");
- } catch (Exception e) {
- e.printStackTrace(System.err);
- System.exit(-1);
- }
- }
- }
|