edu.hws.jcm.draw
Class DrawGeometric

java.lang.Object
  |
  +--edu.hws.jcm.draw.Drawable
        |
        +--edu.hws.jcm.draw.DrawGeometric
All Implemented Interfaces:
Computable, java.io.Serializable
Direct Known Subclasses:
Crosshair, TangentLine

public class DrawGeometric
extends Drawable
implements Computable

A DrawGeometric object is a geometic figure such as a line or rectangle that can be drawn in a CoordinateRect. The data for the object always consists of four numbers, which are interpreted differenetly depending on the object. These numbers can be specified as Value objects. A DrawGeometric is a Computable, and the Values will be re-computed when its compute() method is called. It should be added to a Controller that can respond to any changes in the data that define the Values. If one of the Value objects has an undefined value, nothing will be drawn.

The type of object is given as one of the constants defined in this class: LINE_ABSOLUTE, OVAL_RELATIVE, CROSS, and so on. In the descriptions of these constants, x1, x2, y1, and y2 refer to the values of Value objects that provide data for the DrawGeomentric while h and v refer to int's that can be specified in place of x2 and y2 for certain types of figures. For those figures, h or v is used if x2 or y2, respectively, is null.

See Also:
Serialized Form

Field Summary
protected  double a
          Value of x1.
protected  double b
          Value of y1.
protected  double c
          Value of x2.
protected  java.awt.Color color
          Color of the shappe.
static int CROSS
          Specifies a cross centered on the point (x1,y1).
protected  double d
          Value of y2.
protected  java.awt.Color fillColor
          Rects and ovals are filled with this color, if it is non-null.
protected  int h
          Integer that gives horizontal pixel offset from x1.
static int INFINITE_LINE_ABSOLUTE
          Specifies a line that extends through the points (x1,y1) and (x2,y2) and beyond.
static int INFINITE_LINE_RELATIVE
          Specifies an infinite line through (x1,y1) and (x1+x2,y1+y2), or through (x1,y1) and (x1+h,y1+v) if x2,y2 are null.
static int LINE_ABSOLUTE
          Specifies a line segment from (x1,y1) to (x2,y2).
static int LINE_CENTERED
          Specifies a line segment centered on (x1,y1).
static int LINE_RELATIVE
          Specifies a line segment from (x1,y1) to (x1+x2,y1+y2), or to (x1+h,y1+v) if x2,y2 are null.
protected  int lineWidth
          The width, in pixels, of lines, including the outlines of rects and ovals.
static int OVAL_ABSOLUTE
          Specifies an oval that just fits in the rectangle with corners at (x1,y1) and (x2,y2).
static int OVAL_CENTERED
          Specifies an oval that just fits inside the rect specified by RECT_CENTERED.
static int OVAL_RELATIVE
          Specifies an oval that just fits inside the rect specified by RECT_RELATIVE.
static int RECT_ABSOLUTE
          Specifies a rectangle with corners at (x1,y1) and (x2,y2).
static int RECT_CENTERED
          Specifies a Rectangle centered on (x1,y1).
static int RECT_RELATIVE
          Specifies a rectangle with one corner at (x1,y1), and with width given by x2, or h if if x2 is null, and with height given by y2, or by v if y2 is null.
protected  int shape
          One of the constants such as OVAL_CENTERED, specifying the shape to be drawn
protected  int v
          Integer that gives vertical pixel offset fromy1.
protected  Value x1
          One of the Value objects that determine the shape that is drawn.
protected  Value x2
          One of the Value objects that determine the shape that is drawn.
protected  Value y1
          One of the Value objects that determine the shape that is drawn.
protected  Value y2
          One of the Value objects that determine the shape that is drawn.
 
Fields inherited from class edu.hws.jcm.draw.Drawable
canvas, coords
 
Constructor Summary
DrawGeometric()
          Create a DrawGeometric object.
