Convert a Document to PDF

The ability to easily and reliably convert documents from one format to another is a key feature of Aspose.Words. One of the most popular formats for converting is PDF – a fixed‑layout format, which preserves the original appearance of a document during its rendering on various platforms. The “rendering” term is used in Aspose.Words to describe the process of converting a document into a file format that is paginated or has the concept of pages.

Convert a Word Document to PDF

Conversion from Word to PDF is a rather complex process that requires several stages of calculation. Aspose.Words layout engine mimics the way Microsoft Word’s page layout engine works, making PDF output documents look as close as possible to what you can see in Microsoft Word.

With Aspose.Words you can programmatically convert a document from DOC or DOCX format to PDF without using Microsoft Office. This article explains how to perform this conversion.

Converting DOCX or DOC to PDF

Converting from the DOC or DOCX document format into the PDF format in Aspose.Words is very easy and can be accomplished with just two lines of code that:

  1. Load your document into a Document object using one of its constructors by specifying the document name with its format extension.
  2. Invoke one of the Document.Save methods on the Document object and specify the desired output format as PDF by entering a file name with the “.PDF” extension.

The following code example shows how to convert a document from DOCX into PDF using the Save method:

You can download the template file of this example from Aspose.Words GitHub.

Convert to Different PDF Standards

Aspose.Words provides the PdfCompliance enumeration to support the conversion of DOC or DOCX into various PDF format standards (such as PDF 1.7, PDF 1.5, etc.).

The following code example demonstrates how to convert a document to PDF 1.7 using PdfSaveOptions with compliance to PDF17:

Convert Images to PDF

Converting to PDF is not restricted by Microsoft Word document formats. Any format supported by Aspose.Words, including programmatically created, can also be converted to PDF. For example, we can convert single‑page images, such as JPEG, PNG, BMP, EMF, or WMF, as well as multi‑page images, such as TIFF and GIF, to PDF.

The following code example shows how to convert JPEG and TIFF images to PDF:

To make this code work, you need to add references to Aspose.Words and System.Drawing to your project.

See Also


FAQ

  1. Q: How do I convert a DOCX file to PDF using Aspose.Words for C++?
    A: Load the DOCX into an Aspose::Words::Document object and call its Save method with a file name ending in “.pdf”. Example:

    Aspose::Words::Document doc(u"input.docx");
    doc.Save(u"output.pdf");
    
  2. Q: How can I create a PDF that complies with a specific standard such as PDF/A‑1b or PDF/X‑4?
    A: Use Aspose::Words::Saving::PdfSaveOptions and set its Compliance property to the desired PdfCompliance value, then pass the options to Document::Save. Example:

    Aspose::Words::Saving::PdfSaveOptions options;
    options.set_Compliance(Aspose::Words::Saving::PdfCompliance::PdfA1b);
    doc.Save(u"output_pdfa.pdf", options);
    
  3. Q: How can I protect the generated PDF with a password?
    A: Configure the EncryptionDetails of PdfSaveOptions with a user password (and optionally an owner password) and assign an encryption algorithm. Then save the document with those options. Example:

    Aspose::Words::Saving::PdfSaveOptions options;
    options.get_EncryptionDetails().set_UserPassword(u"myPassword");
    options.get_EncryptionDetails().set_EncryptionAlgorithm(Aspose::Words::Saving::PdfEncryptionAlgorithm::Aes256);
    doc.Save(u"protected.pdf", options);
    
  4. Q: How can I control image quality or compression when converting images to PDF?
    A: Set ImageCompression (e.g., PdfImageCompression::Jpeg) and JpegQuality (0‑100) on PdfSaveOptions. This reduces file size while preserving visual quality. Example:

    Aspose::Words::Saving::PdfSaveOptions options;
    options.set_ImageCompression(Aspose::Words::Saving::PdfImageCompression::Jpeg);
    options.set_JpegQuality(80);
    doc.Save(u"images.pdf", options);
    
  5. Q: How do I combine several images (e.g., a multi‑page TIFF) into a single PDF document?
    A: Load each image as a separate Document (or use ImageLoadOptions for multi‑page images) and append them to a master document using Document::AppendDocument. Finally, save the master document as PDF. Example:

    Aspose::Words::Document master(u"");
    Aspose::Words::Document imgDoc(u"page1.tiff");
    master.AppendDocument(imgDoc, Aspose::Words::ImportFormatMode::KeepSourceFormatting);
    // repeat for additional pages...
    master.Save(u"combined.pdf");