java.lang.Object
org.sejda.sambox.contentstream.PDFStreamEngine
org.sejda.sambox.contentstream.PDFGraphicsStreamEngine
org.sejda.sambox.rendering.PageDrawer
Paints a page in a PDF document to a Graphics context. May be subclassed to provide custom
rendering.
If you want to do custom graphics processing rather than Graphics2D rendering, then you should
subclass PDFGraphicsStreamEngine instead. Subclassing PageDrawer is only suitable for
cases where the goal is to render onto a Graphics2D surface. In that case you'll also
have to subclass PDFRenderer and modify PDFRenderer.createPageDrawer(PageDrawerParameters).
- Author:
- Ben Litchfield
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidappendRectangle(Point2D p0, Point2D p1, Point2D p2, Point2D p3) Append a rectangle to the current path.voidbeginMarkedContentSequence(COSName tag, COSDictionary properties) Called when a marked content group beginsvoidCalled when the BT operator is encountered.voidclip(int windingRule) Modify the current clipping path by intersecting it with the current path.voidCloses the current path.voidcurveTo(float x1, float y1, float x2, float y2, float x3, float y3) Draws a curve from the current point to (x3,y3) using (x1,y1) and (x2,y2) as control points.voidDraw the image.voiddrawPage(Graphics g, PDRectangle pageSize) Draws the page to the requested context.voidCalled when a a marked content group endsvoidendPath()Ends the current path without filling or stroking it.voidendText()Called when the ET operator is encountered.voidfillAndStrokePath(int windingRule) Fills and then strokes the path.voidfillPath(int windingRule) Fill the path.Return the AnnotationFilter.Returns the current point of the current path.protected final Graphics2DReturns the underlying Graphics2D.protected final GeneralPathReturns the current line path.protected final PaintReturns the non-stroking AWT Paint.protected PaintReturns an AWT paint for the given PDColor.final PDFRendererReturns the parent renderer.booleanvoidlineTo(float x, float y) Draws a line from the current point to (x,y).voidmoveTo(float x, float y) Starts a new path at (x,y).voidsetAnnotationFilter(AnnotationFilter annotationFilter) Set the AnnotationFilter.protected final voidsetClip()Sets the clipping path using caching for performance.voidsetTextContentRendered(boolean textContentRendered) voidshadingFill(COSName shadingName) Fill with Shading.voidshowAnnotation(PDAnnotation annotation) Shows the given annotation.protected voidshowFontGlyph(Matrix textRenderingMatrix, PDFont font, int code, Vector displacement) Called when a glyph is to be processed.This method is intended for overriding in subclasses, the default implementation does nothing.voidshowForm(PDFormXObject form) Shows a form from the content stream.voidShows a transparency group from the content stream.protected voidshowTransparencyGroupOnGraphics(PDTransparencyGroup form, Graphics2D graphics) For advanced users, to extract the transparency group into a separate graphics device.protected voidshowType3Glyph(Matrix textRenderingMatrix, PDType3Font font, int code, Vector displacement) Called when a glyph is to be processed.This method is intended for overriding in subclasses, the default implementation does nothing.voidStroke the path.protected voidtransferClip(Graphics2D graphics) Transfer clip to the destination device.Methods inherited from class org.sejda.sambox.contentstream.PDFGraphicsStreamEngine
getPageMethods inherited from class org.sejda.sambox.contentstream.PDFStreamEngine
addOperator, addOperatorIfAbsent, applyTextAdjustment, decreaseLevel, getAppearance, getCurrentPage, getGraphicsStackSize, getGraphicsState, getInitialMatrix, getLevel, getResources, getTextLineMatrix, getTextMatrix, increaseLevel, operatorException, processAnnotation, processChildStream, processOperator, processOperator, processPage, processSoftMask, processStream, processTilingPattern, processTilingPattern, processTransparencyGroup, processType3Stream, restoreGraphicsStack, restoreGraphicsState, saveGraphicsStack, saveGraphicsState, setLineDashPattern, setTextLineMatrix, setTextMatrix, showGlyph, showText, showTextString, showTextStrings, transformedPoint, transformWidth, unsupportedOperator
-
Constructor Details
-
PageDrawer
Constructor.- Parameters:
parameters- Parameters for page drawing.- Throws:
IOException- If there is an error loading properties from the file.
-
-
Method Details
-
getAnnotationFilter
Return the AnnotationFilter.- Returns:
- the AnnotationFilter
-
setAnnotationFilter
Set the AnnotationFilter.Allows to only render annotation accepted by the filter.
- Parameters:
annotationFilter- the AnnotationFilter
-
getRenderer
Returns the parent renderer. -
getGraphics
Returns the underlying Graphics2D. May be null if drawPage has not yet been called. -
getLinePath
Returns the current line path. This is reset to empty after each fill/stroke. -
drawPage
Draws the page to the requested context.- Parameters:
g- The graphics context to draw onto.pageSize- The size of the page to draw.- Throws:
IOException- If there is an IO error while drawing the page.
-
getPaint
Returns an AWT paint for the given PDColor.- Parameters:
color- The color to get a paint for. This can be an actual color or a pattern.- Throws:
IOException
-
setClip
protected final void setClip()Sets the clipping path using caching for performance. We track lastClip manually becauseGraphics.getClip()returns a new object instead of the same one passed tosetClip(). You may need to call this if you overrideshowGlyph(). See PDFBOX-5093 for more. -
transferClip
Transfer clip to the destination device. Override this if you want to avoid to do slow intersecting operations but want the destination device to do this (e.g. SVG). You can get the individual clippings viaPDGraphicsState.getCurrentClippingPaths(). See PDFBOX-5258 for sample code.- Parameters:
graphics- graphics device
-
beginText
Description copied from class:PDFStreamEngineCalled when the BT operator is encountered. This method is for overriding in subclasses, the default implementation does nothing.- Overrides:
beginTextin classPDFStreamEngine- Throws:
IOException- if there was an error processing the text
-
endText
Description copied from class:PDFStreamEngineCalled when the ET operator is encountered. This method is for overriding in subclasses, the default implementation does nothing.- Overrides:
endTextin classPDFStreamEngine- Throws:
IOException- if there was an error processing the text
-
showFontGlyph
protected void showFontGlyph(Matrix textRenderingMatrix, PDFont font, int code, Vector displacement) throws IOException Description copied from class:PDFStreamEngineCalled when a glyph is to be processed.This method is intended for overriding in subclasses, the default implementation does nothing.- Overrides:
showFontGlyphin classPDFStreamEngine- Parameters:
textRenderingMatrix- the current text rendering matrix, Trmfont- the current fontcode- internal PDF character code for the glyphdisplacement- the displacement (i.e. advance) of the glyph in text space- Throws:
IOException- if the glyph cannot be processed
-
showType3Glyph
protected void showType3Glyph(Matrix textRenderingMatrix, PDType3Font font, int code, Vector displacement) throws IOException Description copied from class:PDFStreamEngineCalled when a glyph is to be processed.This method is intended for overriding in subclasses, the default implementation does nothing.- Overrides:
showType3Glyphin classPDFStreamEngine- Parameters:
textRenderingMatrix- the current text rendering matrix, Trmfont- the current fontcode- internal PDF character code for the glyphdisplacement- the displacement (i.e. advance) of the glyph in text space- Throws:
IOException- if the glyph cannot be processed
-
appendRectangle
Description copied from class:PDFGraphicsStreamEngineAppend a rectangle to the current path.- Specified by:
appendRectanglein classPDFGraphicsStreamEngine- Parameters:
p0- point P0 of the rectangle.p1- point P1 of the rectangle.p2- point P2 of the rectangle.p3- point P3 of the rectangle.
-
getNonStrokingPaint
Returns the non-stroking AWT Paint. You may need to call this if you overrideshowGlyph(). See PDFBOX-5093 for more.- Returns:
- The non-stroking AWT Paint.
- Throws:
IOException
-
strokePath
Description copied from class:PDFGraphicsStreamEngineStroke the path.- Specified by:
strokePathin classPDFGraphicsStreamEngine- Throws:
IOException- If there is an IO error while stroking the path.
-
fillPath
Description copied from class:PDFGraphicsStreamEngineFill the path.- Specified by:
fillPathin classPDFGraphicsStreamEngine- Parameters:
windingRule- The winding rule this path will use.- Throws:
IOException
-
fillAndStrokePath
Fills and then strokes the path.- Specified by:
fillAndStrokePathin classPDFGraphicsStreamEngine- Parameters:
windingRule- The winding rule this path will use.- Throws:
IOException- If there is an IO error while filling the path.
-
clip
public void clip(int windingRule) Description copied from class:PDFGraphicsStreamEngineModify the current clipping path by intersecting it with the current path. The clipping path will not be updated until the succeeding painting operator is called.- Specified by:
clipin classPDFGraphicsStreamEngine- Parameters:
windingRule- The winding rule which will be used for clipping.
-
moveTo
public void moveTo(float x, float y) Description copied from class:PDFGraphicsStreamEngineStarts a new path at (x,y).- Specified by:
moveToin classPDFGraphicsStreamEngine
-
lineTo
public void lineTo(float x, float y) Description copied from class:PDFGraphicsStreamEngineDraws a line from the current point to (x,y).- Specified by:
lineToin classPDFGraphicsStreamEngine
-
curveTo
public void curveTo(float x1, float y1, float x2, float y2, float x3, float y3) Description copied from class:PDFGraphicsStreamEngineDraws a curve from the current point to (x3,y3) using (x1,y1) and (x2,y2) as control points.- Specified by:
curveToin classPDFGraphicsStreamEngine
-
getCurrentPoint
Description copied from class:PDFGraphicsStreamEngineReturns the current point of the current path.- Specified by:
getCurrentPointin classPDFGraphicsStreamEngine
-
closePath
public void closePath()Description copied from class:PDFGraphicsStreamEngineCloses the current path.- Specified by:
closePathin classPDFGraphicsStreamEngine
-
endPath
public void endPath()Description copied from class:PDFGraphicsStreamEngineEnds the current path without filling or stroking it. The clipping path is updated here.- Specified by:
endPathin classPDFGraphicsStreamEngine
-
drawImage
Description copied from class:PDFGraphicsStreamEngineDraw the image.- Specified by:
drawImagein classPDFGraphicsStreamEngine- Parameters:
pdImage- The image to draw.- Throws:
IOException- if something went wrong.
-
shadingFill
Description copied from class:PDFGraphicsStreamEngineFill with Shading.- Specified by:
shadingFillin classPDFGraphicsStreamEngine- Parameters:
shadingName- The name of the Shading Dictionary to use for this fill instruction.- Throws:
IOException
-
showAnnotation
Description copied from class:PDFStreamEngineShows the given annotation.- Overrides:
showAnnotationin classPDFStreamEngine- Parameters:
annotation- An annotation on the current page.- Throws:
IOException- If an error occurred reading the annotation
-
showForm
Shows a form from the content stream.- Overrides:
showFormin classPDFStreamEngine- Parameters:
form- form XObject- Throws:
IOException- if the form cannot be processed
-
showTransparencyGroup
Description copied from class:PDFStreamEngineShows a transparency group from the content stream.- Overrides:
showTransparencyGroupin classPDFStreamEngine- Parameters:
form- transparency group (form) XObject- Throws:
IOException- if the transparency group cannot be processed
-
showTransparencyGroupOnGraphics
protected void showTransparencyGroupOnGraphics(PDTransparencyGroup form, Graphics2D graphics) throws IOException For advanced users, to extract the transparency group into a separate graphics device.- Parameters:
form-graphics-- Throws:
IOException
-
beginMarkedContentSequence
Called when a marked content group begins- Overrides:
beginMarkedContentSequencein classPDFStreamEngine- Parameters:
tag- content tagproperties- optional properties
-
endMarkedContentSequence
public void endMarkedContentSequence()Called when a a marked content group ends- Overrides:
endMarkedContentSequencein classPDFStreamEngine
-
isTextContentRendered
public boolean isTextContentRendered() -
setTextContentRendered
public void setTextContentRendered(boolean textContentRendered)
-