ObjectStdDraw
public final class StdDraw
Standard draw. This class provides a basic capability for creating drawings with your programs. It uses a simple graphics model that allows you to create drawings consisting of points, lines, and curves in a window on your computer and to save the drawings to a file.
For additional documentation, see Section 1.5 of Introduction to Programming in Java: An Interdisciplinary Approach by Robert Sedgewick and Kevin Wayne.
| Field Summary | |
|---|---|
static java.awt.Color |
BLACK
|
static java.awt.Color |
BLUE
|
static java.awt.Color |
BOOK_BLUE
Shade of blue used in Introduction to Programming in Java. |
static java.awt.Color |
BOOK_LIGHT_BLUE
|
static java.awt.Color |
BOOK_RED
Shade of red used in Algorithms 4th edition. |
static java.awt.Color |
CYAN
|
static java.awt.Color |
DARK_GRAY
|
static java.awt.Color |
GRAY
|
static java.awt.Color |
GREEN
|
static java.awt.Color |
LIGHT_GRAY
|
static java.awt.Color |
MAGENTA
|
static java.awt.Color |
ORANGE
|
static java.awt.Color |
PINK
|
static java.awt.Color |
RED
|
static java.awt.Color |
WHITE
|
static java.awt.Color |
YELLOW
|
| Method Summary | |
|---|---|
void |
actionPerformed(java.awt.event.ActionEvent e)
This method cannot be called directly. |
static void |
arc(double x,
double y,
double r,
double angle1,
double angle2)
Draw an arc of radius r, centered on (x, y), from angle1 to angle2 (in degrees). |
static void |
circle(double x,
double y,
double r)
Draw a circle of radius r, centered on (x, y). |
static void |
clear()
Clear the screen to the default color (white). |
static void |
clear(java.awt.Color color)
Clear the screen to the given color. |
static void |
ellipse(double x,
double y,
double semiMajorAxis,
double semiMinorAxis)
Draw an ellipse with given semimajor and semiminor axes, centered on (x, y). |
static void |
filledCircle(double x,
double y,
double r)
Draw filled circle of radius r, centered on (x, y). |
static void |
filledEllipse(double x,
double y,
double semiMajorAxis,
double semiMinorAxis)
Draw an ellipse with given semimajor and semiminor axes, centered on (x, y). |
static void |
filledPolygon(double[] x,
double[] y)
Draw a filled polygon with the given (x[i], y[i]) coordinates. |
static void |
filledRectangle(double x,
double y,
double halfWidth,
double halfHeight)
Draw a filled rectangle of given half width and half height, centered on (x, y). |
static void |
filledSquare(double x,
double y,
double r)
Draw a filled square of side length 2r, centered on (x, y). |
static java.awt.Font |
getFont()
Get the current font. |
static java.awt.Color |
getPenColor()
Get the current pen color. |
static double |
getPenRadius()
Get the current pen radius. |
static boolean |
hasNextKeyTyped()
Has the user typed a key? |
static boolean |
isKeyPressed(int keycode)
Is the keycode currently being pressed? This method takes as an argument the keycode (corresponding to a physical key). |
void |
keyPressed(java.awt.event.KeyEvent e)
This method cannot be called directly. |
void |
keyReleased(java.awt.event.KeyEvent e)
This method cannot be called directly. |
void |
keyTyped(java.awt.event.KeyEvent e)
This method cannot be called directly. |
static void |
line(double x0,
double y0,
double x1,
double y1)
Draw a line from (x0, y0) to (x1, y1). |
static void |
main(String[] args)
Test client. |
void |
mouseClicked(java.awt.event.MouseEvent e)
This method cannot be called directly. |
void |
mouseDragged(java.awt.event.MouseEvent e)
This method cannot be called directly. |
void |
mouseEntered(java.awt.event.MouseEvent e)
This method cannot be called directly. |
void |
mouseExited(java.awt.event.MouseEvent e)
This method cannot be called directly. |
void |
mouseMoved(java.awt.event.MouseEvent e)
This method cannot be called directly. |
static boolean |
mousePressed()
Is the mouse being pressed? |
void |
mousePressed(java.awt.event.MouseEvent e)
This method cannot be called directly. |
void |
mouseReleased(java.awt.event.MouseEvent e)
This method cannot be called directly. |
static double |
mouseX()
What is the x-coordinate of the mouse? |
static double |
mouseY()
What is the y-coordinate of the mouse? |
static char |
nextKeyTyped()
What is the next key that was typed by the user? This method returns a Unicode character corresponding to the key typed (such as 'a' or 'A'). |
static void |
picture(double x,
double y,
String s)
Draw picture (gif, jpg, or png) centered on (x, y). |
static void |
picture(double x,
double y,
String s,
double degrees)
Draw picture (gif, jpg, or png) centered on (x, y), rotated given number of degrees |
static void |
picture(double x,
double y,
String s,
double w,
double h)
Draw picture (gif, jpg, or png) centered on (x, y), rescaled to w-by-h. |
static void |
picture(double x,
double y,
String s,
double w,
double h,
double degrees)
Draw picture (gif, jpg, or png) centered on (x, y), rotated given number of degrees, rescaled to w-by-h. |
static void |
point(double x,
double y)
Draw a point at (x, y). |
static void |
polygon(double[] x,
double[] y)
Draw a polygon with the given (x[i], y[i]) coordinates. |
static void |
rectangle(double x,
double y,
double halfWidth,
double halfHeight)
Draw a rectangle of given half width and half height, centered on (x, y). |
static void |
save(String filename)
Save onscreen image to file - suffix must be png, jpg, or gif. |
static void |
setCanvasSize()
Set the window size to the default size 512-by-512 pixels. |
static void |
setCanvasSize(int w,
int h)
Set the window size to w-by-h pixels. |
static void |
setFont()
Set the font to the default font (sans serif, 16 point). |
static void |
setFont(java.awt.Font f)
Set the font to the given value. |
static void |
setPenColor()
Set the pen color to the default color (black). |
static void |
setPenColor(java.awt.Color color)
Set the pen color to the given color. |
static void |
setPenRadius()
Set the pen size to the default (.002). |
static void |
setPenRadius(double r)
Set the radius of the pen to the given size. |
static void |
setScale(double min,
double max)
Set the x-scale and y-scale (a 10% border is added to the values) |
static void |
setXscale()
Set the x-scale to be the default (between 0.0 and 1.0). |
static void |
setXscale(double min,
double max)
Set the x-scale (a 10% border is added to the values) |
static void |
setYscale()
Set the y-scale to be the default (between 0.0 and 1.0). |
static void |
setYscale(double min,
double max)
Set the y-scale (a 10% border is added to the values). |
static void |
show()
Display on-screen and turn off animation mode: subsequent calls to drawing methods such as line(), circle(), and square() will be displayed on screen when called. |
static void |
show(int t)
Display on screen, pause for t milliseconds, and turn on animation mode: subsequent calls to drawing methods such as line(), circle(), and square() will not be displayed on screen until the next call to show(). |
static void |
square(double x,
double y,
double r)
Draw a square of side length 2r, centered on (x, y). |
static void |
text(double x,
double y,
String s)
Write the given text string in the current font, centered on (x, y). |
static void |
text(double x,
double y,
String s,
double degrees)
Write the given text string in the current font, centered on (x, y) and rotated by the specified number of degrees |
static void |
textLeft(double x,
double y,
String s)
Write the given text string in the current font, left-aligned at (x, y). |
static void |
textRight(double x,
double y,
String s)
Write the given text string in the current font, right-aligned at (x, y). |
| Methods inherited from class Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
|---|
public static final java.awt.Color BLACK
public static final java.awt.Color BLUE
public static final java.awt.Color CYAN
public static final java.awt.Color DARK_GRAY
public static final java.awt.Color GRAY
public static final java.awt.Color GREEN
public static final java.awt.Color LIGHT_GRAY
public static final java.awt.Color MAGENTA
public static final java.awt.Color ORANGE
public static final java.awt.Color PINK
public static final java.awt.Color RED
public static final java.awt.Color WHITE
public static final java.awt.Color YELLOW
public static final java.awt.Color BOOK_BLUE
public static final java.awt.Color BOOK_LIGHT_BLUE
public static final java.awt.Color BOOK_RED
| Method Detail |
|---|
public static void setCanvasSize()
public static void setCanvasSize(int w,
int h)
w - the width as a number of pixelsh - the height as a number of pixels
a - RunTimeException if the width or height is 0 or negativepublic static void setXscale()
public static void setYscale()
public static void setXscale(double min,
double max)
min - the minimum value of the x-scalemax - the maximum value of the x-scale
public static void setYscale(double min,
double max)
min - the minimum value of the y-scalemax - the maximum value of the y-scale
public static void setScale(double min,
double max)
min - the minimum value of the x- and y-scalesmax - the maximum value of the x- and y-scalespublic static void clear()
public static void clear(java.awt.Color color)
color - the Color to make the backgroundpublic static double getPenRadius()
public static void setPenRadius()
public static void setPenRadius(double r)
r - the radius of the pen
RuntimeException - if r is negativepublic static java.awt.Color getPenColor()
public static void setPenColor()
public static void setPenColor(java.awt.Color color)
color - the Color to make the penpublic static java.awt.Font getFont()
public static void setFont()
public static void setFont(java.awt.Font f)
f - the font to make text
public static void line(double x0,
double y0,
double x1,
double y1)
x0 - the x-coordinate of the starting pointy0 - the y-coordinate of the starting pointx1 - the x-coordinate of the destination pointy1 - the y-coordinate of the destination point
public static void point(double x,
double y)
x - the x-coordinate of the pointy - the y-coordinate of the point
public static void circle(double x,
double y,
double r)
x - the x-coordinate of the center of the circley - the y-coordinate of the center of the circler - the radius of the circle
RuntimeException - if the radius of the circle is negative
public static void filledCircle(double x,
double y,
double r)
x - the x-coordinate of the center of the circley - the y-coordinate of the center of the circler - the radius of the circle
RuntimeException - if the radius of the circle is negative
public static void ellipse(double x,
double y,
double semiMajorAxis,
double semiMinorAxis)
x - the x-coordinate of the center of the ellipsey - the y-coordinate of the center of the ellipsesemiMajorAxis - is the semimajor axis of the ellipsesemiMinorAxis - is the semiminor axis of the ellipse
RuntimeException - if either of the axes are negative
public static void filledEllipse(double x,
double y,
double semiMajorAxis,
double semiMinorAxis)
x - the x-coordinate of the center of the ellipsey - the y-coordinate of the center of the ellipsesemiMajorAxis - is the semimajor axis of the ellipsesemiMinorAxis - is the semiminor axis of the ellipse
RuntimeException - if either of the axes are negative
public static void arc(double x,
double y,
double r,
double angle1,
double angle2)
x - the x-coordinate of the center of the circley - the y-coordinate of the center of the circler - the radius of the circleangle1 - the starting angle. 0 would mean an arc beginning at 3 o'clock.angle2 - the angle at the end of the arc. For example, if
you want a 90 degree arc, then angle2 should be angle1 + 90.
RuntimeException - if the radius of the circle is negative
public static void square(double x,
double y,
double r)
x - the x-coordinate of the center of the squarey - the y-coordinate of the center of the squarer - radius is half the length of any side of the square
RuntimeException - if r is negative
public static void filledSquare(double x,
double y,
double r)
x - the x-coordinate of the center of the squarey - the y-coordinate of the center of the squarer - radius is half the length of any side of the square
RuntimeException - if r is negative
public static void rectangle(double x,
double y,
double halfWidth,
double halfHeight)
x - the x-coordinate of the center of the rectangley - the y-coordinate of the center of the rectanglehalfWidth - is half the width of the rectanglehalfHeight - is half the height of the rectangle
RuntimeException - if halfWidth or halfHeight is negative
public static void filledRectangle(double x,
double y,
double halfWidth,
double halfHeight)
x - the x-coordinate of the center of the rectangley - the y-coordinate of the center of the rectanglehalfWidth - is half the width of the rectanglehalfHeight - is half the height of the rectangle
RuntimeException - if halfWidth or halfHeight is negative
public static void polygon(double[] x,
double[] y)
x - an array of all the x-coordindates of the polygony - an array of all the y-coordindates of the polygon
public static void filledPolygon(double[] x,
double[] y)
x - an array of all the x-coordindates of the polygony - an array of all the y-coordindates of the polygon
public static void picture(double x,
double y,
String s)
x - the center x-coordinate of the imagey - the center y-coordinate of the images - the name of the image/picture, e.g., "ball.gif"
RuntimeException - if the image is corrupt
public static void picture(double x,
double y,
String s,
double degrees)
x - the center x-coordinate of the imagey - the center y-coordinate of the images - the name of the image/picture, e.g., "ball.gif"degrees - is the number of degrees to rotate counterclockwise
RuntimeException - if the image is corrupt
public static void picture(double x,
double y,
String s,
double w,
double h)
x - the center x coordinate of the imagey - the center y coordinate of the images - the name of the image/picture, e.g., "ball.gif"w - the width of the imageh - the height of the image
RuntimeException - if the width height are negative
RuntimeException - if the image is corrupt
public static void picture(double x,
double y,
String s,
double w,
double h,
double degrees)
x - the center x-coordinate of the imagey - the center y-coordinate of the images - the name of the image/picture, e.g., "ball.gif"w - the width of the imageh - the height of the imagedegrees - is the number of degrees to rotate counterclockwise
RuntimeException - if the image is corrupt
public static void text(double x,
double y,
String s)
x - the center x-coordinate of the texty - the center y-coordinate of the texts - the text
public static void text(double x,
double y,
String s,
double degrees)
x - the center x-coordinate of the texty - the center y-coordinate of the texts - the textdegrees - is the number of degrees to rotate counterclockwise
public static void textLeft(double x,
double y,
String s)
x - the x-coordinate of the texty - the y-coordinate of the texts - the text
public static void textRight(double x,
double y,
String s)
x - the x-coordinate of the texty - the y-coordinate of the texts - the textpublic static void show(int t)
t - number of millisecondspublic static void show()
public static void save(String filename)
filename - the name of the file with one of the required suffixespublic void actionPerformed(java.awt.event.ActionEvent e)
actionPerformed in interface java.awt.event.ActionListenerpublic static boolean mousePressed()
public static double mouseX()
public static double mouseY()
public void mouseClicked(java.awt.event.MouseEvent e)
mouseClicked in interface java.awt.event.MouseListenerpublic void mouseEntered(java.awt.event.MouseEvent e)
mouseEntered in interface java.awt.event.MouseListenerpublic void mouseExited(java.awt.event.MouseEvent e)
mouseExited in interface java.awt.event.MouseListenerpublic void mousePressed(java.awt.event.MouseEvent e)
mousePressed in interface java.awt.event.MouseListenerpublic void mouseReleased(java.awt.event.MouseEvent e)
mouseReleased in interface java.awt.event.MouseListenerpublic void mouseDragged(java.awt.event.MouseEvent e)
mouseDragged in interface java.awt.event.MouseMotionListenerpublic void mouseMoved(java.awt.event.MouseEvent e)
mouseMoved in interface java.awt.event.MouseMotionListenerpublic static boolean hasNextKeyTyped()
public static char nextKeyTyped()
public static boolean isKeyPressed(int keycode)
public void keyTyped(java.awt.event.KeyEvent e)
keyTyped in interface java.awt.event.KeyListenerpublic void keyPressed(java.awt.event.KeyEvent e)
keyPressed in interface java.awt.event.KeyListenerpublic void keyReleased(java.awt.event.KeyEvent e)
keyReleased in interface java.awt.event.KeyListenerpublic static void main(String[] args)