Document Class Documentation

classDocument

Namespace:com::datalogics::PDFL

Detailed Description

The underlying PDF representation of a document. Use document objects to perform most of the functions related to pages in a PDF file, such as deleting pages, inserting blank pages, copying watermarks, creating bookmarks and thumbnails, and so on.

Constructor & Destructor Documentation

Document

Document(StreamFilesf, booleanignore)

Parameters

sf: StreamFile
ignore: boolean

Document

Document()

Creates a new document. The only Cos object in the document will be a Catalog. After the document is created, at least one page must be added using CreatePage or InsertPages before the PDF Viewer can display or save the document.

Document

Document(JavaStreamFilefile, Stringpassword, PermissionRequestOperationperms, booleandoRepair)

Parameters

password: String
perms: PermissionRequestOperation
doRepair: boolean

Document

Document(javax.imageio.stream.ImageInputStreamstream)

Parameters

stream: javax.imageio.stream.ImageInputStream

The stream from which to read the Document.

Open a Document from a javax.imageio.stream.ImageInputStream.

This allows a document to be read from a ImageInputStream object. ImageInputStream can be created from InputStream using MemoryCacheImageInputStream or FileCacheImageInputStream. Once passed to the Document constructor, ownership of the stream is passed to the Document. The Stream must remain open while the Document itself is open.

Document

Document(javax.imageio.stream.ImageInputStreamstream, Stringpassword, PermissionRequestOperationperms, booleandoRepair)

Parameters

stream: javax.imageio.stream.ImageInputStream

The stream from which to read the Document.

password: String

The password to use to attempt to open the document.

perms: PermissionRequestOperation

The permissions being requested. It must be an OR of the PermissionRequestOperation values.

doRepair: boolean

If true, attempt to repair the file if it is damaged. If false, do not attempt to repair the file if it is damaged.

Open a Document from a javax.imageio.stream.ImageInputStream.

This allows a document to be read from a ImageInputStream object. ImageInputStream can be created from InputStream using MemoryCacheImageInputStream or FileCacheImageInputStream. Once passed to the Document constructor, ownership of the stream is passed to the Document. The Stream must remain open while the Document itself is open.

Document

Document(StringfileName)

Parameters

fileName: String

A path name to the file, specified in whatever format is correct for fileSys.

Opens the specified document. If the call fails and the exception is pdErrNeedRebuild, then call again with doRepair set to true. This allows the application to decide whether to perform the time-consuming repair operation.

Document

Document(StringfileName, Stringpassword, PermissionRequestOperationperms, booleandoRepair)

Parameters

fileName: String

A path name to the file.

password: String

The password to use to attempt to open the document.

perms: PermissionRequestOperation

The permissions being requested. It must be an OR of the PermissionRequestOperation values.

doRepair: boolean

If true, attempt to repair the file if it is damaged. If false, do not attempt to repair the file if it is damaged.

Opens the specified document. If the document is already open, it returns a reference to the already opened Document. You must call Close() once for every successful open. If the call fails and the exception is pdErrNeedRebuild, then call again with doRepair equal to true. This allows the application to decide whether to perform the time-consuming repair operation.

Document

Document(StringXPSFilename, XPSConvertParamsConversionParams)

Parameters

XPSFilename: String

The path to the XPS file to convert.

ConversionParams: XPSConvertParams

Additional parameters for XPS conversion.

Create a Document from an XPS file.

Documents are converted one at a time. In multi-threaded applications, threads that are making simultaneous calls to this method will block and execute the method sequentially.

NOTE: This method is only available on Windows or Linux.

Document

Document(StreamFilesf, Stringpassword, PermissionRequestOperationperms, booleandoRepair, booleanignore)

Parameters

sf: StreamFile
password: String
perms: PermissionRequestOperation
doRepair: boolean
ignore: boolean

Member Function Documentation

DisposeChildren

voidDisposeChildren()

Returns:

void

[static initializer]

static void[static initializer]()

applyRedactions

booleanapplyRedactions()

Returns:

boolean

applyRedactions

booleanapplyRedactions(Redactionredact)

Parameters

redact: Redaction

Returns:

boolean

cloneAsPDFADocument

PDFAConvertResultcloneAsPDFADocument(PDFAConvertTypetype, PDFAConvertParamsparms)

Parameters

type: PDFAConvertType

The type of PDF/A conversion to perform

parms: PDFAConvertParams

A PDFAConvertParams object specifying options for the conversion

Returns:

A PDFAConvertResult object containing the Document and SaveFlags.

Create a PDF/A compliant version of this Document.

The returned Document will be compliant with the PDF/A standard. You can save it using any of the standard Save() methods.

The PDFAConvertResult object contains both the Document and the SaveFlags you should use when saving the Document. You MUST use these exact flags to save the returned Document or it will no longer be PDF/A compliant.

The returned Document will have its MajorVersion and MinorVersion set to values required for PDF/A compliance. These will not be visible until after you save the Document.

If this Document could not be converted to PDF/A, the PDFADocument field in the PDFAConvertResult object will be null or a LibraryException will be thrown. A LibraryException message should be checked to see if setting a PDFAConvertParams property will allow conversion to succeed. For example, if the message is "Unembeddable font in annotation", then try calling the setRemoveAllAnnotations() method with a value of true and then call cloneAsPDFADocument().

cloneAsPDFADocumentInternal

DocumentcloneAsPDFADocumentInternal(PDFAConvertTypetype, PDFAConvertParamsparams)

Parameters

type: PDFAConvertType

The type of PDF/A conversion to perform

params: PDFAConvertParams

A PDFAConvertParams object specifying options for the conversion

Returns:

A PDFAConvertResult object containing the Document and SaveFlags.

Create a PDF/A compliant version of this Document.

The returned Document will be compliant with the PDF/A standard. You can save it using any of the standard Save() methods.

The PDFAConvertResult object contains both the Document and the SaveFlags you should use when saving the Document. You MUST use these exact flags to save the returned Document or it will no longer be PDF/A compliant.

The returned Document will have its MajorVersion and MinorVersion set to "1" and "4" respectively. This is required for PDF/A compliance.

If this Document could not be converted to PDF/A, the PDFADocument field in the PDFAConvertResult object will be null.

cloneAsPDFXDocument

PDFXConvertResultcloneAsPDFXDocument(PDFXConvertTypetype, PDFXConvertParamsparms)

Parameters

type: PDFXConvertType

The type of PDF/X conversion to perform

parms: PDFXConvertParams

A PDFXConvertParams object specifying options for the conversion

Returns:

A PDFXConvertResult object containing the Document and SaveFlags.

Create a PDF/X compliant version of this Document.

The returned Document will be compliant with the PDF/A standard. You can save it using any of the standard Save() methods.

The PDFXConvertResult object contains both the Document and the SaveFlags you should use when saving the Document. You MUST use these exact flags to save the returned Document or it will no longer be PDF/X compliant.

The returned Document will have its MajorVersion and MinorVersion set to values required for PDF/X compliance. These will not be visible until after you save the Document.

If this Document could not be converted to PDF/X the PDFXDocument field in the PDFXConvertResult object will be null.

cloneAsPDFXDocumentInternal

DocumentcloneAsPDFXDocumentInternal(PDFXConvertTypetype, PDFXConvertParamsparams)

Parameters

type: PDFXConvertType

The type of PDF/X conversion to perform

params: PDFXConvertParams

A PDFXConvertParams object specifying options for the conversion

Returns:

A PDFXConvertResult object containing the Document and SaveFlags.

Create a PDF/X compliant version of this Document.

The returned Document will be compliant with the PDF/X standard. You can save it using any of the standard Save() methods.

The PDFXConvertResult object contains both the Document and the SaveFlags you should use when saving the Document. You MUST use these exact flags to save the returned Document or it will no longer be PDF/X compliant.

The returned Document will have its MajorVersion and MinorVersion set to "1" and "4" respectively. This is required for PDF/X compliance.

