2018-07-12 12:53:49 +00:00
|
|
|
import { round, rad2deg, deg2rad } from './utils';
|
|
|
|
const PRECISION = 2;
|
2018-07-14 16:04:39 +00:00
|
|
|
|
2018-07-11 12:45:02 +00:00
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
export class Point {
|
2018-07-11 12:45:02 +00:00
|
|
|
x: number;
|
|
|
|
y: number;
|
|
|
|
|
2018-07-14 16:04:39 +00:00
|
|
|
|
2018-07-11 12:45:02 +00:00
|
|
|
constructor(x: number, y: number) {
|
2018-07-12 12:53:49 +00:00
|
|
|
this.x = round(x);
|
|
|
|
this.y = round(y);
|
2018-07-11 12:45:02 +00:00
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
2018-07-12 07:37:52 +00:00
|
|
|
|
|
|
|
/** Returns the distance between this point and that point */
|
2018-07-12 12:53:49 +00:00
|
|
|
dist(that: Point): number {
|
2018-07-12 07:37:52 +00:00
|
|
|
let dx = this.x - that.x;
|
|
|
|
let dy = this.y - that.y;
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
return round(Math.sqrt(Math.pow(dx, 2) + Math.pow(dy,2)));
|
2018-07-12 07:37:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns slope of a line made by this point and that point */
|
|
|
|
slope(that: Point): number {
|
|
|
|
return (that.y - this.y) / (that.x - this.x);
|
|
|
|
}
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
/** Returns the x-delta between this point and that point */
|
|
|
|
dx(that: Point): number {
|
|
|
|
return that.x - this.x;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns the y-delta between this point and that point */
|
|
|
|
dy(that: Point): number {
|
|
|
|
return that.y - this.y;
|
|
|
|
}
|
|
|
|
|
2018-07-12 07:37:52 +00:00
|
|
|
/** Returns the angle between this point and that point */
|
|
|
|
angle(that: Point): number {
|
2018-07-12 12:53:49 +00:00
|
|
|
let rad = Math.atan2(-1 * this.dy(that), this.dx(that));
|
2018-07-12 07:37:52 +00:00
|
|
|
while (rad < 0) rad += 2 * Math.PI;
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
return rad2deg(rad);
|
2018-07-12 07:37:52 +00:00
|
|
|
}
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
/** Rotate this point deg around that point */
|
|
|
|
rotate(deg: number, that: Point): Point {
|
|
|
|
let radius = this.dist(that);
|
2018-07-12 07:37:52 +00:00
|
|
|
let angle = this.angle(that);
|
2018-07-12 12:53:49 +00:00
|
|
|
let x = that.x + radius * Math.cos(deg2rad(angle + deg)) * -1;
|
|
|
|
let y = that.y + radius * Math.sin(deg2rad(angle + deg));
|
2018-07-12 07:37:52 +00:00
|
|
|
|
|
|
|
return new Point(x, y);
|
|
|
|
}
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
/** returns an identical copy of this point */
|
|
|
|
copy(): Point {
|
|
|
|
return new Point(this.x, this.y);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** checks whether this point is equal to that point */
|
|
|
|
equals(that: Point): boolean {
|
|
|
|
return (this.x === that.x && this.y === that.y) ? true : false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Mirrors this point around X value of that point */
|
|
|
|
flipX(that: Point): Point
|
|
|
|
{
|
|
|
|
return new Point(that.x + this.dx(that), that.y);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Mirrors this point around Y value of that point */
|
|
|
|
flipY(that: Point): Point
|
|
|
|
{
|
|
|
|
return new Point(that.x, that.y + this.dy(that));
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Shifts this point distance in the deg direction */
|
|
|
|
shift(deg: number, distance: number): Point {
|
2018-07-12 07:37:52 +00:00
|
|
|
let p = this.copy();
|
|
|
|
p.x += distance;
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
return p.rotate(deg, this);
|
2018-07-12 07:37:52 +00:00
|
|
|
}
|
|
|
|
|
2018-07-12 12:53:49 +00:00
|
|
|
/** Shifts this point distance in the direction of that point */
|
|
|
|
shiftTowards(that: Point, distance: number): Point {
|
|
|
|
return this.shift(this.angle(that), distance);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Shifts this point fraction of the distance towards that point */
|
|
|
|
shiftFractionTowards(that: Point, fraction: number): Point {
|
|
|
|
return this.shiftTowards(that, this.dist(that) * fraction);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Shifts this point distance beyond that point */
|
|
|
|
shiftOutwards(that: Point, distance: number): Point {
|
|
|
|
return this.shiftTowards(that, this.dist(that) + distance);
|
2018-07-12 07:37:52 +00:00
|
|
|
}
|
2018-07-11 12:45:02 +00:00
|
|
|
}
|