Class EscherGraphics
- java.lang.Object
-
- java.awt.Graphics
-
- org.apache.poi.hssf.usermodel.EscherGraphics
-
public class EscherGraphics extends Graphics
Translates Graphics calls into escher calls. The translation is lossy so many features are not supported and some just aren't implemented yet. If in doubt test the specific calls you wish to make. Graphics calls are always performed into an EscherGroup so one will need to be created.Important:
One important concept worth considering is that of font size. One of the difficulties in converting Graphics calls into escher drawing calls is that Excel does not have the concept of absolute pixel positions. It measures its cell widths in 'characters' and the cell heights in points. Unfortunately it's not defined exactly what a type of character it's measuring. Presumably this is due to the fact that the Excel will be using different fonts on different platforms or even within the same platform.
Because of this constraint we've had to calculate the verticalPointsPerPixel. This the amount the font should be scaled by when you issue commands such as drawString(). A good way to calculate this is to use the follow formula:
multiplier = groupHeightInPoints / heightOfGroupThe height of the group is calculated fairly simply by calculating the difference between the y coordinates of the bounding box of the shape. The height of the group can be calculated by using a convenience called
HSSFClientAnchor.getAnchorHeightInPoints().
-
-
Constructor Summary
Constructors Constructor Description EscherGraphics(HSSFShapeGroup escherGroup, HSSFWorkbook workbook, Color forecolor, float verticalPointsPerPixel)Construct an escher graphics object.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclearRect(int x, int y, int width, int height)voidclipRect(int x, int y, int width, int height)voidcopyArea(int x, int y, int width, int height, int dx, int dy)Graphicscreate()voiddispose()voiddrawArc(int x, int y, int width, int height, int startAngle, int arcAngle)booleandrawImage(Image img, int dx1, int dy1, int dx2, int dy2, int sx1, int sy1, int sx2, int sy2, Color bgcolor, ImageObserver observer)booleandrawImage(Image img, int dx1, int dy1, int dx2, int dy2, int sx1, int sy1, int sx2, int sy2, ImageObserver observer)booleandrawImage(Image image, int i, int j, int k, int l, Color color, ImageObserver imageobserver)booleandrawImage(Image image, int i, int j, int k, int l, ImageObserver imageobserver)booleandrawImage(Image image, int i, int j, Color color, ImageObserver imageobserver)booleandrawImage(Image image, int i, int j, ImageObserver imageobserver)voiddrawLine(int x1, int y1, int x2, int y2)voiddrawLine(int x1, int y1, int x2, int y2, int width)voiddrawOval(int x, int y, int width, int height)voiddrawPolygon(int[] xPoints, int[] yPoints, int nPoints)voiddrawPolyline(int[] xPoints, int[] yPoints, int nPoints)voiddrawRect(int x, int y, int width, int height)voiddrawRoundRect(int x, int y, int width, int height, int arcWidth, int arcHeight)voiddrawString(String str, int x, int y)voiddrawString(AttributedCharacterIterator iterator, int x, int y)voidfillArc(int x, int y, int width, int height, int startAngle, int arcAngle)voidfillOval(int x, int y, int width, int height)voidfillPolygon(int[] xPoints, int[] yPoints, int nPoints)Fills a (closed) polygon, as defined by a pair of arrays, which hold the x and y coordinates.voidfillRect(int x, int y, int width, int height)voidfillRoundRect(int x, int y, int width, int height, int arcWidth, int arcHeight)ColorgetBackground()ShapegetClip()RectanglegetClipBounds()ColorgetColor()FontgetFont()FontMetricsgetFontMetrics(Font f)voidsetBackground(Color background)voidsetClip(int x, int y, int width, int height)voidsetClip(Shape shape)voidsetColor(Color color)voidsetFont(Font f)voidsetPaintMode()voidsetXORMode(Color color)voidtranslate(int x, int y)-
Methods inherited from class java.awt.Graphics
create, draw3DRect, drawBytes, drawChars, drawPolygon, fill3DRect, fillPolygon, finalize, getClipBounds, getClipRect, getFontMetrics, hitClip, toString
-
-
-
-
Constructor Detail
-
EscherGraphics
public EscherGraphics(HSSFShapeGroup escherGroup, HSSFWorkbook workbook, Color forecolor, float verticalPointsPerPixel)
Construct an escher graphics object.- Parameters:
escherGroup- The escher group to write the graphics calls into.workbook- The workbook we are using.forecolor- The foreground color to use as default.verticalPointsPerPixel- The font multiplier. (See class description for information on how this works.).
-
-
Method Detail
-
clearRect
public void clearRect(int x, int y, int width, int height)
-
clipRect
@NotImplemented public void clipRect(int x, int y, int width, int height)
-
copyArea
@NotImplemented public void copyArea(int x, int y, int width, int height, int dx, int dy)
-
drawArc
@NotImplemented public void drawArc(int x, int y, int width, int height, int startAngle, int arcAngle)
-
drawImage
@NotImplemented public boolean drawImage(Image img, int dx1, int dy1, int dx2, int dy2, int sx1, int sy1, int sx2, int sy2, Color bgcolor, ImageObserver observer)
-
drawImage
@NotImplemented public boolean drawImage(Image img, int dx1, int dy1, int dx2, int dy2, int sx1, int sy1, int sx2, int sy2, ImageObserver observer)
-
drawImage
public boolean drawImage(Image image, int i, int j, int k, int l, Color color, ImageObserver imageobserver)
-
drawImage
public boolean drawImage(Image image, int i, int j, int k, int l, ImageObserver imageobserver)
-
drawImage
public boolean drawImage(Image image, int i, int j, Color color, ImageObserver imageobserver)
-
drawImage
public boolean drawImage(Image image, int i, int j, ImageObserver imageobserver)
-
drawLine
public void drawLine(int x1, int y1, int x2, int y2)
-
drawLine
public void drawLine(int x1, int y1, int x2, int y2, int width)
-
drawOval
public void drawOval(int x, int y, int width, int height)
-
drawPolygon
public void drawPolygon(int[] xPoints, int[] yPoints, int nPoints)- Specified by:
drawPolygonin classGraphics
-
drawPolyline
@NotImplemented public void drawPolyline(int[] xPoints, int[] yPoints, int nPoints)
- Specified by:
drawPolylinein classGraphics
-
drawRect
@NotImplemented public void drawRect(int x, int y, int width, int height)
-
drawRoundRect
@NotImplemented public void drawRoundRect(int x, int y, int width, int height, int arcWidth, int arcHeight)
- Specified by:
drawRoundRectin classGraphics
-
drawString
public void drawString(String str, int x, int y)
- Specified by:
drawStringin classGraphics
-
drawString
public void drawString(AttributedCharacterIterator iterator, int x, int y)
- Specified by:
drawStringin classGraphics
-
fillArc
public void fillArc(int x, int y, int width, int height, int startAngle, int arcAngle)
-
fillOval
public void fillOval(int x, int y, int width, int height)
-
fillPolygon
public void fillPolygon(int[] xPoints, int[] yPoints, int nPoints)Fills a (closed) polygon, as defined by a pair of arrays, which hold the x and y coordinates.This draws the polygon, with
nPointline segments. The firstnPoint - 1line segments are drawn between sequential points (xPoints[i],yPoints[i],xPoints[i+1],yPoints[i+1]). The final line segment is a closing one, from the last point to the first (assuming they are different).The area inside of the polygon is defined by using an even-odd fill rule (also known as the alternating rule), and the area inside of it is filled.
- Specified by:
fillPolygonin classGraphics- Parameters:
xPoints- array of thexcoordinates.yPoints- array of theycoordinates.nPoints- the total number of points in the polygon.- See Also:
Graphics.drawPolygon(int[], int[], int)
-
fillRect
public void fillRect(int x, int y, int width, int height)
-
fillRoundRect
public void fillRoundRect(int x, int y, int width, int height, int arcWidth, int arcHeight)- Specified by:
fillRoundRectin classGraphics
-
getClipBounds
public Rectangle getClipBounds()
- Specified by:
getClipBoundsin classGraphics
-
getFontMetrics
public FontMetrics getFontMetrics(Font f)
- Specified by:
getFontMetricsin classGraphics
-
setClip
public void setClip(int x, int y, int width, int height)
-
setClip
@NotImplemented public void setClip(Shape shape)
-
setPaintMode
@NotImplemented public void setPaintMode()
- Specified by:
setPaintModein classGraphics
-
setXORMode
@NotImplemented public void setXORMode(Color color)
- Specified by:
setXORModein classGraphics
-
translate
@NotImplemented public void translate(int x, int y)
-
getBackground
public Color getBackground()
-
setBackground
public void setBackground(Color background)
-
-