If this Document could not be converted to PDF/X, the PDFXDocument field in the PDFXConvertResult object will be null.

close

voidclose()

Returns:

void

Closes a document and releases its resources. Changes are not saved. You must use Save to save any modifications before calling Close.

colorConvertPages

booleancolorConvertPages(ColorConvertParamsparams)

Parameters

Returns:

True if color conversion occurred. False if nothing was color converted.

Convert the colors (in place) in a Document as specified by by the params block by applying an ICC profile to the objects contained in the Document.

convertToExcel

static booleanconvertToExcel(StringinputPDFFileFilePath, StringoutputOfficeFilePath)

Parameters

inputPDFFileFilePath: String

The PDF file path to convert.

outputOfficeFilePath: String

The output Office file path.

Returns:

true if the conversion was successful, false if an error occurred.

This function converts a PDF file to a Microsoft Excel Office file (.xlsx).

NOTE: This method is only available on Windows 32/64-bit and Linux 64-bit.

convertToPowerPoint

static booleanconvertToPowerPoint(StringinputPDFFileFilePath, StringoutputOfficeFilePath)

Parameters

inputPDFFileFilePath: String

The PDF file path to convert.

outputOfficeFilePath: String

The output Office file path.

Returns:

true if the conversion was successful, false if an error occurred.

This function converts a PDF file to a Microsoft PowerPoint Office file (.pptx).

NOTE: This method is only available on Windows 32/64-bit and Linux 64-bit.

convertToWord

static booleanconvertToWord(StringinputPDFFileFilePath, StringoutputOfficeFilePath)

Parameters

inputPDFFileFilePath: String

The PDF file path to convert.

outputOfficeFilePath: String

The output Office file path.

Returns:

true if the conversion was successful, false if an error occurred.

This function converts a PDF file to a Microsoft Word Office file (.docx).

NOTE: This method is only available on Windows 32/64-bit and Linux 64-bit.

convertXFAFieldsToAcroFormFields

longconvertXFAFieldsToAcroFormFields()

Returns:

the number of output pages created in the converted document

Convert a XFA document into a document with only AcroForms. XFA content is not widely supported by PDF processors, converting this content transforms XFA fields into AcroForm fields which are more widely suppored by PDF processors All XFA fields are removed.

https://www.datalogics.com/pdf-form-functions .

countXMPMetadataArrayItems

intcountXMPMetadataArrayItems(StringnamespaceName, Stringpath)

Parameters

namespaceName: String

The XML namespace URI for the schema in which the property is to be found.

path: String

The name of the simple property .

Returns:

number of array items in the property array.

Returns the number of array items in a property array associated with a Document.

createCollection

voidcreateCollection()

Returns:

collection object

CreateCollection allows to create new collection in the PDF document.It replaces any existing collection.

createNameTree

NameTreecreateNameTree(StringnameTreeName)

Parameters

nameTreeName: String

The name of the NameTree to create.

Returns:

The retrieved or newly created NameTree.

Retrieves the name tree inside the Names dictionary with the specified key name, or creates it if it does not exist.

createPage

PagecreatePage(intafterPageNum, RectmediaBox)

Parameters

afterPageNum: int

The page number after which the new page is inserted. The first page is 0. Use Document.BeforeFirstPage to insert the new page at the beginning of a document.

mediaBox: Rect

A rectangle specifying the page's media box, specified in user space coordinates.

Returns:

The newly created page.

Creates and acquires a new Page. The page is inserted into the document at the specified location.

delete

synchronized voiddelete(Booleandisposing)

Parameters

disposing: Boolean

Returns:

synchronized void

delete

synchronized voiddelete()

Returns:

synchronized void

Closes that document and releases its resources. Changes are not saved. You must use Save() to save any modifications before destroying this object.

deletePages

voiddeletePages(intfirstPage, intlastPage)

Parameters

firstPage: int

The page number of the first page to delete. The first page is 0.

lastPage: int

The page number of the last page to delete.

Returns:

void

Deletes the specified pages.

deletePages

voiddeletePages(intfirstPage, intlastPage, java.util.EnumSet< PageDeleteFlags >deleteFlags)

Parameters

firstPage: int

The page number of the first page to delete. The first page is 0.

lastPage: int

The page number of the last page to delete.

deleteFlags: java.util.EnumSet< PageDeleteFlags >

One of the DeleteFlags.

Returns:

void

Deletes the specified pages with option to parse Structure Tree.

embedFonts

voidembedFonts()

Returns:

void

Embed unembedded fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

With no flags, fonts marked as embedded or subsettable will be embedded.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, use the version of this call that takes a list of Font objects and a set of flags for embedding. Passing the list of new Fonts and the DontScanDocument flag will directly embed the fonts in the list without scanning the document.

embedFonts

voidembedFonts(java.util.EnumSet< EmbedFlags >flags)

Parameters

flags: java.util.EnumSet< EmbedFlags >

One of the EmbedFlags

Returns:

void

Embed unembedded fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, use the version of this call that takes a list of Font objects and a set of flags for embedding. Passing the list of new Fonts and the DontScanDocument flag will directly embed the fonts in the list without scanning the document.

embedFonts

voidembedFonts(java.util.EnumSet< EmbedFlags >flags, ProgressMonitorprogressMonitor, CancelProccancelProc, ReportProcreportProc)

Parameters

flags: java.util.EnumSet< EmbedFlags >

One of the EmbedFlags

progressMonitor: ProgressMonitor

a ProgressMonitor that will receive progress information, may be null

cancelProc: CancelProc

a CancelProc, which can return true to cancel the operation, may be null

reportProc: ReportProc

a ReportProc, which will be called with warnings about fonts that do not embed, may be null

Returns:

void

Embed unembedded fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, use the version of this call that takes a list of Font objects and a set of flags for embedding. Passing the list of new Fonts and the DontScanDocument flag will directly embed the fonts in the list without scanning the document.

embedFonts

voidembedFonts(java.util.List< Font >fonts)

Parameters

Returns:

void

Embed specified fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

The fonts passed to this function must be fonts actually used in the current document. These fonts may be obtained by using the GetFonts or GetLoadedFonts functions, or obtained from a TextRun. Fonts created by name will not work in this context.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, use the version of this call that takes a list of Font objects and a set of flags for embedding. Passing the list of new Fonts and the DontScanDocument flag will directly embed the fonts in the list without scanning the document.

embedFonts

voidembedFonts(java.util.List< Font >fonts, java.util.EnumSet< EmbedFlags >flags)

Parameters

fonts: java.util.List< Font >

The list of fonts to embed. See restrictions above.

flags: java.util.EnumSet< EmbedFlags >

One of the EmbedFlags

Returns:

void

Embed specified fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

The fonts passed to this function must be fonts actually used in the current document. These fonts may be obtained by using the GetFonts or GetLoadedFonts functions, or obtained from a TextRun. Fonts created by name will not work in this context.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, pass the list of new Fonts and the DontScanDocument flag. This will directly embed the fonts in the list without scanning the document.

embedFonts

voidembedFonts(java.util.List< Font >fonts, java.util.EnumSet< EmbedFlags >flags, ProgressMonitorprogressMonitor, CancelProccancelProc, ReportProcreportProc)

Parameters

fonts: java.util.List< Font >

The list of fonts to embed. See restrictions above.

flags: java.util.EnumSet< EmbedFlags >

One of the EmbedFlags

progressMonitor: ProgressMonitor

a ProgressMonitor that will receive progress information, may be null

cancelProc: CancelProc

a CancelProc, which can return true to cancel the operation, may be null

reportProc: ReportProc

a ReportProc, which will be called with warnings about fonts that do not embed, may be null

Returns:

void

Embed specified fonts in a document.

To keep the changes the document must be saved. Fonts on the user's system that match the original font definition will be embedded. For the Times-Roman and Helvetica and corresponding styles, if displayed with a font alias, then the font alias will be embedded in the file. If the font has information that indicates the font cannot be embedded for print and preview, then the font will not be embedded in the document.

