All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.docx4j.convert.out.FORenderer Maven / Gradle / Ivy

Go to download

docx4j is a library which helps you to work with the Office Open XML file format as used in docx documents, pptx presentations, and xlsx spreadsheets.

There is a newer version: 11.4.11
Show newest version
/*
   Licensed to Plutext Pty Ltd under one or more contributor license agreements.  
   
 *  This file is part of docx4j.

    docx4j is 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.

 */
package org.docx4j.convert.out;

import java.io.OutputStream;
import java.util.List;

import org.docx4j.openpackaging.exceptions.Docx4JException;

/** The pdf conversion process needs a fo renderer to convert the 
 *  fo document into the requested format. The fo renderer is encapsulated in 
 *  this interface.
* * The FORenderer can be: * * 1. The default ApacheFORenderer that gets used if no custom FORenderer has been passed. * This renderer contains the functionality and replaces the classes FopFactoryUtil and FopResultUtils. * The configuration and the result mime is passed via the FOSettings. * * 2. A custom implementation of the FORenderer interface that gets passed via the FOSettings to the * conversion process. * * 3. The DummyFORenderer, that gets used if INTERNAL_FO_MIME has been selected as the output format * in apacheFopMime. Passing the INTERNAL_FO_MIME as the result mime acts as a flag, it selects the * DummyFORenderer and ensures that the rendering is done as a one pass process (in this case, the * result might not be correct, since a two pass conversion may be necessary). The DummyFORenderer itself * just passes the generated fo to the output stream. * * The conversion process might need a two pass conversion, if this is the case, * then the body of some elements might contain a placeholder that needs to be * replaced with the page count in the document or the page count in the section. * A placeholder for the page count of the document is defined as
* PLACEHOLDER_PREFIX + getDocumentPageCountID() + PLACEHOLDER_SUFFIX
* A placeholder for the page count of a section is defined as
* PLACEHOLDER_PREFIX + getSectionPageCountID() + PLACEHOLDER_SUFFIX
* The values need to be calculated by the renderer and the placeholder replaced. The format * of the numbers is defined for the page count of the document by getDocumentPageCountFoFormat() and * the one for the section by getSectionPageCountFoFormat(); * * @since 3.0 */ public interface FORenderer { public static final String PLACEHOLDER_PREFIX = "${"; public static final String PLACEHOLDER_SUFFIX = "}"; /** The definition for the IDs and formats for the page count of one Section. * */ public interface SectionPageInformation { public String getDocumentPageCountID(); public String getDocumentPageCountFoFormat(); public String getSectionPageCountID(); public String getSectionPageCountFoFormat(); } /** Render the foDocument to the requested format, if needed do a 2 pass conversion. * * @param foDocument the fo document to be rendered. * @param settings the conversion settings passed to the conversion process * @param twoPass a two pass rendering might be needed, i.e. the body of some tags contain placeholder * How the renderer calculates the corresponding values and replaces them is its responsability * @param pageNumberInformation This list contains an entry for each section in the document. It defines * the IDs of the corresponding placeholders and the number format (as a fo format).
* This List is only available if twoPass = true. * @param outputStream The output stream on which the output should be rendered * @throws Docx4JException */ public void render(String foDocument, FOSettings settings, boolean twoPass, List pageNumberInformation, OutputStream outputStream) throws Docx4JException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy