Class AbstractBitmapDocumentHandler

    • Field Detail

      • log

        private static org.apache.commons.logging.Log log
        logging instance
      • TARGET_BITMAP_SIZE

        public static final java.lang.String TARGET_BITMAP_SIZE
        Rendering Options key for the controlling the required bitmap size to create. This is used to create thumbnails, for example. If used, the target resolution is ignored. Value type: java.awt.Dimension (size in pixels)
        See Also:
        Constant Field Values
      • imageWriter

        private org.apache.xmlgraphics.image.writer.ImageWriter imageWriter
      • multiImageWriter

        private org.apache.xmlgraphics.image.writer.MultiImageWriter multiImageWriter
      • pageCount

        private int pageCount
      • currentPageDimensions

        private java.awt.Dimension currentPageDimensions
      • currentImage

        private java.awt.image.BufferedImage currentImage
      • scaleFactor

        private double scaleFactor
      • targetBitmapSize

        private java.awt.Dimension targetBitmapSize
    • Constructor Detail

      • AbstractBitmapDocumentHandler

        public AbstractBitmapDocumentHandler​(IFContext context)
        Default constructor.
    • Method Detail

      • 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 abstract java.lang.String getMimeType()
        Returns the MIME type of the output format that is generated by this implementation.
        Returns:
        the MIME type
      • getDefaultExtension

        public abstract java.lang.String getDefaultExtension()
        Returns the default file extension for the supported image type.
        Returns:
        the default file extension (ex. "png")
      • getConfigurator

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

        public BitmapRenderingSettings getSettings()
        Returns the settings for bitmap rendering.
        Returns:
        the settings object
      • setTargetBitmapSize

        public void setTargetBitmapSize​(java.awt.Dimension size)
        Sets the target bitmap size (in pixels) of the bitmap that should be produced. Normally, the bitmap size is calculated automatically based on the page size and the target resolution. But for example, if you want to create thumbnails or small preview bitmaps from pages it is more practical (and efficient) to set the required bitmap size.
        Parameters:
        size - the target bitmap size (in pixels)
      • startPageSequence

        public void startPageSequence​(java.lang.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,
                              java.lang.String name,
                              java.lang.String pageMasterName,
                              java.awt.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
      • createBufferedImage

        protected java.awt.image.BufferedImage createBufferedImage​(int bitmapWidth,
                                                                   int bitmapHeight)
        Creates a new BufferedImage.
        Parameters:
        bitmapWidth - the desired width in pixels
        bitmapHeight - the desired height in pixels
        Returns:
        the new BufferedImage instance
      • 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​(java.lang.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