Class CustomGraphicsStreamEngine
java.lang.Object
org.apache.pdfbox.contentstream.PDFStreamEngine
org.apache.pdfbox.contentstream.PDFGraphicsStreamEngine
org.apache.pdfbox.examples.rendering.CustomGraphicsStreamEngine
Example of a custom PDFGraphicsStreamEngine subclass. Allows text and graphics to be processed
in a custom manner. This example simply prints the operations to stdout.
See PDFStreamEngine for further methods which may be overridden.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidappendRectangle(Point2D p0, Point2D p1, Point2D p2, Point2D p3) Append a rectangle to the current path.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.voidendPath()Ends the current path without filling or stroking it.voidfillAndStrokePath(int windingRule) Fills and then strokes the path.voidfillPath(int windingRule) Fill the path.Returns the current point of the current path.voidlineTo(float x, float y) Draws a line from the current point to (x,y).static voidvoidmoveTo(float x, float y) Starts a new path at (x,y).voidrun()Runs the engine on the current page.voidshadingFill(COSName shadingName) Fill with Shading.protected voidOverridden from PDFStreamEngine.voidshowTextString(byte[] string) Overridden from PDFStreamEngine.voidshowTextStrings(COSArray array) Overridden from PDFStreamEngine.voidStroke the path.Methods inherited from class org.apache.pdfbox.contentstream.PDFGraphicsStreamEngine
getPageMethods inherited from class org.apache.pdfbox.contentstream.PDFStreamEngine
addOperator, applyTextAdjustment, beginMarkedContentSequence, beginText, decreaseLevel, endMarkedContentSequence, endText, getAppearance, getCurrentPage, getGraphicsStackSize, getGraphicsState, getInitialMatrix, getLevel, getResources, getTextLineMatrix, getTextMatrix, increaseLevel, operatorException, processAnnotation, processChildStream, processOperator, processOperator, processPage, processSoftMask, processTilingPattern, processTilingPattern, processTransparencyGroup, processType3Stream, restoreGraphicsStack, restoreGraphicsState, saveGraphicsStack, saveGraphicsState, setLineDashPattern, setTextLineMatrix, setTextMatrix, showAnnotation, showFontGlyph, showForm, showText, showTransparencyGroup, showType3Glyph, transformedPoint, transformWidth, unsupportedOperator
-
Constructor Details
-
CustomGraphicsStreamEngine
Constructor.- Parameters:
page- PDF Page
-
-
Method Details
-
main
- Throws:
IOException
-
run
Runs the engine on the current page.- Throws:
IOException- If there is an IO error while drawing the page.
-
appendRectangle
Description copied from class:PDFGraphicsStreamEngineAppend a rectangle to the current path.- Specified by:
appendRectanglein classPDFGraphicsStreamEngine- Parameters:
p0- starting coordinate of the rectanglep1- second coordinate of the rectanglep2- third coordinate of the rectanglep3- last coordinate of the rectangle- Throws:
IOException- if the rectangle could not be appended
-
drawImage
Description copied from class:PDFGraphicsStreamEngineDraw the image.- Specified by:
drawImagein classPDFGraphicsStreamEngine- Parameters:
pdImage- The image to draw.- Throws:
IOException- if the image could not be drawn
-
clip
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.- Throws:
IOException- if the clipping path could not be modified
-
moveTo
Description copied from class:PDFGraphicsStreamEngineStarts a new path at (x,y).- Specified by:
moveToin classPDFGraphicsStreamEngine- Parameters:
x- the x-coordinate to move toy- the y-coordinate to move to- Throws:
IOException- if the something went wrong when moving to the given coordinate
-
lineTo
Description copied from class:PDFGraphicsStreamEngineDraws a line from the current point to (x,y).- Specified by:
lineToin classPDFGraphicsStreamEngine- Parameters:
x- the X-coordinate of the ending-point of the line to be drawny- the Y-coordinate of the ending-point of the line to be drawn- Throws:
IOException- if the line could not be drawn
-
curveTo
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- Parameters:
x1- the X coordinate of the first Bézier control pointy1- the Y coordinate of the first Bézier control pointx2- the X coordinate of the second Bézier control pointy2- the Y coordinate of the second Bézier control pointx3- the X coordinate of the final end pointy3- the Y coordinate of the final end point- Throws:
IOException- if the curve could not be drawn
-
getCurrentPoint
Description copied from class:PDFGraphicsStreamEngineReturns the current point of the current path.- Specified by:
getCurrentPointin classPDFGraphicsStreamEngine- Returns:
- the current point or null
- Throws:
IOException- if the something went wrong when providing the current point
-
closePath
Description copied from class:PDFGraphicsStreamEngineCloses the current path.- Specified by:
closePathin classPDFGraphicsStreamEngine- Throws:
IOException- if the current path could not be closed
-
endPath
Description copied from class:PDFGraphicsStreamEngineEnds the current path without filling or stroking it. The clipping path is updated here.- Specified by:
endPathin classPDFGraphicsStreamEngine- Throws:
IOException- if the current path could not be ended
-
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- if the path could not be filled
-
fillAndStrokePath
Description copied from class:PDFGraphicsStreamEngineFills and then strokes the path.- Specified by:
fillAndStrokePathin classPDFGraphicsStreamEngine- Parameters:
windingRule- The winding rule this path will use.- Throws:
IOException- if the path could not be filled and stroke
-
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- if the path could not be filled using the given shading
-
showTextString
Overridden from PDFStreamEngine.- Overrides:
showTextStringin classPDFStreamEngine- Parameters:
string- the encoded text- Throws:
IOException- if there was an error showing the text
-
showTextStrings
Overridden from PDFStreamEngine.- Overrides:
showTextStringsin classPDFStreamEngine- Parameters:
array- array of encoded text strings and adjustments- Throws:
IOException- if there was an error showing the text
-
showGlyph
protected void showGlyph(Matrix textRenderingMatrix, PDFont font, int code, Vector displacement) throws IOException Overridden from PDFStreamEngine.- Overrides:
showGlyphin 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
-