The fonts passed to this function must be fonts actually used in the current document. These fonts may be obtained by using the GetFonts or GetLoadedFonts functions, or obtained from a TextRun. Fonts created by name will not work in this context.

By default, the font embedding process scans the entire document for font usage information when subsetting fonts. For documents with large numbers of fonts or pages, this can take a long time. In cases where new Font objects are created and used to set text, it's not necessary to scan the entire document; instead, pass the list of new Fonts and the DontScanDocument flag. This will directly embed the fonts in the list without scanning the document.

embedOCRFonts

voidembedOCRFonts()

Returns:

void

Embed fonts that were used in creating OCR text.

This is also done automatically when saving.

enumIndirectPDFObjects

booleanenumIndirectPDFObjects(PDFObjectEnumProcenumProc)

Parameters

enumProc: PDFObjectEnumProc

A user-supplied callback to call for each indirect object in dP. Enumeration ends when enumProc returns false or all indirect objects have been enumerated. The value parameter returned in enumProc is always null.

Returns:

true if all of the calls to enumProc returned true. It returns false as soon as a call to enumProc returns false.

Enumerates all the indirect objects of this document.

The objects are enumerated in no particular order. Successive enumerations of the same Document are not guaranteed to enumerate objects in the same order.

This method does not enumerate invalid objects, which include objects that are defined as null, objects that are not defined at all (those having no cross-reference entry), and objects that are on the free list.

This re-raises any exception that proc raises.

enumResources

voidenumResources(intstartPage, intendPage, ResourceTyperesourceType, PDFObjectEnumProcenumProc)

Parameters

startPage: int

The first page in the range of pages.

endPage: int

The last page in the range of pages.

resourceType: ResourceType

Resource type to enumerate.

enumProc: PDFObjectEnumProc

A user-supplied callback to call once for each resource of the specified type. NOTE: The resource is the first parameter of the callback, the second is unused.

Returns:

void

Enumerates the specified type of Page Resource, for a specified range of Pages.

This method enumerates resources in each page's Resources dictionary (ColorSpace, Font, ExtGState, etc.).

exportAcroFormsData

booleanexportAcroFormsData(StringfileName, AcroFormExportTypeexportType)

Parameters

fileName: String

The path on disk of the file the AcroForms data is exported to.

exportType: AcroFormExportType

The format type the AcroForm data should be exported to. The supported types are XFDF, FDF, and XML.

Returns:

true indicates exporting succeeded and false indicates an error occurred

Export the AcroForms data. AcroForms data is exported into a format that can later be imported into another AcroForms document.

https://www.datalogics.com/pdf-form-functions .

exportAsPostScript

