Unembed a font

Tags: fontsembedded fontsiText 7
    This file is part of the iText (R) project.
    Copyright (c) 1998-2016 iText Group NV
 * Example written by Bruno Lowagie in answer to a question by a customer.
package com.itextpdf.samples.sandbox.fonts;
import com.itextpdf.io.font.PdfEncodings;
import com.itextpdf.kernel.font.PdfFont;
import com.itextpdf.kernel.font.PdfFontFactory;
import com.itextpdf.kernel.pdf.*;
import com.itextpdf.layout.Document;
import com.itextpdf.layout.element.Paragraph;
import com.itextpdf.samples.GenericTest;
import com.itextpdf.test.annotations.type.SampleTest;
import org.junit.experimental.categories.Category;
import java.io.File;
public class UnembedFont extends GenericTest {
    public static final String DEST = "./target/test/resources/sandbox/fonts/unembed_font.pdf";
    public static final String SRC = "./target/test/resources/sandbox/fonts/withSerifFont.pdf";
    public static void main(String[] args) throws Exception {
        File file = new File(DEST);
        new UnembedFont().manipulatePdf(DEST);
     * Creates a PDF with an embedded font.
    public void createPdf(String file) throws Exception {
        PdfDocument pdfDoc = new PdfDocument(new PdfWriter(file));
        Document doc = new Document(pdfDoc);
        PdfFont font = PdfFontFactory.createFont("./src/test/resources/font/PT_Serif-Web-Regular.ttf", PdfEncodings.WINANSI, true);
        doc.add(new Paragraph("This is a test with Times New Roman.").setFont(font));
     * Processes a dictionary.
     * In case of font dictionaries, the dictionary is processed.
    public void unembedTTF(PdfDictionary dict) {
        // we ignore all dictionaries that aren't font dictionaries
        if (!PdfName.Font.equals(dict.getAsName(PdfName.Type))) {
        // we only remove TTF fonts
        if (dict.getAsDictionary(PdfName.FontFile2) != null) {
        // check if a subset was used (in which case we remove the prefix)
        PdfName baseFont = dict.getAsName(PdfName.BaseFont);
        if (baseFont.getValue().getBytes()[6] == '+') {
            baseFont = new PdfName(baseFont.getValue().substring(7));
            dict.put(PdfName.BaseFont, baseFont);
        // we check if there's a font descriptor
        PdfDictionary fontDescriptor = dict.getAsDictionary(PdfName.FontDescriptor);
        if (fontDescriptor == null)
        // is there is, we replace the fontname and remove the font file
        fontDescriptor.put(PdfName.FontName, baseFont);
    protected void manipulatePdf(String dest) throws Exception {
        PdfDocument pdfDoc = new PdfDocument(new PdfReader(SRC), new PdfWriter(DEST));
        // / we loop over all objects
        PdfObject obj;
        for (int i = 1; i < pdfDoc.getNumberOfPdfObjects(); i++) {
            obj = pdfDoc.getPdfObject(i);
            // we skip all objects that aren't a dictionary
            if (obj == null || !obj.isDictionary())
            // we process all dictionaries
            unembedTTF((PdfDictionary) obj);
        // The unused objects will be removed automatically
        // we persist the altered document
File nameRaw URLUpdated
UnembedFont.javaUnembedFont.java2016-08-08 4:59 pm
File nameRaw URLUpdated
cmp_unembed_font.pdfcmp_unembed_font.pdf2016-08-08 5:00 pm