Package org.apache.fop.area
Class AreaTreeHandler
- java.lang.Object
-
- org.apache.fop.fo.FOEventHandler
-
- org.apache.fop.area.AreaTreeHandler
-
public class AreaTreeHandler extends FOEventHandler
Area tree handler for formatting objects. Concepts: The area tree is to be as small as possible. With minimal classes and data to fully represent an area tree for formatting objects. The area tree needs to be simple to render and follow the spec closely. This area tree has the concept of page sequences. Wherever possible information is discarded or optimized to keep memory use low. The data is also organized to make it possible for renderers to minimize their output. A page can be saved if not fully resolved and once rendered a page contains only size and id reference information. The area tree pages are organized in a model that depends on the type of renderer.
-
-
Field Summary
Fields Modifier and Type Field Description protected AreaTreeModelmodelThe AreaTreeModel in use-
Fields inherited from class org.apache.fop.fo.FOEventHandler
fontInfo, foUserAgent
-
-
Constructor Summary
Constructors Constructor Description AreaTreeHandler(FOUserAgent userAgent, java.lang.String outputFormat, java.io.OutputStream stream)Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddUnresolvedIDRef(java.lang.String idref, Resolvable res)Deprecated.use getIDTracker().addUnresolvedIDRef(idref, res) insteadbooleanalreadyResolvedID(java.lang.String id)Deprecated.use getIDTracker().alreadyResolvedID(id) insteadvoidassociateIDWithPageViewport(java.lang.String id, PageViewport pv)Deprecated.use getIDTracker().associateIDWithPageViewport(id, pv) insteadvoidendDocument()End the document.voidendExternalDocument(ExternalDocument document)Process the end of the external-document extension.voidendPageSequence(PageSequence pageSequence)End the PageSequence.java.lang.StringgeneratePageViewportKey()Generates and returns a unique key for a page viewport.AreaTreeModelgetAreaTreeModel()Get the area tree model for this area tree.IDTrackergetIDTracker()Get the IDTracker for this area tree.LayoutManagerMakergetLayoutManagerMaker()Get the LayoutManager maker for this area tree.java.util.List<PageViewport>getPageViewportsContainingID(java.lang.String id)Deprecated.use getIDTracker().getPageViewportsContainingID(id) insteadFormattingResultsgetResults()Get information about the rendered output, like number of pages created.booleanisComplexScriptFeaturesEnabled()Check whether complex script features are enabled.voidnotifyPageSequenceFinished(AbstractPageSequence pageSequence, int pageCount)Called by the PageSequenceLayoutManager when it is finished with a page-sequence.protected voidsetupModel(FOUserAgent userAgent, java.lang.String outputFormat, java.io.OutputStream stream)Sets up the AreaTreeModel instance for use by the AreaTreeHandler.voidsignalIDProcessed(java.lang.String id)Deprecated.use getIDTracker().signalIDProcessed(id) insteadvoidsignalPendingID(java.lang.String id)Deprecated.use getIDTracker().signalPendingID(id) insteadvoidstartDocument()Prepare AreaTreeHandler for document processing This is called from FOTreeBuilder.startDocument()voidstartExternalDocument(ExternalDocument document)Process the start of the external-document extension.voidstartPageSequence(PageSequence pageSequence)voidstartRoot(Root root)Called upon start of root element.voidtryIDResolution(PageViewport pv)Deprecated.use getIDTracker().tryIDResolution(pv) instead-
Methods inherited from class org.apache.fop.fo.FOEventHandler
character, characters, endBlock, endBlockContainer, endBody, endCell, endColumn, endFlow, endFooter, endFootnote, endFootnoteBody, endHeader, endInline, endInstreamForeignObject, endLeader, endLink, endList, endListBody, endListItem, endListLabel, endMarkup, endPageNumber, endPageNumberCitation, endPageNumberCitationLast, endRetrieveMarker, endRetrieveTableMarker, endRoot, endRow, endStatic, endTable, endWrapper, getFontInfo, getUserAgent, image, pageRef, restoreState, restoreState, startBlock, startBlockContainer, startBody, startCell, startColumn, startFlow, startFooter, startFootnote, startFootnoteBody, startHeader, startInline, startInstreamForeignObject, startLeader, startLink, startList, startListBody, startListItem, startListLabel, startMarkup, startPageNumber, startPageNumberCitation, startPageNumberCitationLast, startRetrieveMarker, startRetrieveTableMarker, startRow, startStatic, startTable, startWrapper
-
-
-
-
Field Detail
-
model
protected AreaTreeModel model
The AreaTreeModel in use
-
-
Constructor Detail
-
AreaTreeHandler
public AreaTreeHandler(FOUserAgent userAgent, java.lang.String outputFormat, java.io.OutputStream stream) throws FOPException
Constructor.- Parameters:
userAgent- FOUserAgent object for processoutputFormat- the MIME type of the output format to use (ex. "application/pdf").stream- OutputStream- Throws:
FOPException- if the RenderPagesModel cannot be created
-
-
Method Detail
-
setupModel
protected void setupModel(FOUserAgent userAgent, java.lang.String outputFormat, java.io.OutputStream stream) throws FOPException
Sets up the AreaTreeModel instance for use by the AreaTreeHandler.- Parameters:
userAgent- FOUserAgent object for processoutputFormat- the MIME type of the output format to use (ex. "application/pdf").stream- OutputStream- Throws:
FOPException- if the RenderPagesModel cannot be created
-
getAreaTreeModel
public AreaTreeModel getAreaTreeModel()
Get the area tree model for this area tree.- Returns:
- AreaTreeModel the model being used for this area tree
-
getLayoutManagerMaker
public LayoutManagerMaker getLayoutManagerMaker()
Get the LayoutManager maker for this area tree.- Returns:
- LayoutManagerMaker the LayoutManager maker being used for this area tree
-
getIDTracker
public IDTracker getIDTracker()
Get the IDTracker for this area tree.- Returns:
- IDTracker used to track reference ids for items in this area tree
-
getResults
public FormattingResults getResults()
Get information about the rendered output, like number of pages created.- Overrides:
getResultsin classFOEventHandler- Returns:
- the results structure
-
isComplexScriptFeaturesEnabled
public boolean isComplexScriptFeaturesEnabled()
Check whether complex script features are enabled.- Returns:
- true if using complex script features
-
startDocument
public void startDocument() throws org.xml.sax.SAXExceptionPrepare AreaTreeHandler for document processing This is called from FOTreeBuilder.startDocument()- Overrides:
startDocumentin classFOEventHandler- Throws:
org.xml.sax.SAXException- if there is an error
-
startRoot
public void startRoot(Root root)
Description copied from class:FOEventHandlerCalled upon start of root element.- Overrides:
startRootin classFOEventHandler- Parameters:
root- element
-
startPageSequence
public void startPageSequence(PageSequence pageSequence)
- Overrides:
startPageSequencein classFOEventHandler- Parameters:
pageSequence- PageSequence that is starting.
-
endPageSequence
public void endPageSequence(PageSequence pageSequence)
End the PageSequence. The PageSequence formats Pages and adds them to the AreaTree. The area tree then handles what happens with the pages.- Overrides:
endPageSequencein classFOEventHandler- Parameters:
pageSequence- the page sequence ending
-
startExternalDocument
public void startExternalDocument(ExternalDocument document)
Process the start of the external-document extension.- Overrides:
startExternalDocumentin classFOEventHandler- Parameters:
document- the external-document node
-
endExternalDocument
public void endExternalDocument(ExternalDocument document)
Process the end of the external-document extension.- Overrides:
endExternalDocumentin classFOEventHandler- Parameters:
document- the external-document node
-
notifyPageSequenceFinished
public void notifyPageSequenceFinished(AbstractPageSequence pageSequence, int pageCount)
Called by the PageSequenceLayoutManager when it is finished with a page-sequence.- Parameters:
pageSequence- the page-sequence just finishedpageCount- The number of pages generated for the page-sequence
-
endDocument
public void endDocument() throws org.xml.sax.SAXExceptionEnd the document.- Overrides:
endDocumentin classFOEventHandler- Throws:
org.xml.sax.SAXException- if there is some error
-
generatePageViewportKey
public java.lang.String generatePageViewportKey()
Generates and returns a unique key for a page viewport.- Returns:
- the generated key.
-
associateIDWithPageViewport
@Deprecated public void associateIDWithPageViewport(java.lang.String id, PageViewport pv)Deprecated.use getIDTracker().associateIDWithPageViewport(id, pv) insteadTie a PageViewport with an ID found on a child area of the PV. Note that an area with a given ID may be on more than one PV, hence an ID may have more than one PV associated with it.- Parameters:
id- the property ID of the areapv- a page viewport that contains the area with this ID
-
signalPendingID
@Deprecated public void signalPendingID(java.lang.String id)
Deprecated.use getIDTracker().signalPendingID(id) insteadThis method tie an ID to the areaTreeHandler until this one is ready to be processed. This is used in page-number-citation-last processing so we know when an id can be resolved.- Parameters:
id- the id of the object being processed
-
signalIDProcessed
@Deprecated public void signalIDProcessed(java.lang.String id)
Deprecated.use getIDTracker().signalIDProcessed(id) insteadSignals that all areas for the formatting object with the given ID have been generated. This is used to determine when page-number-citation-last ref-ids can be resolved.- Parameters:
id- the id of the formatting object which was just finished
-
alreadyResolvedID
@Deprecated public boolean alreadyResolvedID(java.lang.String id)
Deprecated.use getIDTracker().alreadyResolvedID(id) insteadCheck if an ID has already been resolved- Parameters:
id- the id to check- Returns:
- true if the ID has been resolved
-
tryIDResolution
@Deprecated public void tryIDResolution(PageViewport pv)
Deprecated.use getIDTracker().tryIDResolution(pv) insteadTries to resolve all unresolved ID references on the given page.- Parameters:
pv- page viewport whose ID refs to resolve
-
getPageViewportsContainingID
@Deprecated public java.util.List<PageViewport> getPageViewportsContainingID(java.lang.String id)
Deprecated.use getIDTracker().getPageViewportsContainingID(id) insteadGet the set of page viewports that have an area with a given id.- Parameters:
id- the id to lookup- Returns:
- the list of PageViewports
-
addUnresolvedIDRef
@Deprecated public void addUnresolvedIDRef(java.lang.String idref, Resolvable res)Deprecated.use getIDTracker().addUnresolvedIDRef(idref, res) insteadAdd an Resolvable object with an unresolved idref- Parameters:
idref- the idref whose target id has not yet been locatedres- the Resolvable object needing the idref to be resolved
-
-