voidexportAsPostScript(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, PrintProgressProcprintProgressProc, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

printProgressProc: PrintProgressProc

A PrintProgressProc, may be null.

path: String

The output file to be created.

Returns:

void

Exports a PDF document or pages from a PDF document as PostScript allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

exportAsPostScript

voidexportAsPostScript(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

path: String

The output file to be created.

Returns:

void

Exports a PDF document or pages from a PDF document as PostScript allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

exportAsPostScript

voidexportAsPostScript(PrintUserParamsuserParams, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

path: String

The output file to be created.

Returns:

void

Exports a PDF document or pages from a PDF document as PostScript allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

exportXFAFormsData

booleanexportXFAFormsData(StringfileName, XFAFormExportTypeexportType)

Parameters

fileName: String

The path on disk of the file the XFA form data is exported to.

exportType: XFAFormExportType

The format type the XFA data should be exported to. The supported types are XDP, XML, and XFD.

Returns:

true indicates exporting succeeded and false indicates an error occurred

Export the XFA Forms data. XFA forms data is exported into a format that can later be imported into another XFA document.

https://www.datalogics.com/pdf-form-functions .

finalize

voidfinalize()

Returns:

void

Closes that document and releases its resources. Changes are not saved. You must use Save() to save any modifications before destroying this object.

findBookmark

BookmarkfindBookmark(Stringtitle)

Parameters

title: String

The title of the bookmark for which to search.

Returns:

The bookmark within the document's bookmark tree that has the supplied title. Returns NULL if there is no bookmark with the supplied title.

Find bookmark by its title, searching within the document's entire bookmark tree.

findBookmark

BookmarkfindBookmark(Stringtitle, intmaxDepth)

Parameters

title: String

The title of the bookmark for which to search.

maxDepth: int

If supplied (with a value greater than or equal to 0), declares the number of levels below this bookmark to search. (If omitted, the entire subtree is searched.)

Returns:

The bookmark within the document's bookmark tree that has the supplied title. Returns NULL if there is no bookmark with the supplied title.

Find bookmark by its title, searching within the document's bookmark tree to a depth determined by maxDepth (e.g., 0 = root bookmark only and not any of its children, 1 = search one level below root bookmark level, etc. Omit to search entire bookmark tree.)

findLabelForPageNum

StringfindLabelForPageNum(intpageIndex)

Parameters

pageIndex: int

Index of a page in the Document

Returns:

The label string for the page

Fetch the label string for a page index, using the current page labels.

findPDFObjectByID

PDFObjectfindPDFObjectByID(intID)

Parameters

ID: int

Returns:

PDFObject

Retrieves an indirect PDFObject by its ID number. Note that direct PDFObjects cannot be retrieved by ID.

findPageNumForLabel

intfindPageNumForLabel(Stringlabel)

Parameters

label: String

The label string to look up

Returns:

The index of the corresponding page, or -1 if the label could not be matched

Look up a page index based on a label string.

flattenAcroFormFields

voidflattenAcroFormFields()

Returns:

void

Flatten a AcroForms document. Interactive AcroForm fields are flattened into static PDF page content. All AcroForm fields are removed.

NOTE: This method is part of the APDFL Forms Extension that is available separately from APDFL. For more information, please see https://www.datalogics.com/pdf-form-functions .

flattenNonFormAnnotations

voidflattenNonFormAnnotations()

Returns:

void

Flatten a Non-Form (no AcroForm, no XFA) document's Annotations. Annotations are flattened into static PDF page content.

NOTE: This method is part of the APDFL Forms Extension that is available separately from APDFL. For more information, please see https://www.datalogics.com/pdf-form-functions .

flattenOptionalContent

booleanflattenOptionalContent()

Returns:

true if the document was successfully flattened, false otherwise.

Flattens optional content in the document.

Every page in the document will be replaced with a version that has no optional content. The new version of the page will contain only what was visible on the page when the call was made. All other optional content information will be removed from the document.

The document's default optional content context will be used to determine visibility of optional content.

flattenOptionalContent

booleanflattenOptionalContent(OptionalContentContextocc)

Parameters

occ: OptionalContentContext

The optional content context in which content is checked for visibility.

Returns:

true if the document was successfully flattened, false otherwise.

Flattens optional content in the document.

Every page in the document will be replaced with a version that has no optional content. The new version of the page will contain only what was visible on the page when the call was made. All other optional content information will be removed from the document.

flattenTransparency

intflattenTransparency()

Returns:

The number of pages that were flattened.

Flattens all transparencies in the document. To flatten specific pages, see Document.FlattenTransparency(params, firstPage, lastPage)

Documents are flattened one at a time. In multi-threaded applications, threads that are making simultaneous calls to this method will block and execute the method sequentially.

flattenTransparency

intflattenTransparency(FlattenTransparencyParamsparams)

Parameters

params: FlattenTransparencyParams

Additional parameters for performing transparency flattening.

Returns:

The number of pages that were flattened.

Flattens all transparencies in the document. To flatten specific pages, see Document.FlattenTransparency(params, firstPage, lastPage)

Documents are flattened one at a time. In multi-threaded applications, threads that are making simultaneous calls to this method will block and execute the method sequentially.

flattenTransparency

intflattenTransparency(FlattenTransparencyParamsparams, intfirstPage, intlastPage)

Parameters

params: FlattenTransparencyParams

Additional parameters for performing transparency flattening.

firstPage: int

The first page of the range of pages to flatten.

lastPage: int

The last page of the range of pages to flatten.

Returns:

The number of pages that were flattened.

Flattens transparencies in the document that occur on pages within the specified range. When performing flattening on multiple pages, this method is more efficient than making multiple Page.FlattenTransparency() calls.

Documents are flattened one at a time. In multi-threaded applications, threads that are making simultaneous calls to this method will block and execute the method sequentially.

flattenXFAFormFields

longflattenXFAFormFields()

Returns:

the number of output pages created in the flattened document.

Flatten a XFA Document (Static or Dynamic). XFA content is not widely supported by PDF processors, flattening this content transforms into static PDF page content that is part of typical PDF files that can easily be understood by PDF processors. All XFA fields are removed.

https://www.datalogics.com/pdf-form-functions .

flattenXFAFormFieldsAsIfPrinted

longflattenXFAFormFieldsAsIfPrinted()

Returns:

the number of output pages created in the flattened document.

Flatten a XFA Document (Static or Dynamic) as if it was Printed. XFA content is not widely supported by PDF processors, flattening this content transforms into static PDF page content that is part of typical PDF files that can easily be understood by PDF processors. All XFA fields are removed.

The Flattened appearance will take into consideration how the document should appear when printed.

https://www.datalogics.com/pdf-form-functions .

getAuthor

StringgetAuthor()

Returns:

String

The author of the PDF document.

getBaseURI

StringgetBaseURI()

Returns:

String

The Base URI of the PDF document.

getBookmarkRoot

BookmarkgetBookmarkRoot()

Returns:

The document's root bookmark.

Gets the root of the document's bookmark tree. The return value is valid even if the document's bookmark tree is empty (meaning that there is no Outlines key in the underlying PDF file).

getCollection

CollectiongetCollection()

Returns:

collection object if collection exists in the Document or NULL otherwise.

GetCollection allows to retrieve collection from the PDF document.

getCompressionLevel

intgetCompressionLevel()

Returns:

int

The compression level of the document.

The compression level can be one of three values returned by this property:

0 - No compression. All objects are available without inflation.

1 - Partial compression. Objects related to logical structure are stored in object streams and must be inflated.

2 - Full compression. All objects are compressed and must be inflated.

getCreator

StringgetCreator()

Returns:

String

The creator of the PDF file.

getDefaultOptionalContentConfig

OptionalContentConfiggetDefaultOptionalContentConfig()

Returns:

The document's current default OptionalContentConfig.

Gets the default OptionalContentConfig for the document. The OptionalContentConfig determines default settings for optional content, such as the order in which layers (i.e. OptionalContentGroup) appear in the Layers control panel. These settings are used when the document is first opened.

getDeleteOnClose

booleangetDeleteOnClose()

Returns:

The DeleteOnClose property

The document is based on a temporary file that must be deleted when the document is closed or saved.

getFileName

StringgetFileName()

Returns:

The filename associated with this Document.

Get the filename associated with this Document, if it has a representation on disk.

getFonts

java.util.List< Font >getFonts(intfirstPage, intlastPage)

Parameters

firstPage: int

The page number of the first page for which fonts are enumerated. The first page is 0.

lastPage: int

The page number of the last page for which fonts are enumerated.

Returns:

java.util.List< Font >

Get all the fonts in the specified page range. This may take a considerable amount of time for a large page range.

getFormsType

PDDocFormsTypegetFormsType()

Returns:

the Type of Forms the Document contains.

Returns the document's Forms Type. This property is more versatile than the related IsDynamicXFA() and IsStaticXFA() methods.

https://www.datalogics.com/pdf-form-functions .

getHasSignature

booleangetHasSignature()

Returns:

If the Document has a Digital Signature.

The document contains a Digital Signature.

getInfo

StringgetInfo(Stringinfoname)

Parameters

infoname: String

The name of metadata which value will be obtained.

Returns:

The value of the metadata obtained from the PDF file.

Gets the value of metadata information in a PDF file.

getInfoDict

PDFDictgetInfoDict()

Returns:

PDFDict

The Info dictionary of the document as a PDFObject.

getInstanceID

byte[]getInstanceID()

Returns:

byte[]

Get the instance ID for this document.

getIsEmbedded

booleangetIsEmbedded()

Returns:

The IsEmbedded property

The document is embedded in a compound document (OLE, OpenDoc).

getIsLinearized

booleangetIsLinearized()

Returns:

The IsLinearized property

The document is linearized (optimized) for page-served remote (network) access. This flag is get only.

getIsModified

booleangetIsModified()

Returns:

The IsModified property

The document has been modified slightly (for example, bookmarks or text annotations have been opened or closed), but not in a way that warrants saving. This flag is get only.

getIsOptimized

booleangetIsOptimized()

Returns:

The IsOptimized property

The document is optimized. If this flag is cleared, the Adobe PDF Library does not save the file optimized. You can, therefore, linearize a PDF file without optimizing it. Optimizing without linearizing is not allowed, however. This flag can only be set, never cleared.

getIsPxDF

booleangetIsPxDF()

Returns:

The IsPxDF property

The underlying file is PxDF. This flag is get only.

getKeywords

StringgetKeywords()

Returns:

String

The keywords of the PDF file.

getLoadedFonts

java.util.List< Font >getLoadedFonts()

Returns:

java.util.List< Font >

Enumerates all the fonts that have been encountered so far. A font is loaded when a page that uses it is processed. This typically happens when a page is drawn or its thumbnail image is created.

getMajorVersion

shortgetMajorVersion()

Returns:

The major PDF version number of the document.

The major PDF version number of the document. The PDF version is specified in the header of a PDF file in the string "%PDF-xx. yy" where xx is the major version and yy is the minor version.

getMajorVersionIsNewerThanCurrentLibrary

booleangetMajorVersionIsNewerThanCurrentLibrary()

Returns:

The MajorVersionIsNewerThanCurrentLibrary property

The document's major version is newer than the current library version. This flag is get only.

getMergedXMPKeywords

StringgetMergedXMPKeywords()

Returns:

String

A string containing a semicolon-separated list of fields. The first such field is the entire contents of the pdf:Keywords property of the document XMP; the remaining fields are the contents of successive items in the xmp:Keywords bag of keyword items.

getMinorVersion

shortgetMinorVersion()

Returns:

The minor PDF version number of the document.

The minor PDF version number of the document. The PDF version is specified in the header of a PDF file in the string "%PDF-xx. yy" where xx is the major version and yy is the minor version.

Please note: Setting the minor version on a document only changes the version number in the document's file header. It will NOT actually change the PDF's contents and it will NOT alter the PDF to conform to the standard of the new minor version.

The new minor version number will appear in the file header once the document is saved.

getMinorVersionIsNewerThanCurrentLibrary

booleangetMinorVersionIsNewerThanCurrentLibrary()

Returns:

The MinorVersionIsNewerThanCurrentLibrary property

The document's minor version is newer than the current library version. This flag is get only.

getNameTree

NameTreegetNameTree(StringnameTreeName)

Parameters

nameTreeName: String

The name of the NameTree to get.

Returns:

The retrieved NameTree.

Retrieves the name tree inside the Names dictionary with the specified key name.

getNeedsSave

booleangetNeedsSave()

Returns:

The NeedsSave property

The document has been modified and needs to be saved.

getNumPages

intgetNumPages()

Returns:

The number of pages in the document. Remember to subtract 1 from this value if you are going to pass it to a Page method that takes a zero-based page number.

Gets the number of pages in a document.

getOptionalContentConfigs

java.util.List< OptionalContentConfig >getOptionalContentConfigs()

Returns:

A list of all OptionalContentConfigs in the document.

Gets all OptionalContentConfigs stored in this document. The first will be the default OptionalContentConfig (the same value returned by DefaultOptionalContentConfig); subsequent values will be additional Configs stored in the document. Any of these can be made the default by setting it via the DefaultOptionalContentConfig property.

Any OptionalContentConfigs created via the OptionalContentConfig constructor will appear in this list.

getOptionalContentContext

OptionalContentContextgetOptionalContentContext()

Returns:

The document's current OptionalContentContext.

Gets the built-in default OptionalContentContext for the document. This context is used by all content drawing and enumeration calls that do not take an OptionalContentContext parameter, or for which no context is specified.

getOptionalContentGroups

java.util.List< OptionalContentGroup >getOptionalContentGroups()

Returns:

A list of COptionalContentGroup objects.

Gets the optional-content groups for the document. The order of the groups is not guaranteed to be the creation order, and is not the same as the display order (see PDOCConfigGetOCGOrder()).

getPage

PagegetPage(intpageNumber)

Parameters

pageNumber: int

The page number of the page to acquire. The first page is 0.

Returns:

Page

Gets a Page from a document.

getPageLabels

Returns:

java.util.List< PageLabel >

The list of PageLabel objects used in the document.

PageLabels are always stored in page index order; if two PageLabels start on the same page index, the last PageLabel appearing in the list will be used.

getPageMode

PageModegetPageMode()

Returns:

PageMode

The PageMode of the PDF document.

getPermanentID

byte[]getPermanentID()

Returns:

byte[]

Get the permanent ID for this document.

getPermissionFlags

java.util.EnumSet< PermissionFlags >getPermissionFlags()

Returns:

flags that have been set

Allows to obtain security flags for the document.

getProducer

StringgetProducer()

Returns:

String

The producer of the PDF file.

getRequiresFullSave

booleangetRequiresFullSave()

Returns:

The RequiresFullSave property

The document cannot be saved incrementally; when it is saved using Document.Save(), the SaveFlags.Full flag must be specified. This flag can only be set, never cleared.

getRolledBackDocuments

java.util.List< RolledBackDocument >getRolledBackDocuments()

Returns:

The list of Rolled Back Documents, the documents must be saved to disk before they can be loaded into PDFL.

A Document that have been previously saved Incrementally means changes were written to the end of the file leaving its original contents intact. Thus an Incrementally saved file may contain multiple entire PDF documents that represent prior incarnations of the current document. This method retrieves any such previous documents found in sequential order from the beginning of the file.

getRoot

PDFDictgetRoot()

Returns:

PDFDict

The Catalog of the document as a PDFObject.

getStructureIDTree

NameTreegetStructureIDTree()

Returns:

The retrieved IDTree.

Retrieves the IDTree from the StructureTreeRoot dictionary.

getStructureParentTree

NumberTreegetStructureParentTree()

Returns:

The retrieved ParentTree.

Retrieves the ParentTree from the StructureTreeRoot dictionary.

getSubject

StringgetSubject()

Returns:

String

The subject of the PDF document.

getSuppressErrors

booleangetSuppressErrors()

Returns:

The SuppressErrors property

Do not display errors.

getTitle

StringgetTitle()

Returns:

String

The title of the PDF document.

getVersionIsOlderThanCurrentLibrary

booleangetVersionIsOlderThanCurrentLibrary()

Returns:

The VersionIsOlderThanCurrentLibrary property

The document's version is older than the current library version. This flag is get only.

getVersionString

StringgetVersionString()

Returns:

A string containing the PDF version number of the document.

The PDF version of the document, which is specified in the header of a PDF file in the string "%PDF-xx.yy" where xx is the major version and yy is the minor version.

Note that this returns a string containing both the major and minor versions. For version comparisons, use MajorVersion and MinorVersion.

getWasRepaired

booleangetWasRepaired()

Returns:

The WasRepaired property

The document was repaired when it was opened. This flag is get only.

getXMPMetadata

StringgetXMPMetadata()

Returns:

String

The XMP metadata associated with a document.

The XMP metadata returned always represents all the properties in the Document's Info dictionary, and can also contain properties not present in the Info dictionary. This call is preferred to GetInfo, which only returns properties that are in the Info dictionary (although the older function is supported for compatibility).

getXMPMetadataArrayItem

StringgetXMPMetadataArrayItem(StringnamespaceName, Stringpath, intindex)

Parameters

namespaceName: String

The XML namespace URI for the schema in which the property is to be found.

path: String

The name of the desired simple property.

index: int

The index in the metadata property array associated with the property.

Returns:

a string containing the XML text of the value of the specified property in the XMP metadata associated with the Document, or an empty string if no such property is found.

Gets the value of an XMP metadata array item, associated with a document, based on an index.

getXMPMetadataProperty

StringgetXMPMetadataProperty(StringnamespaceName, Stringpath)

Parameters

namespaceName: String

The XML namespace URI for the schema in which the property is to be found.

path: String

The name of the desired simple property. Note that XMP properties can have an XML substructure; this method can only retrieve values from simple textual properties.

Returns:

String

Gets the value of an XMP metadata property associated with a document. It returns the XML text of the value of the specified property in the XMP metadata associated with the Document. The XMP metadata can represent all properties in the Document object's Info dictionary, as well as other properties.

importAcroFormsData

booleanimportAcroFormsData(StringfileName, AcroFormImportTypeimportType)

Parameters

fileName: String

The path on disk of the AcroFormsdata file to be imported.

importType: AcroFormImportType

The format type the data type should be imported to. The supported types are XFDF, FDF, and XML.

Returns:

true indicates importing succeeded and false indicates an error occurred

Import the AcroForms data. AcroForms data is imported from a supported format into the AcroForms document so its existing fields can be populated for example.

https://www.datalogics.com/pdf-form-functions .

importXFAFormsData

booleanimportXFAFormsData(StringfileName)

Parameters

fileName: String

The path on disk of the XFA form data file to be imported, the supported types of data that can be imported are XDP, XML, and XFD.

Returns:

true indicates importing succeeded and false indicates an error occurred

Import the XFA Forms data. XFA forms data is imported from a supported format into the XFA document so its existing fields can be populated for example.

https://www.datalogics.com/pdf-form-functions .

insertPages

voidinsertPages(intmergeAfterThisPage, Documentdoc2, intstartPage, intnumPages, java.util.EnumSet< PageInsertFlags >insertFlags)

Parameters

mergeAfterThisPage: int

The page number in doc after which pages from doc2 are inserted. The first page is 0. If Document.BeforeFirstPage is used, the pages are inserted before the first page in doc. Use Document.LastPage to insert pages after the last page in doc.

doc2: Document

The document containing the pages that are inserted into doc.

startPage: int

The page number of the first page in doc2 to insert into doc. The first page is 0.

numPages: int

The number of pages in doc2 to insert into doc. Use Document.AllPages to insert all pages from doc2 into doc.

insertFlags: java.util.EnumSet< PageInsertFlags >

Flags that determine what additional information is copied from doc2 into doc. It is an OR of the following constants: PageInsertFlags.Bookmarks, PageInsertFlags.Threads, PageInsertFlags.All

Returns:

void

Inserts numPages pages from doc2 into doc. All annotations, and anything else associated with the page (such as a thumbnail image) are copied from the doc2 pages to the new pages in doc. This method does not insert pages if doc equals doc2.

The insertFlags parameter controls whether bookmarks and threads are inserted along with the specified pages. Setting this parameter to PageInsertFlags.All has two effects:

The parameters indicating which pages to insert are ignored: all the pages of doc2 are inserted.

In addition to inserting the pages themselves, it also merges other document data from doc2 into doc:

Named destinations from doc2 (of PDF 1.1 and later) are copied into doc. If there are named destinations in doc2 with the same name as some named destination in doc, the ones in doc retain their names and the copied named destinations are given new names based on the old ones, with distinguishing digits added. Actions and bookmarks referring to the old names are made to refer to the new names after being copied into doc.

If it is also the case that mergeAfterThisPage denotes the last page of the document, then document metadata is merged, and the optional content properties are merged in a more symmetrical manner than would otherwise be the case.

Named destinations from doc2 (of PDF 1.1 and later) are copied into doc. If there are named destinations in doc2 with the same name as some named destination in doc, the ones in doc retain their names and the copied named destinations are given new names based on the old ones, with distinguishing digits added. Actions and bookmarks referring to the old names are made to refer to the new names after being copied into doc.

If it is also the case that mergeAfterThisPage denotes the last page of the document, then document metadata is merged, and the optional content properties are merged in a more symmetrical manner than would otherwise be the case.

Document logical structure from doc2 is copied into doc. If less than the whole of doc2 is being inserted, only those structure elements having content on the copied pages, and the ancestors of those elements, are copied into the logical structure tree of doc. The top-level children of the structure tree root of doc2 are copied as new top-level children of the structure tree root of doc; a structure tree root is created in doc if there was none before. The role maps of the two structure trees are merged, with name conflicts resolved in favor of the role mappings present in doc. Attribute objects having scalar values, or values that are arrays of scalar values, are copied. Class map information from doc2 is also merged into that for doc.

insertPages

voidinsertPages(intmergeAfterThisPage, Documentdoc2, intstartPage, intnumPages, java.util.EnumSet< PageInsertFlags >insertFlags, ProgressMonitorprogressMonitor, CancelProccancelProc)

Parameters

mergeAfterThisPage: int

The page number in doc after which pages from doc2 are inserted. The first page is 0. If Document.BeforeFirstPage is used, the pages are inserted before the first page in doc. Use Document.LastPage to insert pages after the last page in doc.

doc2: Document

The document containing the pages that are inserted into doc.

startPage: int

The page number of the first page in doc2 to insert into doc. The first page is 0.

numPages: int

The number of pages in doc2 to insert into doc. Use Document.AllPages to insert all pages from doc2 into doc.

insertFlags: java.util.EnumSet< PageInsertFlags >

Flags that determine what additional information is copied from doc2 into doc. It is an OR of the following constants: PageInsertFlags.Bookmarks, PageInsertFlags.Threads, PageInsertFlags.All

progressMonitor: ProgressMonitor

a ProgressMonitor that will receive progress information, may be null

cancelProc: CancelProc

a CancelProc, which can return true to cancel the operation, may be null

Returns:

void

Inserts numPages pages from doc2 into doc. All annotations, and anything else associated with the page (such as a thumbnail image) are copied from the doc2 pages to the new pages in doc. This method does not insert pages if doc equals doc2.

The insertFlags parameter controls whether bookmarks and threads are inserted along with the specified pages. Setting this parameter to PageInsertFlags.All has two effects:

The parameters indicating which pages to insert are ignored: all the pages of doc2 are inserted.

In addition to inserting the pages themselves, it also merges other document data from doc2 into doc:

Named destinations from doc2 (of PDF 1.1 and later) are copied into doc. If there are named destinations in doc2 with the same name as some named destination in doc, the ones in doc retain their names and the copied named destinations are given new names based on the old ones, with distinguishing digits added. Actions and bookmarks referring to the old names are made to refer to the new names after being copied into doc.

If it is also the case that mergeAfterThisPage denotes the last page of the document, then document metadata is merged, and the optional content properties are merged in a more symmetrical manner than would otherwise be the case.

Named destinations from doc2 (of PDF 1.1 and later) are copied into doc. If there are named destinations in doc2 with the same name as some named destination in doc, the ones in doc retain their names and the copied named destinations are given new names based on the old ones, with distinguishing digits added. Actions and bookmarks referring to the old names are made to refer to the new names after being copied into doc.

If it is also the case that mergeAfterThisPage denotes the last page of the document, then document metadata is merged, and the optional content properties are merged in a more symmetrical manner than would otherwise be the case.

Document logical structure from doc2 is copied into doc. If less than the whole of doc2 is being inserted, only those structure elements having content on the copied pages, and the ancestors of those elements, are copied into the logical structure tree of doc. The top-level children of the structure tree root of doc2 are copied as new top-level children of the structure tree root of doc; a structure tree root is created in doc if there was none before. The role maps of the two structure trees are merged, with name conflicts resolved in favor of the role mappings present in doc. Attribute objects having scalar values, or values that are arrays of scalar values, are copied. Class map information from doc2 is also merged into that for doc.

isDynamicXFA

booleanisDynamicXFA()

Returns:

true indicates the Document is Dynamic XFA, false indicates it is not

Indicates if the document is Dynamic XFA. Dynamic XFA documents can change in appearance in response to changes in the data. They don't contain a meaningful PDF representation. Such XFA content is not widely supported by PDF processors.

https://www.datalogics.com/pdf-form-functions .

isStaticXFA

booleanisStaticXFA()

Returns:

true indicates the Document is Static XFA, false indicates it is not

Indicates if the document is Static XFA. Static XFA documents have a fixed appearance and layout. They usually contain a meaningful PDF representation. Such XFA content is not widely supported by PDF processors.

https://www.datalogics.com/pdf-form-functions .

mergeXMPKeywords

voidmergeXMPKeywords()

Returns:

void

Causes a string produced as by PDDocGetMergedXAPKeywords() to be stored as the new value of the pdf:Keywords property, and the former value of the pdf:Keywords property to be stored as an item in the xmp:Keywords bag of keyword items.

The algorithm used to compute merged keywords lists detects the case in which the keywords lists have already been merged and makes no changes to the XMP metadata in this case.

movePage

voidmovePage(intmoveToAfterThisPage, intpageToMove)

Parameters

moveToAfterThisPage: int

The new location of the page to move. The first page is 0. It may either be a page number, or the constant Document.BeforeFirstPage.

pageToMove: int

The page number of the page to move.

Returns:

void

Moves one page in a document.

permRequest

booleanpermRequest(PermissionRequestOperationrequestedperm)

Parameters

requestedperm: PermissionRequestOperation

The document permission which to check

Returns:

a boolean if the permission is set in the document.

Tests if a permission is set on a document

permRequest

booleanpermRequest(Stringpassword, PermissionRequestOperationperms)

Parameters

password: String

The document password which authorizes the change. Note - if this argument is set to a NULL (""), then the return will be an indicator of whether or not the requested permission is already set in this document, with no changes made to the PDF document.

perms: PermissionRequestOperation

the permissions on the PDF file which is to be set or checked.

Returns:

a boolean if the permission change is successful or if the permission was set.

Request the permissions to be changed on a PDF document. This takes effect immediately

print

voidprint(PrintUserParamsuserParams)

Parameters

userParams: PrintUserParams

Parameters to control printing.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

print

voidprint(PrintUserParamsuserParams, PrintCancelProcprintCancelProc)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

print

voidprint(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, PrintProgressProcprintProgressProc)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

printProgressProc: PrintProgressProc

A PrintProgressProc, may be null.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

printToFile

voidprintToFile(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, PrintProgressProcprintProgressProc, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

printProgressProc: PrintProgressProc

A PrintProgressProc, may be null.

path: String

The output file to be created.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

printToFile

voidprintToFile(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

printCancelProc: PrintCancelProc

A PrintCancelProc, which can return true to cancel printing, may be null.

path: String

The output file to be created.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

printToFile

voidprintToFile(PrintUserParamsuserParams, Stringpath)

Parameters

userParams: PrintUserParams

Parameters to control printing.

path: String

The output file to be created.

Returns:

void

Prints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.

The output is placed in the specified file.

removeCollection

voidremoveCollection()

Returns:

void

RemoveCollection Removes a collection dictionary from a document.

removeDuplicateOCG

voidremoveDuplicateOCG()

Returns:

void

Removes duplicate optional content group from the document. This does not remove any content associated with the duplicate group,

removeNameTree

voidremoveNameTree(StringnameTreeName)

Parameters

nameTreeName: String

The name of the NameTree to remove.

Returns:

void

Removes the name tree inside the Names dictionary with the specified key name. It does nothing if no object with that name exists.

removeOCG

voidremoveOCG(OptionalContentGroupocg)

Parameters

ocg: OptionalContentGroup

The optional content group to remove.

Returns:

void

Removes the specified optional content group from the document. This does not remove any content associated with the specified group, only the group itself.

replacePages

voidreplacePages(intstartPage, Documentdoc2, intstartPageDoc2, intnumPages, booleanmergeTextAnnots)

Parameters

startPage: int

The first page number in doc to replace. The first page is 0.

doc2: Document

The document from which pages are copied into doc.

startPageDoc2: int

The page number of the first page in doc2 to copy. The first page is 0.

numPages: int

The number of pages to replace.

mergeTextAnnots: boolean

If true, text annotations from doc2 are appended if they are different than all existing annotations on the page in doc. No other types of annotations are copied.

Returns:

void

Replaces the specified range of pages in one document with pages from another. The contents, resources, size and rotation of the pages are replaced. The bookmarks are not copied, because they are attached to the document, not to individual pages.

retrieveCloneAsPDFADocumentSaveFlags

java.util.EnumSet< SaveFlags >retrieveCloneAsPDFADocumentSaveFlags()

Returns:

java.util.EnumSet< SaveFlags >

Get the save flags returned when cloning this document as PDF/A

This method should NOT appear in the client interface!

retrieveCloneAsPDFXDocumentSaveFlags

java.util.EnumSet< SaveFlags >retrieveCloneAsPDFXDocumentSaveFlags()

Returns:

java.util.EnumSet< SaveFlags >

Get the save flags returned when cloning this document as PDF/X

This method should NOT appear in the client interface!

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

A bit field composed of an OR of the SaveFlags values.

Returns:

void

Saves a document to disk. If a full save is requested to the original path, the file is saved to a file system-determined temporary file, the old file is deleted, and the temporary file is renamed to the save file name.

A full save with linearization optimizes the PDF file. During optimization, all objects in a PDF file are rearranged, many of them acquiring not only a new file position, but also a new PDFObject number. At the end of the save operation, PDFL flushes its information of the PD layer and below to synchronize its in-memory state with the new disk file just written.

If the document has a signature, it will be saved incrementally regardless of the full save flag. This is required to preserve the exact contents of the document at the time of signing.

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, JavaStreamFiledest)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

Returns:

void

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, javax.imageio.stream.ImageOutputStreamstream)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

An enum of SaveFlags values.

stream: javax.imageio.stream.ImageOutputStream

The stream to which the file is saved.

Returns:

void

Saves a Document to a javax.imageio.stream.ImageOutputStream.

The save is always performed as a full, copy save. The Document remains open with the original file. If the document was created with Document(), at least one page must be added using createPage() or insertPages() before the Document can be saved. A full save with linearization optimizes the PDF file. During optimization, all objects in a PDF file are rearranged, many of them acquiring not only a new file position, but also a new Cos object number.

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, javax.imageio.stream.ImageOutputStreamstream, ProgressMonitorprogressMonitor, CancelProccancelProc)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >
stream: javax.imageio.stream.ImageOutputStream
progressMonitor: ProgressMonitor
cancelProc: CancelProc

Returns:

void

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, ProgressMonitorprogressMonitor, CancelProccancelProc)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

A bit field composed of an OR of the SaveFlags values.

progressMonitor: ProgressMonitor

a ProgressMonitor that will receive progress information, may be null

cancelProc: CancelProc

a CancelProc, which can return true to cancel the operation, may be null

Returns:

void

Saves a document to disk. If a full save is requested to the original path, the file is saved to a file system-determined temporary file, the old file is deleted, and the temporary file is renamed to the save file name.

A full save with linearization optimizes the PDF file. During optimization, all objects in a PDF file are rearranged, many of them acquiring not only a new file position, but also a new PDFObject number. At the end of the save operation, PDFL flushes its information of the PD layer and below to synchronize its in-memory state with the new disk file just written.

If the document has a signature, it will be saved incrementally regardless of the full save flag. This is required to preserve the exact contents of the document at the time of signing.

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, StringnewPath)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

