首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从现有Pdf和(HTML + CSS)创建新Pdf

从现有Pdf和(HTML + CSS)创建新Pdf
EN

Stack Overflow用户
提问于 2015-10-07 01:22:39
回答 2查看 852关注 0票数 0

我的用例是我在运行中生成pdf。我也有一个pdf单页。我想在现有的PDF页面之前/之后连接新生成的pdf。

我已经能够从超文本标记语言生成PDF (这可能导致2-3个页面) Pdf from HTML with CSS

我试着查看示例,其中之一是连接现有的PDF分页Working with existing PDFs - Concatenate

EN

回答 2

Stack Overflow用户

发布于 2015-10-07 01:46:40

试一下这个例子:

代码语言:javascript
复制
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfContentByte;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfWriter;

public class UtilPDF {

    public static void main(String[] args) {
    try {
        List<InputStream> pdfs = new ArrayList<InputStream>();

        File pdfDir = new File("C:\\PDF");

        boolean pdfDirectoryExists = true;
        if (!pdfDir.exists()) {
            pdfDirectoryExists = pdfDir.mkdir();
        }

        if (pdfDirectoryExists) {
            pdfs.add(new FileInputStream("C:\\PDF\\Document1.pdf"));
            pdfs.add(new FileInputStream("C:\\PDF\\Document2.pdf"));
            OutputStream output = new FileOutputStream("C:\\Projects\\FinalDocument_1_2.pdf");
            UtilPDF.concatPDFs(pdfs, output, true);
        }

    } catch (Exception e) {
        e.printStackTrace();
    }
}

public static void concatPDFs(List<InputStream> streamOfPDFFiles, OutputStream outputStream, boolean paginate) {
    Document document = new Document();

    try {
        List<InputStream> pdfs = streamOfPDFFiles;
        List<PdfReader> readers = new ArrayList<PdfReader>();
        int totalPages = 0;
        Iterator<InputStream> iteratorPDFs = pdfs.iterator();

        // Create Readers for the pdfs.
        while (iteratorPDFs.hasNext()) {
            InputStream pdf = iteratorPDFs.next();
            PdfReader pdfReader = new PdfReader(pdf);
            readers.add(pdfReader);
            totalPages += pdfReader.getNumberOfPages();
        }

        // Create a writer for the outputstream
        PdfWriter writer = PdfWriter.getInstance(document, outputStream);
        document.open();
        BaseFont bf = BaseFont.createFont(BaseFont.HELVETICA, BaseFont.CP1252, BaseFont.NOT_EMBEDDED);
        PdfContentByte cb = writer.getDirectContent(); // Holds the PDF

        // data
        PdfImportedPage page;
        int currentPageNumber = 0;
        int pageOfCurrentReaderPDF = 0;
        Iterator<PdfReader> iteratorPDFReader = readers.iterator();

        // Loop through the PDF files and add to the output.
        while (iteratorPDFReader.hasNext()) {
            PdfReader pdfReader = iteratorPDFReader.next();

            // Create a new page in the target for each source page.
            while (pageOfCurrentReaderPDF < pdfReader.getNumberOfPages()) {
                document.newPage();
                pageOfCurrentReaderPDF++;
                currentPageNumber++;
                page = writer.getImportedPage(pdfReader, pageOfCurrentReaderPDF);
                cb.addTemplate(page, 0, 0);

                // Code for pagination.
                if (paginate) {
                    cb.beginText();
                    cb.setFontAndSize(bf, 9);
                    cb.showTextAligned(PdfContentByte.ALIGN_CENTER, "" + currentPageNumber + " of " + totalPages,
                            520, 5, 0);
                    cb.endText();
                }
            }
            pageOfCurrentReaderPDF = 0;
        }

        outputStream.flush();
        document.close();
        outputStream.close();

    } catch (Exception e) {
        e.printStackTrace();
    } finally {

        if (document.isOpen())
            document.close();

        try {

            if (outputStream != null)
                outputStream.close();

        } catch (IOException ioe) {
            ioe.printStackTrace();
        }
    }
}
}
票数 0
EN

Stack Overflow用户

发布于 2015-10-10 01:03:19

此页面准确地显示了您通过预先添加和附加带有合成的HTML和CSS内容的静态PDF所要求的内容。

http://cloudformatter.com/CSS2Pdf.CustomTipsTricks.InjectPDF

使用说明在这里

http://cloudformatter.com/CSS2Pdf.APIDoc.Usage

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32975880

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档