Class PDFDocumentHandler

All Implemented Interfaces:
IFDocumentHandler

public class PDFDocumentHandler extends AbstractBinaryWritingIFDocumentHandler
IFDocumentHandler implementation that produces PDF.
  • Constructor Details

    • PDFDocumentHandler

      public PDFDocumentHandler(IFContext context)
      Default constructor.
  • Method Details

    • supportsPagesOutOfOrder

      public boolean supportsPagesOutOfOrder()
      Indicates whether the painter supports to handle the pages in mixed order rather than ascending order.
      Returns:
      true if out-of-order handling is supported
    • getMimeType

      public String getMimeType()
      Returns the MIME type of the output format that is generated by this implementation.
      Returns:
      the MIME type
    • getConfigurator

      public IFDocumentHandlerConfigurator getConfigurator()
      Returns the configurator for this document handler, if any.
      Returns:
      the configurator or null if there's no configurator
    • getDocumentNavigationHandler

      public IFDocumentNavigationHandler getDocumentNavigationHandler()
      Returns a document navigation handler if this feature is supported.
      Specified by:
      getDocumentNavigationHandler in interface IFDocumentHandler
      Overrides:
      getDocumentNavigationHandler in class AbstractIFDocumentHandler
      Returns:
      the document navigation handler or null if not supported
    • startDocument

      public void startDocument() throws IFException
      Indicates the start of a document. This method may only be called once before any other event method.
      Specified by:
      startDocument in interface IFDocumentHandler
      Overrides:
      startDocument in class AbstractBinaryWritingIFDocumentHandler
      Throws:
      IFException - if an error occurs while handling this event
    • endDocumentHeader

      public void endDocumentHeader() throws IFException
      Indicates the end of the document header. This method is called before the first page sequence.
      Specified by:
      endDocumentHeader in interface IFDocumentHandler
      Overrides:
      endDocumentHeader in class AbstractIFDocumentHandler
      Throws:
      IFException - if an error occurs while handling this event
    • endDocument

      public void endDocument() throws IFException
      Indicates the end of a document. This method may only be called once after the whole document has been handled. Implementations can release resources (close streams). It is an error to call any event method after this method.
      Specified by:
      endDocument in interface IFDocumentHandler
      Overrides:
      endDocument in class AbstractBinaryWritingIFDocumentHandler
      Throws:
      IFException - if an error occurs while handling this event
    • startPageSequence

      public void startPageSequence(String id) throws IFException
      Indicates the start of a new page sequence.
      Parameters:
      id - the page sequence's identifier (or null if none is available)
      Throws:
      IFException - if an error occurs while handling this event
    • endPageSequence

      public void endPageSequence() throws IFException
      Indicates the end of a page sequence.
      Throws:
      IFException - if an error occurs while handling this event
    • startPage

      public void startPage(int index, String name, String pageMasterName, Dimension size) throws IFException
      Indicates the start of a new page.
      Parameters:
      index - the index of the page (0-based)
      name - the page name (usually the formatted page number)
      pageMasterName - the name of the simple-page-master that generated this page
      size - the size of the page (equivalent to the MediaBox in PDF)
      Throws:
      IFException - if an error occurs while handling this event
    • startPageContent

      public IFPainter startPageContent() throws IFException
      Indicates the start of the page content. The method returns an IFPainter interface which is used to paint the page contents.
      Returns:
      the IFPainter for the page content
      Throws:
      IFException - if an error occurs while handling this event
    • endPageContent

      public void endPageContent() throws IFException
      Indicates the end of the page content. Calls to the IFPainter returned by the respective IFDocumentHandler.startPageContent() method are illegal.
      Throws:
      IFException - if an error occurs while handling this event
    • endPage

      public void endPage() throws IFException
      Indicates the end of a page
      Throws:
      IFException - if an error occurs while handling this event
    • handleExtensionObject

      public void handleExtensionObject(Object extension) throws IFException
      Handles an extension object. This can be a DOM document or any arbitrary object. If an implementation doesn't know how to handle a particular extension it is simply ignored.
      Parameters:
      extension - the extension object
      Throws:
      IFException - if an error occurs while handling this event
    • setDocumentLocale

      public void setDocumentLocale(Locale locale)
      Specified by:
      setDocumentLocale in interface IFDocumentHandler
      Overrides:
      setDocumentLocale in class AbstractIFDocumentHandler
      Parameters:
      locale - Locale of the document.
    • getStructureTreeEventHandler

      public StructureTreeEventHandler getStructureTreeEventHandler()
      Description copied from class: AbstractIFDocumentHandler
      Specified by:
      getStructureTreeEventHandler in interface IFDocumentHandler
      Overrides:
      getStructureTreeEventHandler in class AbstractIFDocumentHandler
      Returns:
      the structure tree builder
    • getPageNumbers

      public Map<Integer,PDFArray> getPageNumbers()