A bit field composed of an OR of the SaveFlags values.

newPath: String

The path to which the file is saved. A path must be specified when either SaveFlags.Full or SaveFlags.Copy are used for saveFlags. If SaveFlags.Incremental is specified in saveFlags, then newPath should be NULL. If SaveFlags.Full is specified and newPath is the same as the file's original path, the new file is saved to a file system-determined temporary path, then the old file is deleted and the new file is renamed to newPath.

Returns:

void

Saves a document to disk. If a full save is requested to the original path, the file is saved to a file system-determined temporary file, the old file is deleted, and the temporary file is renamed to newPath.

If the document was created with Document, at least one page must be added using CreatePage() or InsertPages() before a PDF Viewer can save the document.

A full save with linearization optimizes the PDF file. During optimization, all objects in a PDF file are rearranged, many of them acquiring not only a new file position, but also a new PDFObject number. At the end of the save operation, PDFL flushes its information of the PD layer and below to synchronize its in-memory state with the new disk file just written.

If the document has a signature, it will be saved incrementally regardless of the full save flag. This is required to preserve the exact contents of the document at the time of signing.

save

voidsave(java.util.EnumSet< SaveFlags >saveFlags, StringnewPath, ProgressMonitorprogressMonitor, CancelProccancelProc)

Parameters

