org.docx4j.fonts.fop.util.FopConfigUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of docx4j Show documentation
Show all versions of docx4j Show documentation
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.
/*
* Copyright 2007-2008, Plutext Pty Ltd.
*
* 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.fonts.fop.util;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.docx4j.fonts.Mapper;
import org.docx4j.fonts.PhysicalFont;
import org.docx4j.fonts.PhysicalFonts;
import org.docx4j.fonts.fop.fonts.FontTriplet;
import org.docx4j.openpackaging.exceptions.Docx4JException;
/**
* The sole role of this class is to create an avalon configuration
* (as a String)
* which can be used to configure FOP 1.1 and earlier,
* or FOP post 1.1
*
* @author jharrop
*
*/
public class FopConfigUtil {
protected static Logger log = LoggerFactory.getLogger(FopConfigUtil.class);
public static String createDefaultConfiguration(Mapper fontMapper, Set fontsInUse) throws Docx4JException {
// public static Configuration createDefaultConfiguration(Mapper fontMapper, Map fontsInUse) throws Docx4JException {
// This method now returns a String, since that works best
// with FOP going forward. See comments in FopFactoryUtil.
StringBuilder buffer = new StringBuilder(10240);
buffer.append("true ");
buffer.append("");
buffer.append("");
declareFonts(fontMapper, fontsInUse, buffer);
buffer.append(" ");
if (log.isDebugEnabled()) {
log.debug("\nUsing fop config:\n " + buffer.toString() + "\n");
}
// See FOP's PrintRendererConfigurator
// String myConfig = "true "
// +
// "" +
// "C:\\WINDOWS\\Fonts " +
// " " +
// " ";
return buffer.toString();
}
/**
* Create a FOP font configuration for each font used in the
* document.
*
* @return
*/
protected static void declareFonts(Mapper fontMapper, Set fontsInUse, StringBuilder result) {
for (String fontName : fontsInUse) {
PhysicalFont pf = fontMapper.getFontMappings().get(fontName);
if (pf==null) {
log.error("Document font " + fontName + " is not mapped to a physical font!");
continue;
}
String subFontAtt = "";
if (pf.getEmbedFontInfo().getSubFontName()!=null)
subFontAtt= " sub-font=\"" + pf.getEmbedFontInfo().getSubFontName() + "\"";
result.append("" );
// now add the first font triplet
FontTriplet fontTriplet = (FontTriplet)pf.getEmbedFontInfo().getFontTriplets().get(0);
addFontTriplet(result, fontTriplet);
result.append("" );
// bold, italic etc
PhysicalFont pfVariation = PhysicalFonts.getBoldForm(pf);
if (pfVariation==null) {
log.debug(fontName + " no bold form");
} else {
result.append("" );
addFontTriplet(result, pf.getName(), "normal", "bold");
result.append("" );
}
pfVariation = PhysicalFonts.getBoldItalicForm(pf);
if (pfVariation==null) {
log.debug(fontName + " no bold italic form");
} else {
result.append("" );
addFontTriplet(result, pf.getName(), "italic", "bold");
result.append("" );
}
pfVariation = PhysicalFonts.getItalicForm(pf);
if (pfVariation==null) {
log.debug(fontName + " no italic form");
} else {
result.append("" );
addFontTriplet(result, pf.getName(), "italic", "normal");
result.append("" );
}
}
}
protected static void addFontTriplet(StringBuilder result, FontTriplet fontTriplet) {
addFontTriplet(result, fontTriplet.getName(),
fontTriplet.getStyle(),
weightToCSS2FontWeight(fontTriplet.getWeight()));
}
protected static void addFontTriplet(StringBuilder result, String familyName, String style, String weight) {
result.append(" ");
}
protected static String weightToCSS2FontWeight(int i) {
return (i >= 700 ? "bold" : "normal");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy