X-Git-Url: http://git.megacz.com/?p=anneal.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fqfat%2Fgeom%2FPoint.java;fp=src%2Fedu%2Fberkeley%2Fqfat%2Fgeom%2FPoint.java;h=d54e631b6a42bf3d9e595eff55bc81d8dcabee24;hp=0000000000000000000000000000000000000000;hb=965caa65c5048f85c4335fd4d0f962f8c5ae7012;hpb=b1832d008534acfc7fe0dc8677387ed1016a5b38 diff --git a/src/edu/berkeley/qfat/geom/Point.java b/src/edu/berkeley/qfat/geom/Point.java new file mode 100644 index 0000000..d54e631 --- /dev/null +++ b/src/edu/berkeley/qfat/geom/Point.java @@ -0,0 +1,19 @@ +package edu.berkeley.qfat.geom; +import javax.media.opengl.*; + +/** point in 3-space; immutable */ +public final class Point { + 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 float distance(Point p) { return distance(p.x, p.y, p.z); } + public float distance(float ox, float oy, float oz) { return (float)Math.sqrt((x-ox)*(x-ox)+(y-oy)*(y-oy)+(z-oz)*(z-oz)); } + 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 boolean equals(Object o) { return o!=null && (o instanceof Point) && ((Point)o).x==x && ((Point)o).y==y && ((Point)o).z==z; } + public void glVertex(GL gl) { _glVertex(gl); } + private void _glVertex(GL gl) { gl.glVertex3f(x, y, z); } + public String toString() { return "("+x+","+y+","+z+")"; } + public int hashCode() { return Float.floatToIntBits(x) ^ Float.floatToIntBits(y) ^ Float.floatToIntBits(z); } +}