DrawGeometric(int shape, Value x1, Value y1, int h, int v)
          Create a DrawGeometric with a specified shape and values.
DrawGeometric(int shape, Value x1, Value y1, Value x2, Value y2)
          Create a DrawGeometric with the specified shape and values for x1,x2,y1,y2 Any of the shapes makes sense in this context.
 
Method Summary
 void compute()
          Recompute the values that define the size/postion of the DrawGeometric.
 void draw(java.awt.Graphics g, boolean coordsChanged)
          Do the drawing.
 java.awt.Color getColor()
          Get the non-null color that is used for drawing the shape.
 java.awt.Color getFillColor()
          Get the color that is used for filling ovals and rects.
 int getH()
          Get the horizontal offset from (x1,y1).
 int getLineWidth()
          Get the width, in pixels, of lines that are drawn.
 int getV()
          Get the vertical offset from (x1,y1).
 Value getX1()
          Get the value that gives the x-coordinate of the first point that determines the shape.
 Value getX2()
          Get the value that gives the x-coordinate of the second point that determines the shape.
 Value getY1()
          Get the value that gives the y-coordinate of the first point that determines the shape.
 Value getY2()
          Get the value that gives the y-coordinate of the second point that determines the shape.
 void setColor(java.awt.Color c)
          Set the color that is used for drawing the shape.
 void setFillColor(java.awt.Color c)
          Set the color that is used for filling ovals and rects.
 void setH(int x)
          Set the integer that gives the horizontal offset from (x1,y1).
 void setLineWidth(int width)
          Set the width, in pixels, of lines that are drawn.
 void setPoints(Value x1, Value y1, int h, int v)
          Set the values that specify a point (x1,y1) and an offset (h,v) from that point.
 void setPoints(Value x1, Value y1, Value x2, Value y2)
          Set the Value objects that specify the two points that determine the shape.
 void setShape(int shape)
          Set the shape, which should be given as one of the shape constants such as LINE_ABSOLUTE or CROSS.
 void setV(int y)
          Set the integer that gives the vertical offset from (x1,y1).
 void setX1(Value x)
          Set the value that gives the x-coordinate of the first point that determines the shape.
 void setX2(Value x)
          Set the value that gives the x-coordinate of the second point that determines the shape.
 void setY1(Value y)
          Set the value that gives the y-coordinate of the first point that determines the shape.
 void setY2(Value y)
          Set the value that gives the y-coordinate of the second point that determines the shape.
 
Methods inherited from class edu.hws.jcm.draw.Drawable
getVisible, needsRedraw, setOwnerData, setVisible
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

LINE_ABSOLUTE

public static final int LINE_ABSOLUTE
Specifies a line segment from (x1,y1) to (x2,y2).

INFINITE_LINE_ABSOLUTE

public static final int INFINITE_LINE_ABSOLUTE
Specifies a line that extends through the points (x1,y1) and (x2,y2) and beyond.

RECT_ABSOLUTE

public static final int RECT_ABSOLUTE
Specifies a rectangle with corners at (x1,y1) and (x2,y2).

OVAL_ABSOLUTE

public static final int OVAL_ABSOLUTE
Specifies an oval that just fits in the rectangle with corners at (x1,y1) and (x2,y2).

LINE_RELATIVE

public static final int LINE_RELATIVE
Specifies a line segment from (x1,y1) to (x1+x2,y1+y2), or to (x1+h,y1+v) if x2,y2 are null. (Note that h,v are given in terms of pixels while x1,x2,y1,y2 are given in terms of the CoordinateRect. If you use h,v, you get a line of a fixed size and direction.)

INFINITE_LINE_RELATIVE

public static final int INFINITE_LINE_RELATIVE
Specifies an infinite line through (x1,y1) and (x1+x2,y1+y2), or through (x1,y1) and (x1+h,y1+v) if x2,y2 are null.

RECT_RELATIVE

