X-Git-Url: http://git.megacz.com/?p=anneal.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fqfat%2Fgeom%2FPoint.java;h=20048e46a0ee404ac80755411a5efd3ba0098ee5;hp=38f872d7ea155f4aacf58f4ce8ec15c09d85315f;hb=20fe91a50615c12bdfdec4a72665ff92a700abd5;hpb=40b6b99bd4b0bd6041b8ab94a22201faab23ed90 diff --git a/src/edu/berkeley/qfat/geom/Point.java b/src/edu/berkeley/qfat/geom/Point.java index 38f872d..20048e4 100644 --- a/src/edu/berkeley/qfat/geom/Point.java +++ b/src/edu/berkeley/qfat/geom/Point.java @@ -1,17 +1,24 @@ package edu.berkeley.qfat.geom; import javax.media.opengl.*; +import javax.media.opengl.glu.*; /** point in 3-space; immutable */ -public final class Point implements HasBoundingBox { +public final class Point extends HasPoint implements HasBoundingBox { + + public static final Point ZERO = new Point(0,0,0); + public final float x, y, z; + public Point(double x, double y, double z) { this((float)x, (float)y, (float)z); } public Point(float x, float y, float z) { this.x = x; this.y = y; this.z = z; } + public static final Point ORIGIN = new Point(0,0,0); + public float distance(Point p) { return (float)Math.sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y)+(z-p.z)*(z-p.z)); } - public Point times(Matrix m) { return m.times(this); } public Vec minus(Point p) { return new Vec(x-p.x, y-p.y, z-p.z); } public Point plus(Vec v) { return new Point(x+v.x, y+v.y, z+v.z); } + public Point midpoint(Point p) { return new Point((x+p.x)/2, (y+p.y)/2, (z+p.z)/2); } public void glVertex(GL gl) { gl.glVertex3f(x, y, z); } @@ -20,6 +27,8 @@ public final class Point implements HasBoundingBox { public boolean equals(Object o) { return o!=null && (o instanceof Point) && ((Point)o).x==x && ((Point)o).y==y && ((Point)o).z==z; } public int hashCode() { return Float.floatToIntBits(x) ^ Float.floatToIntBits(y) ^ Float.floatToIntBits(z); } + public Point getPoint() { return this; } + public float getMaxX() { return x; } public float getMinX() { return x; } public float getMaxY() { return y; }