Class PdfDocument
java.lang.Object
com.itextpdf.text.Document
com.itextpdf.text.pdf.PdfDocument
- All Implemented Interfaces:
DocListener, ElementListener, IAccessibleElement, EventListener
PdfDocument is the class that is used by PdfWriter
to translate a Document into a PDF with different pages.
A PdfDocument always listens to a Document
and adds the Pdf representation of every Element that is
added to the Document.
- Since:
- 2.0.8 (class was package-private before)
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionclassstatic class(package private) static classPdfCatalogis the PDF Catalog-object.static classPdfInfois the PDF InfoDictionary. -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected PdfDictionaryprotected intThis represents the current alignment of the PDF Elements.protected PdfActionThe current activePdfActionwhen processing anAnchor.(package private) PdfAnnotationsImpprivate PdfBodyprotected HashMap<String, PdfRectangle> This is the size of the several boxes that will be used in the next page.protected PdfCollectionprotected floatThis is the current height of the document.protected PdfOutlineThis is the currentPdfOutlinein the hierarchy of outlines.private HashMap<AccessibleElementId, AccessibleElementId> private TempFileCacheprotected booleanSignals that OnOpenDocument should be called.protected PdfContentByteThis is the PdfContentByte object, containing the borders and other Graphics.(package private) static final StringThe characters to be applied the hanging punctuation.protected floatThis is the position where the image ends.protected ImageThis is the image that could not be shown on a previous page.protected PdfDocument.Indentationprotected PdfDocument.PdfInfosome meta information about the Document.protected booleanSignals that onParagraph is valid (to avoid that a Chapter/Section title is treated as a Paragraph).private boolean(package private) intStores a list of document level JavaScript actions.protected PdfStringprotected intHolds the type of the last element, that has been added to the document.protected floatThis represents the leading of the lines.Signals that the current leading has to be subtracted from a YMark object when positive and save current leadingprotected PdfLineThe line that is currently being written.The lines that are written until now.protected TreeMap<String, PdfDocument.Destination> Stores the destinations keyed by name.protected floatmargin in y direction starting from the bottom.protected floatmargin in x direction starting from the left.protected floatmargin in x direction starting from the right.protected floatmargin in y direction starting from the top.protected RectangleThis is the size of the next page.protected PdfActionprotected Stringprotected booleanprotected PdfDictionaryprivate booleanThis checks if the page is empty.protected PdfPageLabelsprotected PageResourcesThis are the page resources of the current Page.protected PdfOutlineThis is the root outline of the document.protected static final DecimalFormatprotected booleanHolds value of property strictImageSequence.private HashMap<AccessibleElementId, PdfStructureElement> protected TabSettingsThe current tab settings.protected PdfContentByteThis is the PdfContentByte object, containing the text.protected intprotected HashMap<String, PdfRectangle> This is the size of the several boxes of the current Page.protected PdfViewerPreferencesImpContains the Viewer preferences of this PDF document.protected PdfWriterThePdfWriter.Fields inherited from class Document
accessibleAttributes, chapternumber, close, compress, htmlStyleClass, id, javaScript_onLoad, javaScript_onUnLoad, listeners, marginBottom, marginLeft, marginMirroring, marginMirroringTopBottom, marginRight, marginTop, open, pageN, pageSize, plainRandomAccess, role, wmfFontCorrection -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleanSignals that anElementwas added to theDocument.protected voidAdds an image to the document.(package private) voidaddAdditionalAction(PdfName actionType, PdfAction action) (package private) voidaddAnnotation(PdfAnnotation annot) (package private) voidaddCalculationOrder(PdfFormField formField) private void(package private) voidaddFileAttachment(String description, PdfFileSpecification fs) (package private) void(package private) voidaddJavaScript(String name, PdfAction js) (package private) voidaddOutline(PdfOutline outline, String name) Adds a named outline to the document .(package private) voidAdds aPdfPTableto the document.protected voidaddSpacing(float extraspace, float oldleading, Font f) Calls addSpacing(float, float, Font, boolean (false)).protected voidaddSpacing(float extraspace, float oldleading, Font f, boolean spacingAfter) Adds extra spacing.(package private) voidaddViewerPreference(PdfName key, PdfObject value) voidAdds aPdfWriterto thePdfDocument.protected floatline.height() is usually the same as the leading We should take leading into account if it is not the same as the line.height(package private) voidUpdates the count in the outlines.protected voidIf the current line is not empty or null, it is added to the arraylist of lines and a new empty line is added.voidMethod added by Pelikan Stephanvoidclose()Closes the document.protected ArrayList<IAccessibleElement> endPage()protected voidEnsures that a new line has been started.(package private) booleanChecks if aPdfPTablefits the current page of thePdfDocument.private voidprotected floatWrites all the lines to the text-object.protected void(package private) PdfAcroFormGets the AcroForm object.(package private) RectanglegetBoxSize(String boxName) Gives the size of a trim, art, crop or bleed box, or null if not defined.(package private) PdfDocument.PdfCataloggetCatalog(PdfIndirectReference pages) Gets thePdfCatalog-object.(package private) PdfDocument.PdfInfogetInfo()Gets thePdfInfo-object.private PdfLinefloatGetter for the current leading.(package private) PdfActiongetLocalGotoAction(String name) intgetNextMarkPoint(Object obj) (package private) PageResourcesGets the root outline.protected PdfStructureElementprotected PdfStructureElementgetStructElement(AccessibleElementId id, boolean toSaveFetchedElement) intint[]Getter for the current tab stops.floatgetVerticalPosition(boolean ensureNewLine) Gets the current vertical page position.(package private) floatGets the indentation on the bottom side.protected floatGets the indentation on the left side.protected floatGets the indentation on the right side.protected floatGets the indentation on the top side.protected voidinitPage()Initializes a page.(package private) boolean(package private) booleanGetter for property strictImageSequence.private static boolean(package private) booleanlocalDestination(String name, PdfDestination destination) The local destination to where a local goto with the same name will jump to.(package private) voidImplements a link to other part of the document.protected voidnewLine()Adds the current line to the list of lines and also adds an empty line.booleannewPage()Makes a new page and sends it to thePdfWriter.voidopen()Opens the document.(package private) voidoutlineTree(PdfOutline outline) Recursive method used to write outlines.protected voidRestore @leading from leadingStackprotected voidSave current @leading(package private) voidremoteGoto(String filename, int page, float llx, float lly, float urx, float ury) Implements a link to another document.(package private) voidremoteGoto(String filename, String name, float llx, float lly, float urx, float ury) Implements a link to another document.voidSets the page number to 0.protected voidsaveStructElement(AccessibleElementId id, PdfStructureElement element) (package private) voidImplements an action in an area.(package private) voidsetBoxSize(String boxName, Rectangle size) voidsetCollection(PdfCollection collection) Sets the collection dictionary.(package private) voidsetCropBoxSize(Rectangle crop) (package private) voidsetDuration(int seconds) Sets the display duration for the page (for presentations)(package private) voidsetLanguage(String language) (package private) voidsetLeading(float leading) Setter for the current leading.booleansetMarginMirroring(boolean MarginMirroring) Set the margin mirroring.booleansetMarginMirroringTopBottom(boolean MarginMirroringTopBottom) Set the margin mirroring.booleansetMargins(float marginLeft, float marginRight, float marginTop, float marginBottom) Sets the margins.protected void(package private) voidsetOpenAction(PdfAction action) (package private) voidsetOpenAction(String name) (package private) voidsetPageAction(PdfName actionType, PdfAction action) voidsetPageCount(int pageN) Sets the page number.(package private) voidsetPageEmpty(boolean pageEmpty) (package private) voidsetPageLabels(PdfPageLabels pageLabels) Sets the page labelsbooleansetPageSize(Rectangle pageSize) Sets the pagesize.(package private) voidsetSigFlags(int f) (package private) voidsetStrictImageSequence(boolean strictImageSequence) Setter for property strictImageSequence.voidsetTabSettings(TabSettings tabSettings) Setter for the current tab stops.(package private) voidsetThumbnail(Image image) (package private) voidsetTransition(PdfTransition transition) Sets the transition for the page(package private) voidsetViewerPreferences(int preferences) voidsetXmpMetadata(byte[] xmpMetadata) Use this method to set the XMP Metadata.(package private) voidtraverseOutlineCount(PdfOutline outline) Recursive method to update the count in the outlines.protected voiduseExternalCache(TempFileCache externalCache) (package private) floatwriteLineToContent(PdfLine line, PdfContentByte text, PdfContentByte graphics, Object[] currentValues, float ratio) Writes a text line to the document.(package private) voidWrites the outline tree to the body of the PDF document.Methods inherited from class Document
addAuthor, addCreationDate, addCreator, addDocListener, addHeader, addKeywords, addLanguage, addProducer, addSubject, addTitle, bottom, bottom, bottomMargin, getAccessibleAttribute, getAccessibleAttributes, getHtmlStyleClass, getId, getJavaScript_onLoad, getJavaScript_onUnLoad, getPageNumber, getPageSize, getRole, isInline, isMarginMirroring, isOpen, left, left, leftMargin, removeDocListener, right, right, rightMargin, setAccessibleAttribute, setHtmlStyleClass, setId, setJavaScript_onLoad, setJavaScript_onUnLoad, setRole, top, top, topMargin
-
Field Details
-
writer
ThePdfWriter. -
structElements
-
externalCache
-
externallyStoredStructElements
-
elementsParents
-
isToUseExternalCache
private boolean isToUseExternalCache -
openMCDocument
protected boolean openMCDocument -
structParentIndices
-
markPoints
-
text
This is the PdfContentByte object, containing the text. -
graphics
This is the PdfContentByte object, containing the borders and other Graphics. -
leading
protected float leadingThis represents the leading of the lines. -
alignment
protected int alignmentThis represents the current alignment of the PDF Elements. -
currentHeight
protected float currentHeightThis is the current height of the document. -
isSectionTitle
protected boolean isSectionTitleSignals that onParagraph is valid (to avoid that a Chapter/Section title is treated as a Paragraph).- Since:
- 2.1.2
-
anchorAction
The current activePdfActionwhen processing anAnchor. -
tabSettings
-
leadingStack
-
body
-
textEmptySize
protected int textEmptySize -
nextMarginLeft
protected float nextMarginLeftmargin in x direction starting from the left. Will be valid in the next page -
nextMarginRight
protected float nextMarginRightmargin in x direction starting from the right. Will be valid in the next page -
nextMarginTop
protected float nextMarginTopmargin in y direction starting from the top. Will be valid in the next page -
nextMarginBottom
protected float nextMarginBottommargin in y direction starting from the bottom. Will be valid in the next page -
firstPageEvent
protected boolean firstPageEventSignals that OnOpenDocument should be called. -
line
The line that is currently being written. -
lines
-
lastElementType
protected int lastElementTypeHolds the type of the last element, that has been added to the document. -
hangingPunctuation
The characters to be applied the hanging punctuation.- See Also:
-
indentation
-
info
some meta information about the Document. -
rootOutline
This is the root outline of the document. -
currentOutline
This is the currentPdfOutlinein the hierarchy of outlines. -
viewerPreferences
Contains the Viewer preferences of this PDF document. -
pageLabels
-
localDestinations
Stores the destinations keyed by name. Value is aDestination. -
jsCounter
int jsCounterStores a list of document level JavaScript actions. -
documentLevelJS
-
SIXTEEN_DIGITS
-
documentFileAttachment
-
openActionName
-
openActionAction
-
additionalActions
-
collection
-
annotationsImp
PdfAnnotationsImp annotationsImp -
language
-
nextPageSize
This is the size of the next page. -
thisBoxSize
This is the size of the several boxes of the current Page. -
boxSize
This is the size of the several boxes that will be used in the next page. -
pageEmpty
private boolean pageEmptyThis checks if the page is empty. -
pageAA
-
pageResources
This are the page resources of the current Page. -
strictImageSequence
protected boolean strictImageSequenceHolds value of property strictImageSequence. -
imageEnd
protected float imageEndThis is the position where the image ends. -
imageWait
This is the image that could not be shown on a previous page. -
floatingElements
-
-
Constructor Details
-
PdfDocument
public PdfDocument()Constructs a new PDF document.
-
-
Method Details
-
addWriter
Adds aPdfWriterto thePdfDocument.- Parameters:
writer- thePdfWriterthat writes everything what is added to this document to an outputstream.- Throws:
DocumentException- on error
-
getLeading
public float getLeading()Getter for the current leading.- Returns:
- the current leading
- Since:
- 2.1.2
-
setLeading
void setLeading(float leading) Setter for the current leading.- Parameters:
leading- the current leading- Since:
- 2.1.6
-
pushLeading
protected void pushLeading()Save current @leading -
popLeading
protected void popLeading()Restore @leading from leadingStack -
getTabSettings
-
setTabSettings
Setter for the current tab stops.- Parameters:
tabSettings- the current tab settings- Since:
- 5.4.0
-
add
Signals that anElementwas added to theDocument.- Specified by:
addin interfaceElementListener- Overrides:
addin classDocument- Parameters:
element- the element to add- Returns:
trueif the element was added,falseif not.- Throws:
DocumentException- when a document isn't open yet, or has been closed
-
open
public void open()Opens the document.You have to open the document before you can begin to add content to the body of the document.
- Specified by:
openin interfaceDocListener- Overrides:
openin classDocument
-
close
public void close()Closes the document. Once all the content has been written in the body, you have to close the body. After that nothing can be written to the body anymore.- Specified by:
closein interfaceDocListener- Overrides:
closein classDocument
-
setXmpMetadata
Use this method to set the XMP Metadata.- Parameters:
xmpMetadata- The xmpMetadata to set.- Throws:
IOException
-
newPage
public boolean newPage()Makes a new page and sends it to thePdfWriter.- Specified by:
newPagein interfaceDocListener- Overrides:
newPagein classDocument- Returns:
- true if new page is added
-
endPage
-
setPageSize
Sets the pagesize.- Specified by:
setPageSizein interfaceDocListener- Overrides:
setPageSizein classDocument- Parameters:
pageSize- the new pagesize- Returns:
trueif the page size was set
-
setMargins
public boolean setMargins(float marginLeft, float marginRight, float marginTop, float marginBottom) Sets the margins.- Specified by:
setMarginsin interfaceDocListener- Overrides:
setMarginsin classDocument- Parameters:
marginLeft- the margin on the leftmarginRight- the margin on the rightmarginTop- the margin on the topmarginBottom- the margin on the bottom- Returns:
- a
boolean
-
setMarginMirroring
public boolean setMarginMirroring(boolean MarginMirroring) Description copied from class:DocumentSet the margin mirroring. It will mirror right/left margins for odd/even pages.- Specified by:
setMarginMirroringin interfaceDocListener- Overrides:
setMarginMirroringin classDocument- Parameters:
MarginMirroring-trueto mirror the margins- Returns:
- always
true - See Also:
-
setMarginMirroringTopBottom
public boolean setMarginMirroringTopBottom(boolean MarginMirroringTopBottom) Description copied from class:DocumentSet the margin mirroring. It will mirror top/bottom margins for odd/even pages.- Specified by:
setMarginMirroringTopBottomin interfaceDocListener- Overrides:
setMarginMirroringTopBottomin classDocument- Parameters:
MarginMirroringTopBottom-trueto mirror the margins- Returns:
- always
true - Since:
- 2.1.6
- See Also:
-
setPageCount
public void setPageCount(int pageN) Sets the page number.- Specified by:
setPageCountin interfaceDocListener- Overrides:
setPageCountin classDocument- Parameters:
pageN- the new page number
-
resetPageCount
public void resetPageCount()Sets the page number to 0.- Specified by:
resetPageCountin interfaceDocListener- Overrides:
resetPageCountin classDocument
-
initPage
Initializes a page.If the footer/header is set, it is printed.
- Throws:
DocumentException- on error
-
newLine
Adds the current line to the list of lines and also adds an empty line.- Throws:
DocumentException- on error
-
calculateLineHeight
protected float calculateLineHeight()line.height() is usually the same as the leading We should take leading into account if it is not the same as the line.height- Returns:
- float combined height of the line
- Since:
- 5.5.1
-
carriageReturn
protected void carriageReturn()If the current line is not empty or null, it is added to the arraylist of lines and a new empty line is added. -
getVerticalPosition
public float getVerticalPosition(boolean ensureNewLine) Gets the current vertical page position.- Parameters:
ensureNewLine- Tells whether a new line shall be enforced. This may cause side effects for elements that do not terminate the lines they've started because those lines will get terminated.- Returns:
- The current vertical page position.
-
ensureNewLine
protected void ensureNewLine()Ensures that a new line has been started. -
flushLines
Writes all the lines to the text-object.- Returns:
- the displacement that was caused
- Throws:
DocumentException- on error
-
writeLineToContent
float writeLineToContent(PdfLine line, PdfContentByte text, PdfContentByte graphics, Object[] currentValues, float ratio) throws DocumentException Writes a text line to the document. It takes care of all the attributes.Before entering the line position must have been established and the
textargument must be in text object scope (beginText()).- Parameters:
line- the line to be writtentext- thePdfContentBytewhere the text will be written tographics- thePdfContentBytewhere the graphics will be written tocurrentValues- the current font and extra spacing valuesratio-- Throws:
DocumentException- on error- Since:
- 5.0.3 returns a float instead of void
-
indentLeft
protected float indentLeft()Gets the indentation on the left side.- Returns:
- a margin
-
indentRight
protected float indentRight()Gets the indentation on the right side.- Returns:
- a margin
-
indentTop
protected float indentTop()Gets the indentation on the top side.- Returns:
- a margin
-
indentBottom
float indentBottom()Gets the indentation on the bottom side.- Returns:
- a margin
-
addSpacing
Calls addSpacing(float, float, Font, boolean (false)). -
addSpacing
Adds extra spacing. -
getInfo
-
getCatalog
Gets thePdfCatalog-object.- Parameters:
pages- an indirect reference to this document pages- Returns:
PdfCatalog
-
addOutline
Adds a named outline to the document .- Parameters:
outline- the outline to be addedname- the name of this local destination
-
getRootOutline
Gets the root outline. All the outlines must be created with a parent. The first level is created with this outline.- Returns:
- the root outline
-
calculateOutlineCount
void calculateOutlineCount()Updates the count in the outlines. -
traverseOutlineCount
Recursive method to update the count in the outlines. -
writeOutlines
Writes the outline tree to the body of the PDF document.- Throws:
IOException
-
outlineTree
Recursive method used to write outlines.- Throws:
IOException
-
setViewerPreferences
void setViewerPreferences(int preferences) - See Also:
-
addViewerPreference
-
setPageLabels
Sets the page labels- Parameters:
pageLabels- the page labels
-
getPageLabels
-
localGoto
Implements a link to other part of the document. The jump will be made to a local destination with the same name, that must exist.- Parameters:
name- the name for this linkllx- the lower left x corner of the activation areally- the lower left y corner of the activation areaurx- the upper right x corner of the activation areaury- the upper right y corner of the activation area
-
remoteGoto
Implements a link to another document.- Parameters:
filename- the filename for the remote documentname- the name to jump tollx- the lower left x corner of the activation areally- the lower left y corner of the activation areaurx- the upper right x corner of the activation areaury- the upper right y corner of the activation area
-
remoteGoto
Implements a link to another document.- Parameters:
filename- the filename for the remote documentpage- the page to jump tollx- the lower left x corner of the activation areally- the lower left y corner of the activation areaurx- the upper right x corner of the activation areaury- the upper right y corner of the activation area
-
setAction
Implements an action in an area.- Parameters:
action- thePdfActionllx- the lower left x corner of the activation areally- the lower left y corner of the activation areaurx- the upper right x corner of the activation areaury- the upper right y corner of the activation area
-
getLocalGotoAction
-
localDestination
The local destination to where a local goto with the same name will jump to.- Parameters:
name- the name of this local destinationdestination- thePdfDestinationwith the jump coordinates- Returns:
trueif the local destination was added,falseif a local destination with the same name already existed
-
addJavaScript
-
addJavaScript
-
getDocumentLevelJS
-
addFileAttachment
- Throws:
IOException
-
getDocumentFileAttachment
-
setOpenAction
-
setOpenAction
-
addAdditionalAction
-
setCollection
Sets the collection dictionary.- Parameters:
collection- a dictionary of type PdfCollection
-
getAcroForm
PdfAcroForm getAcroForm()Gets the AcroForm object.- Returns:
- the PdfAcroform object of the PdfDocument
-
setSigFlags
void setSigFlags(int f) -
addCalculationOrder
-
addAnnotation
-
setLanguage
-
setCropBoxSize
-
setBoxSize
-
setNewPageSizeAndMargins
protected void setNewPageSizeAndMargins() -
getBoxSize
-
setPageEmpty
void setPageEmpty(boolean pageEmpty) -
isPageEmpty
boolean isPageEmpty() -
setDuration
void setDuration(int seconds) Sets the display duration for the page (for presentations)- Parameters:
seconds- the number of seconds to display the page
-
setTransition
Sets the transition for the page- Parameters:
transition- the PdfTransition object
-
setPageAction
-
setThumbnail
- Throws:
PdfExceptionDocumentException
-
getPageResources
PageResources getPageResources() -
isStrictImageSequence
boolean isStrictImageSequence()Getter for property strictImageSequence.- Returns:
- Value of property strictImageSequence.
-
setStrictImageSequence
void setStrictImageSequence(boolean strictImageSequence) Setter for property strictImageSequence.- Parameters:
strictImageSequence- New value of property strictImageSequence.
-
clearTextWrap
public void clearTextWrap()Method added by Pelikan Stephan -
getStructParentIndex
-
getNextMarkPoint
-
getStructParentIndexAndNextMarkPoint
-
add
Adds an image to the document.- Parameters:
image- theImageto add- Throws:
PdfException- on errorDocumentException- on error
-
addPTable
Adds aPdfPTableto the document.- Parameters:
ptable- thePdfPTableto be added to the document.- Throws:
DocumentException- on error
-
addDiv
- Throws:
DocumentException
-
flushFloatingElements
- Throws:
DocumentException
-
fitsPage
Checks if aPdfPTablefits the current page of thePdfDocument.- Parameters:
table- the table that has to be checkedmargin- a certain margin- Returns:
trueif thePdfPTablefits the page,falseotherwise.
-
isTagged
-
getLastLine
-
useExternalCache
-
saveStructElement
-
getStructElement
-
getStructElement
protected PdfStructureElement getStructElement(AccessibleElementId id, boolean toSaveFetchedElement) -
flushStructureElementsOnNewPage
protected void flushStructureElementsOnNewPage() -
getStructElements
-