public static final int RECT_RELATIVE
Specifies a rectangle with one corner at (x1,y1), and with width given by x2, or h if if x2 is null, and with height given by y2, or by v if y2 is null.

OVAL_RELATIVE

public static final int OVAL_RELATIVE
Specifies an oval that just fits inside the rect specified by RECT_RELATIVE.

LINE_CENTERED

public static final int LINE_CENTERED
Specifies a line segment centered on (x1,y1). The amount it extends in each direction is given by x2,y2 or by h,v

RECT_CENTERED

public static final int RECT_CENTERED
Specifies a Rectangle centered on (x1,y1). The amount it extends in each direction is given by x2,y2 or by h,v. (Thus, x2 or h is the HALF-width and y2 or v is the HALF-height.)

OVAL_CENTERED

public static final int OVAL_CENTERED
Specifies an oval that just fits inside the rect specified by RECT_CENTERED.

CROSS

public static final int CROSS
Specifies a cross centered on the point (x1,y1). Its arms extend horizontally by a distance of x2, or h, in each direction. Its vertical arms extend y2, or v, in each direction.

shape

protected int shape
One of the constants such as OVAL_CENTERED, specifying the shape to be drawn

x1

protected Value x1
One of the Value objects that determine the shape that is drawn. The shape is specified by two points, (x1,y1) and (x2,y2). x1 must be non-null.

x2

protected Value x2
One of the Value objects that determine the shape that is drawn. The shape is specified by two points, (x1,y1) and (x2,y2). x2 must be non-null for the "ABSOLUTE" shapes. (If not, they revert to "RELATIVE" shapes and use h,v as the offset values.)

y1

protected Value y1
One of the Value objects that determine the shape that is drawn. The shape is specified by two points, (x1,y1) and (x2,y2). y1 must be non-null.

y2

protected Value y2
One of the Value objects that determine the shape that is drawn. The shape is specified by two points, (x1,y1) and (x2,y2). y2 must be non-null for the "ABSOLUTE" shapes. (If not, they revert to "RELATIVE" shapes and use h,v as the offset values.)

h

protected int h
Integer that gives horizontal pixel offset from x1. This is only used if x2 is null.

v

protected int v
Integer that gives vertical pixel offset fromy1. This is only used if y2 is null.

a

protected double a
Value of x1. This is re-computed when the compute() method is called.

b

protected double b
Value of y1. This is re-computed when the compute() method is called.

c

protected double c
Value of x2. This is re-computed when the compute() method is called.

d

protected double d
Value of y2. This is re-computed when the compute() method is called.

color

protected java.awt.Color color
Color of the shappe. Color will be black if this is null. For shapes that have "insides", such as rects, this is the color of the outline.

fillColor

protected java.awt.Color fillColor
Rects and ovals are filled with this color, if it is non-null. If this is null, only the outline of the shape is drawn.

lineWidth

protected int lineWidth
The width, in pixels, of lines, including the outlines of rects and ovals. It is restricted to being an integer in the range from 0 to 10. A value of 0 means that lines won't be drawn at all; this would only be useful for a filled shape that has a colored interior.
Constructor Detail

DrawGeometric

public DrawGeometric()
Create a DrawGeometric object. By default, it is a LINE_ABSOLUTE. However, nothing will be drawn as long as x1,y1,x2,y2 are null.

DrawGeometric

public DrawGeometric(int shape,
                     Value x1,
                     Value y1,
                     Value x2,
                     Value y2)
Create a DrawGeometric with the specified shape and values for x1,x2,y1,y2 Any of the shapes makes sense in this context.
Parameters:
shape - One of the shape constants such as LINE_ABSOLUTE or RECT_RELATIVE.

DrawGeometric

public DrawGeometric(int shape,
                     Value x1,
                     Value y1,
                     int h,
                     int v)
