Document Class Documentation
classDocumentNamespace: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.
Referenced by
Uses types
Constructor & Destructor Documentation
Document
Document(StreamFilesf, booleanignore)Parameters
sf: StreamFileignore: 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)Parameters
file: JavaStreamFile
Document
Document(JavaStreamFilefile, Stringpassword, PermissionRequestOperationperms, booleandoRepair)Parameters
file: JavaStreamFilepassword: Stringperms: PermissionRequestOperationdoRepair: boolean
Document
Document(javax.imageio.stream.ImageInputStreamstream)Parameters
stream: javax.imageio.stream.ImageInputStreamThe 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.ImageInputStreamThe stream from which to read the Document.
password: StringThe password to use to attempt to open the document.
perms: PermissionRequestOperationThe permissions being requested. It must be an OR of the PermissionRequestOperation values.
doRepair: booleanIf 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: StringA 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: StringA path name to the file.
password: StringThe password to use to attempt to open the document.
perms: PermissionRequestOperationThe permissions being requested. It must be an OR of the PermissionRequestOperation values.
doRepair: booleanIf 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: StringThe path to the XPS file to convert.
ConversionParams: XPSConvertParamsAdditional 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: StreamFilepassword: Stringperms: PermissionRequestOperationdoRepair: booleanignore: boolean
Member Function Documentation
DisposeChildren
voidDisposeChildren()Returns:
void[static initializer]
static void[static initializer]()applyRedactions
booleanapplyRedactions()Returns:
booleanapplyRedactions
booleanapplyRedactions(Redactionredact)Parameters
redact: Redaction
Returns:
booleancloneAsPDFADocument
PDFAConvertResultcloneAsPDFADocument(PDFAConvertTypetype, PDFAConvertParamsparms)Parameters
type: PDFAConvertTypeThe type of PDF/A conversion to perform
parms: PDFAConvertParamsA 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: PDFAConvertTypeThe type of PDF/A conversion to perform
params: PDFAConvertParamsA 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: PDFXConvertTypeThe type of PDF/X conversion to perform
parms: PDFXConvertParamsA 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: PDFXConvertTypeThe type of PDF/X conversion to perform
params: PDFXConvertParamsA 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:
voidCloses a document and releases its resources. Changes are not saved. You must use Save to save any modifications before calling Close.
collectNamesOfTree
voidcollectNamesOfTree(PDFArraynamesArray, java.util.List< FileAttachment >attachments)Parameters
namesArray: PDFArrayattachments: java.util.List< FileAttachment >
Returns:
voidcolorConvertPages
booleancolorConvertPages(ColorConvertParamsparams)Parameters
params: ColorConvertParams
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: StringThe PDF file path to convert.
outputOfficeFilePath: StringThe 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: StringThe PDF file path to convert.
outputOfficeFilePath: StringThe 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: StringThe PDF file path to convert.
outputOfficeFilePath: StringThe 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 documentConvert 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: StringThe XML namespace URI for the schema in which the property is to be found.
path: StringThe 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 objectCreateCollection allows to create new collection in the PDF document.It replaces any existing collection.
createNameTree
NameTreecreateNameTree(StringnameTreeName)Parameters
nameTreeName: StringThe 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
Parameters
afterPageNum: intThe 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: RectA 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 voiddelete
synchronized voiddelete()Returns:
synchronized voidCloses 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: intThe page number of the first page to delete. The first page is 0.
lastPage: intThe page number of the last page to delete.
Returns:
voidDeletes the specified pages.
deletePages
voiddeletePages(intfirstPage, intlastPage, java.util.EnumSet< PageDeleteFlags >deleteFlags)Parameters
firstPage: intThe page number of the first page to delete. The first page is 0.
lastPage: intThe page number of the last page to delete.
deleteFlags: java.util.EnumSet< PageDeleteFlags >One of the DeleteFlags.
Returns:
voidDeletes the specified pages with option to parse Structure Tree.
embedFonts
voidembedFonts()Returns:
voidEmbed 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:
voidEmbed 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: ProgressMonitora ProgressMonitor that will receive progress information, may be null
cancelProc: CancelProca CancelProc, which can return true to cancel the operation, may be null
reportProc: ReportProca ReportProc, which will be called with warnings about fonts that do not embed, may be null
Returns:
voidEmbed 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
fonts: java.util.List< Font >
Returns:
voidEmbed 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:
voidEmbed 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: ProgressMonitora ProgressMonitor that will receive progress information, may be null
cancelProc: CancelProca CancelProc, which can return true to cancel the operation, may be null
reportProc: ReportProca ReportProc, which will be called with warnings about fonts that do not embed, may be null
Returns:
voidEmbed 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:
voidEmbed fonts that were used in creating OCR text.
This is also done automatically when saving.
enumIndirectPDFObjects
booleanenumIndirectPDFObjects(PDFObjectEnumProcenumProc)Parameters
enumProc: PDFObjectEnumProcA 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: intThe first page in the range of pages.
endPage: intThe last page in the range of pages.
resourceType: ResourceTypeResource type to enumerate.
enumProc: PDFObjectEnumProcA 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:
voidEnumerates 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: StringThe path on disk of the file the AcroForms data is exported to.
exportType: AcroFormExportTypeThe 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 occurredExport 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: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
printProgressProc: PrintProgressProcA PrintProgressProc, may be null.
path: StringThe output file to be created.
Returns:
voidExports 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: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
path: StringThe output file to be created.
Returns:
voidExports 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: PrintUserParamsParameters to control printing.
path: StringThe output file to be created.
Returns:
voidExports 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: StringThe path on disk of the file the XFA form data is exported to.
exportType: XFAFormExportTypeThe 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 occurredExport 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:
voidCloses 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: StringThe 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: StringThe title of the bookmark for which to search.
maxDepth: intIf 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: intIndex of a page in the Document
Returns:
The label string for the pageFetch the label string for a page index, using the current page labels.
findPDFObjectByID
PDFObjectfindPDFObjectByID(intID)Parameters
ID: int
Returns:
PDFObjectRetrieves an indirect PDFObject by its ID number. Note that direct PDFObjects cannot be retrieved by ID.
findPageNumForLabel
intfindPageNumForLabel(Stringlabel)Parameters
label: StringThe label string to look up
Returns:
The index of the corresponding page, or -1 if the label could not be matchedLook up a page index based on a label string.
flattenAcroFormFields
voidflattenAcroFormFields()Returns:
voidFlatten 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:
voidFlatten 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: OptionalContentContextThe 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: FlattenTransparencyParamsAdditional 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: FlattenTransparencyParamsAdditional parameters for performing transparency flattening.
firstPage: intThe first page of the range of pages to flatten.
lastPage: intThe 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 .
getAttachments
java.util.List< FileAttachment >getAttachments()Returns:
set of attached files.Allows to obtain all attached files from the PDF document.
getAuthor
StringgetAuthor()Returns:
StringThe author of the PDF document.
getBaseURI
StringgetBaseURI()Returns:
StringThe 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:
intThe 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:
StringThe 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 propertyThe 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: intThe page number of the first page for which fonts are enumerated. The first page is 0.
lastPage: intThe 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: StringThe 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:
PDFDictThe 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 propertyThe document is embedded in a compound document (OLE, OpenDoc).
getIsLinearized
booleangetIsLinearized()Returns:
The IsLinearized propertyThe document is linearized (optimized) for page-served remote (network) access. This flag is get only.
getIsModified
booleangetIsModified()Returns:
The IsModified propertyThe 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 propertyThe 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 propertyThe underlying file is PxDF. This flag is get only.
getKeywords
StringgetKeywords()Returns:
StringThe 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 propertyThe document's major version is newer than the current library version. This flag is get only.
getMergedXMPKeywords
StringgetMergedXMPKeywords()Returns:
StringA 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 propertyThe document's minor version is newer than the current library version. This flag is get only.
getNameTree
NameTreegetNameTree(StringnameTreeName)Parameters
nameTreeName: StringThe 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 propertyThe 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: intThe page number of the page to acquire. The first page is 0.
Returns:
PageGets a Page from a document.
getPageLabels
java.util.List< PageLabel >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:
PageModeThe 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 setAllows to obtain security flags for the document.
getProducer
StringgetProducer()Returns:
StringThe producer of the PDF file.
getRequiresFullSave
booleangetRequiresFullSave()Returns:
The RequiresFullSave propertyThe 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:
PDFDictThe 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:
StringThe subject of the PDF document.
getSuppressErrors
booleangetSuppressErrors()Returns:
The SuppressErrors propertyDo not display errors.
getTitle
StringgetTitle()Returns:
StringThe title of the PDF document.
getVersionIsOlderThanCurrentLibrary
booleangetVersionIsOlderThanCurrentLibrary()Returns:
The VersionIsOlderThanCurrentLibrary propertyThe 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 propertyThe document was repaired when it was opened. This flag is get only.
getXMPMetadata
StringgetXMPMetadata()Returns:
StringThe 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: StringThe XML namespace URI for the schema in which the property is to be found.
path: StringThe name of the desired simple property.
index: intThe 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: StringThe XML namespace URI for the schema in which the property is to be found.
path: StringThe 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:
StringGets 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: StringThe path on disk of the AcroFormsdata file to be imported.
importType: AcroFormImportTypeThe 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 occurredImport 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: StringThe 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 occurredImport 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: intThe 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: DocumentThe document containing the pages that are inserted into doc.
startPage: intThe page number of the first page in doc2 to insert into doc. The first page is 0.
numPages: intThe 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:
voidInserts 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: intThe 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: DocumentThe document containing the pages that are inserted into doc.
startPage: intThe page number of the first page in doc2 to insert into doc. The first page is 0.
numPages: intThe 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: ProgressMonitora ProgressMonitor that will receive progress information, may be null
cancelProc: CancelProca CancelProc, which can return true to cancel the operation, may be null
Returns:
voidInserts 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 notIndicates 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 notIndicates 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 .
lookForKidsInNameTree
voidlookForKidsInNameTree(PDFDictnameTree, java.util.List< FileAttachment >attachments)Parameters
nameTree: PDFDictattachments: java.util.List< FileAttachment >
Returns:
voidmergeXMPKeywords
voidmergeXMPKeywords()Returns:
voidCauses 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: intThe 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: intThe page number of the page to move.
Returns:
voidMoves one page in a document.
permRequest
booleanpermRequest(PermissionRequestOperationrequestedperm)Parameters
requestedperm: PermissionRequestOperationThe 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: StringThe 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: PermissionRequestOperationthe 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
voidprint(PrintUserParamsuserParams)Parameters
userParams: PrintUserParamsParameters to control printing.
Returns:
voidPrints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.
voidprint(PrintUserParamsuserParams, PrintCancelProcprintCancelProc)Parameters
userParams: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
Returns:
voidPrints a PDF document or pages from a PDF document allowing the caller to specify options such as page size, rotation, and shrink-to-fit.
voidprint(PrintUserParamsuserParams, PrintCancelProcprintCancelProc, PrintProgressProcprintProgressProc)Parameters
userParams: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
printProgressProc: PrintProgressProcA PrintProgressProc, may be null.
Returns:
voidPrints 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: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
printProgressProc: PrintProgressProcA PrintProgressProc, may be null.
path: StringThe output file to be created.
Returns:
voidPrints 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: PrintUserParamsParameters to control printing.
printCancelProc: PrintCancelProcA PrintCancelProc, which can return true to cancel printing, may be null.
path: StringThe output file to be created.
Returns:
voidPrints 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: PrintUserParamsParameters to control printing.
path: StringThe output file to be created.
Returns:
voidPrints 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:
voidRemoveCollection Removes a collection dictionary from a document.
removeDuplicateOCG
voidremoveDuplicateOCG()Returns:
voidRemoves duplicate optional content group from the document. This does not remove any content associated with the duplicate group,
removeNameTree
voidremoveNameTree(StringnameTreeName)Parameters
nameTreeName: StringThe name of the NameTree to remove.
Returns:
voidRemoves 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: OptionalContentGroupThe optional content group to remove.
Returns:
voidRemoves 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: intThe first page number in doc to replace. The first page is 0.
doc2: DocumentThe document from which pages are copied into doc.
startPageDoc2: intThe page number of the first page in doc2 to copy. The first page is 0.
numPages: intThe number of pages to replace.
mergeTextAnnots: booleanIf 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:
voidReplaces 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:
voidSaves 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 >dest: JavaStreamFile
Returns:
voidsave
voidsave(java.util.EnumSet< SaveFlags >saveFlags, JavaStreamFiledest, ProgressMonitorprogressMonitor, CancelProccancelProc)Parameters
saveFlags: java.util.EnumSet< SaveFlags >dest: JavaStreamFileprogressMonitor: ProgressMonitorcancelProc: CancelProc
Returns:
voidsave
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.ImageOutputStreamThe stream to which the file is saved.
Returns:
voidSaves 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.ImageOutputStreamprogressMonitor: ProgressMonitorcancelProc: CancelProc
Returns:
voidsave
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: ProgressMonitora ProgressMonitor that will receive progress information, may be null
cancelProc: CancelProca CancelProc, which can return true to cancel the operation, may be null
Returns:
voidSaves 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: StringThe 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:
voidSaves 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: StringThe 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: ProgressMonitora ProgressMonitor that will receive progress information, may be null
cancelProc: CancelProca CancelProc, which can return true to cancel the operation, may be null
Returns:
voidSaves 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: Stringoptional PDF document owner password; pass null if not used.
userPassword: Stringoptional PDF document user password; pass null if not used.
Returns:
voidSecure 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: Stringoptional PDF document owner password; pass null if not used.
userPassword: Stringoptional PDF document user password; pass null if not used.
encryptionType: EncryptionTypeEncryption type to be used for securing the document.
Returns:
voidSecure 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: Stringoptional PDF document owner password; pass null if not used.
userPassword: Stringoptional PDF document user password; pass null if not used.
encryptionType: EncryptionTypeEncryption type to be used for securing the document.
encryptMetadata: booleanA flag that indicates whether document metadata will be encrypted.
Returns:
voidSecure 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:
voidThe author of the PDF document.
setBaseURI
voidsetBaseURI(StringURIvalue)Parameters
URIvalue: String
Returns:
voidThe Base URI of the PDF document.
setCreator
voidsetCreator(Stringcreatorvalue)Parameters
creatorvalue: String
Returns:
voidThe creator of the PDF document.
setDeleteOnClose
voidsetDeleteOnClose(booleanvalue)Parameters
value: booleanThe DeleteOnClose property
Returns:
voidThe document is based on a temporary file that must be deleted when the document is closed or saved.
setInfo
voidsetInfo(Stringinfoname, Stringinfovalue)Parameters
infoname: StringThe name of metadata to be set
infovalue: StringThe value for metadata which will be set
Returns:
voidSets metadata information in a PDF document.
setIsEmbedded
voidsetIsEmbedded(booleanvalue)Parameters
value: booleanThe IsEmbedded property
Returns:
voidThe document is embedded in a compound document (OLE, OpenDoc).
setIsOptimized
voidsetIsOptimized(booleanvalue)Parameters
value: booleanThe IsOptimized property
Returns:
voidThe 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:
voidThe keywords of the PDF document.
setMajorVersion
voidsetMajorVersion(shortmajorVersion)Parameters
majorVersion: shortThe new major version number to be set in the document's file header.
Returns:
voidThe 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: shortThe new minor version number to be set in the document's file header.
Returns:
voidThe 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: booleanThe NeedSave property
Returns:
voidThe document has been modified and needs to be saved.
setPageLabels
voidsetPageLabels(java.util.List< PageLabel >arg0)Parameters
Returns:
voidThe list of PageLabel objects used in the document.
setPageMode
voidsetPageMode(PageModepagemode)Parameters
pagemode: PageModethe pagemode to apply to the Document
Returns:
voidThe PageMode of the PDF document.
The default PageMode for a new Document is PageMode.NoPreference .
setProducer
voidsetProducer(Stringproducervalue)Parameters
producervalue: String
Returns:
voidThe producer of the PDF document.
setRequiresFullSave
voidsetRequiresFullSave(booleanvalue)Parameters
value: booleanThe RequiresFullSave property
Returns:
voidThe 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:
voidThe subject of the PDF document.
setSuppressErrors
voidsetSuppressErrors(booleanvalue)Parameters
value: booleanThe SuppressErrors property
Returns:
voidDo not display errors.
setTitle
voidsetTitle(Stringtitlevalue)Parameters
titlevalue: String
Returns:
voidThe title of the PDF document.
setXMPMetadata
voidsetXMPMetadata(Stringmetadata)Parameters
metadata: String
Returns:
voidThe 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: StringThe XML namespace URI for the schema in which the property is to be found.
namespacePrefix: StringA brief string to be used as an abbreviation when creating the XML representation of the property. This string must not be empty.
path: StringThe name of the simple property to be modified.
index: intThe index in the metadata property array associated with the property.
newValue: StringThe new XML text value for the property.
Returns:
voidSets the value of an XMP metadata array item, associated with a document, based on an index.
setXMPMetadataProperty
voidsetXMPMetadataProperty(StringnamespaceName, StringnamespacePrefix, Stringpath, StringnewValue)Parameters
namespaceName: StringThe XML namespace URI for the schema in which the property is to be found.
namespacePrefix: StringA brief string to be used as an abbreviation when creating the XML representation of the property. This string must not be empty.
path: StringThe name of the simple property to be modified.
newValue: StringThe new XML text value for the property.
Returns:
voidSets 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:
voidRemove 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: PageThe page to be added as a watermark.
watermarkParams: WatermarkParamsStructure specifying how the watermark should be added to the document.
Returns:
voidAdds a Page as a watermark to a page range in the given document.
watermark
voidwatermark(WatermarkTextParamswatermarkTextParams, WatermarkParamswatermarkParams)Parameters
watermarkTextParams: WatermarkTextParamsStructure describing the text-based watermark to be added.
watermarkParams: WatermarkParamsStructure specifying how the watermark should be added to the document.
Returns:
voidAdds a text-based watermark to a page range in the given document.