saveFlags: java.util.EnumSet< SaveFlags >

A bit field composed of an OR of the SaveFlags values.

newPath: String

The path to which the file is saved. A path must be specified when either SaveFlags.Full or SaveFlags.Copy are used for saveFlags. If SaveFlags.Incremental is specified in saveFlags, then newPath should be NULL. If SaveFlags.Full is specified and newPath is the same as the file's original path, the new file is saved to a file system-determined temporary path, then the old file is deleted and the new file is renamed to newPath.

progressMonitor: ProgressMonitor

a ProgressMonitor that will receive progress information, may be null

cancelProc: CancelProc

a CancelProc, which can return true to cancel the operation, may be null

Returns:

void

Saves a document to disk. If a full save is requested to the original path, the file is saved to a file system-determined temporary file, the old file is deleted, and the temporary file is renamed to newPath.

If the document was created with Document, at least one page must be added using CreatePage() or InsertPages() before a PDF Viewer can save the document.

A full save with linearization optimizes the PDF file. During optimization, all objects in a PDF file are rearranged, many of them acquiring not only a new file position, but also a new PDFObject number. At the end of the save operation, PDFL flushes its information of the PD layer and below to synchronize its in-memory state with the new disk file just written.

If the document has a signature, it will be saved incrementally regardless of the full save flag. This is required to preserve the exact contents of the document at the time of signing.