Create a DrawGeometric with a specified shape and values. The last two parameters give pixel offsets from x1,y1. The "ABSOLUTE" shapes don't make sense in this context. (They will be treated as the corresponding "RELATIVE" shapes.)
Parameters:
shape - One of the "RELATIVE" or "CENTERED" shape constants such as LINE_RELATIVE or OVAL_CENTERED or CROSS.
Method Detail

setShape

public void setShape(int shape)
Set the shape, which should be given as one of the shape constants such as LINE_ABSOLUTE or CROSS.

setPoints

public void setPoints(Value x1,
                      Value y1,
                      Value x2,
                      Value y2)
Set the Value objects that specify the two points that determine the shape. The first two parameters, x1 and y1, must be non-null.

setPoints

public void setPoints(Value x1,
                      Value y1,
                      int h,
                      int v)
Set the values that specify a point (x1,y1) and an offset (h,v) from that point. This only makes sense for RELATIVE shapes. The Value objects x1 and y1 must be non-null

setX1

public void setX1(Value x)
Set the value that gives the x-coordinate of the first point that determines the shape. This must be non-null, or nothing will be drawn.

getX1

public Value getX1()
Get the value that gives the x-coordinate of the first point that determines the shape.

setX2

public void setX2(Value x)
Set the value that gives the x-coordinate of the second point that determines the shape. If this is null, then the value of h is used instead.

getX2

public Value getX2()
Get the value that gives the x-coordinate of the second point that determines the shape.

setY1

public void setY1(Value y)
Set the value that gives the y-coordinate of the first point that determines the shape. This must be non-null, or nothing will be drawn.

getY1

public Value getY1()
Get the value that gives the y-coordinate of the first point that determines the shape.

setY2

public void setY2(Value y)
Set the value that gives the y-coordinate of the second point that determines the shape. If this is null, then the value of v is used instead.

getY2

public Value getY2()
Get the value that gives the y-coordinate of the second point that determines the shape.

setH

public void setH(int x)
Set the integer that gives the horizontal offset from (x1,y1). This only makes sense for RELATIVE shapes. This method also sets x2 to null, since the h value is only used when x2 is null.

getH

public int getH()
Get the horizontal offset from (x1,y1).

setV

public void setV(int y)
Set the integer that gives the vertical offset from (x1,y1). This only makes sense for RELATIVE shapes. This method also sets y2 to null, since the v value is only used when y2 is null.

getV

public int getV()
Get the vertical offset from (x1,y1).

setColor

public void setColor(java.awt.Color c)
Set the color that is used for drawing the shape. If the color is null, black is used. For shapes that have interiors, such as rects, this is only the color of the outline of the shaape.

getColor

public java.awt.Color getColor()
Get the non-null color that is used for drawing the shape.

setFillColor

public void setFillColor(java.awt.Color c)
Set the color that is used for filling ovals and rects. If the color is null, only the outline of the shape is drawn.

getFillColor

public java.awt.Color getFillColor()
Get the color that is used for filling ovals and rects. If null, no fill is done.

setLineWidth

public void setLineWidth(int width)
Set the width, in pixels, of lines that are drawn. This is also used for outlines of rects and ovals.

getLineWidth

public int getLineWidth()
Get the width, in pixels, of lines that are drawn. This is also used for outlines of rects and ovals.

compute

public void compute()
Recompute the values that define the size/postion of the DrawGeometric. This is ordinarily only called by a Controller.
Specified by:
compute in interface Computable

draw

public void draw(java.awt.Graphics g,
                 boolean coordsChanged)
Do the drawing. This is not meant to be called directly.
Overrides:
draw in class Drawable
Following copied from class: edu.hws.jcm.draw.Drawable
Parameters:
g - The graphics context in which the Drawble is to be drawn. (The drawing can change the color in g, but should not permanently change font, painting mode, etc. Thus, every drawable is responsible for setting the color it wants to use.)
coordsChanged - Indicates whether the CoordinateRect has changed.