Class ElementLayoutController
java.lang.Object
org.jfree.report.flow.layoutprocessor.ElementLayoutController
- All Implemented Interfaces:
Cloneable,LayoutController
- Direct Known Subclasses:
AutoTableItemLayoutController,AutoTableLayoutController,ContentElementLayoutController,SectionLayoutController
Creation-Date: 24.11.2006, 13:56:30
- Author:
- Thomas Morgner
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprotected static class -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intstatic final intstatic final intstatic final intstatic final int -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal LayoutControlleradvance(ReportTarget target) Advances the layout controller to the next state.clone()Creates a copy of this layout controller.protected org.jfree.layouting.util.AttributeMapcomputeAttributes(FlowController fc, Element element, ReportTarget target) Derives a copy of this controller that is suitable to perform a precomputation.protected LayoutControllerfinishElement(ReportTarget target) Finishes the processing of this element.org.jfree.layouting.util.AttributeMapintintgetNode()Retrieves the parent of this layout controller.intprotected FlowControllerhandleDefaultEndElement(ReportTarget target) voidinitialize(Object node, FlowController flowController, LayoutController parent) Initializes the layout controller.booleanChecks, whether the layout controller would be advanceable.booleanprotected FlowControllerperformElementPrecomputation(Expression[] expressions, FlowController fc) protected abstract LayoutControllerprocessContent(ReportTarget target) Processes any content in this element.voidsetFlowController(FlowController flowController) voidsetParent(LayoutController parent) voidsetProcessingState(int processingState) protected FlowControllerstartData(ReportTarget target, FlowController fc) protected LayoutControllerstartElement(ReportTarget target) This method is called for each newly instantiated layout controller.toString()protected FlowControllerMethods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.jfree.report.flow.layoutprocessor.LayoutController
join
-
Field Details
-
NOT_STARTED
public static final int NOT_STARTED- See Also:
-
OPENED
public static final int OPENED- See Also:
-
WAITING_FOR_JOIN
public static final int WAITING_FOR_JOIN- See Also:
-
FINISHING
public static final int FINISHING- See Also:
-
FINISHED
public static final int FINISHED- See Also:
-
-
Constructor Details
-
ElementLayoutController
protected ElementLayoutController()
-
-
Method Details
-
toString
-
getParent
Retrieves the parent of this layout controller. This allows childs to query their context.- Specified by:
getParentin interfaceLayoutController- Returns:
- the layout controller's parent to
nullif there is no parent.
-
initialize
public void initialize(Object node, FlowController flowController, LayoutController parent) throws DataSourceException, ReportDataFactoryException, ReportProcessingException Initializes the layout controller. This method is called exactly once. It is the creators responsibility to call this method. Calling initialize after the first advance must result in a IllegalStateException.- Specified by:
initializein interfaceLayoutController- Parameters:
node- the currently processed object or layout node.flowController- the current flow controller.parent- the parent layout controller that was responsible for instantiating this controller.- Throws:
DataSourceException- if there was a problem reading data from the datasource.ReportProcessingException- if there was a general problem during the report processing.ReportDataFactoryException- if a query failed.
-
advance
public final LayoutController advance(ReportTarget target) throws DataSourceException, ReportProcessingException, ReportDataFactoryException Advances the layout controller to the next state. This method delegates the call to one of the following methods:- Specified by:
advancein interfaceLayoutController- Parameters:
target- the report target that receives generated events.- Returns:
- the new layout controller instance representing the new state.
- Throws:
DataSourceException- if there was a problem reading data from the datasource.ReportProcessingException- if there was a general problem during the report processing.ReportDataFactoryException- if a query failed.
-
startElement
protected LayoutController startElement(ReportTarget target) throws DataSourceException, ReportProcessingException, ReportDataFactoryException This method is called for each newly instantiated layout controller. The returned layout controller instance should have a processing state of either 'OPEN' or 'FINISHING' depending on whether there is any content or any child nodes to process.- Parameters:
target- the report target that receives generated events.- Returns:
- the new layout controller instance representing the new state.
- Throws:
DataSourceException- if there was a problem reading data from the datasource.ReportProcessingException- if there was a general problem during the report processing.ReportDataFactoryException- if a query failed.
-
getAttributeMap
public org.jfree.layouting.util.AttributeMap getAttributeMap() -
getExpressionsCount
public int getExpressionsCount() -
getIterationCount
public int getIterationCount() -
startData
protected FlowController startData(ReportTarget target, FlowController fc) throws DataSourceException, ReportProcessingException, ReportDataFactoryException -
computeAttributes
protected org.jfree.layouting.util.AttributeMap computeAttributes(FlowController fc, Element element, ReportTarget target) throws DataSourceException - Throws:
DataSourceException
-
processContent
protected abstract LayoutController processContent(ReportTarget target) throws DataSourceException, ReportProcessingException, ReportDataFactoryException Processes any content in this element. This method is called when the processing state is 'OPENED'. The returned layout controller will retain the 'OPENED' state as long as there is more content available. Once all content has been processed, the returned layout controller should carry a 'FINISHED' state.- Parameters:
target- the report target that receives generated events.- Returns:
- the new layout controller instance representing the new state.
- Throws:
DataSourceException- if there was a problem reading data from the datasource.ReportProcessingException- if there was a general problem during the report processing.ReportDataFactoryException- if a query failed.
-
finishElement
protected LayoutController finishElement(ReportTarget target) throws ReportProcessingException, DataSourceException, ReportDataFactoryException Finishes the processing of this element. This method is called when the processing state is 'FINISHING'. The element should be closed now and all privatly owned resources should be freed. If the element has a parent, it would be time to join up with the parent now, else the processing state should be set to 'FINISHED'.- Parameters:
target- the report target that receives generated events.- Returns:
- the new layout controller instance representing the new state.
- Throws:
DataSourceException- if there was a problem reading data from the datasource.ReportProcessingException- if there was a general problem during the report processing.ReportDataFactoryException- if there was an error trying query data.
-
handleDefaultEndElement
protected FlowController handleDefaultEndElement(ReportTarget target) throws ReportProcessingException, DataSourceException, ReportDataFactoryException -
isAdvanceable
public boolean isAdvanceable()Description copied from interface:LayoutControllerChecks, whether the layout controller would be advanceable. If this method returns true, it is generally safe to call the 'advance()' method.- Specified by:
isAdvanceablein interfaceLayoutController- Returns:
- true, if the layout controller is advanceable, false otherwise.
-
getElement
-
getFlowController
- Specified by:
getFlowControllerin interfaceLayoutController
-
getProcessingState
public int getProcessingState() -
setProcessingState
public void setProcessingState(int processingState) -
setFlowController
-
setParent
-
clone
Description copied from interface:LayoutControllerCreates a copy of this layout controller.- Specified by:
clonein interfaceLayoutController- Overrides:
clonein classObject- Returns:
- a copy.
-
isPrecomputing
public boolean isPrecomputing() -
performElementPrecomputation
protected FlowController performElementPrecomputation(Expression[] expressions, FlowController fc) throws ReportProcessingException, ReportDataFactoryException, DataSourceException -
tryRepeatingCommit
- Throws:
DataSourceException
-
createPrecomputeInstance
Derives a copy of this controller that is suitable to perform a precomputation.- Specified by:
createPrecomputeInstancein interfaceLayoutController- Parameters:
fc-- Returns:
-
getNode
- Specified by:
getNodein interfaceLayoutController
-