secure

voidsecure(java.util.EnumSet< PermissionFlags >permissions, StringownerPassword, StringuserPassword)

Parameters

permissions: java.util.EnumSet< PermissionFlags >

an "OR" of the types of PDF document specified by Permissions:

ownerPassword: String

optional PDF document owner password; pass null if not used.

userPassword: String

optional PDF document user password; pass null if not used.

Returns:

void

Secure the PDF document securely with password(s). If the document has a security handler, it is retained. If the document does not have a security handler, it is assigned the "Standard" security handler with a 16-bit encryption key length. Access permissions as well as owner and user passwords are assigned to the PDF document. This method by default encrypts PDF's content as well as its metadata. To make selective encryption use appropriate overload of Secure() method.

The document must be saved for the changes to take effect. A full save is required.

secure

voidsecure(java.util.EnumSet< PermissionFlags >permissions, StringownerPassword, StringuserPassword, EncryptionTypeencryptionType)

Parameters

permissions: java.util.EnumSet< PermissionFlags >

an "OR" of the types of PDF document specified by Permissions:

ownerPassword: String

optional PDF document owner password; pass null if not used.

userPassword: String

optional PDF document user password; pass null if not used.

encryptionType: EncryptionType

Encryption type to be used for securing the document.

Returns:

void

