Package edu.macalester.graphics
Class Point
java.lang.Object
edu.macalester.graphics.Point
A point in two-dimensional space.
 
This class is immutable. All methods return a new Point.
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionTreats the given point like a displacement vector and adds it to the current point.doubleangle()Returns the angle in radians counterclockwise (or clockwise if you view y as up) from the x-axis to this point.static PointatAngle(double theta) Returns the unit vector at the given angle in radians.doubleReturns the distance between this point and another point.booleanTwo points are equal if they have the same coordinates.doublegetX()The vertical position of this point.doublegetY()The horizontal position of this point.inthashCode()static Pointinterpolate(Point p0, Point p1, double alpha) Linearly interpolates by alpha between the two points.doubleReturns the distance from this point to the origin.static PointReturns a point whose x is the maximum of the two given points' x coordinates, and whose y is the maximum of the two given points' y coordinates.static PointReturns a point whose x is the minimum of the two given points' x coordinates, and whose y is the minimum of the two given points' y coordinates.rotate(double angle) Returns the point rotated around the origin by the given angle in radians.Returns the point rotated around a given axis point by the given angle in radians.scale(double s) Multiplies this point's coordinates by a scalar.scale(double sx, double sy) Multiplies x by sx and y by sy.Treats p like a displacement vector and subtracts it from the current pointConverts this point to the Java AWT Point2D.toString()withX(double x) Returns a point with the same y as this one, but a different x.withY(double y) Returns a point with the same x as this one, but a different y.wrapAround(Point maxBounds) Makes the coordinates of the input point “wrap around” as if moving in a toroidal space extending from 0 to maxBounds.x, and from 0 to maxBounds.y: coordinates that go off one edge move to the other edge.wrapAround(Point minBounds, Point maxBounds) Makes the coordinates of the input point “wrap around” as if moving in a toroidal space: coordinates that go off one side move to the other side.
- 
Field Details- 
ORIGINThe point (0,0).
- 
UNIT_XThe point (1,0).
- 
UNIT_YThe point (0,1).
- 
ONE_ONEThe point (1,1).
- 
MINA point at (-∞,-∞).
- 
MAXA point at (∞,∞).
 
- 
- 
Constructor Details- 
Pointpublic Point(double x, double y) Creates a point with the given horizontal and vertical components.
- 
PointConverts a Java AWT Point2D to a kilt-graphics Point.
 
- 
- 
Method Details- 
atAngleReturns the unit vector at the given angle in radians.
- 
getXpublic double getX()The vertical position of this point.
- 
getYpublic double getY()The horizontal position of this point.
- 
withXReturns a point with the same y as this one, but a different x.
- 
withYReturns a point with the same x as this one, but a different y.
- 
anglepublic double angle()Returns the angle in radians counterclockwise (or clockwise if you view y as up) from the x-axis to this point.
- 
magnitudepublic double magnitude()Returns the distance from this point to the origin.
- 
distanceReturns the distance between this point and another point.
- 
addTreats the given point like a displacement vector and adds it to the current point.
- 
subtractTreats p like a displacement vector and subtracts it from the current point
- 
scaleMultiplies this point's coordinates by a scalar.
- 
scaleMultiplies x by sx and y by sy.
- 
minReturns a point whose x is the minimum of the two given points' x coordinates, and whose y is the minimum of the two given points' y coordinates.
- 
maxReturns a point whose x is the maximum of the two given points' x coordinates, and whose y is the maximum of the two given points' y coordinates.
- 
wrapAroundMakes the coordinates of the input point “wrap around” as if moving in a toroidal space extending from 0 to maxBounds.x, and from 0 to maxBounds.y: coordinates that go off one edge move to the other edge. Unlike Java’s raw modular arithmetic, this method handles negative values as expected.- Parameters:
- maxBounds- The maximum x and y coordinates
- Returns:
- A new Point whose coordinates are each greater than or equal to zero, and less than the coordinates of maxBounds
 
- 
wrapAroundMakes the coordinates of the input point “wrap around” as if moving in a toroidal space: coordinates that go off one side move to the other side. Unlike Java’s raw modular arithmetic, this method handles negative values as expected.- Parameters:
- minBounds- The minimum x and y coordinates
- maxBounds- The maximum x and y coordinates
- Returns:
- A new Point whose coordinates are each greater than or equal to the coordinates of minBounds, and less than the coordinates of maxBounds
 
- 
rotateReturns the point rotated around the origin by the given angle in radians.
- 
rotateReturns the point rotated around a given axis point by the given angle in radians.
- 
interpolateLinearly interpolates by alpha between the two points.- Parameters:
- p0- The point for alpha = 0
- p1- The point for alpha = 1
- alpha- The continuum from p0 to p1
 
- 
equalsTwo points are equal if they have the same coordinates.
- 
hashCodepublic int hashCode()
- 
toString
- 
toPoint2DConverts this point to the Java AWT Point2D.
 
-