UNPKG

@cantoo/pdf-lib

Version:

Create and modify PDF files with JavaScript

68 lines 2.1 kB
import { intersectionLine } from '../intersections.js'; import { isColinear, isEqual, orthogonal, vector } from '../maths.js'; import GraphElement from './GraphElement.js'; import Point from './Point.js'; export default class Line extends GraphElement { origin() { return this.A; } dirVect() { return vector(this.A, this.B); } constructor(A = new Point(), B = new Point()) { super(); this.A = A; this.B = B; } /** Line equation */ y(x) { const a = this.a(); const b = this.b(); return a * x + b; } /** The slope */ a() { const dirVect = this.dirVect(); return dirVect.y / dirVect.x; } /** Origin y coordinate */ b() { const O = this.origin().toCoords(); const a = this.a(); return O.y - a * O.x; } isEqual(element) { const vect = this.dirVect(); return (element instanceof Line && isColinear(vect, element.dirVect()) && (isEqual(vect.x, 0) ? // We need to take care of the case of the vertical line isEqual(this.origin().toCoords().x, element.origin().toCoords().x) : isEqual(this.b(), element.b()))); } /** Reversed line equation */ x(y) { const dirVect = this.dirVect(); return ((y - this.b()) * dirVect.x) / dirVect.y; } includes(P) { const { x, y } = P.toCoords(); const vect = this.dirVect(); return isEqual(vect.x, 0) ? isEqual(this.origin().toCoords().x, x) : isEqual(this.y(x), y); } /** This is used to standarsize type Segment | HalfLine | Line */ getLine() { const line = new Line(this.origin(), this.B); return line; } orthoProjection(P) { const vectOrtho = orthogonal(this.dirVect()); const A = new Point(P.toCoords()); const ortho = new Line(A, A.plus(vectOrtho)); const H = intersectionLine(this, ortho)[0]; return new Point(H); } } //# sourceMappingURL=Line.js.map