Secure the PDF document securely with password(s). The security handler used for the document depends on the encryption type specified. Access permissions as well as owner and user passwords are assigned to the PDF document. This method by default encrypts PDF's content as well as its metadata. To make selective encryption use appropriate overload of Secure() method.

The document must be saved for the changes to take effect. A full save is required.

secure

voidsecure(java.util.EnumSet< PermissionFlags >permissions, StringownerPassword, StringuserPassword, EncryptionTypeencryptionType, booleanencryptMetadata)

Parameters

permissions: java.util.EnumSet< PermissionFlags >

an "OR" of the types of PDF document specified by Permissions:

ownerPassword: String

optional PDF document owner password; pass null if not used.

userPassword: String

optional PDF document user password; pass null if not used.

encryptionType: EncryptionType

Encryption type to be used for securing the document.

encryptMetadata: boolean

A flag that indicates whether document metadata will be encrypted.

Returns:

void

Secure the PDF document securely with password(s). The security handler used for the document depends on the encryption type specified. Access permissions as well as owner and user passwords are assigned to the PDF document. This method allows selective encryption. Depending on encryptMetadata parameter, it may or may not encrypt PDF's metadata.

The document must be saved for the changes to take effect. A full save is required.

setAuthor

voidsetAuthor(Stringauthorvalue)

Parameters

authorvalue: String

Returns:

void

The author of the PDF document.

setBaseURI

voidsetBaseURI(StringURIvalue)

Parameters

URIvalue: String

Returns:

void

The Base URI of the PDF document.

setCreator

voidsetCreator(Stringcreatorvalue)

Parameters

creatorvalue: String

Returns:

void

The creator of the PDF document.

setDeleteOnClose

voidsetDeleteOnClose(booleanvalue)

Parameters

value: boolean

The DeleteOnClose property

Returns:

void

The document is based on a temporary file that must be deleted when the document is closed or saved.

setInfo

voidsetInfo(Stringinfoname, Stringinfovalue)

Parameters

infoname: String

The name of metadata to be set

infovalue: String

The value for metadata which will be set

Returns:

void

Sets metadata information in a PDF document.

setIsEmbedded

voidsetIsEmbedded(booleanvalue)

Parameters

value: boolean

The IsEmbedded property

Returns:

void

The document is embedded in a compound document (OLE, OpenDoc).

setIsOptimized

voidsetIsOptimized(booleanvalue)

Parameters

value: boolean

The IsOptimized property

Returns:

void

The document is optimized. If this flag is cleared, the Adobe PDF Library does not save the file optimized. You can, therefore, linearize a PDF file without optimizing it. Optimizing without linearizing is not allowed, however. This flag can only be set, never cleared.

setKeywords

voidsetKeywords(Stringkeywordsvalue)

Parameters

keywordsvalue: String

Returns:

void

The keywords of the PDF document.

setMajorVersion

voidsetMajorVersion(shortmajorVersion)

Parameters

majorVersion: short

The new major version number to be set in the document's file header.

Returns:

void

The major PDF version number of the document. The PDF version is specified in the header of a PDF file in the string "%PDF-x.y" where x is the major version and y is the minor version. For example, version 1.2 has the string "%PDF-1.2". See Section I.2 in the PDF Reference.

Please note: Setting the major version on a document only changes the version number in the document's file header. It will NOT actually change the PDF's contents and it will NOT alter the PDF to conform to the standard of the new major version.

The new major version number will appear in the file header once the document is saved.

setMinorVersion

voidsetMinorVersion(shortminorVersion)

Parameters

minorVersion: short

The new minor version number to be set in the document's file header.

Returns:

void

The minor PDF version number of the document. The PDF version is specified in the header of a PDF file in the string "%PDF-xx. yy" where xx is the major version and yy is the minor version. For example, version 1.2 has the string "%PDF-1 .2".

Please note: Setting the minor version on a document only changes the version number in the document's file header. It will NOT actually change the PDF's contents and it will NOT alter the PDF to conform to the standard of the new minor version.

The new minor version number will appear in the file header once the document is saved.

setNeedsSave

voidsetNeedsSave(booleanvalue)

Parameters

value: boolean

The NeedSave property

Returns:

void

The document has been modified and needs to be saved.

setPageMode

voidsetPageMode(PageModepagemode)

Parameters

pagemode: PageMode

the pagemode to apply to the Document

Returns:

void

The PageMode of the PDF document.

The default PageMode for a new Document is PageMode.NoPreference .

setProducer

voidsetProducer(Stringproducervalue)

Parameters

producervalue: String

Returns:

void

The producer of the PDF document.

setRequiresFullSave

voidsetRequiresFullSave(booleanvalue)

Parameters

value: boolean

The RequiresFullSave property

Returns:

void

The document cannot be saved incrementally; when it is saved using Document.Save(), the SaveFlags.Full flag must be specified. This flag can only be set, never cleared.

setSubject

voidsetSubject(Stringsubjectvalue)

Parameters

subjectvalue: String

Returns:

void

The subject of the PDF document.

setSuppressErrors

voidsetSuppressErrors(booleanvalue)

Parameters

value: boolean

The SuppressErrors property

Returns:

void

Do not display errors.

setTitle

voidsetTitle(Stringtitlevalue)

Parameters

titlevalue: String

Returns:

void

The title of the PDF document.

setXMPMetadata

voidsetXMPMetadata(Stringmetadata)

Parameters

metadata: String

Returns:

void

The XMP metadata associated with a document.

The XMP metadata returned always represents all the properties in the Document's Info dictionary, and can also contain properties not present in the Info dictionary. This call is preferred to GetInfo, which only returns properties that are in the Info dictionary (although the older function is supported for compatibility).

setXMPMetadataArrayItem

voidsetXMPMetadataArrayItem(StringnamespaceName, StringnamespacePrefix, Stringpath, intindex, StringnewValue)

Parameters

namespaceName: String

The XML namespace URI for the schema in which the property is to be found.

namespacePrefix: String

A brief string to be used as an abbreviation when creating the XML representation of the property. This string must not be empty.

path: String

The name of the simple property to be modified.

index: int

The index in the metadata property array associated with the property.

newValue: String

The new XML text value for the property.

Returns:

void

Sets the value of an XMP metadata array item, associated with a document, based on an index.

setXMPMetadataProperty

voidsetXMPMetadataProperty(StringnamespaceName, StringnamespacePrefix, Stringpath, StringnewValue)

Parameters

namespaceName: String

The XML namespace URI for the schema in which the property is to be found.

namespacePrefix: String

A brief string to be used as an abbreviation when creating the XML representation of the property. This string must not be empty.

path: String

The name of the simple property to be modified.

newValue: String

The new XML text value for the property.

Returns:

void

Sets the value of an XMP metadata property associated with a document. The XMP metadata represents all the properties in pdDoc object's Info dictionary, and can also contain properties that are not in the Info dictionary.

unsecure

voidunsecure()

Returns:

void

Remove security handler from the PDF document. If the document has a security handler, it is removed. If the document does not have a security handler, this method does nothing.

To remove the security handler, you must hold the PermissionRequestOperation.Secure permission, which you can obtain via Document.PermRequest. This call will throw an ApplicationException if you do not hold the Secure permission.

The document must be saved for the changes to take effect. A full save is required.

watermark

voidwatermark(Pagepage, WatermarkParamswatermarkParams)

Parameters

page: Page

The page to be added as a watermark.

watermarkParams: WatermarkParams

Structure specifying how the watermark should be added to the document.

Returns:

void

Adds a Page as a watermark to a page range in the given document.

watermark

voidwatermark(WatermarkTextParamswatermarkTextParams, WatermarkParamswatermarkParams)

Parameters

watermarkTextParams: WatermarkTextParams

Structure describing the text-based watermark to be added.

watermarkParams: WatermarkParams

Structure specifying how the watermark should be added to the document.

Returns:

void

Adds a text-based watermark to a page range in the given document.