weka.gui.visualize.PostscriptGraphics Maven / Gradle / Ivy
Show all versions of weka-dev Show documentation
/*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
/*
* PostscriptGraphics.java
* Copyright (C) 2003-2012 University of Waikato, Hamilton, New Zealand
*
*/
package weka.gui.visualize;
import java.awt.AlphaComposite;
import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Composite;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.GraphicsConfiguration;
import java.awt.GraphicsDevice;
import java.awt.GraphicsEnvironment;
import java.awt.Image;
import java.awt.Paint;
import java.awt.Polygon;
import java.awt.Rectangle;
import java.awt.RenderingHints;
import java.awt.Shape;
import java.awt.Stroke;
import java.awt.Toolkit;
import java.awt.font.FontRenderContext;
import java.awt.font.GlyphVector;
import java.awt.geom.AffineTransform;
import java.awt.image.BufferedImage;
import java.awt.image.BufferedImageOp;
import java.awt.image.ColorModel;
import java.awt.image.ImageObserver;
import java.awt.image.PixelGrabber;
import java.awt.image.RenderedImage;
import java.awt.image.renderable.RenderableImage;
import java.io.OutputStream;
import java.io.PrintStream;
import java.text.AttributedCharacterIterator;
import java.util.Calendar;
import java.util.Hashtable;
import java.util.Map;
/**
* The PostscriptGraphics class extends the Graphics2D class to produce an
* encapsulated postscript file rather than on-screen display.
*
* Currently only a small (but useful) subset of Graphics methods have been
* implemented. To handle the ability to Clone a Graphics object, the graphics
* state of the eps is set from the graphics state of the local
* PostscriptGraphics before output. To use, create a PostscriptGraphics object,
* and pass it to the PaintComponent method of a JComponent.
*
* If necessary additional font replacements can be inserted, since some fonts
* might be displayed incorrectly.
*
* @see #addPSFontReplacement(String, String)
* @see #m_PSFontReplacement
* @author Dale Fletcher ([email protected])
* @author FracPete (fracpete at waikato dot ac dot nz)
* @version $Revision: 10222 $
*/
public class PostscriptGraphics extends Graphics2D {
/**
* This inner class is used to maintain the graphics states of the PostScript
* file and graphics context.
*/
private class GraphicsState {
/** The current pen color */
protected Color m_currentColor;
/** The current Font */
protected Font m_currentFont;
/** The current Stroke (not yet used) */
protected Stroke m_currentStroke;
/** x,y Translation */
protected int m_xOffset;
protected int m_yOffset;
/** the scale factors */
protected double m_xScale;
protected double m_yScale;
/**
* Create a new GraphicsState with default values.
*/
GraphicsState() {
m_currentColor = Color.white;
m_currentFont = new Font("Courier", Font.PLAIN, 11);
m_currentStroke = new BasicStroke();
m_xOffset = 0;
m_yOffset = 0;
m_xScale = 1.0;
m_yScale = 1.0;
}
/**
* Create a new cloned GraphicsState
*
* @param copy The GraphicsState to clone
*/
GraphicsState(GraphicsState copy) {
m_currentColor = copy.m_currentColor;
m_currentFont = copy.m_currentFont;
m_currentStroke = copy.m_currentStroke;
m_xOffset = copy.m_xOffset;
m_yOffset = copy.m_yOffset;
m_xScale = copy.m_xScale;
m_yScale = copy.m_yScale;
}
/* Stroke Methods */
protected Stroke getStroke() {
return m_currentStroke;
}
protected void setStroke(Stroke s) {
m_currentStroke = s;
}
/* Font Methods */
protected Font getFont() {
return m_currentFont;
}
protected void setFont(Font f) {
m_currentFont = f;
}
/* Color Methods */
protected Color getColor() {
return m_currentColor;
}
protected void setColor(Color c) {
m_currentColor = c;
}
/* Translation methods */
protected void setXOffset(int xo) {
m_xOffset = xo;
}
protected void setYOffset(int yo) {
m_yOffset = yo;
}
protected int getXOffset() {
return m_xOffset;
}
protected int getYOffset() {
return m_yOffset;
}
protected void setXScale(double x) {
m_xScale = x;
}
protected void setYScale(double y) {
m_yScale = y;
}
protected double getXScale() {
return m_xScale;
}
protected double getYScale() {
return m_yScale;
}
}
/** The bounding box of the output */
protected Rectangle m_extent;
/** The output file */
protected PrintStream m_printstream;
/** The current global PostScript graphics state for all cloned objects */
protected GraphicsState m_psGraphicsState;
/** The current local graphics state for this PostscriptGraphics object */
protected GraphicsState m_localGraphicsState;
/** whether to print some debug information */
protected final static boolean DEBUG = false;
/** the font replacement */
protected static Hashtable m_PSFontReplacement;
/** output if we're in debug mode */
static {
if (DEBUG) {
System.err.println(PostscriptGraphics.class.getName() + ": DEBUG ON");
}
// get font replacements
m_PSFontReplacement = new Hashtable();
m_PSFontReplacement.put("SansSerif.plain", "Helvetica.plain"); // SansSerif.plain
// is
// displayed
// as Courier
// in GV???
m_PSFontReplacement.put("Dialog.plain", "Helvetica.plain"); // dialog is a
// Sans Serif
// font, but GV
// displays it
// as Courier???
m_PSFontReplacement.put("Microsoft Sans Serif", "Helvetica.plain"); // MS
// Sans
// Serif
// is a
// Sans
// Serif
// font
// (hence
// the
// name!),
// but
// GV
// displays
// it as
// Courier???
m_PSFontReplacement.put("MicrosoftSansSerif", "Helvetica.plain"); // MS Sans
// Serif
// is a
// Sans
// Serif
// font
// (hence
// the
// name!),
// but GV
// displays
// it as
// Courier???
}
/**
* Constructor Creates a new PostscriptGraphics object, given dimensions and
* output file.
*
* @param width The width of eps in points.
* @param height The height of eps in points.
* @param os File to send postscript to.
*/
public PostscriptGraphics(int width, int height, OutputStream os) {
m_extent = new Rectangle(0, 0, height, width);
m_printstream = new PrintStream(os);
m_localGraphicsState = new GraphicsState();
m_psGraphicsState = new GraphicsState();
Header();
}
/**
* Creates a new cloned PostscriptGraphics object.
*
* @param copy The PostscriptGraphics object to clone.
*/
PostscriptGraphics(PostscriptGraphics copy) {
m_extent = new Rectangle(copy.m_extent);
m_printstream = copy.m_printstream;
m_localGraphicsState = new GraphicsState(copy.m_localGraphicsState); // create
// a
// local
// copy
// of
// the
// current
// state
m_psGraphicsState = copy.m_psGraphicsState; // link to global state of eps
// file
}
/**
* Finalizes output file.
*/
public void finished() {
m_printstream.flush();
}
/**
* Output postscript header to PrintStream, including helper macros.
*/
private void Header() {
m_printstream.println("%!PS-Adobe-3.0 EPSF-3.0");
m_printstream.println("%%BoundingBox: 0 0 " + xScale(m_extent.width) + " "
+ yScale(m_extent.height));
m_printstream
.println("%%CreationDate: " + Calendar.getInstance().getTime());
m_printstream.println("/Oval { % x y w h filled");
m_printstream.println("gsave");
m_printstream
.println("/filled exch def /h exch def /w exch def /y exch def /x exch def");
m_printstream.println("x w 2 div add y h 2 div sub translate");
m_printstream.println("1 h w div scale");
m_printstream.println("filled {0 0 moveto} if");
m_printstream.println("0 0 w 2 div 0 360 arc");
m_printstream
.println("filled {closepath fill} {stroke} ifelse grestore} bind def");
m_printstream.println("/Rect { % x y w h filled");
m_printstream
.println("/filled exch def /h exch def /w exch def /y exch def /x exch def");
m_printstream.println("newpath ");
m_printstream.println("x y moveto");
m_printstream.println("w 0 rlineto");
m_printstream.println("0 h neg rlineto");
m_printstream.println("w neg 0 rlineto");
m_printstream.println("closepath");
m_printstream.println("filled {fill} {stroke} ifelse} bind def");
m_printstream.println("%%BeginProlog\n%%EndProlog");
m_printstream.println("%%Page 1 1");
setFont(null); // set to default
setColor(null); // set to default
setStroke(null); // set to default
}
/**
* adds the PS font name to replace and its replacement in the replacement
* hashtable
*
* @param replace the PS font name to replace
* @param with the PS font name to replace the font with
*/
public static void addPSFontReplacement(String replace, String with) {
m_PSFontReplacement.put(replace, with);
}
/**
* Convert Java Y coordinate (0 = top) to PostScript (0 = bottom) Also apply
* current Translation
*
* @param y Java Y coordinate
* @return translated Y to postscript
*/
private int yTransform(int y) {
return (m_extent.height - (m_localGraphicsState.getYOffset() + y));
}
/**
* Apply current X Translation
*
* @param x Java X coordinate
* @return translated X to postscript
*/
private int xTransform(int x) {
return (m_localGraphicsState.getXOffset() + x);
}
/**
* scales the given number with the provided scale factor
*/
private int doScale(int number, double factor) {
return (int) StrictMath.round(number * factor);
}
/**
* scales the given x value with current x scale factor
*/
private int xScale(int x) {
return doScale(x, m_localGraphicsState.getXScale());
}
/**
* scales the given y value with current y scale factor
*/
private int yScale(int y) {
return doScale(y, m_localGraphicsState.getYScale());
}
/**
* Set the current eps graphics state to that of the local one
*/
private void setStateToLocal() {
setColor(this.getColor());
setFont(this.getFont());
setStroke(this.getStroke());
}
/**
* returns a two hexadecimal representation of i, if shorter than 2 chars then
* an additional "0" is put in front
*/
private String toHex(int i) {
String result;
result = Integer.toHexString(i);
if (result.length() < 2) {
result = "0" + result;
}
return result;
}
/***** overridden Graphics methods *****/
/**
* Draw a filled rectangle with the background color.
*
* @param x starting x coord
* @param y starting y coord
* @param width rectangle width
* @param height rectangle height
*/
@Override
public void clearRect(int x, int y, int width, int height) {
setStateToLocal();
Color saveColor = getColor();
setColor(Color.white); // background color for page
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " " + xScale(width) + " " + yScale(height) + " true Rect");
setColor(saveColor);
}
/**
* Not implemented
*/
@Override
public void clipRect(int x, int y, int width, int height) {
}
/**
* Not implemented
*/
@Override
public void copyArea(int x, int y, int width, int height, int dx, int dy) {
}
/**
* Clone a PostscriptGraphics object
*/
@Override
public Graphics create() {
if (DEBUG) {
m_printstream.println("%create");
}
PostscriptGraphics psg = new PostscriptGraphics(this);
return (psg);
}
/**
* Not implemented
*/
@Override
public void dispose() {
}
/**
* Draw an outlined rectangle with 3D effect in current pen color. (Current
* implementation: draw simple outlined rectangle)
*
* @param x starting x coord
* @param y starting y coord
* @param width rectangle width
* @param height rectangle height
* @param raised True: appear raised, False: appear etched
*/
@Override
public void draw3DRect(int x, int y, int width, int height, boolean raised) {
drawRect(x, y, width, height);
}
/**
* Not implemented
*/
@Override
public void drawArc(int x, int y, int width, int height, int startAngle,
int arcAngle) {
}
/**
* simply calls drawString(String,int,int)
*
* @see #drawString(String,int,int)
*/
@Override
public void drawBytes(byte[] data, int offset, int length, int x, int y) {
drawString(new String(data, offset, length), x, y);
}
/**
* simply calls drawString(String,int,int)
*
* @see #drawString(String,int,int)
*/
@Override
public void drawChars(char[] data, int offset, int length, int x, int y) {
drawString(new String(data, offset, length), x, y);
}
/**
* calls drawImage(Image,int,int,int,int,Color,ImageObserver)
*
* @see #drawImage(Image,int,int,int,int,Color,ImageObserver)
*/
@Override
public boolean drawImage(Image img, int x, int y, Color bgcolor,
ImageObserver observer) {
return drawImage(img, x, y, img.getWidth(observer),
img.getHeight(observer), bgcolor, observer);
}
/**
* calls drawImage(Image,int,int,Color,ImageObserver) with Color.WHITE as
* background color
*
* @see #drawImage(Image,int,int,Color,ImageObserver)
* @see Color#WHITE
*/
@Override
public boolean drawImage(Image img, int x, int y, ImageObserver observer) {
return drawImage(img, x, y, Color.WHITE, observer);
}
/**
* PS see http://astronomy.swin.edu.au/~pbourke/geomformats/postscript/ Java
* http
* ://show.docjava.com:8086/book/cgij/doc/ip/graphics/SimpleImageFrame.java
* .html
*/
@Override
public boolean drawImage(Image img, int x, int y, int width, int height,
Color bgcolor, ImageObserver observer) {
try {
// get data from image
int[] pixels = new int[width * height];
PixelGrabber grabber = new PixelGrabber(img, 0, 0, width, height, pixels,
0, width);
grabber.grabPixels();
ColorModel model = ColorModel.getRGBdefault();
// print data to ps
m_printstream.println("gsave");
m_printstream.println(xTransform(xScale(x)) + " "
+ (yTransform(yScale(y)) - yScale(height)) + " translate");
m_printstream.println(xScale(width) + " " + yScale(height) + " scale");
m_printstream.println(width + " " + height + " " + "8" + " [" + width
+ " 0 0 " + (-height) + " 0 " + height + "]");
m_printstream.println("{<");
int index;
for (int i = 0; i < height; i++) {
for (int j = 0; j < width; j++) {
index = i * width + j;
m_printstream.print(toHex(model.getRed(pixels[index])));
m_printstream.print(toHex(model.getGreen(pixels[index])));
m_printstream.print(toHex(model.getBlue(pixels[index])));
}
m_printstream.println();
}
m_printstream.println(">}");
m_printstream.println("false 3 colorimage");
m_printstream.println("grestore");
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* calls drawImage(Image,int,int,int,int,Color,ImageObserver) with the color
* WHITE as background
*
* @see #drawImage(Image,int,int,int,int,Color,ImageObserver)
* @see Color#WHITE
*/
@Override
public boolean drawImage(Image img, int x, int y, int width, int height,
ImageObserver observer) {
return drawImage(img, x, y, width, height, Color.WHITE, observer);
}
/**
* Not implemented
*/
@Override
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) {
return false;
}
/**
* calls drawImage(Image,int,int,int,int,int,int,int,int,Color,ImageObserver)
* with Color.WHITE as background color
*
* @see #drawImage(Image,int,int,int,int,int,int,int,int,Color,ImageObserver)
*/
@Override
public boolean drawImage(Image img, int dx1, int dy1, int dx2, int dy2,
int sx1, int sy1, int sx2, int sy2, ImageObserver observer) {
return drawImage(img, dx1, dy1, dx2, dy2, sx1, sy1, sx2, sy2, Color.WHITE,
observer);
}
/**
* Draw a line in current pen color.
*
* @param x1 starting x coord
* @param y1 starting y coord
* @param x2 ending x coord
* @param y2 ending y coord
*/
@Override
public void drawLine(int x1, int y1, int x2, int y2) {
setStateToLocal();
m_printstream.println(xTransform(xScale(x1)) + " " + yTransform(yScale(y1))
+ " moveto " + xTransform(xScale(x2)) + " " + yTransform(yScale(y2))
+ " lineto stroke");
}
/**
* Draw an Oval outline in current pen color.
*
* @param x x-axis center of oval
* @param y y-axis center of oval
* @param width oval width
* @param height oval height
*/
@Override
public void drawOval(int x, int y, int width, int height) {
setStateToLocal();
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " " + xScale(width) + " " + yScale(height) + " false Oval");
}
/**
* Not implemented
*/
@Override
public void drawPolygon(int[] xPoints, int[] yPoints, int nPoints) {
}
/**
* Not implemented
*/
@Override
public void drawPolyline(int[] xPoints, int[] yPoints, int nPoints) {
}
/**
* Draw an outlined rectangle in current pen color.
*
* @param x starting x coord
* @param y starting y coord
* @param width rectangle width
* @param height rectangle height
*/
@Override
public void drawRect(int x, int y, int width, int height) {
setStateToLocal();
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " " + xScale(width) + " " + yScale(height) + " false Rect");
}
/**
* Not implemented
*/
@Override
public void drawRoundRect(int x, int y, int width, int height, int arcWidth,
int arcHeight) {
}
/**
* Not implemented
*/
@Override
public void drawString(AttributedCharacterIterator iterator, int x, int y) {
}
/**
* Escapes brackets in the string with backslashes.
*
* @param s the string to escape
* @return the escaped string
*/
protected String escape(String s) {
StringBuffer result;
int i;
result = new StringBuffer();
for (i = 0; i < s.length(); i++) {
if ((s.charAt(i) == '(') || (s.charAt(i) == ')')) {
result.append('\\');
}
result.append(s.charAt(i));
}
return result.toString();
}
/**
* Draw text in current pen color.
*
* @param str Text to output
* @param x starting x coord
* @param y starting y coord
*/
@Override
public void drawString(String str, int x, int y) {
setStateToLocal();
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " moveto" + " (" + escape(str) + ") show stroke");
}
/**
* Draw a filled rectangle with 3D effect in current pen color. (Current
* implementation: draw simple filled rectangle)
*
* @param x starting x coord
* @param y starting y coord
* @param width rectangle width
* @param height rectangle height
* @param raised True: appear raised, False: appear etched
*/
@Override
public void fill3DRect(int x, int y, int width, int height, boolean raised) {
fillRect(x, y, width, height);
}
/**
* Not implemented
*/
@Override
public void fillArc(int x, int y, int width, int height, int startAngle,
int arcAngle) {
}
/**
* Draw a filled Oval in current pen color.
*
* @param x x-axis center of oval
* @param y y-axis center of oval
* @param width oval width
* @param height oval height
*/
@Override
public void fillOval(int x, int y, int width, int height) {
setStateToLocal();
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " " + xScale(width) + " " + yScale(height) + " true Oval");
}
/**
* Not implemented
*/
@Override
public void fillPolygon(int[] xPoints, int[] yPoints, int nPoints) {
}
/**
* Not implemented
*/
@Override
public void fillPolygon(Polygon p) {
}
/**
* Draw a filled rectangle in current pen color.
*
* @param x starting x coord
* @param y starting y coord
* @param width rectangle width
* @param height rectangle height
*/
@Override
public void fillRect(int x, int y, int width, int height) {
if (width == m_extent.width && height == m_extent.height) {
clearRect(x, y, width, height); // if we're painting the entire
// background, just make it white
} else {
if (DEBUG) {
m_printstream.println("% fillRect");
}
setStateToLocal();
m_printstream.println(xTransform(xScale(x)) + " " + yTransform(yScale(y))
+ " " + xScale(width) + " " + yScale(height) + " true Rect");
}
}
/**
* Not implemented
*/
@Override
public void fillRoundRect(int x, int y, int width, int height, int arcWidth,
int arcHeight) {
}
/**
* Not implemented
*/
@Override
public void finalize() {
}
/**
* Not implemented
*/
@Override
public Shape getClip() {
return (null);
}
/**
* This returns the full current drawing area
*
* @return full drawing area
*/
@Override
public Rectangle getClipBounds() {
return (new Rectangle(0, 0, m_extent.width, m_extent.height));
}
/**
* This returns the full current drawing area
*
* @return full drawing area
*/
@Override
public Rectangle getClipBounds(Rectangle r) {
r.setBounds(0, 0, m_extent.width, m_extent.height);
return r;
}
/**
* Not implemented
*/
@Override
public Rectangle getClipRect() {
return null;
}
/**
* Get current pen color.
*
* @return current pen color.
*/
@Override
public Color getColor() {
return (m_localGraphicsState.getColor());
}
/**
* Get current font.
*
* @return current font.
*/
@Override
public Font getFont() {
return (m_localGraphicsState.getFont());
}
/**
* Get Font metrics
*
* @param f Font
* @return Font metrics.
*/
@Override
@SuppressWarnings("deprecation")
public FontMetrics getFontMetrics(Font f) {
return (Toolkit.getDefaultToolkit().getFontMetrics(f));
}
/**
* Not implemented
*/
@Override
public void setClip(int x, int y, int width, int height) {
}
/**
* Not implemented
*/
@Override
public void setClip(Shape clip) {
}
/**
* Set current pen color. Default to black if null.
*
* @param c new pen color.
*/
@Override
public void setColor(Color c) {
if (c != null) {
m_localGraphicsState.setColor(c);
if (m_psGraphicsState.getColor().equals(c)) {
return;
}
m_psGraphicsState.setColor(c);
} else {
m_localGraphicsState.setColor(Color.black);
m_psGraphicsState.setColor(getColor());
}
m_printstream.print(getColor().getRed() / 255.0);
m_printstream.print(" ");
m_printstream.print(getColor().getGreen() / 255.0);
m_printstream.print(" ");
m_printstream.print(getColor().getBlue() / 255.0);
m_printstream.println(" setrgbcolor");
}
/**
* replaces the font (PS name) if necessary and returns the new name
*/
private static String replacePSFont(String font) {
String result;
result = font;
// do we have to replace it? -> same style, size
if (m_PSFontReplacement.containsKey(font)) {
result = m_PSFontReplacement.get(font).toString();
if (DEBUG) {
System.out.println("switched font from '" + font + "' to '" + result
+ "'");
}
}
return result;
}
/**
* Set current font. Default to Plain Courier 11 if null.
*
* @param font new font.
*/
@Override
public void setFont(Font font) {
if (font != null) {
m_localGraphicsState.setFont(font);
if (font.getName().equals(m_psGraphicsState.getFont().getName())
&& (m_psGraphicsState.getFont().getStyle() == font.getStyle())
&& (m_psGraphicsState.getFont().getSize() == yScale(font.getSize()))) {
return;
}
m_psGraphicsState.setFont(new Font(font.getName(), font.getStyle(),
yScale(getFont().getSize())));
} else {
m_localGraphicsState.setFont(new Font("Courier", Font.PLAIN, 11));
m_psGraphicsState.setFont(getFont());
}
m_printstream.println("/(" + replacePSFont(getFont().getPSName()) + ")"
+ " findfont");
m_printstream.println(yScale(getFont().getSize()) + " scalefont setfont");
}
/**
* Not implemented
*/
@Override
public void setPaintMode() {
}
/**
* Not implemented
*/
@Override
public void setXORMode(Color c1) {
}
/**
* Translates the origin of the graphics context to the point (x, y) in the
* current coordinate system. Modifies this graphics context so that its new
* origin corresponds to the point (x, y) in this graphics context's original
* coordinate system. All coordinates used in subsequent rendering operations
* on this graphics context will be relative to this new origin.
*
* @param x the x coordinate.
* @param y the y coordinate.
*/
@Override
public void translate(int x, int y) {
if (DEBUG) {
System.out.println("translate with x = " + x + " and y = " + y);
}
m_localGraphicsState.setXOffset(m_localGraphicsState.getXOffset()
+ xScale(x));
m_localGraphicsState.setYOffset(m_localGraphicsState.getYOffset()
+ yScale(y));
m_psGraphicsState.setXOffset(m_psGraphicsState.getXOffset() + xScale(x));
m_psGraphicsState.setYOffset(m_psGraphicsState.getYOffset() + yScale(y));
}
/***** END overridden Graphics methods *****/
/***** START overridden Graphics2D methods *****/
@Override
public FontRenderContext getFontRenderContext() {
return (new FontRenderContext(null, true, true));
}
@Override
public void clip(Shape s) {
}
@Override
public Stroke getStroke() {
return (m_localGraphicsState.getStroke());
}
@Override
public Color getBackground() {
return (Color.white);
}
@Override
public void setBackground(Color c) {
}
@Override
public Composite getComposite() {
return (AlphaComposite.getInstance(AlphaComposite.SRC));
}
@Override
public Paint getPaint() {
return ((new Color(getColor().getRed(), getColor().getGreen(), getColor()
.getBlue())));
}
@Override
public AffineTransform getTransform() {
return (new AffineTransform());
}
@Override
public void setTransform(AffineTransform at) {
}
@Override
public void transform(AffineTransform at) {
}
@Override
public void shear(double d1, double d2) {
}
@Override
public void scale(double d1, double d2) {
m_localGraphicsState.setXScale(d1);
m_localGraphicsState.setYScale(d2);
if (DEBUG) {
System.err.println("d1 = " + d1 + ", d2 = " + d2);
}
}
@Override
public void rotate(double d1, double d2, double d3) {
}
@Override
public void rotate(double d1) {
}
@Override
public void translate(double d1, double d2) {
}
@Override
public RenderingHints getRenderingHints() {
return (new RenderingHints(null));
}
@Override
public void addRenderingHints(Map, ?> m) {
}
@Override
public void setRenderingHints(Map, ?> m) {
}
@Override
public Object getRenderingHint(RenderingHints.Key key) {
return (null);
}
@Override
public void setRenderingHint(RenderingHints.Key key, Object o) {
}
@Override
public void setStroke(Stroke s) {
if (s != null) {
m_localGraphicsState.setStroke(s);
if (s.equals(m_psGraphicsState.getStroke())) {
return;
}
m_psGraphicsState.setStroke(s);
} else {
m_localGraphicsState.setStroke(new BasicStroke());
m_psGraphicsState.setStroke(getStroke());
}
// ouput postscript here to set stroke.
}
@Override
public void setPaint(Paint p) {
}
@Override
public void setComposite(Composite c) {
}
@Override
public GraphicsConfiguration getDeviceConfiguration() {
GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
GraphicsDevice gd = ge.getDefaultScreenDevice();
return (gd.getDefaultConfiguration());
}
@Override
public boolean hit(Rectangle r, Shape s, boolean onstroke) {
return (false);
}
@Override
public void fill(Shape s) {
}
@Override
public void drawGlyphVector(GlyphVector gv, float f1, float f2) {
}
@Override
public void drawString(AttributedCharacterIterator aci, float f1, float f2) {
}
@Override
public void drawString(String str, float x, float y) {
drawString(str, (int) x, (int) y);
}
@Override
public void drawRenderableImage(RenderableImage ri, AffineTransform at) {
}
@Override
public void drawRenderedImage(RenderedImage ri, AffineTransform af) {
}
@Override
public void drawImage(BufferedImage bi, BufferedImageOp bio, int i1, int i2) {
}
@Override
public boolean drawImage(Image im, AffineTransform at, ImageObserver io) {
return (false);
}
@Override
public void draw(Shape s) {
}
/***** END *****/
}