⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pdfcopy.java

📁 处理PDF
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * $Id: PdfCopy.java 3527 2008-07-06 15:34:38Z blowagie $ * * Copyright (C) 2002 Mark Thompson * * The contents of this file are subject to the Mozilla Public License Version 1.1 * (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.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the License. * * The Original Code is 'iText, a free JAVA-PDF library'. * * The Initial Developer of the Original Code is Bruno Lowagie. Portions created by * the Initial Developer are Copyright (C) 1999, 2000, 2001, 2002 by Bruno Lowagie. * All Rights Reserved. * Co-Developer of the code is Paulo Soares. Portions created by the Co-Developer * are Copyright (C) 2000, 2001, 2002 by Paulo Soares. All Rights Reserved. * * Contributor(s): all the names of the contributors are added in the source code * where applicable. * * Alternatively, the contents of this file may be used under the terms of the * LGPL license (the "GNU LIBRARY GENERAL PUBLIC LICENSE"), in which case the * provisions of LGPL are applicable instead of those above.  If you wish to * allow use of your version of this file only under the terms of the LGPL * License and not to allow others to use your version of this file under * the MPL, indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by the LGPL. * If you do not delete the provisions above, a recipient may use your version * of this file under either the MPL or the GNU LIBRARY GENERAL PUBLIC LICENSE. * * This library is free software; you can redistribute it and/or modify it * under the terms of the MPL as stated above or under the terms of the GNU * Library General Public License as published by the Free Software Foundation; * either version 2 of the License, or any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Library general Public License for more * details. * * If you didn't download this code from the following link, you should check if * you aren't using an obsolete version: * http://www.lowagie.com/iText/ */package com.lowagie.text.pdf;import java.io.IOException;import java.io.OutputStream;import java.util.HashMap;import java.util.Iterator;import com.lowagie.text.Document;import com.lowagie.text.DocumentException;import com.lowagie.text.ExceptionConverter;import com.lowagie.text.Rectangle;import java.util.ArrayList;/** * Make copies of PDF documents. Documents can be edited after reading and * before writing them out. * @author Mark Thompson */public class PdfCopy extends PdfWriter {    /**     * This class holds information about indirect references, since they are     * renumbered by iText.     */    static class IndirectReferences {        PdfIndirectReference theRef;        boolean hasCopied;        IndirectReferences(PdfIndirectReference ref) {            theRef = ref;            hasCopied = false;        }        void setCopied() { hasCopied = true; }        boolean getCopied() { return hasCopied; }        PdfIndirectReference getRef() { return theRef; }    };    protected HashMap indirects;    protected HashMap indirectMap;    protected int currentObjectNum = 1;    protected PdfReader reader;    protected PdfIndirectReference acroForm;    protected int[] namePtr = {0};    /** Holds value of property rotateContents. */    private boolean rotateContents = true;    protected PdfArray fieldArray;    protected HashMap fieldTemplates;        /**     * A key to allow us to hash indirect references     */    protected static class RefKey {        int num;        int gen;        RefKey(int num, int gen) {            this.num = num;            this.gen = gen;        }        RefKey(PdfIndirectReference ref) {            num = ref.getNumber();            gen = ref.getGeneration();        }        RefKey(PRIndirectReference ref) {            num = ref.getNumber();            gen = ref.getGeneration();        }        public int hashCode() {            return (gen<<16)+num;        }        public boolean equals(Object o) {            if (!(o instanceof RefKey)) return false;            RefKey other = (RefKey)o;            return this.gen == other.gen && this.num == other.num;        }        public String toString() {            return Integer.toString(num) + ' ' + gen;        }    }        /**     * Constructor     * @param document     * @param os outputstream     */    public PdfCopy(Document document, OutputStream os) throws DocumentException {        super(new PdfDocument(), os);        document.addDocListener(pdf);        pdf.addWriter(this);        indirectMap = new HashMap();    }    /** Getter for property rotateContents.     * @return Value of property rotateContents.     *     */    public boolean isRotateContents() {        return this.rotateContents;    }        /** Setter for property rotateContents.     * @param rotateContents New value of property rotateContents.     *     */    public void setRotateContents(boolean rotateContents) {        this.rotateContents = rotateContents;    }    /**     * Grabs a page from the input document     * @param reader the reader of the document     * @param pageNumber which page to get     * @return the page     */    public PdfImportedPage getImportedPage(PdfReader reader, int pageNumber) {        if (currentPdfReaderInstance != null) {            if (currentPdfReaderInstance.getReader() != reader) {                try {                    currentPdfReaderInstance.getReader().close();                    currentPdfReaderInstance.getReaderFile().close();                }                catch (IOException ioe) {                    // empty on purpose                }                currentPdfReaderInstance = reader.getPdfReaderInstance(this);            }        }        else {            currentPdfReaderInstance = reader.getPdfReaderInstance(this);        }        return currentPdfReaderInstance.getImportedPage(pageNumber);                }            /**     * Translate a PRIndirectReference to a PdfIndirectReference     * In addition, translates the object numbers, and copies the     * referenced object to the output file.     * NB: PRIndirectReferences (and PRIndirectObjects) really need to know what     * file they came from, because each file has its own namespace. The translation     * we do from their namespace to ours is *at best* heuristic, and guaranteed to     * fail under some circumstances.     */    protected PdfIndirectReference copyIndirect(PRIndirectReference in) throws IOException, BadPdfFormatException {        PdfIndirectReference theRef;        RefKey key = new RefKey(in);        IndirectReferences iRef = (IndirectReferences)indirects.get(key);        if (iRef != null) {            theRef = iRef.getRef();            if (iRef.getCopied()) {                return theRef;            }        }        else {            theRef = body.getPdfIndirectReference();            iRef = new IndirectReferences(theRef);            indirects.put(key, iRef);        }        PdfObject obj = PdfReader.getPdfObjectRelease(in);        if (obj != null && obj.isDictionary()) {            PdfObject type = PdfReader.getPdfObjectRelease(((PdfDictionary)obj).get(PdfName.TYPE));            if (type != null && PdfName.PAGE.equals(type)) {                return theRef;            }        }        iRef.setCopied();        obj = copyObject(obj);        addToBody(obj, theRef);        return theRef;    }        /**     * Translate a PRDictionary to a PdfDictionary. Also translate all of the     * objects contained in it.     */    protected PdfDictionary copyDictionary(PdfDictionary in)    throws IOException, BadPdfFormatException {        PdfDictionary out = new PdfDictionary();        PdfObject type = PdfReader.getPdfObjectRelease(in.get(PdfName.TYPE));                for (Iterator it = in.getKeys().iterator(); it.hasNext();) {            PdfName key = (PdfName)it.next();            PdfObject value = in.get(key);            //	    System.out.println("Copy " + key);            if (type != null && PdfName.PAGE.equals(type)) {                if (!key.equals(PdfName.B) && !key.equals(PdfName.PARENT))                    out.put(key, copyObject(value));            }            else                out.put(key, copyObject(value));        }        return out;    }        /**     * Translate a PRStream to a PdfStream. The data part copies itself.     */    protected PdfStream copyStream(PRStream in) throws IOException, BadPdfFormatException {        PRStream out = new PRStream(in, null);                for (Iterator it = in.getKeys().iterator(); it.hasNext();) {            PdfName key = (PdfName) it.next();            PdfObject value = in.get(key);            out.put(key, copyObject(value));        }                return out;    }            /**     * Translate a PRArray to a PdfArray. Also translate all of the objects contained     * in it     */    protected PdfArray copyArray(PdfArray in) throws IOException, BadPdfFormatException {        PdfArray out = new PdfArray();                for (Iterator i = in.getArrayList().iterator(); i.hasNext();) {            PdfObject value = (PdfObject)i.next();            out.add(copyObject(value));        }        return out;    }        /**     * Translate a PR-object to a Pdf-object     */    protected PdfObject copyObject(PdfObject in) throws IOException,BadPdfFormatException {        if (in == null)            return PdfNull.PDFNULL;        switch (in.type) {            case PdfObject.DICTIONARY:                //	        System.out.println("Dictionary: " + in.toString());                return copyDictionary((PdfDictionary)in);            case PdfObject.INDIRECT:                return copyIndirect((PRIndirectReference)in);            case PdfObject.ARRAY:                return copyArray((PdfArray)in);            case PdfObject.NUMBER:            case PdfObject.NAME:            case PdfObject.STRING:            case PdfObject.NULL:            case PdfObject.BOOLEAN:            case 0:                return in;            case PdfObject.STREAM:                return copyStream((PRStream)in);                //                return in;            default:                if (in.type < 0) {                    String lit = ((PdfLiteral)in).toString();                    if (lit.equals("true") || lit.equals("false")) {                        return new PdfBoolean(lit);                    }                    return new PdfLiteral(lit);                }                System.out.println("CANNOT COPY type " + in.type);                return null;        }    }        /**     * convenience method. Given an imported page, set our "globals"     */    protected int setFromIPage(PdfImportedPage iPage) {        int pageNum = iPage.getPageNumber();        PdfReaderInstance inst = currentPdfReaderInstance = iPage.getPdfReaderInstance();        reader = inst.getReader();        setFromReader(reader);        return pageNum;    }        /**     * convenience method. Given a reader, set our "globals"     */    protected void setFromReader(PdfReader reader) {        this.reader = reader;        indirects = (HashMap)indirectMap.get(reader);        if (indirects == null) {            indirects = new HashMap();            indirectMap.put(reader,indirects);            PdfDictionary catalog = reader.getCatalog();            PRIndirectReference ref = null;            PdfObject o = catalog.get(PdfName.ACROFORM);            if (o == null || o.type() != PdfObject.INDIRECT)                return;            ref = (PRIndirectReference)o;            if (acroForm == null) acroForm = body.getPdfIndirectReference();            indirects.put(new RefKey(ref), new IndirectReferences(acroForm));        }    }    /**     * Add an imported page to our output     * @param iPage an imported page     * @throws IOException, BadPdfFormatException     */    public void addPage(PdfImportedPage iPage) throws IOException, BadPdfFormatException {        int pageNum = setFromIPage(iPage);                PdfDictionary thePage = reader.getPageN(pageNum);        PRIndirectReference origRef = reader.getPageOrigRef(pageNum);        reader.releasePage(pageNum);        RefKey key = new RefKey(origRef);        PdfIndirectReference pageRef;        IndirectReferences iRef = (IndirectReferences)indirects.get(key);        if (iRef != null && !iRef.getCopied()) {            pageReferences.add(iRef.getRef());            iRef.setCopied();        }        pageRef = getCurrentPage();        if (iRef == null) {            iRef = new IndirectReferences(pageRef);            indirects.put(key, iRef);        }        iRef.setCopied();        PdfDictionary newPage = copyDictionary(thePage);        root.addPage(newPage);        ++currentPageNumber;    }        /**     * Copy the acroform for an input document. Note that you can only have one,     * we make no effort to merge them.     * @param reader The reader of the input file that is being copied     * @throws IOException, BadPdfFormatException     */    public void copyAcroForm(PdfReader reader) throws IOException, BadPdfFormatException {        setFromReader(reader);                PdfDictionary catalog = reader.getCatalog();        PRIndirectReference hisRef = null;        PdfObject o = catalog.get(PdfName.ACROFORM);        if (o != null && o.type() == PdfObject.INDIRECT)            hisRef = (PRIndirectReference)o;        if (hisRef == null) return; // bugfix by John Englar        RefKey key = new RefKey(hisRef);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -